Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

ESP8266 (d1 mini clone) crashes using artnet.forwardArtDmxDataToFastLED #99

Closed
Themicles opened this issue May 9, 2024 · 6 comments
Closed

Comments

@Themicles
Copy link

Crash occurs right after the following serial message:
WARN: ArtNet packet size is less than requested LED numbers to forward
requested: 19362 received : 512

That number after requested: doesn't change no matter how many LEDs I set in NUM_LEDS

I cannot make the loop version from the receive_fastled example work either, but there's no crash.

However I am able to use the receive example with the serial readout of the DMX values and that works fine.

@hideakitai
Copy link
Owner

Could you give me a minimal code to reproduce your problem in my environment?

@Themicles
Copy link
Author

Themicles commented May 9, 2024

The following code is just a cut down version of the example receive_fastled and results in the same crash after this message:
WARN: ArtNet packet size is less than requested LED numbers to forward
requested: 32286 received : 512

Note the requested number is this time different than my previous attempts.

#include <FastLED.h>  // include FastLED *before* Artnet

// Please include ArtnetWiFi.h to use Artnet on the platform
// which can use both WiFi and Ethernet
#include <ArtnetWiFi.h>
// this is also valid for other platforms which can use only WiFi
// #include <Artnet.h>

// WiFi stuff
const char* ssid = "your-ssid";
const char* pwd = "your-password";

ArtnetWiFiReceiver artnet;
uint8_t universe = 1;  // 0 - 15

// FastLED
#define NUM_LEDS 2
CRGB leds[NUM_LEDS];
const uint8_t PIN_LED_DATA = 12;

void setup() {
    Serial.begin(115200);
    delay(2000);

    FastLED.addLeds<NEOPIXEL, PIN_LED_DATA>(leds, NUM_LEDS);

    // WiFi stuff
    WiFi.begin(ssid, pwd);
    while (WiFi.status() != WL_CONNECTED) {
        Serial.print(".");
        delay(500);
    }
    Serial.print("WiFi connected, IP = ");
    Serial.println(WiFi.localIP());

    artnet.begin();

    // if Artnet packet comes to this universe, forward them to fastled directly
    artnet.forwardArtDmxDataToFastLED(universe, leds, NUM_LEDS);
}

void loop() {
    artnet.parse();  // check if artnet packet has come and execute callback
    FastLED.show();
}

@Themicles
Copy link
Author

Themicles commented May 9, 2024

Taking a stab at debugging this myself, I've narrowed it down to var "num" from
void forwardArtDmxDataToFastLED
does not survive past
this->subscribeArtDmxUniverse(universe, [&](const uint8_t* data, const uint16_t size, const ArtDmxMetadata &metadata, const RemoteInfo &remote) {
I came to this by doing a Serial.print of num at various points in the code in Receiver.h until it stopped report "2"

Despite more than a decade of debugging code, I still consider myself a hobbyist and don't really understand why that would be the case.

@hideakitai
Copy link
Owner

Thanks, #100 will fix it

@hideakitai
Copy link
Owner

@Themicles v0.4.5 released. Please try it

@Themicles
Copy link
Author

Sorry about the delayed response, I was on site working on some prep for a show next weekend.

I have updated the library and recompiled, then uploaded the sketch to the ESP8266. Had to switch computers because the upload kept getting garbled, but after doing so, it is working as expected. Thanks!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants