-
Notifications
You must be signed in to change notification settings - Fork 101
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
Build errors on RaspberryPi4 #104
Comments
Try my fork, I used to have similar issues. https://github.com/lubomirmolin/rpi-ws281x-nodejs |
thank you for your reply! |
Are you trying to install it on Windows machine? I know I had some issues with the platform |
no no - it's clear that this couldn't work on a Windows machine ... |
hi, I note this discussion on at least the first error (not warning). Thanks Simon |
any update for this issue and how to get this module working? |
https://github.com/TheMightyPilot , I resorted to going back to node version 10.21.0 . There are a few libraries including this one that are failing beyond V10. |
oh and also (and prob more significantly) went for this , "rpi-ws281x", library instead of this one. |
Thanks for your reply @SimonGAndrews I've used NVM to switch to use node 10.21.0 and npm installed the rpi-ws281x package, however it seems running the test I get the same type of error as I did with this ws281x-native:
|
to be honest MightyPilot , I got lost with this type of error and went in circles with node versions and reinstalls of node and the the packages I am using. The table https://nodejs.org/en/download/releases/ is a usefull reference to check node version against compatible NODE_MODULE_VERSION. It looks from the error you've got that elements of node > 10.72 (or installed packages) are still hanging around. You can try googling the key bit of the error "compiled against a different Node.js version using NODE_MODULE_VERSION" and there are some stack overflows that may help. But in the end, I gave up and I used a different NPM package to work with the neopixel LEDs. I used https://www.npmjs.com/package/rpi-ws281x |
The latest version of this, 0.10, should work fine with node 12 and higher. This issue should be resolved now. |
Currently it still doesn't work on Node 14. Well, 0.10 works fine, however any other 1.x version gives an error on build. |
I cannot get this to build due to it not being able to find nan.h. I have tried 8, 10, and 12. |
@DJHoltkamp Thanks for the report, I think I might have found a problem with the latest release that could have caused that. Would you mind testing again with the version 1.0.1 I just released? |
@usefulthink - So doing npm install rpi-ws281x-native@1.0.1, I now fail with the error "napi.h: No such file or directory". So it fixed the other problem, but this still remains or created a new issue. |
Thanks! So I'm wondering now, why is it even including napi.h? That shouldn't be required. @DJHoltkamp If you don't mind, can you do that again with version 1.0.2? I removed the requirement for napi.h and rewrote the module-initializer. Will probably gat my raspberry back to running order so I can test it myself in the future... Sorry about that. |
@usefulthink Well, I got to a whole stack of error now, but the first one is: |
sorry about that, I hope that I can get a PI back to running order in the next days so I can debug this myself. It's probably just something small, but I don't want to continue like this. |
Ok, so I figured that as it's completely broken now anyway I can also give that another round of blind deployment :D I published another version if you still like to try it, otherwise you can probably also use this as an alternative: https://www.npmjs.com/package/rpi-ws281x |
Ok, thanks! I imagine this will be an easy fix once you can actually try natively compiling it. |
Sorry to ping this again, but that alternate package you posted does not support some brightness features I need. Did this issue of not being able to compile ever get fixed? I just tried compiling again and still got a new batch of errors about GetFunction and setBrightness.. |
Any news? I need to run this on a RPI 3B+ |
Was curious if anything in the works for this. Starting a project and have a rpi 3b+ i was testing with fresh rasp pi os lite, and nodejs 14. I'm getting an error also that seems related to the GetFunction in the same area of the most recent commit. Saw this user make a comment about getting something of his working but the NODE_MODULE implementation was different. |
same problem here, but with a raspberry Pi Zero and Nodejs 14, on raspbian 10 |
I think i fixed it, the question is how did it work at all before? This is the diff:
So GetFunction needed the Nan:: namespace, makes sense. But some bindings where pointing to non-existing functions (reset and setbrightness), while others where missing. (set*) Now it compiles and functions in my setup. (raspbian 10 on pi zero with nodejs 14) |
any updates on this PR? I to am having some issue on build. 239 error make: Leaving directory '/home/pi/ext_nisa/node_modules/rpi-ws281x-native/build'
240 error gyp info it worked if it ends with ok
240 error gyp info using node-gyp@7.1.2
240 error gyp info using node@14.17.0 | linux | arm
240 error gyp info find Python using Python version 3.7.3 found at "/usr/bin/python3"
240 error gyp info spawn /usr/bin/python3
240 error gyp info spawn args [
240 error gyp info spawn args '/home/pi/ext_nisa/node_modules/node-gyp/gyp/gyp_main.py',
240 error gyp info spawn args 'binding.gyp',
240 error gyp info spawn args '-f',
240 error gyp info spawn args 'make',
240 error gyp info spawn args '-I',
240 error gyp info spawn args '/home/pi/ext_nisa/node_modules/rpi-ws281x-native/build/config.gypi',
240 error gyp info spawn args '-I',
240 error gyp info spawn args '/home/pi/ext_nisa/node_modules/node-gyp/addon.gypi',
240 error gyp info spawn args '-I',
240 error gyp info spawn args '/home/pi/.cache/node-gyp/14.17.0/include/node/common.gypi',
240 error gyp info spawn args '-Dlibrary=shared_library',
240 error gyp info spawn args '-Dvisibility=default',
240 error gyp info spawn args '-Dnode_root_dir=/home/pi/.cache/node-gyp/14.17.0',
240 error gyp info spawn args '-Dnode_gyp_dir=/home/pi/ext_nisa/node_modules/node-gyp',
240 error gyp info spawn args '-Dnode_lib_file=/home/pi/.cache/node-gyp/14.17.0/<(target_arch)/node.lib',
240 error gyp info spawn args '-Dmodule_root_dir=/home/pi/ext_nisa/node_modules/rpi-ws281x-native',
240 error gyp info spawn args '-Dnode_engine=v8',
240 error gyp info spawn args '--depth=.',
240 error gyp info spawn args '--no-parallel',
240 error gyp info spawn args '--generator-output',
240 error gyp info spawn args 'build',
240 error gyp info spawn args '-Goutput_dir=.'
240 error gyp info spawn args ]
240 error gyp info spawn make
240 error gyp info spawn args [ 'BUILDTYPE=Release', '-C', 'build' ]
240 error ../src/rpi-ws281x.cc: In function ‘void InitAll(Nan::ADDON_REGISTER_FUNCTION_ARGS_TYPE)’:
240 error ../src/rpi-ws281x.cc:229:5: error: ‘GetFunction’ was not declared in this scope
240 error GetFunction(Nan::New<FunctionTemplate>(init)).ToLocalChecked());
240 error ^~~~~~~~~~~
240 error ../src/rpi-ws281x.cc:229:5: note: suggested alternative:
240 error In file included from ../../nan/nan.h:286,
240 error from ../src/rpi-ws281x.cc:1:
240 error ../../nan/nan_maybe_43_inl.h:66:33: note: ‘Nan::GetFunction’
240 error inline MaybeLocal<v8::Function> GetFunction(
240 error ^~~~~~~~~~~
240 error ../src/rpi-ws281x.cc:232:44: error: ‘setBrightness’ was not declared in this scope
240 error GetFunction(Nan::New<FunctionTemplate>(setBrightness)).ToLocalChecked());
240 error ^~~~~~~~~~~~~
240 error ../src/rpi-ws281x.cc:235:44: error: ‘reset’ was not declared in this scope
240 error GetFunction(Nan::New<FunctionTemplate>(reset)).ToLocalChecked());
240 error ^~~~~
240 error ../src/rpi-ws281x.cc:235:44: note: suggested alternative: ‘tzset’
240 error GetFunction(Nan::New<FunctionTemplate>(reset)).ToLocalChecked());
240 error ^~~~~
240 error tzset
240 error In file included from ../../nan/nan.h:58,
240 error from ../src/rpi-ws281x.cc:1:
240 error ../src/rpi-ws281x.cc: At global scope:
240 error /home/pi/.cache/node-gyp/14.17.0/include/node/node.h:758:43: warning: cast between incompatible function types from ‘void (*)(Nan::ADDON_REGISTER_FUNCTION_ARGS_TYPE)’ {aka ‘void (*)(v8::Local<v8::Object>)’} to ‘node::addon_register_func’ {aka ‘void (*)(v8::Local<v8::Object>, v8::Local<v8::Value>, void*)’} [-Wcast-function-type]
240 error (node::addon_register_func) (regfunc), \
240 error ^
240 error /home/pi/.cache/node-gyp/14.17.0/include/node/node.h:792:3: note: in expansion of macro ‘NODE_MODULE_X’
240 error NODE_MODULE_X(modname, regfunc, NULL, 0) // NOLINT (readability/null_usage)
240 error ^~~~~~~~~~~~~
240 error ../src/rpi-ws281x.cc:244:1: note: in expansion of macro ‘NODE_MODULE’
240 error NODE_MODULE(addon, InitAll)
240 error ^~~~~~~~~~~
240 error make: *** [rpi_ws281x.target.mk:114: Release/obj.target/rpi_ws281x/src/rpi-ws281x.o] Error 1
240 error gyp ERR! build error
240 error gyp ERR! stack Error: `make` failed with exit code: 2
240 error gyp ERR! stack at ChildProcess.onExit (/home/pi/ext_nisa/node_modules/node-gyp/lib/build.js:194:23)
240 error gyp ERR! stack at ChildProcess.emit (events.js:376:20)
240 error gyp ERR! stack at Process.ChildProcess._handle.onexit (internal/child_process.js:277:12)
240 error gyp ERR! System Linux 5.10.17-v7l+
240 error gyp ERR! command "/usr/bin/node" "/home/pi/ext_nisa/node_modules/.bin/node-gyp" "rebuild" "-j4" "--release"
240 error gyp ERR! cwd /home/pi/ext_nisa/node_modules/rpi-ws281x-native
240 error gyp ERR! node -v v14.17.0
240 error gyp ERR! node-gyp -v v7.1.2
240 error gyp ERR! not ok |
Additionally would love to see a PR which fixes this issue. Seems to make the project unusable. |
I got it working by changing the file
Unfortunatly the |
Wow, this is very disappointing to hear. I have another library working, but I specifically wanted to get this library working because I could find no other replacement that allowed me to set the brightness of the LEDs. If you or anyone else knows how to fix this or an alternate library, please let me know. |
I've made it work with node 14, on 1.x branch and If I remember correctly I used set Brightness, However you can write your own method for setBrightness, pretty much just add multiplier for R G B and check for max 255 and lowest. 0 https://github.com/gbkwiatt/node-rpi-ws281x-native This is what I've done with it example of my method export const setBrightness = ([r, g, b]) => {
const divider = config.leds.brightness / 255
const R = r * divider
const G = g * divider
const B = b * divider
return [R, G, B]
} Where divider is the "multiplier" and that's my LEDs Init const channelsCommon = {
count: config.leds.totalNum,
invert: config.leds.invert,
brightness: config.leds.brightness,
stripType: ws281x.stripType[config.leds.stripType],
}
const options = {
dma: config.leds.dma,
freq: config.leds.freq,
/** we have to define 2 channels regardless */
channels: [
{ gpio: config.leds.channel == 0 ? config.leds.gpio : 18, ...channelsCommon },
{ gpio: config.leds.channel == 1 ? config.leds.gpio : 19, ...channelsCommon },
],
}
/** init stripe */
channel = ws281x.init(options) Not sure if that will be helpful for you |
Thanks for the code examples. I will probably end up writing my own |
This is somewhat helpful, but perhaps this library or this protocol simply does not support what I thought it did. I thought that this supported using brightness within the color array itself as a 4th channel to say how much power actually goes to the LED to produce that color. For instance, if I wanted it to be fully red, but very dim, I could specify this. You would then push this through the library like this:
Does something like this not exist, or does the protocol not work this way? |
Okay, I think a found a way to change the global brightness! function setBrightness(channel, value) {
channel.brightness = value
ws281x.render();
}
// ...
var channel = ws281x(NUM_LEDS, options);
setBrightness(channel, 50); This seems to work just fine with the new 1.x version of this project. EDIT: Obviously I still needed to edit the file |
Ok, this entire time, I have been chasing the wrong issue. I assumed the lack of brightness settings was not letting me get smooth linear color interpolation when trying to make a smooth animation between lights on my strip. This is why I thought your brightness solution wasn't working. When I tried to interpolate between the LED's to animate, it would have a bit of flashing where it would get brighter and darker as it transitioned. After all of this searching, I finally figured out the issue: There is no gamma correction in this library Once I figured it out, it looks 100% perfect. I'm just frustrated it took me this long. For the record, this is how you would do it:
If this library is actively maintained, I would say this is a feature that should be added. It would be very helpful, maybe even as a default setting. |
Ah fair maybe I should use gamma correction. I do use color lerp / interpolation and it works pretty well. Deffinitely library could be maintained, it's pretty cool project and since i proficient in JS and pretty much everything can be ported from C to node, sky is the limit and I love it. |
Please keep an eye on https://github.com/psy0rz/rpi-ws281x-smi It allows you to control 16 ledstrips in parallel on all raspberry pi types. |
Hi!
I get lots of build errors when trying to
npm install rpi-ws281x-native
on a Raspi4 (Raspbian buster 4.19.97). (node-gyp rebuild fails at the nan module.)I tried different versions of node (10.0.0, 12.13.1, 13.12.0, 14.1.0).
Any ideas how to deal with this?
The text was updated successfully, but these errors were encountered: