-
-
Notifications
You must be signed in to change notification settings - Fork 40.1k
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
Support more than 256 leds #24675
Comments
In general, yeah, AVR ram limitations are usually an issue. I'm not sure of the best solution, but a typedef sounds like probably the best option here. There is a similar thing for the layer state bitmask, for instance. Also, damn, that board looks spectacular |
That board is gorgeous! Maybe the LED index type can be defined conditionally based on #if (RGB_MATRIX_LED_COUNT) <= 255
typedef uint8_t led_index_t; // Continue using uint8_t by default.
#else
typedef uint_fast16_t led_index_t; // If there are more than 255 LEDs.
#endif
bool SOME_EFFECT(effect_params_t* params) {
LED_MATRIX_USE_LIMITS(led_min, led_max);
for (led_index_t i = led_min; i < led_max; i++) {
... |
Yep, that's what I'm thinking. |
I ran into this on my last board, but dang, your implementation of 'maxing out led count' is far more wondrous. |
I made a split keyboard with 4 leds under each key (10 for the 2 2U keys) and the results are pretty spectacular. This sums up to 162 leds per half, or 324 leds on both. QMK currently uses a
uint_8
in most places to iterate over leds, so this required some patches which I want to polish up and contribute back.I'm not intimately familiar with the codebase or nuances of QMK, so it would be great with some guidance on the best way to implement it for this project. I assume RAM is enough of a concern for the AVR platform that replacing all relevant
uint_8
withuint_16
would be problematic? Would atypedef uintX_t num_leds_t
then be best setting the type to uint16_t ifRGB_MATRIX_LED_COUNT > 255
, and using that type everywhere instead? Anything else I should know before putting time into implementing this properly?The text was updated successfully, but these errors were encountered: