From 76616827870a95b5bb142a3f1ae1b55d8d60b991 Mon Sep 17 00:00:00 2001 From: Nick Brassel Date: Sun, 19 Feb 2023 11:51:29 +1100 Subject: [PATCH] PROGMEM led mappings --- lib/python/qmk/cli/xap/generate_lighting.py | 10 +++---- quantum/xap/lighting_map.h | 33 +++++++++++---------- 2 files changed, 22 insertions(+), 21 deletions(-) diff --git a/lib/python/qmk/cli/xap/generate_lighting.py b/lib/python/qmk/cli/xap/generate_lighting.py index 1716056489c..e19639a65fe 100644 --- a/lib/python/qmk/cli/xap/generate_lighting.py +++ b/lib/python/qmk/cli/xap/generate_lighting.py @@ -28,7 +28,7 @@ def _append_lighting_map(lines, feature, spec): ifdef_prefix = PREFIX_MAP[feature]['ifdef'] def_prefix = PREFIX_MAP[feature]['def'] - lines.append(f'static uint8_t {feature}_effect_map[][2] = {{') + lines.append(f'static const uint8_t {feature}_effect_map[][2] PROGMEM = {{') for id, obj in spec.get('effects', {}).items(): define = obj['define'] offset = f' + {obj["offset"]}' if obj['offset'] else '' @@ -54,16 +54,16 @@ def _append_lighting_map(lines, feature, spec): f''' uint8_t {feature}2xap(uint8_t val) {{ for(uint8_t i = 0; i < ARRAY_SIZE({feature}_effect_map); i++) {{ - if ({feature}_effect_map[i][1] == val) - return {feature}_effect_map[i][0]; + if (pgm_read_byte(&{feature}_effect_map[i][1]) == val) + return pgm_read_byte(&{feature}_effect_map[i][0]); }} return 0xFF; }} uint8_t xap2{feature}(uint8_t val) {{ for(uint8_t i = 0; i < ARRAY_SIZE({feature}_effect_map); i++) {{ - if ({feature}_effect_map[i][0] == val) - return {feature}_effect_map[i][1]; + if (pgm_read_byte(&{feature}_effect_map[i][0]) == val) + return pgm_read_byte(&{feature}_effect_map[i][1]); }} return 0xFF; }}''' diff --git a/quantum/xap/lighting_map.h b/quantum/xap/lighting_map.h index 420cb7e2b99..f44965ddf09 100644 --- a/quantum/xap/lighting_map.h +++ b/quantum/xap/lighting_map.h @@ -1,4 +1,4 @@ -// Copyright 2022 QMK +// Copyright 2023 QMK // SPDX-License-Identifier: GPL-2.0-or-later /******************************************************************************* @@ -31,7 +31,7 @@ #define ENABLE_LED_MATRIX_SOLID #ifdef RGBLIGHT_ENABLE -static uint8_t rgblight_effect_map[][2] = { +static const uint8_t rgblight_effect_map[][2] PROGMEM = { #ifdef RGBLIGHT_EFFECT_STATIC_LIGHT { 0x00, RGBLIGHT_MODE_STATIC_LIGHT}, @@ -204,16 +204,16 @@ static uint8_t rgblight_effect_map[][2] = { uint8_t rgblight2xap(uint8_t val) { for(uint8_t i = 0; i < ARRAY_SIZE(rgblight_effect_map); i++) { - if (rgblight_effect_map[i][1] == val) - return rgblight_effect_map[i][0]; + if (pgm_read_byte(&rgblight_effect_map[i][1]) == val) + return pgm_read_byte(&rgblight_effect_map[i][0]); } return 0xFF; } uint8_t xap2rgblight(uint8_t val) { for(uint8_t i = 0; i < ARRAY_SIZE(rgblight_effect_map); i++) { - if (rgblight_effect_map[i][0] == val) - return rgblight_effect_map[i][1]; + if (pgm_read_byte(&rgblight_effect_map[i][0]) == val) + return pgm_read_byte(&rgblight_effect_map[i][1]); } return 0xFF; } @@ -389,7 +389,7 @@ enum { ENABLED_RGBLIGHT_EFFECTS = 0 }; #endif //RGBLIGHT_ENABLE #ifdef RGB_MATRIX_ENABLE -static uint8_t rgb_matrix_effect_map[][2] = { +static const uint8_t rgb_matrix_effect_map[][2] PROGMEM = { #ifdef ENABLE_RGB_MATRIX_SOLID_COLOR { 0x00, RGB_MATRIX_SOLID_COLOR}, @@ -612,16 +612,16 @@ static uint8_t rgb_matrix_effect_map[][2] = { uint8_t rgb_matrix2xap(uint8_t val) { for(uint8_t i = 0; i < ARRAY_SIZE(rgb_matrix_effect_map); i++) { - if (rgb_matrix_effect_map[i][1] == val) - return rgb_matrix_effect_map[i][0]; + if (pgm_read_byte(&rgb_matrix_effect_map[i][1]) == val) + return pgm_read_byte(&rgb_matrix_effect_map[i][0]); } return 0xFF; } uint8_t xap2rgb_matrix(uint8_t val) { for(uint8_t i = 0; i < ARRAY_SIZE(rgb_matrix_effect_map); i++) { - if (rgb_matrix_effect_map[i][0] == val) - return rgb_matrix_effect_map[i][1]; + if (pgm_read_byte(&rgb_matrix_effect_map[i][0]) == val) + return pgm_read_byte(&rgb_matrix_effect_map[i][1]); } return 0xFF; } @@ -847,7 +847,7 @@ enum { ENABLED_RGB_MATRIX_EFFECTS = 0 }; #endif //RGB_MATRIX_ENABLE #ifdef LED_MATRIX_ENABLE -static uint8_t led_matrix_effect_map[][2] = { +static const uint8_t led_matrix_effect_map[][2] PROGMEM = { #ifdef ENABLE_LED_MATRIX_SOLID { 0x00, LED_MATRIX_SOLID}, @@ -963,16 +963,16 @@ static uint8_t led_matrix_effect_map[][2] = { uint8_t led_matrix2xap(uint8_t val) { for(uint8_t i = 0; i < ARRAY_SIZE(led_matrix_effect_map); i++) { - if (led_matrix_effect_map[i][1] == val) - return led_matrix_effect_map[i][0]; + if (pgm_read_byte(&led_matrix_effect_map[i][1]) == val) + return pgm_read_byte(&led_matrix_effect_map[i][0]); } return 0xFF; } uint8_t xap2led_matrix(uint8_t val) { for(uint8_t i = 0; i < ARRAY_SIZE(led_matrix_effect_map); i++) { - if (led_matrix_effect_map[i][0] == val) - return led_matrix_effect_map[i][1]; + if (pgm_read_byte(&led_matrix_effect_map[i][0]) == val) + return pgm_read_byte(&led_matrix_effect_map[i][1]); } return 0xFF; } @@ -1090,3 +1090,4 @@ enum { ENABLED_LED_MATRIX_EFFECTS = 0 #endif }; #endif //LED_MATRIX_ENABLE +