mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
ee6b6b9c38
The mips-malta board is a maintainance burden, has no working UART input and is unobtainable and thus must be removed. 1. Unobtainable board ===================== The mips-malta board is not an off-the-shelf part. A quick web search only show the MIPS website where one is told to "contact sales". I could find it on ebay, used, at €155 and from single seller. Not having access to the board means: a. We cannot maintain it. In fact it could be broken right now. b. Potential RIOT uses have not access to the board either. In other words, it is pointless to run on hardware nobody has. 2. No working UART input ======================== Not all applications need UART input, but that is no excuse for not supporting it: a. Makes development & debugging way harder. b. It is impossible to run interactive tests. b.1. Constrains the rest of the platforms by providing an incentive to not make tests interactive. c. The lack of UART is a witness to the poor quality of the port. I want to stress point (c). If something as basic as a serial port cannot work, how can we expect more complex fucntionality to work. The answer is impossible to know, because of point (1). 3. Maintainance burden ====================== The RIOT project has limited time and human resources which can be better spent. a. Compiling for mips-malta wastes CPU time. b. Blacklisting the board in the test wastes contributor's time. c. Adapting the board's makefile during build system rework takes time and makes the reworks harder. c.1. Add to that that the changes are most of the time not even tested on the board because of (1). Look at the github issues/PRs and you will see it. d. Developers usually stick to the lowest common denominator. Issue (2) sets this denominator unacceptably low. MIPS platform in general ======================== In commits I will address general issues in the MIPS platform and why it should all be removed.
131 lines
4.4 KiB
Makefile
131 lines
4.4 KiB
Makefile
# name of your application
|
|
APPLICATION = gnrc_border_router
|
|
|
|
# If no BOARD is found in the environment, use this default:
|
|
BOARD ?= samr21-xpro
|
|
|
|
# This has to be the absolute path to the RIOT base directory:
|
|
RIOTBASE ?= $(CURDIR)/../..
|
|
|
|
BOARD_INSUFFICIENT_MEMORY := airfy-beacon arduino-duemilanove arduino-leonardo \
|
|
arduino-mega2560 arduino-nano arduino-uno \
|
|
b-l072z-lrwan1 blackpill \
|
|
bluepill calliope-mini cc2650-launchpad cc2650stk \
|
|
hifive1 i-nucleo-lrwan1 lsn50 maple-mini mega-xplained microbit msb-430 \
|
|
msb-430h nrf51dk nrf51dongle nrf6310 \
|
|
nucleo-f031k6 nucleo-f042k6 \
|
|
nucleo-f303k8 nucleo-l031k6 nucleo-f030r8 \
|
|
nucleo-f070rb nucleo-f072rb nucleo-f103rb \
|
|
nucleo-f302r8 nucleo-f334r8 nucleo-l053r8 \
|
|
nucleo-l073rz opencm904 saml10-xpro saml11-xpro \
|
|
spark-core stm32f0discovery stm32l0538-disco \
|
|
telosb waspmote-pro \
|
|
weio wsn430-v1_3b wsn430-v1_4 yunjia-nrf51822 z1
|
|
|
|
# The following boards do not have an available UART
|
|
BOARD_BLACKLIST += pic32-wifire pic32-clicker ruuvitag thingy52
|
|
|
|
# use ethos (ethernet over serial) for network communication and stdio over
|
|
# UART, but not on native, as native has a tap interface towards the host.
|
|
ifeq (,$(filter native,$(BOARD)))
|
|
GNRC_NETIF_NUMOF := 2
|
|
USEMODULE += stdio_ethos
|
|
|
|
# ethos baudrate can be configured from make command
|
|
ETHOS_BAUDRATE ?= 115200
|
|
CFLAGS += -DETHOS_BAUDRATE=$(ETHOS_BAUDRATE)
|
|
else
|
|
GNRC_NETIF_NUMOF := 2
|
|
TERMFLAGS += -z [::1]:17754
|
|
USEMODULE += socket_zep
|
|
endif
|
|
|
|
# SLIP legacy compatibility
|
|
# Uncomment the lines below if you want to use SLIP with this example and don't
|
|
# forget to comment the lines above for ethos.
|
|
#ifeq (,$(SLIP_UART))
|
|
# set default (last available UART)
|
|
#SLIP_UART="UART_DEV(UART_NUMOF-1)"
|
|
#endif
|
|
#ifeq (,$(SLIP_BAUDRATE))
|
|
# set default
|
|
#SLIP_BAUDRATE=115200
|
|
#endif
|
|
|
|
#GNRC_NETIF_NUMOF := 2
|
|
#INCLUDES += -I$(CURDIR)
|
|
#CFLAGS += -DSLIP_UART=$(SLIP_UART)
|
|
#CFLAGS += -DSLIP_BAUDRATE=$(SLIP_BAUDRATE)
|
|
# Include SLIP package for IP over Serial communication
|
|
#USEMODULE += slipdev
|
|
|
|
# Include packages that pull up and auto-init the link layer.
|
|
# NOTE: 6LoWPAN will be included if IEEE802.15.4 devices are present
|
|
USEMODULE += gnrc_netdev_default
|
|
USEMODULE += auto_init_gnrc_netif
|
|
# Specify the mandatory networking modules for 6LoWPAN border router
|
|
USEMODULE += gnrc_sixlowpan_border_router_default
|
|
# Add forwarding table
|
|
USEMODULE += fib
|
|
# Additional networking modules that can be dropped if not needed
|
|
USEMODULE += gnrc_icmpv6_echo
|
|
# Add also the shell, some shell commands
|
|
USEMODULE += shell
|
|
USEMODULE += shell_commands
|
|
USEMODULE += ps
|
|
|
|
# include UHCP client
|
|
USEMODULE += gnrc_uhcpc
|
|
|
|
# Optionally include RPL as a routing protocol. When includede gnrc_uhcpc will
|
|
# configure the node as a RPL DODAG root when receiving a prefix.
|
|
#USEMODULE += gnrc_rpl
|
|
|
|
# Comment this out to disable code in RIOT that does safety checking
|
|
# which is not needed in a production environment but helps in the
|
|
# development process:
|
|
DEVELHELP ?= 1
|
|
|
|
# Change this to 0 show compiler invocation lines by default:
|
|
QUIET ?= 1
|
|
TAP ?= tap0
|
|
IPV6_PREFIX ?= 2001:db8::/64
|
|
|
|
ifeq (native,$(BOARD))
|
|
TERMDEPS += uhcpd-daemon
|
|
|
|
.PHONY: uhcpd-daemon
|
|
|
|
uhcpd-daemon: host-tools
|
|
$(RIOTTOOLS)/uhcpd/bin/uhcpd $(TAP) $(IPV6_PREFIX) &
|
|
else
|
|
# We override the `make term` command to use ethos
|
|
TERMPROG ?= sudo sh $(RIOTTOOLS)/ethos/start_network.sh
|
|
TERMFLAGS ?= $(PORT) $(TAP) $(IPV6_PREFIX)
|
|
|
|
# We depend on the ethos host tools to run the border router, we build them
|
|
# if necessary
|
|
TERMDEPS += host-tools
|
|
endif
|
|
|
|
include $(RIOTBASE)/Makefile.include
|
|
|
|
.PHONY: host-tools
|
|
|
|
host-tools:
|
|
$(Q)env -u CC -u CFLAGS make -C $(RIOTTOOLS)
|
|
|
|
# Set a custom channel if needed
|
|
ifneq (,$(filter cc110x,$(USEMODULE))) # radio is cc110x sub-GHz
|
|
DEFAULT_CHANNEL ?= 0
|
|
CFLAGS += -DCC110X_DEFAULT_CHANNEL=$(DEFAULT_CHANNEL)
|
|
else
|
|
ifneq (,$(filter at86rf212b,$(USEMODULE))) # radio is IEEE 802.15.4 sub-GHz
|
|
DEFAULT_CHANNEL ?= 5
|
|
CFLAGS += -DIEEE802154_DEFAULT_SUBGHZ_CHANNEL=$(DEFAULT_CHANNEL)
|
|
else # radio is IEEE 802.15.4 2.4 GHz
|
|
DEFAULT_CHANNEL ?= 26
|
|
CFLAGS += -DIEEE802154_DEFAULT_CHANNEL=$(DEFAULT_CHANNEL)
|
|
endif
|
|
endif
|