mirror of
https://github.com/Keychron/qmk_firmware.git
synced 2024-11-23 17:06:52 +06:00
72d4e4bfd7
* Add provisional Helix implementation to test the quantum/split_common. * copy keyboards/helix/serial.[ch] to quantum/split_common/ * Make serial.c a pure driver. Remove buffer name and buffer size from serial.c. They should be placed in the caller(matrix.c, split_utils.c). * remove quantum/split_common/serial_backward_compatibility.h * Changed array serial_master_buffer to structure serial_m2s_buffer. * Changed array serial_slave_buffer to structure serial_s2m_buffer. * Change keyboards/miniaxe/matrix.c I also made changes to quantum/split_comon/matrix.c to keyboards/miniaxe/matrix.c. Note: I contacted @ka2hiro, creator of miniaxe, and I got permission to change keyboards/miniaxe/matrix.c. * update history comment in quantum/split_common/serial.c * Revert "Add provisional Helix implementation to test the quantum/split_common." This reverts commit 168c82ef82c88e79979d9796bab9cc819cc2f685. * fix keyboards/miniaxe/matrix.c, quantum/split_common/matrix.c avr-gcc 4.9.[23] report error. avr-gcc 5.4.0, avr-gcc 7.3.0 pass. It is funny. * update comment quantum/split_common/serial.c * Reserve RGBLIGHT_SPLIT macro in quantum/split_common
152 lines
3.6 KiB
C
152 lines
3.6 KiB
C
#include <avr/io.h>
|
|
#include <avr/wdt.h>
|
|
#include <avr/power.h>
|
|
#include <avr/interrupt.h>
|
|
#include <util/delay.h>
|
|
#include <avr/eeprom.h>
|
|
#include "split_util.h"
|
|
#include "matrix.h"
|
|
#include "keyboard.h"
|
|
#include "config.h"
|
|
#include "timer.h"
|
|
#include "split_flags.h"
|
|
|
|
#ifdef BACKLIGHT_ENABLE
|
|
# include "backlight.h"
|
|
#endif
|
|
|
|
#ifdef SPLIT_HAND_PIN
|
|
# include "pincontrol.h"
|
|
#endif
|
|
|
|
#if defined(USE_I2C) || defined(EH)
|
|
# include "i2c.h"
|
|
#endif
|
|
|
|
volatile bool isLeftHand = true;
|
|
|
|
volatile uint8_t setTries = 0;
|
|
|
|
static void setup_handedness(void) {
|
|
#ifdef SPLIT_HAND_PIN
|
|
// Test pin SPLIT_HAND_PIN for High/Low, if low it's right hand
|
|
pinMode(SPLIT_HAND_PIN, PinDirectionInput);
|
|
isLeftHand = digitalRead(SPLIT_HAND_PIN);
|
|
#else
|
|
#ifdef EE_HANDS
|
|
isLeftHand = eeprom_read_byte(EECONFIG_HANDEDNESS);
|
|
#else
|
|
// I2C_MASTER_RIGHT is deprecated, use MASTER_RIGHT instead, since this works for both serial and i2c
|
|
#if defined(I2C_MASTER_RIGHT) || defined(MASTER_RIGHT)
|
|
isLeftHand = !has_usb();
|
|
#else
|
|
isLeftHand = has_usb();
|
|
#endif
|
|
#endif
|
|
#endif
|
|
}
|
|
|
|
static void keyboard_master_setup(void) {
|
|
#if defined(USE_I2C) || defined(EH)
|
|
i2c_master_init();
|
|
#ifdef SSD1306OLED
|
|
matrix_master_OLED_init ();
|
|
#endif
|
|
#else
|
|
serial_master_init();
|
|
#endif
|
|
|
|
// For master the Backlight info needs to be sent on startup
|
|
// Otherwise the salve won't start with the proper info until an update
|
|
BACKLIT_DIRTY = true;
|
|
}
|
|
|
|
static void keyboard_slave_setup(void) {
|
|
timer_init();
|
|
#if defined(USE_I2C) || defined(EH)
|
|
i2c_slave_init(SLAVE_I2C_ADDRESS);
|
|
#else
|
|
serial_slave_init();
|
|
#endif
|
|
}
|
|
|
|
bool has_usb(void) {
|
|
USBCON |= (1 << OTGPADE); //enables VBUS pad
|
|
_delay_us(5);
|
|
return (USBSTA & (1<<VBUS)); //checks state of VBUS
|
|
}
|
|
|
|
void split_keyboard_setup(void) {
|
|
setup_handedness();
|
|
|
|
if (has_usb()) {
|
|
keyboard_master_setup();
|
|
} else {
|
|
keyboard_slave_setup();
|
|
}
|
|
sei();
|
|
}
|
|
|
|
void keyboard_slave_loop(void) {
|
|
matrix_init();
|
|
|
|
//Init RGB
|
|
#ifdef RGBLIGHT_ENABLE
|
|
rgblight_init();
|
|
#endif
|
|
|
|
while (1) {
|
|
// Matrix Slave Scan
|
|
matrix_slave_scan();
|
|
|
|
// Read Backlight Info
|
|
#ifdef BACKLIGHT_ENABLE
|
|
#ifdef USE_I2C
|
|
if (BACKLIT_DIRTY) {
|
|
backlight_set(i2c_slave_buffer[I2C_BACKLIT_START]);
|
|
BACKLIT_DIRTY = false;
|
|
}
|
|
#else // USE_SERIAL
|
|
backlight_set(serial_m2s_buffer.backlight_level);
|
|
#endif
|
|
#endif
|
|
// Read RGB Info
|
|
#ifdef RGBLIGHT_ENABLE
|
|
#ifdef USE_I2C
|
|
if (RGB_DIRTY) {
|
|
// Disable interupts (RGB data is big)
|
|
cli();
|
|
// Create new DWORD for RGB data
|
|
uint32_t dword;
|
|
|
|
// Fill the new DWORD with the data that was sent over
|
|
uint8_t *dword_dat = (uint8_t *)(&dword);
|
|
for (int i = 0; i < 4; i++) {
|
|
dword_dat[i] = i2c_slave_buffer[I2C_RGB_START+i];
|
|
}
|
|
|
|
// Update the RGB now with the new data and set RGB_DIRTY to false
|
|
rgblight_update_dword(dword);
|
|
RGB_DIRTY = false;
|
|
// Re-enable interupts now that RGB is set
|
|
sei();
|
|
}
|
|
#else // USE_SERIAL
|
|
#ifdef RGBLIGHT_SPLIT
|
|
// Add serial implementation for RGB here
|
|
#endif
|
|
#endif
|
|
#endif
|
|
}
|
|
}
|
|
|
|
// this code runs before the usb and keyboard is initialized
|
|
void matrix_setup(void) {
|
|
split_keyboard_setup();
|
|
|
|
if (!has_usb()) {
|
|
//rgblight_init();
|
|
keyboard_slave_loop();
|
|
}
|
|
}
|