diff options
author | Nick Brassel <nick@tzarc.org> | 2021-06-18 09:10:06 +1000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-06-18 09:10:06 +1000 |
commit | 172e6a703041363decd6fc829542f33180c13beb (patch) | |
tree | a5d4afaa672ab44826865fd76b201e3899083192 /tmk_core/common/host.c | |
parent | ef92c9ee2cf4745637635ec1895399e4f013914c (diff) | |
download | qmk_firmware-172e6a703041363decd6fc829542f33180c13beb.tar.gz qmk_firmware-172e6a703041363decd6fc829542f33180c13beb.zip |
Extensible split data sync (#11930)
* Extensible split data sync capability through transactions.
- Split common transport has been split up between the transport layer
and data layer.
- Split "transactions" model used, with convergence between I2C and
serial data definitions.
- Slave matrix "generation count" is used to determine if the full slave
matrix needs to be retrieved.
- Encoders get the same "generation count" treatment.
- All other blocks of data are synchronised when a change is detected.
- All transmissions have a globally-configurable deadline before a
transmission is forced (`FORCED_SYNC_THROTTLE_MS`, default 100ms).
- Added atomicity for all core-synced data, preventing partial updates
- Added retries to AVR i2c_master's i2c_start, to minimise the number of
failed transactions when interrupts are disabled on the slave due to
atomicity checks.
- Some keyboards have had slight modifications made in order to ensure
that they still build due to firmware size restrictions.
* Fixup LED_MATRIX compile.
* Parameterise ERROR_DISCONNECT_COUNT.
Diffstat (limited to 'tmk_core/common/host.c')
-rw-r--r-- | tmk_core/common/host.c | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/tmk_core/common/host.c b/tmk_core/common/host.c index e7d92cfac..a8b391e89 100644 --- a/tmk_core/common/host.c +++ b/tmk_core/common/host.c | |||
@@ -17,6 +17,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>. | |||
17 | 17 | ||
18 | #include <stdint.h> | 18 | #include <stdint.h> |
19 | //#include <avr/interrupt.h> | 19 | //#include <avr/interrupt.h> |
20 | #include "keyboard.h" | ||
20 | #include "keycode.h" | 21 | #include "keycode.h" |
21 | #include "host.h" | 22 | #include "host.h" |
22 | #include "util.h" | 23 | #include "util.h" |
@@ -35,15 +36,20 @@ void host_set_driver(host_driver_t *d) { driver = d; } | |||
35 | 36 | ||
36 | host_driver_t *host_get_driver(void) { return driver; } | 37 | host_driver_t *host_get_driver(void) { return driver; } |
37 | 38 | ||
39 | #ifdef SPLIT_KEYBOARD | ||
40 | uint8_t split_led_state = 0; | ||
41 | void set_split_host_keyboard_leds(uint8_t led_state) { split_led_state = led_state; } | ||
42 | #endif | ||
43 | |||
38 | uint8_t host_keyboard_leds(void) { | 44 | uint8_t host_keyboard_leds(void) { |
45 | #ifdef SPLIT_KEYBOARD | ||
46 | if (!is_keyboard_master()) return split_led_state; | ||
47 | #endif | ||
39 | if (!driver) return 0; | 48 | if (!driver) return 0; |
40 | return (*driver->keyboard_leds)(); | 49 | return (*driver->keyboard_leds)(); |
41 | } | 50 | } |
42 | 51 | ||
43 | led_t host_keyboard_led_state(void) { | 52 | led_t host_keyboard_led_state(void) { return (led_t)host_keyboard_leds(); } |
44 | if (!driver) return (led_t){0}; | ||
45 | return (led_t)((*driver->keyboard_leds)()); | ||
46 | } | ||
47 | 53 | ||
48 | /* send report */ | 54 | /* send report */ |
49 | void host_keyboard_send(report_keyboard_t *report) { | 55 | void host_keyboard_send(report_keyboard_t *report) { |