forked from kofal.net/zmk
refactor(core): Move to stack allocated events.
* Move to local/stack allocated event API that doesn't require dynamic allocation/freeing. * Disable heap, we no longer use alloc/free unless using LVGL. * Tons of refactors all over to account for the new event approach.
This commit is contained in:
committed by
Pete Johanson
parent
50e473276f
commit
33209dee1d
@@ -38,7 +38,8 @@ struct zmk_event_subscription {
|
||||
zmk_event_t header; \
|
||||
struct event_type data; \
|
||||
}; \
|
||||
struct event_type##_event *new_##event_type(struct event_type); \
|
||||
struct event_type##_event copy_raised_##event_type(const struct event_type *ev); \
|
||||
int raise_##event_type(struct event_type); \
|
||||
struct event_type *as_##event_type(const zmk_event_t *eh); \
|
||||
extern const struct zmk_event_type zmk_event_##event_type;
|
||||
|
||||
@@ -46,12 +47,14 @@ struct zmk_event_subscription {
|
||||
const struct zmk_event_type zmk_event_##event_type = {.name = STRINGIFY(event_type)}; \
|
||||
const struct zmk_event_type *zmk_event_ref_##event_type __used \
|
||||
__attribute__((__section__(".event_type"))) = &zmk_event_##event_type; \
|
||||
struct event_type##_event *new_##event_type(struct event_type data) { \
|
||||
struct event_type##_event *ev = \
|
||||
(struct event_type##_event *)k_malloc(sizeof(struct event_type##_event)); \
|
||||
ev->header.event = &zmk_event_##event_type; \
|
||||
ev->data = data; \
|
||||
return ev; \
|
||||
struct event_type##_event copy_raised_##event_type(const struct event_type *ev) { \
|
||||
struct event_type##_event *outer = CONTAINER_OF(ev, struct event_type##_event, data); \
|
||||
return *outer; \
|
||||
}; \
|
||||
int raise_##event_type(struct event_type data) { \
|
||||
struct event_type##_event ev = {.data = data}; \
|
||||
ev.header.event = &zmk_event_##event_type; \
|
||||
return ZMK_EVENT_RAISE(ev); \
|
||||
}; \
|
||||
struct event_type *as_##event_type(const zmk_event_t *eh) { \
|
||||
return (eh->event == &zmk_event_##event_type) ? &((struct event_type##_event *)eh)->data \
|
||||
@@ -68,17 +71,15 @@ struct zmk_event_subscription {
|
||||
.listener = &zmk_listener_##mod, \
|
||||
};
|
||||
|
||||
#define ZMK_EVENT_RAISE(ev) zmk_event_manager_raise((zmk_event_t *)ev);
|
||||
#define ZMK_EVENT_RAISE(ev) zmk_event_manager_raise((zmk_event_t *)&ev);
|
||||
|
||||
#define ZMK_EVENT_RAISE_AFTER(ev, mod) \
|
||||
zmk_event_manager_raise_after((zmk_event_t *)ev, &zmk_listener_##mod);
|
||||
zmk_event_manager_raise_after((zmk_event_t *)&ev, &zmk_listener_##mod);
|
||||
|
||||
#define ZMK_EVENT_RAISE_AT(ev, mod) \
|
||||
zmk_event_manager_raise_at((zmk_event_t *)ev, &zmk_listener_##mod);
|
||||
zmk_event_manager_raise_at((zmk_event_t *)&ev, &zmk_listener_##mod);
|
||||
|
||||
#define ZMK_EVENT_RELEASE(ev) zmk_event_manager_release((zmk_event_t *)ev);
|
||||
|
||||
#define ZMK_EVENT_FREE(ev) k_free((void *)ev);
|
||||
#define ZMK_EVENT_RELEASE(ev) zmk_event_manager_release((zmk_event_t *)&ev);
|
||||
|
||||
int zmk_event_manager_raise(zmk_event_t *event);
|
||||
int zmk_event_manager_raise_after(zmk_event_t *event, const struct zmk_listener *listener);
|
||||
|
||||
@@ -21,7 +21,7 @@ struct zmk_keycode_state_changed {
|
||||
|
||||
ZMK_EVENT_DECLARE(zmk_keycode_state_changed);
|
||||
|
||||
static inline struct zmk_keycode_state_changed_event *
|
||||
static inline struct zmk_keycode_state_changed
|
||||
zmk_keycode_state_changed_from_encoded(uint32_t encoded, bool pressed, int64_t timestamp) {
|
||||
uint16_t page = ZMK_HID_USAGE_PAGE(encoded);
|
||||
uint16_t id = ZMK_HID_USAGE_ID(encoded);
|
||||
@@ -38,11 +38,10 @@ zmk_keycode_state_changed_from_encoded(uint32_t encoded, bool pressed, int64_t t
|
||||
implicit_modifiers = SELECT_MODS(encoded);
|
||||
}
|
||||
|
||||
return new_zmk_keycode_state_changed(
|
||||
(struct zmk_keycode_state_changed){.usage_page = page,
|
||||
.keycode = id,
|
||||
.implicit_modifiers = implicit_modifiers,
|
||||
.explicit_modifiers = explicit_modifiers,
|
||||
.state = pressed,
|
||||
.timestamp = timestamp});
|
||||
return (struct zmk_keycode_state_changed){.usage_page = page,
|
||||
.keycode = id,
|
||||
.implicit_modifiers = implicit_modifiers,
|
||||
.explicit_modifiers = explicit_modifiers,
|
||||
.state = pressed,
|
||||
.timestamp = timestamp};
|
||||
}
|
||||
|
||||
@@ -17,8 +17,7 @@ struct zmk_layer_state_changed {
|
||||
|
||||
ZMK_EVENT_DECLARE(zmk_layer_state_changed);
|
||||
|
||||
static inline struct zmk_layer_state_changed_event *create_layer_state_changed(uint8_t layer,
|
||||
bool state) {
|
||||
return new_zmk_layer_state_changed((struct zmk_layer_state_changed){
|
||||
static inline int raise_layer_state_changed(uint8_t layer, bool state) {
|
||||
return raise_zmk_layer_state_changed((struct zmk_layer_state_changed){
|
||||
.layer = layer, .state = state, .timestamp = k_uptime_get()});
|
||||
}
|
||||
|
||||
@@ -19,8 +19,8 @@ struct zmk_mouse_button_state_changed {
|
||||
|
||||
ZMK_EVENT_DECLARE(zmk_mouse_button_state_changed);
|
||||
|
||||
static inline struct zmk_mouse_button_state_changed_event *
|
||||
zmk_mouse_button_state_changed_from_encoded(uint32_t encoded, bool pressed, int64_t timestamp) {
|
||||
return new_zmk_mouse_button_state_changed((struct zmk_mouse_button_state_changed){
|
||||
static inline int raise_zmk_mouse_button_state_changed_from_encoded(uint32_t encoded, bool pressed,
|
||||
int64_t timestamp) {
|
||||
return raise_zmk_mouse_button_state_changed((struct zmk_mouse_button_state_changed){
|
||||
.buttons = ZMK_HID_USAGE_ID(encoded), .state = pressed, .timestamp = timestamp});
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user