// Copyright 2023 NaturalZh (@NaturalZh) // SPDX-License-Identifier: GPL-2.0-or-later #include "quantum.h" /** * 74HC595 Skyloong LED display Driver * data(default):1-on/0-off * bit0 --- MAC layer indicator * bit1 --- Win layer indicator * bit2 --- CAPS indicator * bit3 --- NUM indicator * bit4 --- SCR indicator * bit7 --- Skyloong LOGO display * **/ #define HC595_ST_PIN A6 //74HC595 storage register clock input #define HC595_SH_PIN A5 //74HC595 shift register clock input #define HC595_DS A7 // 74HC595 serial data input #include "led_hc595.c" uint8_t IND = 0; //buffer of LED Display #if defined(RGB_MATRIX_ENABLE) /*&& defined(CAPS_LOCK_INDEX)*/ const aw20216s_led_t PROGMEM g_aw20216s_leds[AW20216S_LED_COUNT] = { /* Each AW20216 channel is controlled by a register at some offset between 0x00 * and 0xD7 inclusive. * See drivers/awinic/aw20216.h for the mapping between register offsets and * driver pin locations. * driver * | R location * | | G location * | | | B location * | | | | */ {0, CS1_SW1, CS2_SW1, CS3_SW1}, {0, CS1_SW3, CS2_SW3, CS3_SW3}, {0, CS1_SW4, CS2_SW4, CS3_SW4}, {0, CS1_SW5, CS2_SW5, CS3_SW5}, {0, CS1_SW6, CS2_SW6, CS3_SW6}, {0, CS1_SW7, CS2_SW7, CS3_SW7}, {0, CS1_SW8, CS2_SW8, CS3_SW8}, {0, CS1_SW9, CS2_SW9, CS3_SW9}, {0, CS1_SW10, CS2_SW10, CS3_SW10}, {0, CS1_SW11, CS2_SW11, CS3_SW11}, {0, CS1_SW12, CS2_SW12, CS3_SW12}, {0, CS10_SW2, CS11_SW2, CS12_SW2}, {0, CS10_SW3, CS11_SW3, CS12_SW3}, //encoder no led {0, CS10_SW5, CS11_SW5, CS12_SW5}, {0, CS10_SW6, CS11_SW6, CS12_SW6}, {0, CS10_SW7, CS11_SW7, CS12_SW7}, {0, CS10_SW8, CS11_SW8, CS12_SW8}, {0, CS4_SW1, CS5_SW1, CS6_SW1}, {0, CS4_SW2, CS5_SW2, CS6_SW2}, {0, CS4_SW3, CS5_SW3, CS6_SW3}, {0, CS4_SW4, CS5_SW4, CS6_SW4}, {0, CS4_SW5, CS5_SW5, CS6_SW5}, {0, CS4_SW6, CS5_SW6, CS6_SW6}, {0, CS4_SW7, CS5_SW7, CS6_SW7}, {0, CS4_SW8, CS5_SW8, CS6_SW8}, {0, CS4_SW9, CS5_SW9, CS6_SW9}, {0, CS4_SW10, CS5_SW10, CS6_SW10}, {0, CS4_SW11, CS5_SW11, CS6_SW11}, {0, CS4_SW12, CS5_SW12, CS6_SW12}, {0, CS13_SW2, CS14_SW2, CS15_SW2}, {0, CS13_SW3, CS14_SW3, CS15_SW3}, {0, CS13_SW4, CS14_SW4, CS15_SW4}, {0, CS13_SW5, CS14_SW5, CS15_SW5}, {0, CS13_SW6, CS14_SW6, CS15_SW6}, {0, CS13_SW7, CS14_SW7, CS15_SW7}, {0, CS7_SW1, CS8_SW1, CS9_SW1}, {0, CS7_SW2, CS8_SW2, CS9_SW2}, {0, CS7_SW3, CS8_SW3, CS9_SW3}, {0, CS7_SW4, CS8_SW4, CS9_SW4}, {0, CS7_SW5, CS8_SW5, CS9_SW5}, {0, CS7_SW6, CS8_SW6, CS9_SW6}, {0, CS7_SW7, CS8_SW7, CS9_SW7}, {0, CS7_SW8, CS8_SW8, CS9_SW8}, {0, CS7_SW9, CS8_SW9, CS9_SW9}, {0, CS7_SW10, CS8_SW10, CS9_SW10}, {0, CS7_SW11, CS8_SW11, CS9_SW11}, {0, CS7_SW12, CS8_SW12, CS9_SW12}, {0, CS16_SW2, CS17_SW2, CS18_SW2}, {0, CS16_SW3, CS17_SW3, CS18_SW3}, {0, CS16_SW4, CS17_SW4, CS18_SW4}, {0, CS16_SW5, CS17_SW5, CS18_SW5}, {0, CS16_SW6, CS17_SW6, CS18_SW6}, {0, CS16_SW7, CS17_SW7, CS18_SW7}, {1, CS1_SW1, CS2_SW1, CS3_SW1}, {1, CS1_SW2, CS2_SW2, CS3_SW2}, {1, CS1_SW3, CS2_SW3, CS3_SW3}, {1, CS1_SW4, CS2_SW4, CS3_SW4}, {1, CS1_SW5, CS2_SW5, CS3_SW5}, {1, CS1_SW6, CS2_SW6, CS3_SW6}, {1, CS1_SW7, CS2_SW7, CS3_SW7}, {1, CS1_SW8, CS2_SW8, CS3_SW8}, {1, CS1_SW9, CS2_SW9, CS3_SW9}, {1, CS1_SW10, CS2_SW10, CS3_SW10}, {1, CS1_SW11, CS2_SW11, CS3_SW11}, {1, CS1_SW12, CS2_SW12, CS3_SW12}, {1, CS10_SW3, CS11_SW3, CS12_SW3}, {1, CS10_SW4, CS11_SW4, CS12_SW4}, {1, CS10_SW5, CS11_SW5, CS12_SW5}, {1, CS10_SW6, CS11_SW6, CS12_SW6}, {1, CS4_SW1, CS5_SW1, CS6_SW1}, {1, CS4_SW2, CS5_SW2, CS6_SW2}, {1, CS4_SW3, CS5_SW3, CS6_SW3}, {1, CS4_SW4, CS5_SW4, CS6_SW4}, {1, CS4_SW5, CS5_SW5, CS6_SW5}, {1, CS4_SW6, CS5_SW6, CS6_SW6}, {1, CS4_SW7, CS5_SW7, CS6_SW7}, {1, CS4_SW8, CS5_SW8, CS6_SW8}, {1, CS4_SW9, CS5_SW9, CS6_SW9}, {1, CS4_SW10, CS5_SW10, CS6_SW10}, {1, CS4_SW11, CS5_SW11, CS6_SW11}, {1, CS13_SW2, CS14_SW2, CS15_SW2}, {1, CS13_SW3, CS14_SW3, CS15_SW3}, {1, CS13_SW4, CS14_SW4, CS15_SW4}, {1, CS13_SW5, CS14_SW5, CS15_SW5}, {1, CS13_SW6, CS14_SW6, CS15_SW6}, {1, CS13_SW7, CS14_SW7, CS15_SW7}, {1, CS7_SW1, CS8_SW1, CS9_SW1}, {1, CS7_SW2, CS8_SW2, CS9_SW2}, {1, CS7_SW3, CS8_SW3, CS9_SW3}, {1, CS7_SW5, CS8_SW5, CS9_SW5}, {1, CS7_SW6, CS8_SW6, CS9_SW6}, {1, CS7_SW8, CS8_SW8, CS9_SW8}, {1, CS7_SW10, CS8_SW10, CS9_SW10}, {1, CS7_SW11, CS8_SW11, CS9_SW11}, {1, CS7_SW12, CS8_SW12, CS9_SW12}, {1, CS16_SW2, CS17_SW2, CS18_SW2}, {1, CS16_SW3, CS17_SW3, CS18_SW3}, {1, CS16_SW4, CS17_SW4, CS18_SW4}, {1, CS16_SW5, CS17_SW5, CS18_SW5}, {1, CS16_SW6, CS17_SW6, CS18_SW6} }; #endif void suspend_power_down_kb() { # ifdef RGB_MATRIX_ENABLE writePinLow(SDB); # endif writePinLow(MAC_PIN); s_serial_to_parallel(0); suspend_power_down_user(); } void suspend_wakeup_init_kb() { # ifdef RGB_MATRIX_ENABLE writePinHigh(SDB); # endif s_serial_to_parallel(IND); suspend_wakeup_init_user(); } bool shutdown_kb(bool jump_to_bootloader) { writePinLow(SDB); s_serial_to_parallel(0); return shutdown_user(jump_to_bootloader); } layer_state_t default_layer_state_set_kb(layer_state_t state) { switch (get_highest_layer(state)) { case 0: writePinLow(MAC_PIN); //switch to win layer display IND = IND & (~MAC_ON); IND = IND | WIN_ON; break; case 1: writePinHigh(MAC_PIN); //switch to mac layer display IND = IND & (~WIN_ON); IND = IND | MAC_ON; break; } s_serial_to_parallel(IND); return state; } bool rgb_matrix_indicators_advanced_kb(uint8_t led_min, uint8_t led_max) { if (!rgb_matrix_indicators_advanced_user(led_min, led_max)) { return false; } //caps lock display if (host_keyboard_led_state().caps_lock) { RGB_MATRIX_INDICATOR_SET_COLOR(CAPS_LOCK_INDEX, 255, 255, 255); IND = IND | CAPS_ON; } else { if (!rgb_matrix_get_flags()) { RGB_MATRIX_INDICATOR_SET_COLOR(CAPS_LOCK_INDEX, 0, 0, 0); } IND = IND & (~CAPS_ON); } //number lock display if (host_keyboard_led_state().num_lock) { RGB_MATRIX_INDICATOR_SET_COLOR(NUM_LOCK_INDEX, 255, 255, 255); IND = IND | NUM_ON; } else { if (!rgb_matrix_get_flags()) { RGB_MATRIX_INDICATOR_SET_COLOR(NUM_LOCK_INDEX, 0, 0, 0); } IND = IND & (~NUM_ON); } //scroll lock display if (host_keyboard_led_state().scroll_lock) { RGB_MATRIX_INDICATOR_SET_COLOR(SCR_LOCK_INDEX, 255, 255, 255); IND = IND | SCR_ON; } else { if (!rgb_matrix_get_flags()) { RGB_MATRIX_INDICATOR_SET_COLOR(SCR_LOCK_INDEX, 0, 0, 0); } IND = IND & (~SCR_ON); } s_serial_to_parallel(IND); return true; } void board_init(void) { // JTAG-DP Disabled and SW-DP Disabled AFIO->MAPR = (AFIO->MAPR & ~AFIO_MAPR_SWJ_CFG_Msk) | AFIO_MAPR_SWJ_CFG_DISABLE; # ifdef RGB_MATRIX_ENABLE setPinOutput(SDB); writePinHigh(SDB); # endif setPinOutput(MAC_PIN); writePinHigh(MAC_PIN); s_serial_to_parallel(SKYLOONG); }