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 | |
| 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')
| -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) { |
