Feature implementation
- #2236 - #1984 Better PSRAM handling platformio.ini update On/Off bus handling
This commit is contained in:
		| @@ -188,12 +188,11 @@ void WLED::loop() | ||||
|     DEBUG_PRINT(F("Runtime: "));       DEBUG_PRINTLN(millis()); | ||||
|     DEBUG_PRINT(F("Unix time: "));     toki.printTime(toki.getTime()); | ||||
|     DEBUG_PRINT(F("Free heap: "));     DEBUG_PRINTLN(ESP.getFreeHeap()); | ||||
|     #if defined(ARDUINO_ARCH_ESP32) && defined(WLED_USE_PSRAM) | ||||
|     #if defined(ARDUINO_ARCH_ESP32) && defined(BOARD_HAS_PSRAM) | ||||
|     if (psramFound()) { | ||||
|       DEBUG_PRINT(F("Total PSRAM: "));    DEBUG_PRINT(ESP.getPsramSize()/1024); DEBUG_PRINTLN("kB"); | ||||
|       DEBUG_PRINT(F("Free PSRAM: "));     DEBUG_PRINT(ESP.getFreePsram()/1024); DEBUG_PRINTLN("kB"); | ||||
|     } else | ||||
|       DEBUG_PRINTLN(F("No PSRAM")); | ||||
|     } | ||||
|     #endif | ||||
|     DEBUG_PRINT(F("Wifi state: "));      DEBUG_PRINTLN(WiFi.status()); | ||||
|  | ||||
| @@ -321,25 +320,33 @@ void WLED::setup() | ||||
| #endif | ||||
|   DEBUG_PRINT(F("heap ")); DEBUG_PRINTLN(ESP.getFreeHeap()); | ||||
|  | ||||
|   #if defined(ARDUINO_ARCH_ESP32) && defined(WLED_USE_PSRAM) | ||||
| #if defined(ARDUINO_ARCH_ESP32) && defined(BOARD_HAS_PSRAM) | ||||
|   #if defined(CONFIG_IDF_TARGET_ESP32S3) | ||||
|   // S3: reserve GPIO 33-37 for "octal" PSRAM | ||||
|   managed_pin_type pins[] = { {33, true}, {34, true}, {35, true}, {36, true}, {37, true} }; | ||||
|   pinManager.allocateMultiplePins(pins, sizeof(pins)/sizeof(managed_pin_type), PinOwner::SPI_RAM); | ||||
|   #elif defined(CONFIG_IDF_TARGET_ESP32S2) | ||||
|   // S2: reserve GPIO 26-32 for PSRAM | ||||
|   managed_pin_type pins[] = { {26, true}, {27, true}, {28, true}, {29, true}, {30, true}, {31, true}, {32, true} }; | ||||
|   pinManager.allocateMultiplePins(pins, sizeof(pins)/sizeof(managed_pin_type), PinOwner::SPI_RAM); | ||||
|   #elif defined(CONFIG_IDF_TARGET_ESP32C3) | ||||
|   // C3: reserve GPIO 12-17 for PSRAM | ||||
|   managed_pin_type pins[] = { {12, true}, {13, true}, {14, true}, {15, true}, {16, true}, {17, true} }; | ||||
|   pinManager.allocateMultiplePins(pins, sizeof(pins)/sizeof(managed_pin_type), PinOwner::SPI_RAM); | ||||
|   #else | ||||
|   // GPIO16/GPIO17 reserved for SPI RAM | ||||
|   managed_pin_type pins[] = { {16, true}, {17, true} }; | ||||
|   pinManager.allocateMultiplePins(pins, sizeof(pins)/sizeof(managed_pin_type), PinOwner::SPI_RAM); | ||||
|   #endif | ||||
|   #if defined(WLED_USE_PSRAM) | ||||
|   if (psramFound()) { | ||||
| #if !defined(CONFIG_IDF_TARGET_ESP32C3) && !defined(CONFIG_IDF_TARGET_ESP32S2) && !defined(CONFIG_IDF_TARGET_ESP32S3) | ||||
|     // GPIO16/GPIO17 reserved for SPI RAM | ||||
|     managed_pin_type pins[2] = { {16, true}, {17, true} }; | ||||
|     pinManager.allocateMultiplePins(pins, 2, PinOwner::SPI_RAM); | ||||
| #elif defined(CONFIG_IDF_TARGET_ESP32S3) | ||||
|     // S3: add GPIO 33-37 for "octal" PSRAM | ||||
|     managed_pin_type pins[5] = { {33, true}, {34, true}, {35, true}, {36, true}, {37, true} }; | ||||
|     pinManager.allocateMultiplePins(pins, 5, PinOwner::SPI_RAM); | ||||
|     DEBUG_PRINT(F("Total PSRAM: ")); DEBUG_PRINT(ESP.getPsramSize()/1024); DEBUG_PRINTLN("kB"); | ||||
|     DEBUG_PRINT(F("Free PSRAM : ")); DEBUG_PRINT(ESP.getFreePsram()/1024); DEBUG_PRINTLN("kB"); | ||||
|   } | ||||
|   #else | ||||
|     DEBUG_PRINTLN(F("PSRAM not used.")); | ||||
|   #endif | ||||
| #endif | ||||
|       DEBUG_PRINT(F("Total PSRAM: "));    DEBUG_PRINT(ESP.getPsramSize()/1024); DEBUG_PRINTLN("kB"); | ||||
|       DEBUG_PRINT(F("Free PSRAM : "));    DEBUG_PRINT(ESP.getFreePsram()/1024); DEBUG_PRINTLN("kB"); | ||||
|     } else | ||||
|       DEBUG_PRINTLN(F("No PSRAM found.")); | ||||
|   #endif | ||||
|   #if defined(ARDUINO_ARCH_ESP32) && defined(BOARD_HAS_PSRAM) && !defined(WLED_USE_PSRAM) | ||||
|       DEBUG_PRINTLN(F("PSRAM not used.")); | ||||
|   #endif | ||||
|  | ||||
|   //DEBUG_PRINT(F("LEDs inited. heap usage ~")); | ||||
|   //DEBUG_PRINTLN(heapPreAlloc - ESP.getFreeHeap()); | ||||
| @@ -429,8 +436,6 @@ void WLED::setup() | ||||
|   if (Serial.available() > 0 && Serial.peek() == 'I') handleImprovPacket(); | ||||
| #endif | ||||
|  | ||||
|   strip.service(); // why? | ||||
|  | ||||
| #ifndef WLED_DISABLE_OTA | ||||
|   if (aOtaEnabled) { | ||||
|     ArduinoOTA.onStart([]() { | ||||
| @@ -481,6 +486,8 @@ void WLED::beginStrip() | ||||
|     else if (bri == 0) bri = 128; | ||||
|   } else { | ||||
|     briLast = briS; bri = 0; | ||||
|     strip.fill(BLACK); | ||||
|     strip.show(); | ||||
|   } | ||||
|   if (bootPreset > 0) { | ||||
|     applyPreset(bootPreset, CALL_MODE_INIT); | ||||
| @@ -591,7 +598,7 @@ bool WLED::initEthernet() | ||||
|     return false; | ||||
|   } | ||||
|  | ||||
|    /* | ||||
|   /* | ||||
|   For LAN8720 the most correct way is to perform clean reset each time before init | ||||
|   applying LOW to power or nRST pin for at least 100 us (please refer to datasheet, page 59) | ||||
|   ESP_IDF > V4 implements it (150 us, lan87xx_reset_hw(esp_eth_phy_t *phy) function in  | ||||
| @@ -718,8 +725,6 @@ void WLED::initInterfaces() | ||||
|     ArduinoOTA.begin(); | ||||
| #endif | ||||
|  | ||||
|   strip.service(); | ||||
|  | ||||
|   // Set up mDNS responder: | ||||
|   if (strlen(cmDNS) > 0) { | ||||
|     // "end" must be called before "begin" is called a 2nd time | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Blaz Kristan
					Blaz Kristan