Merge fixes & updates
- Segment::setName() - S2 limits - bus debug macros - remove cctBlending from strip
This commit is contained in:
		| @@ -114,8 +114,9 @@ bool deserializeConfig(JsonObject doc, bool fromFS) { | ||||
|   CJSON(strip.correctWB, hw_led["cct"]); | ||||
|   CJSON(strip.cctFromRgb, hw_led[F("cr")]); | ||||
|   CJSON(cctICused, hw_led[F("ic")]); | ||||
|   CJSON(strip.cctBlending, hw_led[F("cb")]); | ||||
|   Bus::setCCTBlend(strip.cctBlending); | ||||
|   int cctBlending = 0; | ||||
|   CJSON(cctBlending, hw_led[F("cb")]); | ||||
|   Bus::setCCTBlend(cctBlending); | ||||
|   strip.setTargetFps(hw_led["fps"]); //NOP if 0, default 42 FPS | ||||
|   CJSON(useGlobalLedBuffer, hw_led[F("ld")]); | ||||
|  | ||||
| @@ -162,34 +163,6 @@ bool deserializeConfig(JsonObject doc, bool fromFS) { | ||||
|     DEBUG_PRINTF_P(PSTR("Heap before buses: %d\n"), ESP.getFreeHeap()); | ||||
|     int s = 0;  // bus iterator | ||||
|     if (fromFS) BusManager::removeAll(); // can't safely manipulate busses directly in network callback | ||||
|     unsigned mem = 0; | ||||
|  | ||||
|     // determine if it is sensible to use parallel I2S outputs on ESP32 (i.e. more than 5 outputs = 1 I2S + 4 RMT) | ||||
|     bool useParallel = false; | ||||
|     #if defined(ARDUINO_ARCH_ESP32) && !defined(ARDUINO_ARCH_ESP32S2) && !defined(ARDUINO_ARCH_ESP32S3) && !defined(ARDUINO_ARCH_ESP32C3) | ||||
|     unsigned digitalCount = 0; | ||||
|     unsigned maxLedsOnBus = 0; | ||||
|     unsigned maxChannels = 0; | ||||
|     for (JsonObject elm : ins) { | ||||
|       unsigned type = elm["type"] | TYPE_WS2812_RGB; | ||||
|       unsigned len = elm["len"] | DEFAULT_LED_COUNT; | ||||
|       if (!Bus::isDigital(type)) continue; | ||||
|       if (!Bus::is2Pin(type)) { | ||||
|         digitalCount++; | ||||
|         unsigned channels = Bus::getNumberOfChannels(type); | ||||
|         if (len > maxLedsOnBus)     maxLedsOnBus = len; | ||||
|         if (channels > maxChannels) maxChannels  = channels; | ||||
|       } | ||||
|     } | ||||
|     DEBUG_PRINTF_P(PSTR("Maximum LEDs on a bus: %u\nDigital buses: %u\n"), maxLedsOnBus, digitalCount); | ||||
|     // we may remove 300 LEDs per bus limit when NeoPixelBus is updated beyond 2.9.0 | ||||
|     if (maxLedsOnBus <= 300 && digitalCount > 5) { | ||||
|       DEBUG_PRINTLN(F("Switching to parallel I2S.")); | ||||
|       useParallel = true; | ||||
|       BusManager::useParallelOutput(); | ||||
|       mem = BusManager::memUsage(maxChannels, maxLedsOnBus, 8); // use alternate memory calculation | ||||
|     } | ||||
|     #endif | ||||
|  | ||||
|     for (JsonObject elm : ins) { | ||||
|       if (s >= WLED_MAX_BUSSES+WLED_MIN_VIRTUAL_BUSSES) break; | ||||
| @@ -816,7 +789,7 @@ void serializeConfig() { | ||||
|   hw_led["cct"] = strip.correctWB; | ||||
|   hw_led[F("cr")] = strip.cctFromRgb; | ||||
|   hw_led[F("ic")] = cctICused; | ||||
|   hw_led[F("cb")] = strip.cctBlending; | ||||
|   hw_led[F("cb")] = Bus::getCCTBlend(); | ||||
|   hw_led["fps"] = strip.getTargetFps(); | ||||
|   hw_led[F("rgbwm")] = Bus::getGlobalAWMode(); // global auto white mode override | ||||
|   hw_led[F("ld")] = useGlobalLedBuffer; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Blaž Kristan
					Blaž Kristan