Keyboard: Helix serial improvements (#3608)
* add change_reciver2sender()/change_sender2reciver()
This is a change to improve readability.
* txled, rxled off in matrix_init()
* add serial_send_packet() / serial_recive_packet()
This is a change to reduce object size.
* add serial_low() at ISR() top
* add __attribute__((always_inline)) to some functions
* modify serial_send_packet()/serial_recive_packet()
A little, object size reduction.
A little, speedup.
* add debug code to helix/serial.c
* Adjust sampling timing of serial signal being received
* add split_scomm.c/split_scomm.h and change serial.c/serial.h
serial.c was divided into 2 layers, split_scom.c and serial.c.
The upper layer split_scomm.c is called from matrix.c.
The lower layer serial.c accesses the hardware.
* add split_scomm.c/split_scomm.h into helix/rev1
* reduce object size helix/rev2/matrix.c
* remove checksum check, add parity check
* force occur parity error for test
* parity test ok. remove test code
* change some comment & add skip code when buffer_size == 0
* serial.c: multiple types of transaction support
Add 4 bits transaction-type field at packet top.
Select Transaction Descriptor Table entry by transaction-type.
* helix serial master-slave transaction optimize
Using multi-type transaction feature of serial.c, communication contents between master slaves were optimized.
* add debug code for retry
* add comment into each config.h
* fix ISR status drop
* add a debug macro 'debug_retry_chg()'
* reduce led_test size
* remove debug code from helix/serial.c and etc.
* helix:five_rows change TAPPING_TERM value 140
* Improved compatibility with let's split of serial.c. Finish helix/serial.c improvement.
- The difference with the original let's split's serial.c
- It's high-speed about 4 times.
- Stable bi-directional data transfer. (Helix need master to slave transfer)
- serial.h was divided 2 files, serial_config.h and sereial.h
- With multiple types of transaction support, communication contents can be optimized. (NEW flexible API)
- USE OLD Simple APIs (compatible with let's split serial.c)
- files :
- serial_config.h -- hardware configuration (need include by config.h)
- serial.c/serial.h -- serial communication
- USE NEW flexible APIs. (Support multi-type transaction function.)
serial.c was divided into 2 layers, split_scom.c and serial.c.
The upper layer split_scomm.c is called from matrix.c.
The lower layer serial.c accesses the hardware.
- files
- split_scomm.c -- communication buffer is defined in here. call by matrix.c.
- split_scomm.h -- buffer size is defined in here. include by matrix.c, split_util.c
- serial_config.h -- hardware configuration (need include by config.h)
To use the NEW API, specify #define SERIAL_USE_MULTI_TRANSACTION
- serial.c/serial.h -- serial communication lower layer
- NEW APIs for serial.c / serial.h (The lower layer)
// Soft Serial Transaction Descriptor
typedef struct _SSTD_t {
uint8_t *status;
uint8_t initiator2target_buffer_size;
uint8_t *initiator2target_buffer;
uint8_t target2initiator_buffer_size;
uint8_t *target2initiator_buffer;
} SSTD_t;
// initiator is transaction start side
void soft_serial_initiator_init(SSTD_t *sstd_table);
// target is interrupt accept side
void soft_serial_target_init(SSTD_t *sstd_table);
int soft_serial_transaction(int sstd_index);
int soft_serial_get_and_clean_target_status(int sstd_index);
- NEW APIs for split_scomm.c / split_scomm.h (The upper layer)
move from old serial.c the following buffer and functions
serial_slave_buffer[]
serial_master_buffer[]
void serial_master_init(void)
void serial_slave_init(void)
int serial_update_buffers(void)
define SERIAL_xxxxx_BUFFER_LENGTH move from serial_config.h to split_scomm.h
7 years ago
|
|
|
SRC += i2c.c
|
|
|
|
SRC += serial.c
|
|
|
|
SRC += ssd1306.c
|
|
|
|
|
|
|
|
# MCU name
|
|
|
|
MCU = atmega32u4
|
|
|
|
|
|
|
|
# Processor frequency.
|
|
|
|
# This will define a symbol, F_CPU, in all source code files equal to the
|
|
|
|
# processor frequency in Hz. You can then use this symbol in your source code to
|
|
|
|
# calculate timings. Do NOT tack on a 'UL' at the end, this will be done
|
|
|
|
# automatically to create a 32-bit value in your source code.
|
|
|
|
#
|
|
|
|
# This will be an integer division of F_USB below, as it is sourced by
|
|
|
|
# F_USB after it has run through any CPU prescalers. Note that this value
|
|
|
|
# does not *change* the processor frequency - it should merely be updated to
|
|
|
|
# reflect the processor speed set externally so that the code can use accurate
|
|
|
|
# software delays.
|
|
|
|
F_CPU = 16000000
|
|
|
|
|
|
|
|
#
|
|
|
|
# LUFA specific
|
|
|
|
#
|
|
|
|
# Target architecture (see library "Board Types" documentation).
|
|
|
|
ARCH = AVR8
|
|
|
|
|
|
|
|
# Input clock frequency.
|
|
|
|
# This will define a symbol, F_USB, in all source code files equal to the
|
|
|
|
# input clock frequency (before any prescaling is performed) in Hz. This value may
|
|
|
|
# differ from F_CPU if prescaling is used on the latter, and is required as the
|
|
|
|
# raw input clock is fed directly to the PLL sections of the AVR for high speed
|
|
|
|
# clock generation for the USB and other AVR subsections. Do NOT tack on a 'UL'
|
|
|
|
# at the end, this will be done automatically to create a 32-bit value in your
|
|
|
|
# source code.
|
|
|
|
#
|
|
|
|
# If no clock division is performed on the input clock inside the AVR (via the
|
|
|
|
# CPU clock adjust registers or the clock division fuses), this will be equal to F_CPU.
|
|
|
|
F_USB = $(F_CPU)
|
|
|
|
|
|
|
|
# Bootloader
|
|
|
|
# This definition is optional, and if your keyboard supports multiple bootloaders of
|
|
|
|
# different sizes, comment this out, and the correct address will be loaded
|
|
|
|
# automatically (+60). See bootloader.mk for all options.
|
|
|
|
BOOTLOADER = caterina
|
|
|
|
|
|
|
|
# Interrupt driven control endpoint task(+60)
|
|
|
|
OPT_DEFS += -DINTERRUPT_CONTROL_ENDPOINT
|
|
|
|
|
|
|
|
# Build Options
|
|
|
|
# change to "no" to disable the options, or define them in the Makefile in
|
|
|
|
# the appropriate keymap folder that will get included automatically
|
|
|
|
#
|
|
|
|
BOOTMAGIC_ENABLE = no # Virtual DIP switch configuration(+1000)
|
|
|
|
MOUSEKEY_ENABLE = no # Mouse keys(+4700)
|
|
|
|
EXTRAKEY_ENABLE = no # Audio control and System control(+450)
|
|
|
|
CONSOLE_ENABLE = no # Console for debug(+400)
|
|
|
|
COMMAND_ENABLE = no # Commands for debug and configuration
|
|
|
|
NKRO_ENABLE = no # Nkey Rollover - if this doesn't work, see here: https://github.com/tmk/tmk_keyboard/wiki/FAQ#nkro-doesnt-work
|
|
|
|
BACKLIGHT_ENABLE = no # Enable keyboard backlight functionality
|
|
|
|
MIDI_ENABLE = no # MIDI controls
|
|
|
|
AUDIO_ENABLE = no # Audio output on port C6
|
|
|
|
UNICODE_ENABLE = no # Unicode
|
|
|
|
BLUETOOTH_ENABLE = no # Enable Bluetooth with the Adafruit EZ-Key HID
|
|
|
|
RGBLIGHT_ENABLE = no # Enable WS2812 RGB underlight.
|
|
|
|
SUBPROJECT_rev1 = no
|
|
|
|
USE_I2C = yes
|
|
|
|
# Do not enable SLEEP_LED_ENABLE. it uses the same timer as BACKLIGHT_ENABLE
|
|
|
|
SLEEP_LED_ENABLE = no # Breathing sleep LED during USB suspend
|
|
|
|
|
|
|
|
CUSTOM_MATRIX = yes
|
|
|
|
|
|
|
|
DEFAULT_FOLDER = helix/rev2
|