2021-05-31 00:28:57 +02:00
|
|
|
############################################################################
|
|
|
|
# tools/esp32s2/Config.mk
|
|
|
|
#
|
2024-09-10 14:15:58 +02:00
|
|
|
# SPDX-License-Identifier: Apache-2.0
|
|
|
|
#
|
2021-05-31 00:28:57 +02:00
|
|
|
# Licensed to the Apache Software Foundation (ASF) under one or more
|
|
|
|
# contributor license agreements. See the NOTICE file distributed with
|
|
|
|
# this work for additional information regarding copyright ownership. The
|
|
|
|
# ASF licenses this file to you under the Apache License, Version 2.0 (the
|
|
|
|
# "License"); you may not use this file except in compliance with the
|
|
|
|
# License. You may obtain a copy of the License at
|
|
|
|
#
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
#
|
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
# License for the specific language governing permissions and limitations
|
|
|
|
# under the License.
|
|
|
|
#
|
|
|
|
############################################################################
|
|
|
|
|
|
|
|
# These are the macros that will be used in the NuttX make system to compile
|
|
|
|
# and assemble source files and to insert the resulting object files into an
|
|
|
|
# archive. These replace the default definitions at tools/Config.mk
|
|
|
|
|
|
|
|
ifeq ($(CONFIG_ESP32S2_FLASH_2M),y)
|
|
|
|
FLASH_SIZE := 2MB
|
|
|
|
else ifeq ($(CONFIG_ESP32S2_FLASH_4M),y)
|
|
|
|
FLASH_SIZE := 4MB
|
|
|
|
else ifeq ($(CONFIG_ESP32S2_FLASH_8M),y)
|
|
|
|
FLASH_SIZE := 8MB
|
|
|
|
else ifeq ($(CONFIG_ESP32S2_FLASH_16M),y)
|
|
|
|
FLASH_SIZE := 16MB
|
|
|
|
endif
|
|
|
|
|
2024-08-29 13:44:00 +02:00
|
|
|
ifeq ($(CONFIG_ESPRESSIF_FLASH_MODE_DIO),y)
|
2021-05-31 00:28:57 +02:00
|
|
|
FLASH_MODE := dio
|
2024-08-29 13:44:00 +02:00
|
|
|
else ifeq ($(CONFIG_ESPRESSIF_FLASH_MODE_DOUT),y)
|
2021-05-31 00:28:57 +02:00
|
|
|
FLASH_MODE := dout
|
2024-08-29 13:44:00 +02:00
|
|
|
else ifeq ($(CONFIG_ESPRESSIF_FLASH_MODE_QIO),y)
|
2021-05-31 00:28:57 +02:00
|
|
|
FLASH_MODE := qio
|
2024-08-29 13:44:00 +02:00
|
|
|
else ifeq ($(CONFIG_ESPRESSIF_FLASH_MODE_QOUT),y)
|
2021-05-31 00:28:57 +02:00
|
|
|
FLASH_MODE := qout
|
|
|
|
endif
|
|
|
|
|
2024-08-29 13:44:00 +02:00
|
|
|
ifeq ($(CONFIG_ESPRESSIF_FLASH_FREQ_80M),y)
|
2021-05-31 00:28:57 +02:00
|
|
|
FLASH_FREQ := 80m
|
2024-08-29 13:44:00 +02:00
|
|
|
else ifeq ($(CONFIG_ESPRESSIF_FLASH_FREQ_40M),y)
|
2021-05-31 00:28:57 +02:00
|
|
|
FLASH_FREQ := 40m
|
2024-08-29 13:44:00 +02:00
|
|
|
else ifeq ($(CONFIG_ESPRESSIF_FLASH_FREQ_26M),y)
|
2021-05-31 00:28:57 +02:00
|
|
|
FLASH_FREQ := 26m
|
2024-08-29 13:44:00 +02:00
|
|
|
else ifeq ($(CONFIG_ESPRESSIF_FLASH_FREQ_20M),y)
|
2021-05-31 00:28:57 +02:00
|
|
|
FLASH_FREQ := 20m
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifeq ($(CONFIG_ESP32S2_FLASH_DETECT),y)
|
|
|
|
ESPTOOL_WRITEFLASH_OPTS := -fs detect -fm dio -ff $(FLASH_FREQ)
|
|
|
|
else
|
|
|
|
ESPTOOL_WRITEFLASH_OPTS := -fs $(FLASH_SIZE) -fm dio -ff $(FLASH_FREQ)
|
|
|
|
endif
|
|
|
|
|
2022-01-03 22:25:58 +01:00
|
|
|
ifneq ($(CONFIG_ESP32S2_SECURE_BOOT)$(CONFIG_ESP32S2_SECURE_FLASH_ENC_ENABLED),)
|
2021-11-19 22:01:42 +01:00
|
|
|
ESPTOOL_RESET_OPTS += --after no_reset
|
|
|
|
endif
|
|
|
|
|
2021-09-08 11:28:41 +02:00
|
|
|
ESPTOOL_FLASH_OPTS := -fs $(FLASH_SIZE) -fm $(FLASH_MODE) -ff $(FLASH_FREQ)
|
|
|
|
|
2021-09-13 18:56:55 +02:00
|
|
|
# Configure the variables according to build environment
|
|
|
|
|
2021-05-31 00:28:57 +02:00
|
|
|
ifdef ESPTOOL_BINDIR
|
2024-05-28 14:44:07 +02:00
|
|
|
ifeq ($(CONFIG_ESP32S2_APP_FORMAT_MCUBOOT),y)
|
2022-01-03 22:25:58 +01:00
|
|
|
BL_OFFSET := 0x1000
|
|
|
|
|
2021-11-19 22:01:42 +01:00
|
|
|
ifeq ($(CONFIG_ESP32S2_SECURE_BOOT),y)
|
|
|
|
BOOTLOADER := $(ESPTOOL_BINDIR)/mcuboot-esp32s2.signed.bin
|
|
|
|
else
|
|
|
|
BOOTLOADER := $(ESPTOOL_BINDIR)/mcuboot-esp32s2.bin
|
2022-01-03 22:25:58 +01:00
|
|
|
endif
|
|
|
|
|
|
|
|
FLASH_BL := $(BL_OFFSET) $(BOOTLOADER)
|
|
|
|
|
|
|
|
ifneq ($(CONFIG_ESP32S2_SECURE_BOOT)$(CONFIG_ESP32S2_SECURE_FLASH_ENC_ENABLED),)
|
|
|
|
ESPTOOL_BINS :=
|
|
|
|
else
|
2021-11-19 22:01:42 +01:00
|
|
|
ESPTOOL_BINS := $(FLASH_BL)
|
|
|
|
endif
|
2021-09-13 18:56:55 +02:00
|
|
|
endif
|
2021-09-02 00:39:56 +02:00
|
|
|
endif
|
|
|
|
|
2024-05-28 14:44:07 +02:00
|
|
|
ifeq ($(CONFIG_ESP32S2_APP_FORMAT_MCUBOOT),y)
|
2021-09-13 18:56:55 +02:00
|
|
|
ifeq ($(CONFIG_ESP32S2_ESPTOOL_TARGET_PRIMARY),y)
|
|
|
|
VERIFIED := --confirm
|
2024-08-29 13:44:00 +02:00
|
|
|
APP_OFFSET := $(CONFIG_ESPRESSIF_OTA_PRIMARY_SLOT_OFFSET)
|
2021-09-13 18:56:55 +02:00
|
|
|
else ifeq ($(CONFIG_ESP32S2_ESPTOOL_TARGET_SECONDARY),y)
|
|
|
|
VERIFIED :=
|
2024-08-29 13:44:00 +02:00
|
|
|
APP_OFFSET := $(CONFIG_ESPRESSIF_OTA_SECONDARY_SLOT_OFFSET)
|
2021-09-13 18:56:55 +02:00
|
|
|
endif
|
|
|
|
|
2021-11-19 22:01:42 +01:00
|
|
|
ifeq ($(CONFIG_ESP32S2_SECURE_BOOT),y)
|
|
|
|
APP_IMAGE := nuttx.signed.bin
|
|
|
|
else
|
|
|
|
APP_IMAGE := nuttx.bin
|
|
|
|
endif
|
2022-01-04 18:34:36 +01:00
|
|
|
|
2021-09-13 18:56:55 +02:00
|
|
|
FLASH_APP := $(APP_OFFSET) $(APP_IMAGE)
|
2022-01-04 18:34:36 +01:00
|
|
|
|
|
|
|
ifeq ($(CONFIG_ESP32S2_SECURE_FLASH_ENC_ENABLED),y)
|
|
|
|
IMGTOOL_ALIGN_ARGS := --align 32 --max-align 32
|
|
|
|
else
|
|
|
|
IMGTOOL_ALIGN_ARGS := --align 4
|
|
|
|
endif
|
|
|
|
|
|
|
|
IMGTOOL_SIGN_ARGS := --pad $(VERIFIED) $(IMGTOOL_ALIGN_ARGS) -v 0 -s auto \
|
|
|
|
-H $(CONFIG_ESP32S2_APP_MCUBOOT_HEADER_SIZE) --pad-header \
|
2024-08-29 13:44:00 +02:00
|
|
|
-S $(CONFIG_ESPRESSIF_OTA_SLOT_SIZE)
|
2024-05-23 10:36:29 +02:00
|
|
|
else
|
|
|
|
# CONFIG_ESPRESSIF_SIMPLE_BOOT
|
|
|
|
|
|
|
|
APP_OFFSET := 0x1000
|
|
|
|
APP_IMAGE := nuttx.bin
|
|
|
|
FLASH_APP := $(APP_OFFSET) $(APP_IMAGE)
|
|
|
|
ESPTOOL_BINDIR := .
|
2021-09-13 18:56:55 +02:00
|
|
|
endif
|
2021-09-02 00:39:56 +02:00
|
|
|
|
2021-09-13 18:56:55 +02:00
|
|
|
ESPTOOL_BINS += $(FLASH_APP)
|
2021-09-04 12:28:53 +02:00
|
|
|
|
2021-11-19 22:01:42 +01:00
|
|
|
# Commands for colored and formatted output
|
|
|
|
|
|
|
|
RED = \033[1;31m
|
|
|
|
YELLOW = \033[1;33m
|
|
|
|
BOLD = \033[1m
|
|
|
|
RST = \033[0m
|
|
|
|
|
|
|
|
# Functions for printing help messages
|
|
|
|
|
|
|
|
define HELP_SIGN_APP
|
|
|
|
$(Q) echo ""
|
|
|
|
$(Q) echo "$(YELLOW)Application not signed. Sign the application before flashing.$(RST)"
|
|
|
|
$(Q) echo "To sign the application, you can use this command:"
|
2022-01-04 18:34:36 +01:00
|
|
|
$(Q) echo " imgtool sign -k $(ESPSEC_KEYDIR)/$(CONFIG_ESP32S2_SECURE_BOOT_APP_SIGNING_KEY) --public-key-format hash $(IMGTOOL_SIGN_ARGS) nuttx.hex nuttx.signed.bin"
|
2021-11-19 22:01:42 +01:00
|
|
|
$(Q) echo ""
|
|
|
|
endef
|
|
|
|
|
|
|
|
define HELP_FLASH_BOOTLOADER
|
|
|
|
$(Q) echo ""
|
2022-01-03 22:25:58 +01:00
|
|
|
$(Q) echo "$(YELLOW)Security features enabled, so bootloader not flashed automatically.$(RST)"
|
2021-11-19 22:01:42 +01:00
|
|
|
$(Q) echo "Use the following command to flash the bootloader:"
|
|
|
|
$(Q) echo " esptool.py $(ESPTOOL_OPTS) write_flash $(ESPTOOL_WRITEFLASH_OPTS) $(FLASH_BL)"
|
|
|
|
$(Q) echo ""
|
|
|
|
endef
|
|
|
|
|
2021-09-02 00:39:56 +02:00
|
|
|
# MERGEBIN -- Merge raw binary files into a single file
|
|
|
|
|
|
|
|
define MERGEBIN
|
|
|
|
$(Q) if [ -z $(ESPTOOL_BINDIR) ]; then \
|
|
|
|
echo "MERGEBIN error: Missing argument for binary files directory."; \
|
|
|
|
echo "USAGE: make ESPTOOL_BINDIR=<dir>"; \
|
|
|
|
exit 1; \
|
|
|
|
fi
|
|
|
|
$(Q) if [ -z $(FLASH_SIZE) ]; then \
|
|
|
|
echo "Missing Flash memory size configuration for the ESP32-S2 chip."; \
|
|
|
|
exit 1; \
|
|
|
|
fi
|
2021-09-08 11:28:41 +02:00
|
|
|
esptool.py -c esp32s2 merge_bin --output nuttx.merged.bin $(ESPTOOL_FLASH_OPTS) $(ESPTOOL_BINS)
|
2021-09-02 00:39:56 +02:00
|
|
|
$(Q) echo nuttx.merged.bin >> nuttx.manifest
|
|
|
|
$(Q) echo "Generated: nuttx.merged.bin"
|
|
|
|
endef
|
2021-05-31 00:28:57 +02:00
|
|
|
|
2021-11-19 22:01:42 +01:00
|
|
|
# SIGNBIN -- Create the signed binary image file for Secure Boot
|
2021-09-13 18:56:55 +02:00
|
|
|
|
|
|
|
define SIGNBIN
|
2021-11-19 22:01:42 +01:00
|
|
|
$(Q) echo "SIGNBIN: ESP32-S2 signed binary"
|
2021-09-13 18:56:55 +02:00
|
|
|
$(Q) if ! imgtool version 1>/dev/null 2>&1; then \
|
|
|
|
echo ""; \
|
|
|
|
echo "imgtool not found. Please run: \"pip install imgtool\""; \
|
|
|
|
echo ""; \
|
|
|
|
echo "Run make again to create the nuttx.signed.bin image."; \
|
|
|
|
exit 1; \
|
|
|
|
fi
|
2021-11-19 22:01:42 +01:00
|
|
|
$(Q) if [ -z "$(ESPSEC_KEYDIR)" ]; then \
|
|
|
|
echo "SIGNBIN error: Missing argument for secure boot keys directory."; \
|
|
|
|
echo "USAGE: make ESPSEC_KEYDIR=<dir>"; \
|
|
|
|
exit 1; \
|
|
|
|
fi
|
|
|
|
|
|
|
|
$(eval APP_SIGN_KEY := $(ESPSEC_KEYDIR)/$(subst ",,$(CONFIG_ESP32S2_SECURE_BOOT_APP_SIGNING_KEY)))
|
|
|
|
$(Q) if [ ! -f "$(APP_SIGN_KEY)" ]; then \
|
|
|
|
echo ""; \
|
|
|
|
echo "$(RED)SIGNBIN error:$(RST) Application signing key $(BOLD)$(CONFIG_ESP32S2_SECURE_BOOT_APP_SIGNING_KEY)$(RST) does not exist."; \
|
|
|
|
echo "Generate using:"; \
|
|
|
|
echo " imgtool keygen --key $(CONFIG_ESP32S2_SECURE_BOOT_APP_SIGNING_KEY) --type <ESP32S2_SECURE_SIGNED_APPS_SCHEME>"; \
|
|
|
|
echo ""; \
|
|
|
|
exit 1; \
|
|
|
|
fi
|
|
|
|
|
2022-01-04 18:34:36 +01:00
|
|
|
imgtool sign $(IMGTOOL_KEY_ARGS) $(IMGTOOL_SIGN_ARGS) nuttx.hex nuttx.signed.bin
|
2021-09-13 18:56:55 +02:00
|
|
|
$(Q) echo nuttx.signed.bin >> nuttx.manifest
|
|
|
|
$(Q) echo "Generated: nuttx.signed.bin (MCUboot compatible)"
|
|
|
|
endef
|
|
|
|
|
2021-11-19 22:01:42 +01:00
|
|
|
# MKIMAGE -- Convert an ELF file into a compatible binary file
|
2021-09-13 18:56:55 +02:00
|
|
|
|
2021-11-19 22:01:42 +01:00
|
|
|
ifeq ($(CONFIG_ESP32S2_SECURE_BOOT),y)
|
|
|
|
define MKIMAGE
|
|
|
|
$(if $(CONFIG_ESP32S2_SECURE_BOOT_BUILD_SIGNED_BINARIES),$(call SIGNBIN),$(call HELP_SIGN_APP))
|
|
|
|
endef
|
|
|
|
else
|
2024-05-28 14:44:07 +02:00
|
|
|
ifeq ($(CONFIG_ESP32S2_APP_FORMAT_MCUBOOT),y)
|
2021-11-19 22:01:42 +01:00
|
|
|
define MKIMAGE
|
|
|
|
$(Q) echo "MKIMAGE: ESP32-S2 binary"
|
|
|
|
$(Q) if ! imgtool version 1>/dev/null 2>&1; then \
|
|
|
|
echo ""; \
|
|
|
|
echo "imgtool not found. Please run: \"pip install imgtool\""; \
|
|
|
|
echo ""; \
|
|
|
|
echo "Run make again to create the nuttx.bin image."; \
|
|
|
|
exit 1; \
|
|
|
|
fi
|
2022-01-04 18:34:36 +01:00
|
|
|
imgtool sign $(IMGTOOL_SIGN_ARGS) nuttx.hex nuttx.bin
|
2022-05-27 09:57:40 +02:00
|
|
|
$(Q) echo nuttx.bin >> nuttx.manifest
|
2021-11-19 22:01:42 +01:00
|
|
|
$(Q) echo "Generated: nuttx.bin (MCUboot compatible)"
|
|
|
|
endef
|
2024-05-23 10:36:29 +02:00
|
|
|
else
|
|
|
|
define MKIMAGE
|
|
|
|
$(Q) echo "MKIMAGE: ESP32-S2 binary"
|
|
|
|
$(Q) if ! esptool.py version 1>/dev/null 2>&1; then \
|
|
|
|
echo ""; \
|
|
|
|
echo "esptool.py not found. Please run: \"pip install esptool==4.8.dev4\""; \
|
|
|
|
echo ""; \
|
|
|
|
echo "Run make again to create the nuttx.bin image."; \
|
|
|
|
exit 1; \
|
|
|
|
fi
|
|
|
|
$(Q) if [ -z $(FLASH_SIZE) ]; then \
|
|
|
|
echo "Missing Flash memory size configuration."; \
|
|
|
|
exit 1; \
|
|
|
|
fi
|
|
|
|
$(eval ELF2IMAGE_OPTS := $(if $(CONFIG_ESPRESSIF_SIMPLE_BOOT),--ram-only-header) -fs $(FLASH_SIZE) -fm $(FLASH_MODE) -ff $(FLASH_FREQ))
|
|
|
|
esptool.py -c esp32s2 elf2image $(ELF2IMAGE_OPTS) -o nuttx.bin nuttx
|
|
|
|
$(Q) echo nuttx.bin >> nuttx.manifest
|
|
|
|
$(Q) echo "Generated: nuttx.bin"
|
|
|
|
endef
|
2021-11-19 22:01:42 +01:00
|
|
|
endif
|
2021-09-13 18:56:55 +02:00
|
|
|
endif
|
|
|
|
|
2021-05-31 00:28:57 +02:00
|
|
|
# POSTBUILD -- Perform post build operations
|
|
|
|
|
|
|
|
define POSTBUILD
|
2021-11-19 22:01:42 +01:00
|
|
|
$(call MKIMAGE)
|
|
|
|
$(if $(CONFIG_ESP32S2_MERGE_BINS),$(call MERGEBIN))
|
2021-05-31 00:28:57 +02:00
|
|
|
endef
|
|
|
|
|
|
|
|
# ESPTOOL_BAUD -- Serial port baud rate used when flashing/reading via esptool.py
|
|
|
|
|
|
|
|
ESPTOOL_BAUD ?= 921600
|
|
|
|
|
2021-10-14 15:57:21 +02:00
|
|
|
# FLASH -- Download a binary image via esptool.py
|
2021-05-31 00:28:57 +02:00
|
|
|
|
2021-10-14 15:57:21 +02:00
|
|
|
define FLASH
|
2021-05-31 00:28:57 +02:00
|
|
|
$(Q) if [ -z $(ESPTOOL_PORT) ]; then \
|
2021-10-14 15:57:21 +02:00
|
|
|
echo "FLASH error: Missing serial port device argument."; \
|
|
|
|
echo "USAGE: make flash ESPTOOL_PORT=<port> [ ESPTOOL_BAUD=<baud> ] [ ESPTOOL_BINDIR=<dir> ]"; \
|
2021-05-31 00:28:57 +02:00
|
|
|
exit 1; \
|
|
|
|
fi
|
2021-12-30 15:58:24 +01:00
|
|
|
$(eval ESPTOOL_OPTS := -c esp32s2 -p $(ESPTOOL_PORT) -b $(ESPTOOL_BAUD) $(ESPTOOL_RESET_OPTS) $(if $(CONFIG_ESP32S2_ESPTOOLPY_NO_STUB),--no-stub))
|
2021-11-19 22:01:42 +01:00
|
|
|
esptool.py $(ESPTOOL_OPTS) write_flash $(ESPTOOL_WRITEFLASH_OPTS) $(ESPTOOL_BINS)
|
|
|
|
|
2022-01-03 22:25:58 +01:00
|
|
|
$(if $(CONFIG_ESP32S2_SECURE_BOOT)$(CONFIG_ESP32S2_SECURE_FLASH_ENC_ENABLED),$(call HELP_FLASH_BOOTLOADER))
|
2021-05-31 00:28:57 +02:00
|
|
|
endef
|