mirror of
https://github.com/qmk/qmk_firmware.git
synced 2025-02-27 01:56:43 +00:00
294 lines
9.0 KiB
C
294 lines
9.0 KiB
C
// Copyright 2023 JZ-Skyloong (@JZ-Skyloong)
|
||
// SPDX-License-Identifier: GPL-2.0-or-later
|
||
#include "quantum.h"
|
||
|
||
#define MAC_OFF 0x1A //disable mac layer indicator on LED display
|
||
#define MAC_ON 0x3B //enable mac layer indicator on LED diaplay
|
||
|
||
|
||
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);
|
||
suspend_power_down_user();
|
||
}
|
||
|
||
void suspend_wakeup_init_kb() {
|
||
# ifdef RGB_MATRIX_ENABLE
|
||
writePinHigh(SDB);
|
||
# endif
|
||
suspend_wakeup_init_user();
|
||
}
|
||
|
||
bool shutdown_kb(bool jump_to_bootloader) {
|
||
writePinLow(SDB);
|
||
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);
|
||
IND =& MAC_OFF;
|
||
serial_to_parallel(IND);
|
||
break;
|
||
case 1:
|
||
writePinHigh(MAC_PIN);
|
||
IND =|| MAC_ON;
|
||
serial_to_parallel(IND);
|
||
break;
|
||
}
|
||
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;
|
||
}
|
||
|
||
if (host_keyboard_led_state().caps_lock) {
|
||
RGB_MATRIX_INDICATOR_SET_COLOR(CAPS_LOCK_INDEX, 255, 255, 255);
|
||
} else {
|
||
if (!rgb_matrix_get_flags()) {
|
||
RGB_MATRIX_INDICATOR_SET_COLOR(CAPS_LOCK_INDEX, 0, 0, 0);
|
||
}
|
||
}
|
||
|
||
switch (get_highest_layer(layer_state)) {
|
||
case 2:{
|
||
RGB_MATRIX_INDICATOR_SET_COLOR(WIN_MOD_INDEX, 255, 255, 255);
|
||
if (!rgb_matrix_get_flags()) {
|
||
RGB_MATRIX_INDICATOR_SET_COLOR(MAC_MOD_INDEX, 0, 0, 0);
|
||
}
|
||
} break;
|
||
case 3:{
|
||
RGB_MATRIX_INDICATOR_SET_COLOR(MAC_MOD_INDEX, 255, 255, 255);
|
||
if (!rgb_matrix_get_flags()) {
|
||
RGB_MATRIX_INDICATOR_SET_COLOR(WIN_MOD_INDEX, 0, 0, 0);
|
||
}
|
||
} break;
|
||
|
||
case 0:{
|
||
if (L_WIN) {
|
||
RGB_MATRIX_INDICATOR_SET_COLOR(WIN_MOD_INDEX, 255, 255, 255);
|
||
if (!rgb_matrix_get_flags()) {
|
||
RGB_MATRIX_INDICATOR_SET_COLOR(MAC_MOD_INDEX, 0, 0, 0);
|
||
}
|
||
}else{
|
||
if (!rgb_matrix_get_flags()) {
|
||
RGB_MATRIX_INDICATOR_SET_COLOR(WIN_MOD_INDEX, 0, 0, 0);
|
||
}
|
||
}
|
||
} break;
|
||
|
||
case 1:{
|
||
if (L_MAC) {
|
||
RGB_MATRIX_INDICATOR_SET_COLOR(MAC_MOD_INDEX, 255, 255, 255);
|
||
if (!rgb_matrix_get_flags()) {
|
||
RGB_MATRIX_INDICATOR_SET_COLOR(WIN_MOD_INDEX, 0, 0, 0);
|
||
}
|
||
}else{
|
||
if (!rgb_matrix_get_flags()) {
|
||
RGB_MATRIX_INDICATOR_SET_COLOR(MAC_MOD_INDEX, 0, 0, 0);
|
||
}
|
||
}
|
||
} break;
|
||
|
||
default:{
|
||
if (!rgb_matrix_get_flags()) {
|
||
RGB_MATRIX_INDICATOR_SET_COLOR(WIN_MOD_INDEX, 0, 0, 0);
|
||
RGB_MATRIX_INDICATOR_SET_COLOR(MAC_MOD_INDEX, 0, 0, 0);
|
||
}
|
||
}
|
||
}
|
||
return false;
|
||
}
|
||
|
||
|
||
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);
|
||
}
|
||
|
||
/*
|
||
LED display driver
|
||
*/
|
||
#define ClockTime 15
|
||
#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
|
||
|
||
static inline void setPinOutput_writeLow(pin_t pin) {
|
||
ATOMIC_BLOCK_FORCEON {
|
||
setPinOutput(pin);
|
||
writePinLow(pin);
|
||
}
|
||
}
|
||
|
||
static inline void setPinOutput_writeHigh(pin_t pin) {
|
||
ATOMIC_BLOCK_FORCEON {
|
||
setPinOutput(pin);
|
||
writePinHigh(pin);
|
||
}
|
||
}
|
||
|
||
static inline void select_delay(uint16_t n) {
|
||
while (n-- > 0) {
|
||
asm volatile("nop" ::: "memory");
|
||
};
|
||
}
|
||
|
||
static inline void clockPulse(uint16_t n) {
|
||
writePinHigh(HC595_SH_PIN);
|
||
writePinHigh(HC595_ST_PIN);
|
||
select_delay(n);
|
||
writePinLow(HC595_SH_PIN);
|
||
writePinLow(HC595_ST_PIN);
|
||
}
|
||
|
||
void serial_to_parallel(uint8_t data) { // 串口转并口函数
|
||
setPinOutput_writeLow(HC595_DS);
|
||
setPinOutput_writeLow(HC595_SH_PIN);
|
||
setPinOutput_writeLow(HC595_ST_PIN);
|
||
for(uint8_t i = 0; i < 8; i++) { // 循环8次,每次输出一位数据
|
||
HC595_DS = (data & 0x01); // 将最低位写入串口数据输入端
|
||
clockPulse(ClockTime);
|
||
data >>= 1; // 将数据右移一位,准备输出下一位数据
|
||
}
|
||
}
|