2019-12-12 13:46:20 +01:00
|
|
|
# ESP32 specific flashing options
|
2022-02-01 22:11:43 +01:00
|
|
|
FLASH_CHIP = $(CPU)
|
2019-12-12 13:46:20 +01:00
|
|
|
FLASH_MODE ?= dout
|
|
|
|
FLASH_FREQ = 40m # DO NOT CHANGE
|
|
|
|
FLASH_SIZE ?= 4
|
|
|
|
BOOTLOADER_POS = 0x1000
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2022-03-02 15:13:05 +01:00
|
|
|
ESPTOOL ?= $(RIOTTOOLS)/esptools/esptool_v3.2.py
|
|
|
|
|
2019-12-12 13:46:20 +01:00
|
|
|
include $(RIOTCPU)/esp_common/Makefile.include
|
2019-11-21 10:15:18 +01:00
|
|
|
|
2019-12-12 13:46:20 +01:00
|
|
|
# regular Makefile
|
2019-11-21 10:15:18 +01:00
|
|
|
|
2022-02-01 22:11:43 +01:00
|
|
|
TARGET_ARCH_$(CPU) ?= xtensa-$(CPU)-elf
|
|
|
|
TARGET_ARCH ?= $(TARGET_ARCH_$(CPU))
|
2019-11-28 18:03:43 +01:00
|
|
|
|
2022-02-01 22:11:43 +01:00
|
|
|
CPU_UC = $(shell echo '$(CPU)' | tr '[:lower:]' '[:upper:]')
|
|
|
|
|
|
|
|
PSEUDOMODULES += esp_bootloader
|
2018-10-08 12:20:49 +02:00
|
|
|
PSEUDOMODULES += esp_gdbstub
|
|
|
|
PSEUDOMODULES += esp_hw_counter
|
|
|
|
PSEUDOMODULES += esp_i2c_hw
|
2020-07-12 13:26:07 +02:00
|
|
|
PSEUDOMODULES += esp_jtag
|
2020-01-09 17:00:23 +01:00
|
|
|
PSEUDOMODULES += esp_rtc_timer_32k
|
2018-10-08 12:20:49 +02:00
|
|
|
PSEUDOMODULES += esp_spi_ram
|
2019-08-16 15:47:12 +02:00
|
|
|
PSEUDOMODULES += esp_wifi_enterprise
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2022-02-01 22:11:43 +01:00
|
|
|
INCLUDES += -I$(RIOTCPU)/$(CPU)/esp-idf/include
|
|
|
|
INCLUDES += -I$(RIOTCPU)/$(CPU)/esp-idf/include/log
|
|
|
|
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/driver/include
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_common/include
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_hw_support/include
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_hw_support/include/soc
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_rom/include
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_rom/include/$(CPU)
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_timer/include
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/hal/$(CPU)/include
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/hal/include
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/heap/include
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/log/include
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/newlib/platform_include
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/soc/include
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/soc/$(CPU)/include
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/xtensa/include
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/xtensa/$(CPU)/include
|
|
|
|
|
|
|
|
ifneq (,$(filter esp_spi_ram,$(USEMODULE)))
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_hw_support/include/soc/$(CPU)
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifneq (,$(filter esp_idf_spi_flash,$(USEMODULE)))
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/bootloader_support/include
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/spi_flash/include
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifneq (,$(filter esp_wifi_any,$(USEMODULE)))
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/bootloader_support/include
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_eth/include
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_event/include
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_netif/include
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_system/include
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_wifi/include
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/nvs_flash/include
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/spi_flash/include
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifneq (,$(filter esp_wifi_enterprise,$(USEMODULE)))
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/wpa_supplicant/esp_supplicant/include
|
|
|
|
endif
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2020-06-25 10:17:10 +02:00
|
|
|
ifneq (,$(filter esp_eth,$(USEMODULE)))
|
2022-03-02 14:06:45 +01:00
|
|
|
INCLUDES += -I$(RIOTCPU)/$(CPU)/esp-eth
|
2022-02-01 22:11:43 +01:00
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_eth/include
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_event/include
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_netif/include
|
|
|
|
INCLUDES += -I$(ESP32_SDK_DIR)/components/esp_wifi/include
|
2020-06-25 10:17:10 +02:00
|
|
|
endif
|
2020-03-26 01:41:36 +01:00
|
|
|
|
2022-02-01 22:11:43 +01:00
|
|
|
# we use ESP32 only in single core mode
|
|
|
|
CFLAGS += -DCONFIG_ESP_SYSTEM_SINGLE_CORE_MODE
|
|
|
|
CFLAGS += -DCONFIG_FREERTOS_UNICORE
|
|
|
|
|
|
|
|
# other ESP-IDF configurations
|
|
|
|
CFLAGS += -DCONFIG_IDF_TARGET_$(CPU_UC)
|
|
|
|
CFLAGS += -DESP_PLATFORM
|
2019-12-12 13:46:20 +01:00
|
|
|
CFLAGS += -DLOG_TAG_IN_BRACKETS
|
2022-02-01 22:11:43 +01:00
|
|
|
|
|
|
|
# shortcuts used by ESP-IDF
|
|
|
|
CFLAGS += -Dasm=__asm
|
|
|
|
CFLAGS += -Dtypeof=__typeof__
|
2022-01-21 14:04:38 +01:00
|
|
|
CFLAGS += -D_CONST=const
|
2019-11-21 06:55:33 +01:00
|
|
|
|
2022-02-01 22:11:43 +01:00
|
|
|
LINKFLAGS += -L$(ESP32_SDK_DIR)/components/xtensa/$(CPU)
|
|
|
|
ARCHIVES += -lxt_hal
|
|
|
|
|
2018-10-08 12:20:49 +02:00
|
|
|
LINKFLAGS += -L$(RIOTCPU)/$(CPU)/ld/
|
2022-02-01 22:11:43 +01:00
|
|
|
LINKFLAGS += -T$(ESP32_SDK_DIR)/components/soc/$(CPU)/ld/$(CPU).peripherals.ld
|
|
|
|
LINKFLAGS += -T$(ESP32_SDK_DIR)/components/esp_rom/$(CPU)/ld/$(CPU).rom.api.ld
|
|
|
|
LINKFLAGS += -T$(ESP32_SDK_DIR)/components/esp_rom/$(CPU)/ld/$(CPU).rom.ld
|
|
|
|
LINKFLAGS += -T$(ESP32_SDK_DIR)/components/esp_rom/$(CPU)/ld/$(CPU).rom.newlib-data.ld
|
|
|
|
LINKFLAGS += -T$(ESP32_SDK_DIR)/components/esp_rom/$(CPU)/ld/$(CPU).rom.newlib-funcs.ld
|
|
|
|
LINKFLAGS += -T$(ESP32_SDK_DIR)/components/esp_rom/$(CPU)/ld/$(CPU).rom.newlib-time.ld
|
|
|
|
LINKFLAGS += -T$(ESP32_SDK_DIR)/components/esp_rom/$(CPU)/ld/$(CPU).rom.spiflash.ld
|
|
|
|
LINKFLAGS += -T$(ESP32_SDK_DIR)/components/esp_rom/$(CPU)/ld/$(CPU).rom.redefined.ld
|
|
|
|
LINKFLAGS += -T$(RIOTCPU)/$(CPU)/ld/memory.ld
|
|
|
|
LINKFLAGS += -T$(RIOTCPU)/$(CPU)/ld/sections.ld
|
2019-08-06 07:58:10 +02:00
|
|
|
LINKFLAGS += -nostdlib -lgcc -Wl,-gc-sections
|
2019-08-06 07:39:33 +02:00
|
|
|
|
2020-08-10 14:45:39 +02:00
|
|
|
# Libraries needed when using esp_wifi_any pseudomodule
|
2020-06-25 10:17:10 +02:00
|
|
|
ifneq (,$(filter esp_wifi_any,$(USEMODULE)))
|
2022-02-01 22:11:43 +01:00
|
|
|
LINKFLAGS += -L$(ESP32_SDK_LIB_WIFI_DIR)/$(CPU)
|
|
|
|
LINKFLAGS += -L$(ESP32_SDK_LIB_PHY_DIR)/$(CPU)
|
|
|
|
ARCHIVES += -lcore -lrtc -lnet80211 -lpp -lcoexist
|
2020-08-10 14:45:39 +02:00
|
|
|
ARCHIVES += -lphy -lstdc++
|
2020-06-25 10:17:10 +02:00
|
|
|
endif
|
2020-03-09 20:01:03 +01:00
|
|
|
|
2020-08-10 14:45:39 +02:00
|
|
|
# Libraries needed when using esp_now module
|
2020-06-25 10:17:10 +02:00
|
|
|
ifneq (,$(filter esp_now,$(USEMODULE)))
|
2020-08-10 14:45:39 +02:00
|
|
|
ARCHIVES += -lespnow -lmesh
|
2020-06-25 10:17:10 +02:00
|
|
|
endif
|
2020-03-09 20:01:03 +01:00
|
|
|
|
2021-12-07 11:27:51 +01:00
|
|
|
ifneq (,$(filter cpp,$(USEMODULE)))
|
2020-08-10 14:45:39 +02:00
|
|
|
ARCHIVES += -lstdc++
|
2020-06-25 10:17:10 +02:00
|
|
|
endif
|
2021-09-28 00:00:22 +02:00
|
|
|
|
2022-02-01 22:11:43 +01:00
|
|
|
ifneq (,$(filter esp_bootloader,$(USEMODULE)))
|
|
|
|
# Bootloader file used by esptool.inc.mk
|
|
|
|
BOOTLOADER_BIN ?= $(BINDIR)/esp_bootloader/bootloader.bin
|
|
|
|
endif
|
|
|
|
|
2021-09-28 00:00:22 +02:00
|
|
|
ifneq (,$(filter esp_jtag,$(USEMODULE)))
|
|
|
|
PROGRAMMERS_SUPPORTED += openocd
|
|
|
|
PARTITION_POS = 0x8000
|
|
|
|
OPENOCD_PRE_FLASH_CMDS = -c 'echo "Installing Bootloader at $(BOOTLOADER_POS)"' \
|
2022-02-01 22:11:43 +01:00
|
|
|
-c 'flash write_image erase "$(BOOTLOADER_BIN)" $(BOOTLOADER_POS) bin' \
|
2021-09-28 00:00:22 +02:00
|
|
|
-c 'echo "Installing partition table at $(PARTITION_POS)"' \
|
|
|
|
-c 'flash write_image erase "$(BINDIR)/partitions.bin" $(PARTITION_POS) bin'
|
2021-09-28 01:13:45 +02:00
|
|
|
IMAGE_OFFSET = 0x10000
|
2021-09-28 01:26:07 +02:00
|
|
|
# Flash checksumming not supported on xtensa
|
|
|
|
OPENOCD_SKIP_VERIFY = yes
|
2021-09-28 22:32:18 +02:00
|
|
|
# Without resets debug target fails with 'Target not examined yet'
|
|
|
|
OPENOCD_DBG_EXTRA_CMD += -c 'reset halt'
|
2021-09-28 00:00:22 +02:00
|
|
|
endif
|
2022-02-01 22:11:43 +01:00
|
|
|
|
|
|
|
$(BOOTLOADER_BIN):
|