2018-09-05 02:39:50 +02:00
|
|
|
# check some environment variables first
|
|
|
|
|
|
|
|
ifndef ESP8266_NEWLIB_DIR
|
|
|
|
$(info ESP8266_NEWLIB_DIR should be defined as /path/to/newlib directory)
|
|
|
|
$(info ESP8266_NEWLIB_DIR is set by default to /opt/esp/newlib-xtensa)
|
|
|
|
export ESP8266_NEWLIB_DIR=/opt/esp/newlib-xtensa
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifndef ESP8266_SDK_DIR
|
|
|
|
$(info ESP8266_SDK_DIR should be defined as /path/to/sdk directory)
|
|
|
|
$(info ESP8266_SDK_DIR is set by default to /opt/esp/esp-open-sdk/sdk)
|
|
|
|
export ESP8266_SDK_DIR=/opt/esp/esp-open-sdk/sdk
|
|
|
|
endif
|
|
|
|
|
|
|
|
# Options to control the compilation
|
|
|
|
|
|
|
|
ifeq ($(USE_SDK), 1)
|
|
|
|
USEMODULE += esp_sdk
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifeq ($(ENABLE_GDB), 1)
|
|
|
|
USEMODULE += esp_gdb
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifeq ($(ENABLE_GDBSTUB), 1)
|
|
|
|
USEMODULE += esp_gdbstub
|
2018-12-26 16:03:38 +01:00
|
|
|
endif
|
|
|
|
|
|
|
|
# SPECIAL module dependencies
|
|
|
|
# cannot be done in Makefile.dep since Makefile.dep is included too late
|
|
|
|
|
|
|
|
ifneq (, $(filter esp_sw_timer, $(USEMODULE)))
|
|
|
|
USEMODULE += esp_sdk
|
|
|
|
endif
|
|
|
|
|
2019-02-02 14:37:21 +01:00
|
|
|
ifneq (, $(filter esp_wifi, $(USEMODULE)))
|
|
|
|
$(eval GNRC_NETIF_NUMOF=$(shell echo $$(($(GNRC_NETIF_NUMOF)+1))))
|
|
|
|
USEMODULE += esp_sdk
|
|
|
|
USEMODULE += netopt
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifneq (, $(filter esp_now, $(USEMODULE)))
|
2019-01-16 19:30:59 +01:00
|
|
|
$(eval GNRC_NETIF_NUMOF=$(shell echo $$(($(GNRC_NETIF_NUMOF)+1))))
|
|
|
|
USEMODULE += esp_sdk
|
|
|
|
USEMODULE += netopt
|
|
|
|
endif
|
|
|
|
|
2018-12-26 16:03:38 +01:00
|
|
|
ifneq (, $(filter esp_gdbstub, $(USEMODULE)))
|
2018-09-05 02:39:50 +02:00
|
|
|
USEMODULE += esp_gdb
|
|
|
|
endif
|
|
|
|
|
|
|
|
# regular Makefile
|
|
|
|
|
|
|
|
export TARGET_ARCH ?= xtensa-lx106-elf
|
|
|
|
|
|
|
|
# ESP8266 pseudomodules
|
|
|
|
PSEUDOMODULES += esp_gdb
|
|
|
|
PSEUDOMODULES += esp_sdk
|
|
|
|
PSEUDOMODULES += esp_sw_timer
|
|
|
|
PSEUDOMODULES += esp_spiffs
|
|
|
|
|
2018-12-26 16:03:38 +01:00
|
|
|
USEMODULE += esp
|
|
|
|
USEMODULE += mtd
|
2019-08-31 13:29:21 +02:00
|
|
|
USEMODULE += newlib
|
2019-09-04 14:39:49 +02:00
|
|
|
USEMODULE += newlib_nano
|
2019-08-31 13:29:21 +02:00
|
|
|
USEMODULE += newlib_syscalls_default
|
2018-12-26 16:03:38 +01:00
|
|
|
USEMODULE += periph
|
|
|
|
USEMODULE += ps
|
|
|
|
USEMODULE += random
|
|
|
|
USEMODULE += sdk
|
2019-08-31 13:29:21 +02:00
|
|
|
USEMODULE += stdio_uart
|
2018-12-26 16:03:38 +01:00
|
|
|
USEMODULE += xtensa
|
|
|
|
|
2018-09-05 02:39:50 +02:00
|
|
|
ifneq (, $(filter pthread, $(USEMODULE)))
|
2018-12-26 16:03:38 +01:00
|
|
|
# has to be included before $(ESP8266_NEWLIB_DIR)
|
2018-09-05 02:39:50 +02:00
|
|
|
INCLUDES += -I$(RIOTBASE)/sys/posix/pthread/include
|
|
|
|
endif
|
|
|
|
|
|
|
|
INCLUDES += -I$(ESP8266_NEWLIB_DIR)/$(TARGET_ARCH)/include
|
|
|
|
INCLUDES += -I$(RIOTBOARD)/common/$(CPU)/include
|
2019-01-27 14:39:10 +01:00
|
|
|
INCLUDES += -I$(RIOTCPU)/esp_common/vendor/
|
2018-09-05 02:39:50 +02:00
|
|
|
INCLUDES += -I$(RIOTCPU)/$(CPU)
|
|
|
|
INCLUDES += -I$(RIOTCPU)/$(CPU)/vendor
|
|
|
|
INCLUDES += -I$(RIOTCPU)/$(CPU)/vendor/espressif
|
|
|
|
|
2019-01-27 14:07:39 +01:00
|
|
|
CFLAGS += -DESP_OPEN_SDK -DSCHED_PRIO_LEVELS=32 -DCONTEXT_SWITCH_BY_INT
|
2018-09-05 02:39:50 +02:00
|
|
|
CFLAGS += -Wno-unused-parameter -Wformat=0
|
2018-12-26 16:03:38 +01:00
|
|
|
CFLAGS += -mlongcalls -mtext-section-literals
|
2019-08-31 13:33:45 +02:00
|
|
|
CFLAGS += -ffunction-sections -fdata-sections -fzero-initialized-in-bss
|
2018-09-05 02:39:50 +02:00
|
|
|
ASFLAGS += --longcalls --text-section-literals
|
|
|
|
|
|
|
|
ifneq (, $(filter esp_sdk, $(USEMODULE)))
|
|
|
|
INCLUDES += -I$(ESP8266_SDK_DIR)/include
|
|
|
|
CFLAGS += -DUSE_US_TIMER
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifneq (, $(filter esp_gdbstub, $(USEMODULE)))
|
|
|
|
GDBSTUB_DIR ?= $(RIOTCPU)/$(CPU)/vendor/esp-gdbstub
|
|
|
|
CFLAGS += -DGDBSTUB_FREERTOS=0
|
|
|
|
INCLUDES += -I$(GDBSTUB_DIR)
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifneq (, $(filter esp_gdb, $(USEMODULE)))
|
2018-12-26 16:03:38 +01:00
|
|
|
CFLAGS += -Og -ggdb -g3
|
2018-09-05 02:39:50 +02:00
|
|
|
else
|
2018-12-26 16:03:38 +01:00
|
|
|
CFLAGS += -Os
|
2018-09-05 02:39:50 +02:00
|
|
|
endif
|
|
|
|
|
|
|
|
ifeq ($(QEMU), 1)
|
|
|
|
CFLAGS += -DQEMU
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifeq ($(FLASH_MODE), qio)
|
|
|
|
CFLAGS += -DFLASH_MODE_QIO
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifeq ($(FLASH_MODE), qout)
|
|
|
|
CFLAGS += -DFLASH_MODE_QOUT
|
|
|
|
endif
|
|
|
|
|
|
|
|
LINKFLAGS += -L$(ESP8266_NEWLIB_DIR)/$(TARGET_ARCH)/lib
|
|
|
|
LINKFLAGS += -L$(ESP8266_SDK_DIR)/lib
|
|
|
|
|
|
|
|
ifneq (, $(filter esp_sdk, $(USEMODULE)))
|
|
|
|
LINKFLAGS += -Wl,--start-group $(BINDIR)/sdk.a
|
|
|
|
ifneq (, $(filter esp_now, $(USEMODULE)))
|
|
|
|
LINKFLAGS += -lespnow
|
|
|
|
endif
|
|
|
|
LINKFLAGS += -lmain -lnet80211 -lcrypto -lwpa2 -lwpa -llwip -lpp -lphy -lc -lhal
|
|
|
|
LINKFLAGS += -Wl,--end-group
|
|
|
|
LINKFLAGS += -T$(RIOTCPU)/$(CPU)/ld/esp8266.riot-os.sdk.app.ld
|
|
|
|
else
|
|
|
|
LINKFLAGS += -Wl,--start-group -lphy -lhal -lc -Wl,--end-group
|
|
|
|
LINKFLAGS += -T$(RIOTCPU)/$(CPU)/ld/esp8266.riot-os.no_sdk.app.ld
|
|
|
|
endif
|
|
|
|
|
|
|
|
LINKFLAGS += -T$(RIOTCPU)/$(CPU)/ld/eagle.rom.addr.v6.ld
|
|
|
|
LINKFLAGS += -nostdlib -lgcc -u ets_run -Wl,-gc-sections # -Wl,--print-gc-sections
|
|
|
|
|
2018-12-19 17:45:41 +01:00
|
|
|
# The ELFFILE is the base one used for flashing
|
|
|
|
FLASHFILE ?= $(ELFFILE)
|
|
|
|
|
2018-09-05 02:39:50 +02:00
|
|
|
# configure preflasher to convert .elf to .bin before flashing
|
2019-06-05 12:09:58 +02:00
|
|
|
FLASH_SIZE = -fs 1MB
|
2019-05-17 13:52:34 +02:00
|
|
|
PREFLASHER ?= esptool.py
|
2018-12-19 17:45:41 +01:00
|
|
|
PREFFLAGS ?= elf2image $(FLASH_SIZE) $(FLASHFILE)
|
2019-06-05 11:53:00 +02:00
|
|
|
FLASHDEPS += preflash
|
2018-09-05 02:39:50 +02:00
|
|
|
|
|
|
|
# flasher configuration
|
|
|
|
ifeq ($(QEMU), 1)
|
2019-05-17 13:52:34 +02:00
|
|
|
FLASHER = cat
|
2018-12-19 17:45:41 +01:00
|
|
|
FFLAGS += $(FLASHFILE)-0x00000.bin /dev/zero | head -c $$((0x10000)) | cat -
|
|
|
|
FFLAGS += $(FLASHFILE)-0x10000.bin /dev/zero | head -c $$((0xfc000)) | cat -
|
|
|
|
FFLAGS += $(RIOTCPU)/$(CPU)/bin/esp_init_data_default.bin > $(FLASHFILE).bin
|
2018-09-05 02:39:50 +02:00
|
|
|
else
|
|
|
|
FLASH_MODE ?= dout
|
|
|
|
export PROGRAMMER_SPEED ?= 460800
|
2019-05-17 13:52:34 +02:00
|
|
|
FLASHER = esptool.py
|
|
|
|
FFLAGS += -p $(PORT) -b $(PROGRAMMER_SPEED) write_flash
|
|
|
|
FFLAGS += -fm $(FLASH_MODE)
|
2018-12-19 17:45:41 +01:00
|
|
|
FFLAGS += 0 $(FLASHFILE)-0x00000.bin
|
|
|
|
FFLAGS += 0x10000 $(FLASHFILE)-0x10000.bin; esptool.py -p $(PORT) run
|
2018-09-05 02:39:50 +02:00
|
|
|
endif
|
2019-08-28 19:43:17 +02:00
|
|
|
|
|
|
|
OPTIONAL_CFLAGS_BLACKLIST += -fdiagnostics-color
|
|
|
|
OPTIONAL_CFLAGS_BLACKLIST += -Wformat-overflow
|
|
|
|
OPTIONAL_CFLAGS_BLACKLIST += -Wformat-truncation
|
2019-08-28 18:40:38 +02:00
|
|
|
OPTIONAL_CFLAGS_BLACKLIST += -gz
|