From de42ccc1d0e10aa7b6450d7759b990f6eefeae56 Mon Sep 17 00:00:00 2001 From: Piotr Gaczkowski Date: Wed, 27 Mar 2024 13:44:56 +0100 Subject: [PATCH] Enable Async on RP2040 --- .github/workflows/ci.yml | 12 +++++++----- examples/AsyncDemo/.picow_rp2040.test.skip | 0 library.json | 14 ++++++++++++++ src/ElegantOTA.h | 18 ++++++++++-------- 4 files changed, 31 insertions(+), 13 deletions(-) delete mode 100644 examples/AsyncDemo/.picow_rp2040.test.skip diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 85d6685..69b147b 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -1,6 +1,6 @@ name: Arduino Library CI -on: +on: push: paths-ignore: - '**/**.md' @@ -25,7 +25,7 @@ jobs: - uses: actions/setup-python@v1 with: python-version: '3.x' - + - uses: actions/checkout@v2 - uses: actions/checkout@v2 @@ -41,19 +41,20 @@ jobs: - name: Install test dependencies run: arduino-cli lib install --git-url https://github.com/me-no-dev/ESPAsyncWebServer --git-url https://github.com/me-no-dev/ESPAsyncTCP --git-url https://github.com/me-no-dev/AsyncTCP - + - name: Skip SyncDemo Example run: | cd examples cd Demo touch .esp32.test.skip touch .esp8266.test.skip + touch .picow_rp2040.test.skip - name: Configure ElegantOTA to Async Mode run: | cd src sed -i 's/ELEGANTOTA_USE_ASYNC_WEBSERVER 0/ELEGANTOTA_USE_ASYNC_WEBSERVER 1/' ElegantOTA.h - + - name: Test Async Demo run: python3 ci/build_platform.py esp8266 esp32 @@ -63,7 +64,7 @@ jobs: - uses: actions/setup-python@v1 with: python-version: '3.x' - + - uses: actions/checkout@v2 - uses: actions/checkout@v2 @@ -80,6 +81,7 @@ jobs: cd AsyncDemo touch .esp32.test.skip touch .esp8266.test.skip + touch .picow_rp2040.test.skip - name: Test Sync Demo run: python3 ci/build_platform.py esp8266 esp32 picow_rp2040 diff --git a/examples/AsyncDemo/.picow_rp2040.test.skip b/examples/AsyncDemo/.picow_rp2040.test.skip deleted file mode 100644 index e69de29..0000000 diff --git a/library.json b/library.json index b685a6d..01d5cd4 100644 --- a/library.json +++ b/library.json @@ -15,6 +15,20 @@ "maintainer": true } ], + "dependencies": + [ + { + "owner": "esphome", + "name": "ESPAsyncWebServer-esphome", + "version": "^3.0.0", + "platforms": ["espressif8266", "espressif32"] + }, + { + "name": "ESPAsyncWebServer", + "version": "https://github.com/doomhammer/ESPAsyncWebServer#more-rp2040-fixes", + "platforms": ["raspberrypi"] + } + ], "version": "3.1.1", "frameworks": "arduino", "platforms": ["espressif8266", "espressif32", "raspberrypi"] diff --git a/src/ElegantOTA.h b/src/ElegantOTA.h index eb961cb..ac33e79 100644 --- a/src/ElegantOTA.h +++ b/src/ElegantOTA.h @@ -79,18 +79,20 @@ _____ _ _ ___ _____ _ #include "Arduino.h" #include "FS.h" #include "LittleFS.h" - #include "WiFiClient.h" - #include "WiFiServer.h" - #include "WebServer.h" - #include "WiFiUdp.h" #include "StreamString.h" #include "Updater.h" - #define HARDWARE "RP2040" - #define ELEGANTOTA_WEBSERVER WebServer - // Throw an error if async mode is enabled #if ELEGANTOTA_USE_ASYNC_WEBSERVER == 1 - #error "Async mode is not supported on RP2040. Please set ELEGANTOTA_USE_ASYNC_WEBSERVER to 0." + #include "AsyncTCP_RP2040W.h" + #include "ESPAsyncWebServer.h" + #define ELEGANTOTA_WEBSERVER AsyncWebServer + #else + #include "WiFiClient.h" + #include "WiFiServer.h" + #include "WebServer.h" + #include "WiFiUdp.h" + #define ELEGANTOTA_WEBSERVER WebServer #endif + #define HARDWARE "RP2040" extern uint8_t _FS_start; extern uint8_t _FS_end; #endif