From a5a9bf43cc6b3b3113b6a53f9ea34a7fdcaeccb0 Mon Sep 17 00:00:00 2001 From: Ivan Kravets Date: Wed, 21 Jun 2023 16:30:13 +0300 Subject: [PATCH 01/28] Use correct import --- monitor/filter_exception_decoder.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/monitor/filter_exception_decoder.py b/monitor/filter_exception_decoder.py index f3c680669..5a646e838 100644 --- a/monitor/filter_exception_decoder.py +++ b/monitor/filter_exception_decoder.py @@ -17,7 +17,7 @@ import subprocess import sys -from platformio.project.exception import PlatformioException +from platformio.exception import PlatformioException from platformio.public import ( DeviceMonitorFilterBase, load_build_metadata, From a47ecbfca0654f57004052cd90ce5f97214c40fa Mon Sep 17 00:00:00 2001 From: Maximilian Gerhardt Date: Mon, 3 Jul 2023 11:37:16 +0200 Subject: [PATCH 02/28] Fix OpenOCD configuration for Lolin S2 boards (#1139) * Fix OpenOCD board -> target on Lolin S2 Mini * Same for lolin_s2_pico.json --- boards/lolin_s2_mini.json | 2 +- boards/lolin_s2_pico.json | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/boards/lolin_s2_mini.json b/boards/lolin_s2_mini.json index 3fe4f7122..59832f8cb 100644 --- a/boards/lolin_s2_mini.json +++ b/boards/lolin_s2_mini.json @@ -25,7 +25,7 @@ "wifi" ], "debug": { - "openocd_board": "esp32s2.cfg" + "openocd_target": "esp32s2.cfg" }, "frameworks": [ "arduino", diff --git a/boards/lolin_s2_pico.json b/boards/lolin_s2_pico.json index dab2b7ec0..0214a0eea 100644 --- a/boards/lolin_s2_pico.json +++ b/boards/lolin_s2_pico.json @@ -25,7 +25,7 @@ "wifi" ], "debug": { - "openocd_board": "esp32s2.cfg" + "openocd_target": "esp32s2.cfg" }, "frameworks": [ "arduino", From 28656548e267d7a8022251cb5af74bf19dd44050 Mon Sep 17 00:00:00 2001 From: valeros Date: Thu, 13 Jul 2023 14:20:22 +0300 Subject: [PATCH 03/28] Override default behavior of memory analysis feature --- builder/main.py | 6 ++++++ builder/sizedata.py | 26 ++++++++++++++++++++++++++ 2 files changed, 32 insertions(+) create mode 100644 builder/sizedata.py diff --git a/builder/main.py b/builder/main.py index 21348d37d..3aabec6d4 100644 --- a/builder/main.py +++ b/builder/main.py @@ -533,6 +533,12 @@ def __fetch_fs_size(target, source, env): print("Warning! '-Wl,-T' option for specifying linker scripts is deprecated. " "Please use 'board_build.ldscript' option in your 'platformio.ini' file.") +# +# Override memory inspection behavior +# + +env.SConscript("sizedata.py", exports="env") + # # Default targets # diff --git a/builder/sizedata.py b/builder/sizedata.py new file mode 100644 index 000000000..e6e947627 --- /dev/null +++ b/builder/sizedata.py @@ -0,0 +1,26 @@ +import re + +Import("env") + + +def pioSizeIsRamSectionCustom(env, section): + if section and re.search( + r"\.dram0\.data|\.dram0\.bss|\.noinit", section.get("name", "") + ): + return True + + return False + + +def pioSizeIsFlashectionCustom(env, section): + if section and re.search( + r"\.iram0\.text|\.iram0\.vectors|\.dram0\.data|\.flash\.text|\.flash\.rodata|\.flash\.appdesc", + section.get("name", ""), + ): + return True + + return False + + +env.AddMethod(pioSizeIsRamSectionCustom, "pioSizeIsRamSection") +env.AddMethod(pioSizeIsFlashectionCustom, "pioSizeIsFlashSection") From ea405523d8ffc267f95d5fc9d8028435f9ab0e78 Mon Sep 17 00:00:00 2001 From: valeros Date: Thu, 13 Jul 2023 14:21:58 +0300 Subject: [PATCH 04/28] Remove unnecessary ULP binary dependency --- builder/frameworks/ulp.py | 1 - 1 file changed, 1 deletion(-) diff --git a/builder/frameworks/ulp.py b/builder/frameworks/ulp.py index 416b5b20d..5af8f87d1 100644 --- a/builder/frameworks/ulp.py +++ b/builder/frameworks/ulp.py @@ -129,7 +129,6 @@ def compile_ulp_binary(): os.path.join(ULP_BUILD_DIR, "ulp_main.h"), os.path.join(ULP_BUILD_DIR, "ulp_main.ld"), os.path.join(ULP_BUILD_DIR, "ulp_main.bin"), - os.path.join(ULP_BUILD_DIR, "esp32.ulp.ld"), ], None, ulp_env.VerboseAction(" ".join(cmd), "Generating ULP project files $TARGETS"), From 26aa55aa9589f97e227590e8db8d9d606d518600 Mon Sep 17 00:00:00 2001 From: valeros Date: Fri, 21 Jul 2023 15:56:22 +0300 Subject: [PATCH 05/28] Process "build_src_flags" option in IDF build script Resolves #1146 --- builder/frameworks/espidf.py | 1 + 1 file changed, 1 insertion(+) diff --git a/builder/frameworks/espidf.py b/builder/frameworks/espidf.py index 71cce2923..d7d43fc02 100644 --- a/builder/frameworks/espidf.py +++ b/builder/frameworks/espidf.py @@ -1547,6 +1547,7 @@ def _skip_prj_source_files(node): + get_project_lib_includes(env) ) + project_env.ProcessFlags(env.get("SRC_BUILD_FLAGS")) env.Append( PIOBUILDFILES=compile_source_files( target_configs.get(project_target_name), From f1fce6c1a8d20fe63a74676f76213a7f1490bc39 Mon Sep 17 00:00:00 2001 From: Valerii Koval Date: Thu, 27 Jul 2023 14:46:25 +0300 Subject: [PATCH 06/28] Improve dynamic memory size calculation // Resolves #1159 For better results a partition with either `factory` or `ota_0` subtype should be used instead of selecting the biggest partition size with the type `app`. If both partitions are set, then the partition with the `factory` subtype is used by default. --- builder/main.py | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) diff --git a/builder/main.py b/builder/main.py index 3aabec6d4..261b5681b 100644 --- a/builder/main.py +++ b/builder/main.py @@ -139,12 +139,17 @@ def _parse_partitions(env): def _update_max_upload_size(env): if not env.get("PARTITIONS_TABLE_CSV"): return - sizes = [ - _parse_size(p["size"]) for p in _parse_partitions(env) + sizes = { + p["subtype"]: _parse_size(p["size"]) for p in _parse_partitions(env) if p["type"] in ("0", "app") - ] - if sizes: - board.update("upload.maximum_size", max(sizes)) + } + + # One of the `factory` or `ota_0` partitions is used to determine available memory + # size. If both partitions are set, then the `factory` partition is used by default + # https://docs.espressif.com/projects/esp-idf/en/latest/esp32/api-guides/partition-tables.html#subtype + max_upload_size = sizes.get("factory", sizes.get("ota_0", 0)) + if max_upload_size: + board.update("upload.maximum_size", max_upload_size) def _to_unix_slashes(path): From 1d25419ae173dcb928c45ef060c26a9f29599221 Mon Sep 17 00:00:00 2001 From: Ivan Kravets Date: Mon, 31 Jul 2023 18:01:01 +0300 Subject: [PATCH 07/28] Use "platformio.public.fetch_http_content" API for HTTP requests --- platform.py | 20 +++++++++----------- 1 file changed, 9 insertions(+), 11 deletions(-) diff --git a/platform.py b/platform.py index 516fed44b..50ce9123c 100644 --- a/platform.py +++ b/platform.py @@ -17,7 +17,6 @@ import sys import json import re -import requests from platformio.public import PlatformBase, to_unix_path @@ -349,16 +348,15 @@ def _prepare_url_for_index_file(url_items): ) index_file_url = _prepare_url_for_index_file(url_items) - r = requests.get(index_file_url, timeout=10) - if r.status_code != 200: - raise ValueError( - ( - "Failed to download package index file due to a bad response (%d) " - "from the remote `%s`" - ) - % (r.status_code, index_file_url) - ) - return r.json() + + try: + from platformio.public import fetch_http_content + content = fetch_http_content(index_file_url) + except ImportError: + import requests + content = requests.get(index_file_url, timeout=5).text + + return json.loads(content) def configure_arduino_toolchains(self, package_index): if not package_index: From 95125e2627e13e5625e5cb68fe69830a01f1c723 Mon Sep 17 00:00:00 2001 From: valeros Date: Tue, 1 Aug 2023 19:38:55 +0300 Subject: [PATCH 08/28] Update Arduino core to v2.0.11 - Added several new boards (including Nano ESP32) // Resolves #1162 - Added DFU upload method via dfu-util for the new Arduino Nano ESP32 - Updated IDF version to v4.4.5 for mixed Arduino/IDF projects --- boards/adafruit_matrixportal_esp32s3.json | 65 +++++++++++++++++++++++ boards/arduino_nano_esp32.json | 53 ++++++++++++++++++ boards/dfrobot_romeo_esp32s3.json | 47 ++++++++++++++++ boards/m5stamp-pico.json | 34 ++++++++++++ boards/nebulas3.json | 47 ++++++++++++++++ builder/main.py | 22 ++++++++ platform.json | 10 +++- platform.py | 12 ++++- 8 files changed, 287 insertions(+), 3 deletions(-) create mode 100644 boards/adafruit_matrixportal_esp32s3.json create mode 100644 boards/arduino_nano_esp32.json create mode 100644 boards/dfrobot_romeo_esp32s3.json create mode 100644 boards/m5stamp-pico.json create mode 100644 boards/nebulas3.json diff --git a/boards/adafruit_matrixportal_esp32s3.json b/boards/adafruit_matrixportal_esp32s3.json new file mode 100644 index 000000000..3446cd217 --- /dev/null +++ b/boards/adafruit_matrixportal_esp32s3.json @@ -0,0 +1,65 @@ +{ + "build": { + "arduino":{ + "ldscript": "esp32s3_out.ld", + "partitions": "partitions-8MB-tinyuf2.csv" + }, + "core": "esp32", + "extra_flags": [ + "-DARDUINO_ADAFRUIT_MATRIXPORTAL_ESP32S3", + "-DARDUINO_USB_CDC_ON_BOOT=1", + "-DARDUINO_RUNNING_CORE=1", + "-DARDUINO_EVENT_RUNNING_CORE=1", + "-DBOARD_HAS_PSRAM" + ], + "f_cpu": "240000000L", + "f_flash": "80000000L", + "flash_mode": "qio", + "hwids": [ + [ + "0x239A", + "0x8125" + ], + [ + "0x239A", + "0x0125" + ], + [ + "0x239A", + "0x8126" + ] + ], + "mcu": "esp32s3", + "variant": "adafruit_matrixportal_esp32s3" + }, + "connectivity": [ + "wifi" + ], + "debug": { + "openocd_target": "esp32s3.cfg" + }, + "frameworks": [ + "arduino", + "espidf" + ], + "name": "Adafruit MatrixPortal ESP32-S3", + "upload": { + "arduino": { + "flash_extra_images": [ + [ + "0x410000", + "variants/adafruit_matrixportal_esp32s3/tinyuf2.bin" + ] + ] + }, + "flash_size": "8MB", + "maximum_ram_size": 327680, + "maximum_size": 8388608, + "use_1200bps_touch": true, + "wait_for_upload_port": true, + "require_upload_port": true, + "speed": 460800 + }, + "url": "https://www.adafruit.com/product/5778", + "vendor": "Adafruit" +} diff --git a/boards/arduino_nano_esp32.json b/boards/arduino_nano_esp32.json new file mode 100644 index 000000000..c6da4e227 --- /dev/null +++ b/boards/arduino_nano_esp32.json @@ -0,0 +1,53 @@ +{ + "build": { + "arduino":{ + "ldscript": "esp32s3_out.ld", + "partitions": "app3M_fat9M_fact512k_16MB.csv", + "memory_type": "qio_opi" + }, + "core": "esp32", + "extra_flags": [ + "-DARDUINO_NANO_ESP32", + "-DBOARD_HAS_PIN_REMAP", + "-DBOARD_HAS_PSRAM", + "-DUSB_MANUFACTURER=\\\"Arduino\\\"", + "-DUSB_PRODUCT=\\\"NanoESP32\\\"", + "-DARDUINO_USB_CDC_ON_BOOT=1", + "-DARDUINO_USB_DFU_ON_BOOT=1", + "-DARDUINO_RUNNING_CORE=1", + "-DARDUINO_EVENT_RUNNING_CORE=1" + ], + "f_cpu": "240000000L", + "f_flash": "80000000L", + "flash_mode": "qio", + "hwids": [ + [ + "0x2341", + "0x0070" + ] + ], + "mcu": "esp32s3", + "variant": "arduino_nano_nora" + }, + "connectivity": [ + "wifi" + ], + "debug": { + "openocd_target": "esp32s3.cfg" + }, + "frameworks": [ + "arduino", + "espidf" + ], + "name": "Arduino Nano ESP32", + "upload": { + "flash_size": "16MB", + "maximum_ram_size": 327680, + "maximum_size": 16777216, + "require_upload_port": true, + "speed": 460800, + "protocol": "dfu" + }, + "url": "https://docs.arduino.cc/hardware/nano-esp32", + "vendor": "Arduino" +} diff --git a/boards/dfrobot_romeo_esp32s3.json b/boards/dfrobot_romeo_esp32s3.json new file mode 100644 index 000000000..63a7cb472 --- /dev/null +++ b/boards/dfrobot_romeo_esp32s3.json @@ -0,0 +1,47 @@ +{ + "build": { + "arduino": { + "ldscript": "esp32s3_out.ld", + "partitions": "app3M_fat9M_16MB.csv", + "memory_type": "qio_opi" + }, + "core": "esp32", + "extra_flags": [ + "-DARDUINO_DFROBOT_ROMEO_ESP32S3", + "-DARDUINO_USB_MODE=1", + "-DARDUINO_RUNNING_CORE=1", + "-DARDUINO_EVENT_RUNNING_CORE=1" + ], + "f_cpu": "240000000L", + "f_flash": "80000000L", + "flash_mode": "qio", + "hwids": [ + [ + "0x303A", + "0x1001" + ] + ], + "mcu": "esp32s3", + "variant": "dfrobot_romeo_esp32s3" + }, + "connectivity": [ + "wifi" + ], + "debug": { + "openocd_target": "esp32s3.cfg" + }, + "frameworks": [ + "arduino", + "espidf" + ], + "name": "DFRobot Romeo ESP32-S3", + "upload": { + "flash_size": "16MB", + "maximum_ram_size": 327680, + "maximum_size": 16777216, + "require_upload_port": true, + "speed": 460800 + }, + "url": "https://wiki.dfrobot.com/", + "vendor": "DFRobot" +} diff --git a/boards/m5stamp-pico.json b/boards/m5stamp-pico.json new file mode 100644 index 000000000..8f39fe5ce --- /dev/null +++ b/boards/m5stamp-pico.json @@ -0,0 +1,34 @@ +{ + "build": { + "arduino":{ + "ldscript": "esp32_out.ld" + }, + "core": "esp32", + "extra_flags": "-DARDUINO_M5Stamp_Pico", + "f_cpu": "240000000L", + "f_flash": "40000000L", + "flash_mode": "dio", + "mcu": "esp32", + "variant": "m5stack_stamp_pico" + }, + "connectivity": [ + "wifi", + "bluetooth", + "ethernet", + "can" + ], + "frameworks": [ + "arduino", + "espidf" + ], + "name": "M5Stamp-Pico", + "upload": { + "flash_size": "4MB", + "maximum_ram_size": 327680, + "maximum_size": 4194304, + "require_upload_port": true, + "speed": 1500000 + }, + "url": "https://shop.m5stack.com/products/m5stamp-pico-mate-with-pin-headers", + "vendor": "M5Stack" +} diff --git a/boards/nebulas3.json b/boards/nebulas3.json new file mode 100644 index 000000000..dc6236494 --- /dev/null +++ b/boards/nebulas3.json @@ -0,0 +1,47 @@ +{ + "build": { + "arduino": { + "ldscript": "esp32s3_out.ld", + "memory_type": "qio_opi" + }, + "core": "esp32", + "extra_flags": [ + "-DARDUINO_NEBULAS3", + "-DARDUINO_USB_MODE=1", + "-DARDUINO_RUNNING_CORE=1", + "-DARDUINO_EVENT_RUNNING_CORE=1", + "-DARDUINO_USB_CDC_ON_BOOT=1" + ], + "f_cpu": "240000000L", + "f_flash": "80000000L", + "flash_mode": "qio", + "hwids": [ + [ + "0x303A", + "0x1001" + ] + ], + "mcu": "esp32s3", + "variant": "Nebula_S3" + }, + "connectivity": [ + "wifi" + ], + "debug": { + "openocd_target": "esp32s3.cfg" + }, + "frameworks": [ + "arduino", + "espidf" + ], + "name": "Kinetic Dynamics Nebula S3", + "upload": { + "flash_size": "4MB", + "maximum_ram_size": 327680, + "maximum_size": 4194304, + "require_upload_port": true, + "speed": 460800 + }, + "url": "https://kineticdynamics.in/product/nebula-s3/", + "vendor": "Kinetic Dynamics" +} diff --git a/builder/main.py b/builder/main.py index 261b5681b..dd0055f4f 100644 --- a/builder/main.py +++ b/builder/main.py @@ -460,6 +460,28 @@ def __fetch_fs_size(target, source, env): env.VerboseAction("$UPLOADCMD", "Uploading $SOURCE") ] +elif upload_protocol == "dfu": + # C:\Users\ROOT\AppData\Local\Arduino15\packages\arduino\tools\dfu-util\0.11.0-arduino5/dfu-util --device 0x2341:0x0070 -D C:\Users\ROOT\AppData\Local\Temp\arduino_build_789426/sketch_jul31a.ino.bin -Q + + hwids = board.get("build.hwids", [["0x2341", "0x0070"]]) + vid = hwids[0][0] + pid = hwids[0][1] + + upload_actions = [env.VerboseAction("$UPLOADCMD", "Uploading $SOURCE")] + + env.Replace( + UPLOADER=join( + platform.get_package_dir("tool-dfuutil-arduino") or "", "dfu-util" + ), + UPLOADERFLAGS=[ + "-d", + ",".join(["%s:%s" % (hwid[0], hwid[1]) for hwid in hwids]), + "-Q", + "-D" + ], + UPLOADCMD='"$UPLOADER" $UPLOADERFLAGS "$SOURCE"', + ) + elif upload_protocol in debug_tools: openocd_args = ["-d%d" % (2 if int(ARGUMENTS.get("PIOVERBOSE", 0)) else 1)] diff --git a/platform.json b/platform.json index 818fffa79..be4cd4489 100644 --- a/platform.json +++ b/platform.json @@ -67,7 +67,7 @@ "type": "framework", "optional": true, "owner": "platformio", - "version": "~3.20009.0" + "version": "~3.20011.0" }, "framework-arduino-mbcwb": { "type": "framework", @@ -80,7 +80,7 @@ "optional": true, "owner": "platformio", "version": "~3.50002.0", - "optionalVersions": ["~3.40404.0"] + "optionalVersions": ["~3.40405.0"] }, "tool-esptoolpy": { "type": "uploader", @@ -92,6 +92,12 @@ "owner": "meteca", "version": ">=2.0.0" }, + "tool-dfuutil-arduino": { + "type": "uploader", + "optional": true, + "owner": "platformio", + "version": "~1.11.0" + }, "tool-openocd-esp32": { "type": "debugger", "optional": true, diff --git a/platform.py b/platform.py index 50ce9123c..0e4de8669 100644 --- a/platform.py +++ b/platform.py @@ -46,6 +46,12 @@ def configure_default_packages(self, variables, targets): if os.path.isdir("ulp"): self.packages["toolchain-esp32ulp"]["optional"] = False + # Currently only Arduino Nano ESP32 uses the dfuutil tool as uploader + if variables.get("board") == "arduino_nano_esp32": + self.packages["tool-dfuutil-arduino"]["optional"] = False + else: + del self.packages["tool-dfuutil-arduino"] + build_core = variables.get( "board_build.core", board_config.get("build.core", "arduino") ).lower() @@ -96,7 +102,7 @@ def configure_default_packages(self, variables, targets): if "arduino" in frameworks: # Downgrade the IDF version for mixed Arduino+IDF projects - self.packages["framework-espidf"]["version"] = "~3.40404.0" + self.packages["framework-espidf"]["version"] = "~3.40405.0" else: # Use the latest toolchains available for IDF v5.0 for target in ( @@ -247,6 +253,10 @@ def _add_dynamic_options(self, board): "default": link == debug.get("default_tool"), } + # Avoid erasing Arduino Nano bootloader by preloading app binary + if board.id == "arduino_nano_esp32": + debug["tools"][link]["load_cmds"] = "preload" + board.manifest["debug"] = debug return board From 91bdde3a1bb4bc578353f406be771b9cec0c968c Mon Sep 17 00:00:00 2001 From: Tinyu Date: Wed, 2 Aug 2023 17:55:29 +0800 Subject: [PATCH 09/28] Add M5Stack-CoreS3 board (#1106) --- boards/m5stack-cores3.json | 46 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 46 insertions(+) create mode 100644 boards/m5stack-cores3.json diff --git a/boards/m5stack-cores3.json b/boards/m5stack-cores3.json new file mode 100644 index 000000000..72571e0b7 --- /dev/null +++ b/boards/m5stack-cores3.json @@ -0,0 +1,46 @@ +{ + "build": { + "arduino": { + "ldscript": "esp32s3_out.ld", + "partitions": "default_16MB.csv" + }, + "core": "esp32", + "extra_flags": [ + "-DARDUINO_M5STACK_CORES3", + "-DARDUINO_USB_MODE=1", + "-DARDUINO_RUNNING_CORE=1", + "-DARDUINO_EVENT_RUNNING_CORE=1" + ], + "f_cpu": "240000000L", + "f_flash": "80000000L", + "flash_mode": "qio", + "hwids": [ + [ + "0x303A", + "0x8119" + ] + ], + "mcu": "esp32s3", + "variant": "m5stack_cores3" + }, + "connectivity": [ + "wifi" + ], + "debug": { + "openocd_target": "esp32s3.cfg" + }, + "frameworks": [ + "arduino", + "espidf" + ], + "name": "M5Stack CoreS3", + "upload": { + "flash_size": "16MB", + "maximum_ram_size": 327680, + "maximum_size": 16777216, + "require_upload_port": true, + "speed": 921600 + }, + "url": "https://docs.m5stack.com/en/core/CoreS3", + "vendor": "M5Stack" +} From a6291f80828fe8d838fb6bd15228e313018960f6 Mon Sep 17 00:00:00 2001 From: valeros Date: Wed, 2 Aug 2023 12:57:22 +0300 Subject: [PATCH 10/28] Add Arduino Nano ESP32 env to examples --- examples/arduino-blink/platformio.ini | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/examples/arduino-blink/platformio.ini b/examples/arduino-blink/platformio.ini index 808c16f65..85e0fab00 100644 --- a/examples/arduino-blink/platformio.ini +++ b/examples/arduino-blink/platformio.ini @@ -34,9 +34,13 @@ framework = arduino board = lolin_c3_mini monitor_speed = 115200 - [env:esp32-s3-devkitc-1] platform = espressif32 framework = arduino board = esp32-s3-devkitc-1 monitor_speed = 115200 + +[env:arduino_nano_esp32] +platform = espressif32 +framework = arduino +board = arduino_nano_esp32 From 650fb5d59802141a9a623883a693e7d4ec399aa1 Mon Sep 17 00:00:00 2001 From: valeros Date: Wed, 2 Aug 2023 12:57:52 +0300 Subject: [PATCH 11/28] Typo fix in Smart Bee S3 manifest --- boards/bee_s3.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/boards/bee_s3.json b/boards/bee_s3.json index 2f65542fd..16e47ee79 100644 --- a/boards/bee_s3.json +++ b/boards/bee_s3.json @@ -1,7 +1,7 @@ { "build": { "arduino": { - "ldscript": "esp32s2_out.ld" + "ldscript": "esp32s3_out.ld" }, "core": "esp32", "extra_flags": [ From 07820cf6f46d2b0fb564d7c20358dd4c2e1fe255 Mon Sep 17 00:00:00 2001 From: valeros Date: Wed, 2 Aug 2023 13:00:27 +0300 Subject: [PATCH 12/28] Update dynamic memory calculation process The order of partitions should also be taken into account as the factory partition may be allocated for a bootloader (e.g. Adafruit's custom partition file with a UF2 bootloader) and appear after ota_0 used for app --- builder/main.py | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/builder/main.py b/builder/main.py index dd0055f4f..c5579bf91 100644 --- a/builder/main.py +++ b/builder/main.py @@ -145,11 +145,14 @@ def _update_max_upload_size(env): } # One of the `factory` or `ota_0` partitions is used to determine available memory - # size. If both partitions are set, then the `factory` partition is used by default + # size. If both partitions are set, we should prefer the `factory`, but there are + # cases (e.g. Adafruit's `partitions-4MB-tinyuf2.csv`) that uses the `factory` + # partition for their UF2 bootloader. So let's use the first match # https://docs.espressif.com/projects/esp-idf/en/latest/esp32/api-guides/partition-tables.html#subtype - max_upload_size = sizes.get("factory", sizes.get("ota_0", 0)) - if max_upload_size: - board.update("upload.maximum_size", max_upload_size) + for p in _parse_partitions(env): + if p["type"] in ("0", "app") and p["subtype"] in ("factory", "ota_0"): + board.update("upload.maximum_size", _parse_size(p["size"])) + break def _to_unix_slashes(path): From fc336a9b9989743be3765d3a64f112ae04b16061 Mon Sep 17 00:00:00 2001 From: valeros Date: Thu, 3 Aug 2023 13:38:40 +0300 Subject: [PATCH 13/28] Update IDF to v5.1.0 --- builder/frameworks/espidf.py | 5 +- .../main/ulp_adc_example_main.c | 51 ++++++++++--------- examples/espidf-ulp-adc/ulp/adc.S | 9 +++- examples/espidf-ulp-adc/ulp/example_config.h | 16 ++++++ platform.json | 10 ++-- platform.py | 2 +- 6 files changed, 60 insertions(+), 33 deletions(-) create mode 100644 examples/espidf-ulp-adc/ulp/example_config.h diff --git a/builder/frameworks/espidf.py b/builder/frameworks/espidf.py index d7d43fc02..6105a4ed8 100644 --- a/builder/frameworks/espidf.py +++ b/builder/frameworks/espidf.py @@ -351,7 +351,7 @@ def _add_archive(archive_path, link_args): args = click.parser.split_arg_string(fragment) if fragment_role == "flags": link_args["LINKFLAGS"].extend(args) - elif fragment_role == "libraries": + elif fragment_role in ("libraries", "libraryPath"): if fragment.startswith("-l"): link_args["LIBS"].extend(args) elif fragment.startswith("-L"): @@ -1104,6 +1104,7 @@ def _get_installed_pip_packages(python_exe_path): "pyparsing": "~=3.0.9" if IDF5 else ">=2.0.3,<2.4.0", "kconfiglib": "~=14.1.0" if IDF5 else "~=13.7.1", "idf-component-manager": "~=1.2.3" if IDF5 else "~=1.0", + "esp-idf-kconfig": "~=1.2.0" } python_exe_path = get_python_exe() @@ -1543,7 +1544,7 @@ def _skip_prj_source_files(node): # Add include dirs from PlatformIO build system to project CPPPATH so # they're visible to PIOBUILDFILES project_env.AppendUnique( - CPPPATH=["$PROJECT_INCLUDE_DIR", "$PROJECT_SRC_DIR"] + CPPPATH=["$PROJECT_INCLUDE_DIR", "$PROJECT_SRC_DIR", "$PROJECT_DIR"] + get_project_lib_includes(env) ) diff --git a/examples/espidf-ulp-adc/main/ulp_adc_example_main.c b/examples/espidf-ulp-adc/main/ulp_adc_example_main.c index 6b3ff5648..882128329 100644 --- a/examples/espidf-ulp-adc/main/ulp_adc_example_main.c +++ b/examples/espidf-ulp-adc/main/ulp_adc_example_main.c @@ -9,17 +9,20 @@ #include #include +#include #include "esp_sleep.h" -#include "nvs.h" -#include "nvs_flash.h" #include "soc/rtc_cntl_reg.h" #include "soc/sens_reg.h" #include "driver/gpio.h" #include "driver/rtc_io.h" -#include "driver/dac.h" -#include "esp32/ulp.h" +#include "ulp.h" #include "ulp_main.h" #include "esp_adc/adc_oneshot.h" +#include "ulp/example_config.h" +#include "ulp_adc.h" + +#include "freertos/FreeRTOS.h" +#include "freertos/task.h" extern const uint8_t ulp_main_bin_start[] asm("_binary_ulp_main_bin_start"); extern const uint8_t ulp_main_bin_end[] asm("_binary_ulp_main_bin_end"); @@ -42,15 +45,21 @@ void app_main(void) init_ulp_program(); } else { printf("Deep sleep wakeup\n"); - printf("ULP did %d measurements since last reset\n", ulp_sample_counter & UINT16_MAX); - printf("Thresholds: low=%d high=%d\n", ulp_low_thr, ulp_high_thr); + printf("ULP did %"PRIu32" measurements since last reset\n", ulp_sample_counter & UINT16_MAX); + printf("Thresholds: low=%"PRIu32" high=%"PRIu32"\n", ulp_low_thr, ulp_high_thr); ulp_last_result &= UINT16_MAX; - printf("Value=%d was %s threshold\n", ulp_last_result, + printf("Value=%"PRIu32" was %s threshold\n", ulp_last_result, ulp_last_result < ulp_low_thr ? "below" : "above"); } printf("Entering deep sleep\n\n"); start_ulp_program(); ESP_ERROR_CHECK( esp_sleep_enable_ulp_wakeup() ); + +#if !CONFIG_IDF_TARGET_ESP32 + /* RTC peripheral power domain needs to be kept on to keep SAR ADC related configs during sleep */ + esp_sleep_pd_config(ESP_PD_DOMAIN_RTC_PERIPH, ESP_PD_OPTION_ON); +#endif + esp_deep_sleep_start(); } @@ -60,35 +69,31 @@ static void init_ulp_program(void) (ulp_main_bin_end - ulp_main_bin_start) / sizeof(uint32_t)); ESP_ERROR_CHECK(err); - //-------------ADC1 Init---------------// - adc_oneshot_unit_handle_t adc1_handle; - adc_oneshot_unit_init_cfg_t init_config1 = { - .unit_id = ADC_UNIT_1, + ulp_adc_cfg_t cfg = { + .adc_n = EXAMPLE_ADC_UNIT, + .channel = EXAMPLE_ADC_CHANNEL, + .width = EXAMPLE_ADC_WIDTH, + .atten = EXAMPLE_ADC_ATTEN, .ulp_mode = ADC_ULP_MODE_FSM, }; - ESP_ERROR_CHECK(adc_oneshot_new_unit(&init_config1, &adc1_handle)); - //-------------ADC1 Channel Config---------------// - // Note: when changing channel here, also change 'adc_channel' constant in adc.S - adc_oneshot_chan_cfg_t config = { - .bitwidth = ADC_BITWIDTH_DEFAULT, - .atten = ADC_ATTEN_DB_11, - }; - ESP_ERROR_CHECK(adc_oneshot_config_channel(adc1_handle, ADC_CHANNEL_6, &config)); + ESP_ERROR_CHECK(ulp_adc_init(&cfg)); - /* Set low and high thresholds, approx. 1.35V - 1.75V*/ - ulp_low_thr = 1500; - ulp_high_thr = 2000; + ulp_low_thr = EXAMPLE_ADC_LOW_TRESHOLD; + ulp_high_thr = EXAMPLE_ADC_HIGH_TRESHOLD; /* Set ULP wake up period to 20ms */ ulp_set_wakeup_period(0, 20000); +#if CONFIG_IDF_TARGET_ESP32 /* Disconnect GPIO12 and GPIO15 to remove current drain through - * pullup/pulldown resistors. + * pullup/pulldown resistors on modules which have these (e.g. ESP32-WROVER) * GPIO12 may be pulled high to select flash voltage. */ rtc_gpio_isolate(GPIO_NUM_12); rtc_gpio_isolate(GPIO_NUM_15); +#endif // CONFIG_IDF_TARGET_ESP32 + esp_deep_sleep_disable_rom_logging(); // suppress boot messages } diff --git a/examples/espidf-ulp-adc/ulp/adc.S b/examples/espidf-ulp-adc/ulp/adc.S index 1b59ccee7..b96f51c3b 100644 --- a/examples/espidf-ulp-adc/ulp/adc.S +++ b/examples/espidf-ulp-adc/ulp/adc.S @@ -1,3 +1,8 @@ +/* + * SPDX-FileCopyrightText: 2022 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Unlicense OR CC0-1.0 + */ /* ULP Example: using ADC in deep sleep This example code is in the Public Domain (or CC0 licensed, at your option.) @@ -22,9 +27,9 @@ */ #include "soc/rtc_cntl_reg.h" #include "soc/soc_ulp.h" +#include "example_config.h" - /* ADC1 channel 6, GPIO34 */ - .set adc_channel, 6 + .set adc_channel, EXAMPLE_ADC_CHANNEL /* Configure the number of ADC samples to average on each measurement. For convenience, make it a power of 2. */ diff --git a/examples/espidf-ulp-adc/ulp/example_config.h b/examples/espidf-ulp-adc/ulp/example_config.h new file mode 100644 index 000000000..baa86dd84 --- /dev/null +++ b/examples/espidf-ulp-adc/ulp/example_config.h @@ -0,0 +1,16 @@ +/* + * SPDX-FileCopyrightText: 2022 Espressif Systems (Shanghai) CO LTD + * + * SPDX-License-Identifier: Unlicense OR CC0-1.0 + */ +#pragma once + +/* Ints are used here to be able to include the file in assembly as well */ +#define EXAMPLE_ADC_CHANNEL 6 // ADC_CHANNEL_6, GPIO34 on ESP32, GPIO7 on ESP32-S3 +#define EXAMPLE_ADC_UNIT 0 // ADC_UNIT_1 +#define EXAMPLE_ADC_ATTEN 3 // ADC_ATTEN_DB_11 +#define EXAMPLE_ADC_WIDTH 0 // ADC_BITWIDTH_DEFAULT + +/* Set low and high thresholds, approx. 1.35V - 1.75V*/ +#define EXAMPLE_ADC_LOW_TRESHOLD 1500 +#define EXAMPLE_ADC_HIGH_TRESHOLD 2000 diff --git a/platform.json b/platform.json index be4cd4489..d2cc34a86 100644 --- a/platform.json +++ b/platform.json @@ -34,28 +34,28 @@ "type": "toolchain", "owner": "espressif", "version": "8.4.0+2021r2-patch5", - "optionalVersions": ["11.2.0+2022r1"] + "optionalVersions": ["12.2.0+20230208"] }, "toolchain-xtensa-esp32s2": { "type": "toolchain", "optional": true, "owner": "espressif", "version": "8.4.0+2021r2-patch5", - "optionalVersions": ["11.2.0+2022r1"] + "optionalVersions": ["12.2.0+20230208"] }, "toolchain-xtensa-esp32s3": { "type": "toolchain", "optional": true, "owner": "espressif", "version": "8.4.0+2021r2-patch5", - "optionalVersions": ["11.2.0+2022r1"] + "optionalVersions": ["12.2.0+20230208"] }, "toolchain-riscv32-esp": { "type": "toolchain", "optional": true, "owner": "espressif", "version": "8.4.0+2021r2-patch5", - "optionalVersions": ["11.2.0+2022r1"] + "optionalVersions": ["12.2.0+20230208"] }, "toolchain-esp32ulp": { "type": "toolchain", @@ -79,7 +79,7 @@ "type": "framework", "optional": true, "owner": "platformio", - "version": "~3.50002.0", + "version": "~3.50100.0", "optionalVersions": ["~3.40405.0"] }, "tool-esptoolpy": { diff --git a/platform.py b/platform.py index 0e4de8669..6e4331105 100644 --- a/platform.py +++ b/platform.py @@ -111,7 +111,7 @@ def configure_default_packages(self, variables, targets): "xtensa-esp32s3", "riscv32-esp" ): - self.packages["toolchain-%s" % target]["version"] = "11.2.0+2022r1" + self.packages["toolchain-%s" % target]["version"] = "12.2.0+20230208" for available_mcu in ("esp32", "esp32s2", "esp32s3"): if available_mcu == mcu: From bd031b8c99e4bfb3a97915613b310096843df91e Mon Sep 17 00:00:00 2001 From: valeros Date: Thu, 3 Aug 2023 13:56:50 +0300 Subject: [PATCH 14/28] IDF: Reduce time between consecutive builds by enabling implicit build cache --- builder/frameworks/espidf.py | 1 + 1 file changed, 1 insertion(+) diff --git a/builder/frameworks/espidf.py b/builder/frameworks/espidf.py index 6105a4ed8..b62770021 100644 --- a/builder/frameworks/espidf.py +++ b/builder/frameworks/espidf.py @@ -624,6 +624,7 @@ def prepare_build_envs(config, default_env, debug_allowed=True): defines = extract_defines(cg) compile_commands = cg.get("compileCommandFragments", []) build_env = default_env.Clone() + build_env.SetOption("implicit_cache", 1) for cc in compile_commands: build_flags = cc.get("fragment") if not build_flags.startswith("-D"): From 95e0a731cc4a21322610b8f3dbbf19cb9233ad35 Mon Sep 17 00:00:00 2001 From: Stijn Tintel Date: Thu, 3 Aug 2023 15:50:34 +0300 Subject: [PATCH 15/28] Initial support for ESP32-C6-DevKitC-1 (#1054) Signed-off-by: Stijn Tintel --- boards/esp32-c6-devkitc-1.json | 25 ++++++++++++++++++++++ builder/frameworks/_embed_files.py | 6 +++--- builder/frameworks/espidf.py | 10 ++++----- builder/main.py | 2 +- examples/espidf-hello-world/platformio.ini | 3 +++ platform.py | 6 +++--- 6 files changed, 40 insertions(+), 12 deletions(-) create mode 100644 boards/esp32-c6-devkitc-1.json diff --git a/boards/esp32-c6-devkitc-1.json b/boards/esp32-c6-devkitc-1.json new file mode 100644 index 000000000..6e90aee03 --- /dev/null +++ b/boards/esp32-c6-devkitc-1.json @@ -0,0 +1,25 @@ +{ + "build": { + "core": "esp32", + "f_cpu": "160000000L", + "f_flash": "80000000L", + "flash_mode": "qio", + "mcu": "esp32c6" + }, + "connectivity": [ + "wifi" + ], + "frameworks": [ + "espidf" + ], + "name": "Espressif ESP32-C6-DevKitC-1", + "upload": { + "flash_size": "8MB", + "maximum_ram_size": 524288, + "maximum_size": 8388608, + "require_upload_port": true, + "speed": 460800 + }, + "url": "https://docs.espressif.com/projects/espressif-esp-dev-kits/en/latest/esp32c6/esp32-c6-devkitc-1/index.html", + "vendor": "Espressif" +} diff --git a/builder/frameworks/_embed_files.py b/builder/frameworks/_embed_files.py index 5469e3bce..c89dc4338 100644 --- a/builder/frameworks/_embed_files.py +++ b/builder/frameworks/_embed_files.py @@ -110,14 +110,14 @@ def transform_to_asm(target, source, env): " ".join( [ "riscv32-esp-elf-objcopy" - if mcu == "esp32c3" + if mcu in ("esp32c3", "esp32c6") else "xtensa-%s-elf-objcopy" % mcu, "--input-target", "binary", "--output-target", - "elf32-littleriscv" if mcu == "esp32c3" else "elf32-xtensa-le", + "elf32-littleriscv" if mcu in ("esp32c3","esp32c6") else "elf32-xtensa-le", "--binary-architecture", - "riscv" if mcu == "esp32c3" else "xtensa", + "riscv" if mcu in ("esp32c3","esp32c6") else "xtensa", "--rename-section", ".data=.rodata.embedded", "$SOURCE", diff --git a/builder/frameworks/espidf.py b/builder/frameworks/espidf.py index b62770021..a273dcee9 100644 --- a/builder/frameworks/espidf.py +++ b/builder/frameworks/espidf.py @@ -62,7 +62,7 @@ IDF_ENV_VERSION = "1.0.0" FRAMEWORK_DIR = platform.get_package_dir("framework-espidf") TOOLCHAIN_DIR = platform.get_package_dir( - "toolchain-%s" % ("riscv32-esp" if mcu == "esp32c3" else ("xtensa-%s" % mcu)) + "toolchain-%s" % ("riscv32-esp" if mcu in ("esp32c3","esp32c6") else ("xtensa-%s" % mcu)) ) @@ -234,7 +234,7 @@ def populate_idf_env_vars(idf_env): os.path.dirname(get_python_exe()), ] - if mcu != "esp32c3": + if mcu not in ("esp32c3", "esp32c6"): additional_packages.append( os.path.join(platform.get_package_dir("toolchain-esp32ulp"), "bin"), ) @@ -489,7 +489,7 @@ def extract_linker_script_fragments(framework_components_dir, sdk_config): sys.stderr.write("Error: Failed to extract paths to linker script fragments\n") env.Exit(1) - if mcu == "esp32c3": + if mcu in ("esp32c3", "esp32c6"): result.append(os.path.join(framework_components_dir, "riscv", "linker.lf")) # Add extra linker fragments @@ -1500,7 +1500,7 @@ def _skip_prj_source_files(node): ( board.get( "upload.bootloader_offset", - "0x0" if mcu in ("esp32c3", "esp32s3") else "0x1000", + "0x0" if mcu in ("esp32c3", "esp32c6", "esp32s3") else "0x1000", ), os.path.join("$BUILD_DIR", "bootloader.bin"), ), @@ -1580,7 +1580,7 @@ def _skip_prj_source_files(node): # ulp_dir = os.path.join(PROJECT_DIR, "ulp") -if os.path.isdir(ulp_dir) and os.listdir(ulp_dir) and mcu != "esp32c3": +if os.path.isdir(ulp_dir) and os.listdir(ulp_dir) and mcu not in ("esp32c3", "esp32c6"): env.SConscript("ulp.py", exports="env sdk_config project_config idf_variant") # diff --git a/builder/main.py b/builder/main.py index c5579bf91..0c9767083 100644 --- a/builder/main.py +++ b/builder/main.py @@ -199,7 +199,7 @@ def __fetch_fs_size(target, source, env): mcu = board.get("build.mcu", "esp32") toolchain_arch = "xtensa-%s" % mcu filesystem = board.get("build.filesystem", "spiffs") -if mcu == "esp32c3": +if mcu in ("esp32c3", "esp32c6"): toolchain_arch = "riscv32-esp" if "INTEGRATION_EXTRA_DATA" not in env: diff --git a/examples/espidf-hello-world/platformio.ini b/examples/espidf-hello-world/platformio.ini index 226510eb1..8347b1654 100644 --- a/examples/espidf-hello-world/platformio.ini +++ b/examples/espidf-hello-world/platformio.ini @@ -20,3 +20,6 @@ board = esp32-s2-kaluga-1 [env:esp32-c3-devkitm-1] board = esp32-c3-devkitm-1 + +[env:esp32-c6-devkitc-1] +board = esp32-c6-devkitc-1 diff --git a/platform.py b/platform.py index 6e4331105..cc45624a2 100644 --- a/platform.py +++ b/platform.py @@ -119,8 +119,8 @@ def configure_default_packages(self, variables, targets): else: self.packages.pop("toolchain-xtensa-%s" % available_mcu, None) - if mcu in ("esp32s2", "esp32s3", "esp32c3"): - # RISC-V based toolchain for ESP32C3, ESP32S2, ESP32S3 ULP + if mcu in ("esp32s2", "esp32s3", "esp32c3", "esp32c6"): + # RISC-V based toolchain for ESP32C3, ESP32C6 ESP32S2, ESP32S3 ULP self.packages["toolchain-riscv32-esp"]["optional"] = False if build_core == "mbcwb": @@ -183,7 +183,7 @@ def _add_dynamic_options(self, board): "tumpa", ] - if board.get("build.mcu", "") in ("esp32c3", "esp32s3"): + if board.get("build.mcu", "") in ("esp32c3", "esp32c6", "esp32s3"): supported_debug_tools.append("esp-builtin") upload_protocol = board.manifest.get("upload", {}).get("protocol") From f1fdbc5838f6271379c89dd97242fb0614fdfdde Mon Sep 17 00:00:00 2001 From: valeros Date: Mon, 7 Aug 2023 14:54:11 +0300 Subject: [PATCH 16/28] Allow specifying custom application partition name // Issue #1166 This way developers can select an arbitrary partition which will be used for dynamic memory checks. --- builder/main.py | 25 ++++++++++++++++++++----- 1 file changed, 20 insertions(+), 5 deletions(-) diff --git a/builder/main.py b/builder/main.py index 0c9767083..1c8f997ba 100644 --- a/builder/main.py +++ b/builder/main.py @@ -144,12 +144,27 @@ def _update_max_upload_size(env): if p["type"] in ("0", "app") } - # One of the `factory` or `ota_0` partitions is used to determine available memory - # size. If both partitions are set, we should prefer the `factory`, but there are - # cases (e.g. Adafruit's `partitions-4MB-tinyuf2.csv`) that uses the `factory` - # partition for their UF2 bootloader. So let's use the first match + partitions = {p["name"]: p for p in _parse_partitions(env)} + + # User-specified partition name has the highest priority + custom_app_partition_name = board.get("build.app_partition_name", "") + if custom_app_partition_name: + selected_partition = partitions.get(custom_app_partition_name, {}) + if selected_partition: + board.update("upload.maximum_size", _parse_size(selected_partition["size"])) + return + else: + print( + "Warning! Selected partition `%s` is not available in the partition " \ + "table! Default partition will be used!" % custom_app_partition_name + ) + + # Otherwise, one of the `factory` or `ota_0` partitions is used to determine + # available memory size. If both partitions are set, we should prefer the `factory`, + # but there are cases (e.g. Adafruit's `partitions-4MB-tinyuf2.csv`) that uses the + # `factory` partition for their UF2 bootloader. So let's use the first match # https://docs.espressif.com/projects/esp-idf/en/latest/esp32/api-guides/partition-tables.html#subtype - for p in _parse_partitions(env): + for p in partitions.values(): if p["type"] in ("0", "app") and p["subtype"] in ("factory", "ota_0"): board.update("upload.maximum_size", _parse_size(p["size"])) break From a2f651319061e97a0acaa1aecacd08c39118fcd4 Mon Sep 17 00:00:00 2001 From: Jason2866 <24528715+Jason2866@users.noreply.github.com> Date: Wed, 23 Aug 2023 13:02:25 +0200 Subject: [PATCH 17/28] Add espressif esp32-c6-devkitm-1 board (#1173) --- boards/esp32-c6-devkitm-1.json | 29 +++++++++++++++++++++++++++++ 1 file changed, 29 insertions(+) create mode 100644 boards/esp32-c6-devkitm-1.json diff --git a/boards/esp32-c6-devkitm-1.json b/boards/esp32-c6-devkitm-1.json new file mode 100644 index 000000000..c30687fa9 --- /dev/null +++ b/boards/esp32-c6-devkitm-1.json @@ -0,0 +1,29 @@ +{ + "build": { + "core": "esp32", + "f_cpu": "160000000L", + "f_flash": "80000000L", + "flash_mode": "qio", + "mcu": "esp32c6", + "variant": "esp32c6" + }, + "connectivity": [ + "wifi" + ], + "debug": { + "openocd_target": "esp32c6.cfg" + }, + "frameworks": [ + "espidf" + ], + "name": "Espressif ESP32-C6-DevKitM-1", + "upload": { + "flash_size": "4MB", + "maximum_ram_size": 327680, + "maximum_size": 4194304, + "require_upload_port": true, + "speed": 460800 + }, + "url": "https://docs.espressif.com/projects/espressif-esp-dev-kits/en/latest/esp32c6/esp32-c6-devkitm-1/index.html", + "vendor": "Espressif" +} From 167c149b2aad83b69668569f90e3ffd14a45af0e Mon Sep 17 00:00:00 2001 From: Valerii Koval Date: Fri, 25 Aug 2023 17:01:34 +0300 Subject: [PATCH 18/28] Update IDF to v5.1.1 --- platform.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/platform.json b/platform.json index d2cc34a86..7ff99d5b2 100644 --- a/platform.json +++ b/platform.json @@ -79,7 +79,7 @@ "type": "framework", "optional": true, "owner": "platformio", - "version": "~3.50100.0", + "version": "~3.50101.0", "optionalVersions": ["~3.40405.0"] }, "tool-esptoolpy": { From 6a92e31a19c5d4ff19b61b473f9e38a6a3b706ff Mon Sep 17 00:00:00 2001 From: Jason2866 <24528715+Jason2866@users.noreply.github.com> Date: Sun, 27 Aug 2023 11:33:21 +0200 Subject: [PATCH 19/28] bee_motion_s3: use s3 linker script (#1176) --- boards/bee_motion_s3.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/boards/bee_motion_s3.json b/boards/bee_motion_s3.json index c620b80c3..c1cae0fd0 100644 --- a/boards/bee_motion_s3.json +++ b/boards/bee_motion_s3.json @@ -1,7 +1,7 @@ { "build": { "arduino": { - "ldscript": "esp32s2_out.ld" + "ldscript": "esp32s3_out.ld" }, "core": "esp32", "extra_flags": [ From a737d97feb3858ac7d6d87e541e063da76fada79 Mon Sep 17 00:00:00 2001 From: Jason2866 <24528715+Jason2866@users.noreply.github.com> Date: Sun, 27 Aug 2023 11:34:01 +0200 Subject: [PATCH 20/28] esp32s3camlcd: use correct s3 linker script (#1175) --- boards/esp32s3camlcd.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/boards/esp32s3camlcd.json b/boards/esp32s3camlcd.json index 5a807a858..1d7e0c497 100644 --- a/boards/esp32s3camlcd.json +++ b/boards/esp32s3camlcd.json @@ -1,7 +1,7 @@ { "build": { "arduino":{ - "ldscript": "esp32_out.ld", + "ldscript": "esp32s3_out.ld", "memory_type": "opi_opi" }, "boot": "opi", From 682da88fe2cebd4dbca96628ea135a6d31b3d9c3 Mon Sep 17 00:00:00 2001 From: valeros Date: Mon, 14 Aug 2023 13:15:07 +0300 Subject: [PATCH 21/28] Delete obsolete comment --- builder/main.py | 1 - 1 file changed, 1 deletion(-) diff --git a/builder/main.py b/builder/main.py index 1c8f997ba..bc0e4fe5d 100644 --- a/builder/main.py +++ b/builder/main.py @@ -479,7 +479,6 @@ def __fetch_fs_size(target, source, env): ] elif upload_protocol == "dfu": - # C:\Users\ROOT\AppData\Local\Arduino15\packages\arduino\tools\dfu-util\0.11.0-arduino5/dfu-util --device 0x2341:0x0070 -D C:\Users\ROOT\AppData\Local\Temp\arduino_build_789426/sketch_jul31a.ino.bin -Q hwids = board.get("build.hwids", [["0x2341", "0x0070"]]) vid = hwids[0][0] From bf5a65ba6b9b3c8471fc57e8b0d200a04135b2cb Mon Sep 17 00:00:00 2001 From: valeros Date: Mon, 14 Aug 2023 14:54:50 +0300 Subject: [PATCH 22/28] Install chardet as fallback package for charset_normalizer on Darwin ARM64 --- builder/frameworks/espidf.py | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/builder/frameworks/espidf.py b/builder/frameworks/espidf.py index a273dcee9..9881c1fcc 100644 --- a/builder/frameworks/espidf.py +++ b/builder/frameworks/espidf.py @@ -27,6 +27,7 @@ import shutil import os import pkg_resources +import platform as sys_platform import click import semantic_version @@ -1108,6 +1109,9 @@ def _get_installed_pip_packages(python_exe_path): "esp-idf-kconfig": "~=1.2.0" } + if sys_platform.system() == "Darwin" and "arm" in sys_platform.machine().lower(): + deps["chardet"] = ">=3.0.2,<4" + python_exe_path = get_python_exe() installed_packages = _get_installed_pip_packages(python_exe_path) packages_to_install = [] From f8518b861bd9d7d07821f663ed67ccf6c92113a2 Mon Sep 17 00:00:00 2001 From: valeros Date: Mon, 28 Aug 2023 16:10:48 +0300 Subject: [PATCH 23/28] Switch IDF projects to a standalone GDB packages Note: This change requires PlatformIO Core >=6.1.11a2 --- builder/main.py | 13 +++++++++++-- platform.json | 14 +++++++++++++- platform.py | 18 +++++++++++++++++- 3 files changed, 41 insertions(+), 4 deletions(-) diff --git a/builder/main.py b/builder/main.py index bc0e4fe5d..d6706ae28 100644 --- a/builder/main.py +++ b/builder/main.py @@ -230,7 +230,16 @@ def __fetch_fs_size(target, source, env): AS="%s-elf-as" % toolchain_arch, CC="%s-elf-gcc" % toolchain_arch, CXX="%s-elf-g++" % toolchain_arch, - GDB="%s-elf-gdb" % toolchain_arch, + GDB=join( + platform.get_package_dir( + "tool-riscv32-esp-elf-gdb" + if mcu in ("esp32c3", "esp32c6") + else "tool-xtensa-esp-elf-gdb" + ) + or "", + "bin", + "%s-elf-gdb" % toolchain_arch, + ) if env.get("PIOFRAMEWORK") == ["espidf"] else "%s-elf-gdb" % toolchain_arch, OBJCOPY=join( platform.get_package_dir("tool-esptoolpy") or "", "esptool.py"), RANLIB="%s-elf-ranlib" % toolchain_arch, @@ -282,7 +291,7 @@ def __fetch_fs_size(target, source, env): BUILDERS=dict( ElfToBin=Builder( action=env.VerboseAction(" ".join([ - '"$PYTHONEXE" "$OBJCOPY"', + '"$PYTHONEXE" "$OBJCOPY"', "--chip", mcu, "elf2image", "--flash_mode", "${__get_board_flash_mode(__env__)}", "--flash_freq", "${__get_board_f_flash(__env__)}", diff --git a/platform.json b/platform.json index 7ff99d5b2..cf1f58e38 100644 --- a/platform.json +++ b/platform.json @@ -63,6 +63,18 @@ "owner": "platformio", "version": "~1.23500.0" }, + "tool-xtensa-esp-elf-gdb": { + "type": "debugger", + "optional": true, + "owner": "espressif", + "version": "~12.1.0+20221002" + }, + "tool-riscv32-esp-elf-gdb": { + "type": "debugger", + "optional": true, + "owner": "espressif", + "version": "~12.1.0+20221002" + }, "framework-arduinoespressif32": { "type": "framework", "optional": true, @@ -79,7 +91,7 @@ "type": "framework", "optional": true, "owner": "platformio", - "version": "~3.50101.0", + "version": "~3.50100.0", "optionalVersions": ["~3.40405.0"] }, "tool-esptoolpy": { diff --git a/platform.py b/platform.py index cc45624a2..dfdb7c785 100644 --- a/platform.py +++ b/platform.py @@ -56,7 +56,7 @@ def configure_default_packages(self, variables, targets): "board_build.core", board_config.get("build.core", "arduino") ).lower() - if len(frameworks) == 1 and "arduino" in frameworks and build_core == "esp32": + if frameworks == ["arduino"] and build_core == "esp32": # In case the upstream Arduino framework is specified in the configuration # file then we need to dynamically extract toolchain versions from the # Arduino index file. This feature can be disabled via a special option: @@ -93,6 +93,17 @@ def configure_default_packages(self, variables, targets): sys.exit(1) if "espidf" in frameworks: + if frameworks == ["espidf"]: + # Starting from v12, Espressif's toolchains are shipped without + # bundled GDB. Instead, it's distributed as separate packages for Xtensa + # and RISC-V targets. Currently only IDF depends on the latest toolchain + for gdb_package in ("tool-xtensa-esp-elf-gdb", "tool-riscv32-esp-elf-gdb"): + self.packages[gdb_package]["optional"] = False + if IS_WINDOWS: + # Note: On Windows GDB v12 is not able to + # launch a GDB server in pipe mode while v11 works fine + self.packages[gdb_package]["version"] = "~11.2.0" + # Common packages for IDF and mixed Arduino+IDF projects for p in self.packages: if p in ("tool-cmake", "tool-ninja", "toolchain-esp32ulp"): @@ -113,6 +124,11 @@ def configure_default_packages(self, variables, targets): ): self.packages["toolchain-%s" % target]["version"] = "12.2.0+20230208" + if "arduino" in frameworks: + # Disable standalone GDB packages for Arduino and Arduino/IDF projects + for gdb_package in ("tool-xtensa-esp-elf-gdb", "tool-riscv32-esp-elf-gdb"): + self.packages.pop(gdb_package, None) + for available_mcu in ("esp32", "esp32s2", "esp32s3"): if available_mcu == mcu: self.packages["toolchain-xtensa-%s" % mcu]["optional"] = False From 3ac254be8443658e350897fc6bc308b080fc5917 Mon Sep 17 00:00:00 2001 From: valeros Date: Mon, 28 Aug 2023 16:27:07 +0300 Subject: [PATCH 24/28] Typo fix --- platform.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/platform.json b/platform.json index cf1f58e38..4f3797abf 100644 --- a/platform.json +++ b/platform.json @@ -91,7 +91,7 @@ "type": "framework", "optional": true, "owner": "platformio", - "version": "~3.50100.0", + "version": "~3.50101.0", "optionalVersions": ["~3.40405.0"] }, "tool-esptoolpy": { From a846cb0022b904bdea816915764dee9ee1ad69cd Mon Sep 17 00:00:00 2001 From: valeros Date: Mon, 28 Aug 2023 22:59:30 +0300 Subject: [PATCH 25/28] Fix GDB package version --- platform.json | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/platform.json b/platform.json index 4f3797abf..49413a0c7 100644 --- a/platform.json +++ b/platform.json @@ -67,13 +67,13 @@ "type": "debugger", "optional": true, "owner": "espressif", - "version": "~12.1.0+20221002" + "version": "~12.1.0" }, "tool-riscv32-esp-elf-gdb": { "type": "debugger", "optional": true, "owner": "espressif", - "version": "~12.1.0+20221002" + "version": "~12.1.0" }, "framework-arduinoespressif32": { "type": "framework", From ceafaa7c176c18875538886b35e7291b2635f64a Mon Sep 17 00:00:00 2001 From: valeros Date: Wed, 30 Aug 2023 17:32:34 +0300 Subject: [PATCH 26/28] Update dynamic partition offset calculation process Resolves #1178 --- builder/main.py | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) diff --git a/builder/main.py b/builder/main.py index d6706ae28..1f493503a 100644 --- a/builder/main.py +++ b/builder/main.py @@ -108,7 +108,9 @@ def _parse_partitions(env): return result = [] - next_offset = 0 + # The first offset is 0x9000 because partition table is flashed to 0x8000 and + # occupies an entire flash sector, which size is 0x1000 + next_offset = 0x9000 with open(partitions_csv) as fp: for line in fp.readlines(): line = line.strip() @@ -117,11 +119,14 @@ def _parse_partitions(env): tokens = [t.strip() for t in line.split(",")] if len(tokens) < 5: continue + + bound = 0x10000 if tokens[1] in ("0", "app") else 4 + calculated_offset = (next_offset + bound - 1) & ~(bound - 1) partition = { "name": tokens[0], "type": tokens[1], "subtype": tokens[2], - "offset": tokens[3] or next_offset, + "offset": tokens[3] or calculated_offset, "size": tokens[4], "flags": tokens[5] if len(tokens) > 5 else None } @@ -130,9 +135,6 @@ def _parse_partitions(env): partition["size"] ) - bound = 0x10000 if partition["type"] in ("0", "app") else 4 - next_offset = (next_offset + bound - 1) & ~(bound - 1) - return result From 36b7a184053a4d5c1b1005dba4f6cd7e3fbdc615 Mon Sep 17 00:00:00 2001 From: valeros Date: Thu, 31 Aug 2023 16:36:07 +0300 Subject: [PATCH 27/28] Add a warning about the latest GDB package integration --- builder/frameworks/espidf.py | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/builder/frameworks/espidf.py b/builder/frameworks/espidf.py index 9881c1fcc..41739557b 100644 --- a/builder/frameworks/espidf.py +++ b/builder/frameworks/espidf.py @@ -38,7 +38,7 @@ DefaultEnvironment, ) -from platformio import fs +from platformio import fs, __version__ from platformio.compat import IS_WINDOWS from platformio.proc import exec_command from platformio.builder.tools.piolib import ProjectAsLibBuilder @@ -70,6 +70,15 @@ assert os.path.isdir(FRAMEWORK_DIR) assert os.path.isdir(TOOLCHAIN_DIR) +# The latest IDF uses a standalone GDB package which requires at least PlatformIO 6.1.11 +if ( + ["espidf"] == env.get("PIOFRAMEWORK") + and semantic_version.Version.coerce(__version__) + <= semantic_version.Version("6.1.10") + and "__debug" in COMMAND_LINE_TARGETS +): + print("Warning! Debugging an IDF project requires PlatformIO Core >= 6.1.11!") + # Arduino framework as a component is not compatible with ESP-IDF >=4.1 if "arduino" in env.subst("$PIOFRAMEWORK"): ARDUINO_FRAMEWORK_DIR = platform.get_package_dir("framework-arduinoespressif32") From d2b14ad4d837dca252f1b3e2edb6acc4ec3f35cd Mon Sep 17 00:00:00 2001 From: valeros Date: Thu, 31 Aug 2023 16:38:09 +0300 Subject: [PATCH 28/28] Bump version to 6.4.0 --- platform.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/platform.json b/platform.json index 49413a0c7..5bf959b7b 100644 --- a/platform.json +++ b/platform.json @@ -18,7 +18,7 @@ "type": "git", "url": "https://github.com/platformio/platform-espressif32.git" }, - "version": "6.3.2", + "version": "6.4.0", "frameworks": { "arduino": { "package": "framework-arduinoespressif32",