aboutsummaryrefslogtreecommitdiff
path: root/lib/pbdrv/pb-route.c
diff options
context:
space:
mode:
Diffstat (limited to 'lib/pbdrv/pb-route.c')
-rw-r--r--lib/pbdrv/pb-route.c97
1 files changed, 97 insertions, 0 deletions
diff --git a/lib/pbdrv/pb-route.c b/lib/pbdrv/pb-route.c
new file mode 100644
index 0000000..ee47700
--- /dev/null
+++ b/lib/pbdrv/pb-route.c
@@ -0,0 +1,97 @@
+#include "pb-route.h"
+#include "pb-mod.h"
+#include "pb-send.h"
+#include "pb-types.h"
+#include "pb-mem.h"
+
+__weak bool pb_hook_route_msg(pb_msg_t * msg) { return false; }
+__weak void pb_route_msg(pb_msg_t * msg) {
+ if (pb_hook_route_msg(msg)) return;
+
+ switch (msg->type) {
+ case PB_CMD_PROP: return pb_route_cmd_prop(msg);
+ case PB_CMD_STATE: return pb_route_cmd_state(msg);
+ case PB_CMD_MAGIC: return pb_route_cmd_magic(msg);
+ default: return;
+ }
+}
+
+__weak bool pb_hook_route_cmd_prop(pb_msg_t * msg) { return false; }
+__weak void pb_route_cmd_prop(pb_msg_t * msg) {
+ if (pb_hook_route_cmd_prop(msg)) return;
+
+ switch (msg->action) {
+ case PB_ACTION_REQ: return pb_route_cmd_prop_req(msg);
+ case PB_ACTION_RES: return pb_route_cmd_prop_res(msg);
+ case PB_ACTION_SET: return pb_route_cmd_prop_set(msg);
+ default: return;
+ }
+}
+
+__weak bool pb_hook_route_cmd_state(pb_msg_t * msg) { return false; }
+__weak void pb_route_cmd_state(pb_msg_t * msg) {
+ if (pb_hook_route_cmd_state(msg)) return;
+
+ switch (msg->action) {
+ case PB_ACTION_REQ: return pb_route_cmd_state_req(msg);
+ case PB_ACTION_RES: return pb_route_cmd_state_res(msg);
+ case PB_ACTION_SET: return pb_route_cmd_state_set(msg);
+ default: return;
+ }
+}
+
+__weak bool pb_hook_route_cmd_magic(pb_msg_t * msg) { return false; }
+__weak void pb_route_cmd_magic(pb_msg_t * msg) {
+ if (pb_hook_route_cmd_magic(msg)) return;
+
+ switch (msg->action) {
+ case PB_ACTION_REQ: return pb_route_cmd_magic_req(msg);
+ case PB_ACTION_RES: return pb_route_cmd_magic_res(msg);
+ default: return;
+ }
+}
+
+// all properties are user-defined
+__weak void pb_route_cmd_prop_req(pb_msg_t * msg) {}
+__weak void pb_route_cmd_prop_res(pb_msg_t * msg) {}
+__weak void pb_route_cmd_prop_set(pb_msg_t * msg) {}
+
+static pb_global_state_t _main_state = PB_GS_NOINIT;
+__weak void pb_hook_main_state_update(pb_global_state_t state) {}
+__weak void pb_route_cmd_state_req(pb_msg_t * msg) {
+ pb_global_state_t own_state = pb_hook_mod_state_read();
+ pb_buf_t buf = pb_send_state_res(own_state);
+ pb_send_reply(msg, &buf);
+ pb_buf_free(&buf);
+
+ // notify of new global state variable
+ pb_cmd_state_t * cmd = msg->cmd;
+ if (cmd->state != _main_state)
+ pb_hook_main_state_update(cmd->state);
+ _main_state = cmd->state;
+}
+
+__weak void pb_route_cmd_state_res(pb_msg_t * msg) {}
+
+__weak void pb_route_cmd_state_set(pb_msg_t * msg) {
+ pb_cmd_state_t * cmd = msg->cmd;
+ pb_hook_mod_state_write(cmd->state);
+}
+
+__weak void pb_route_cmd_magic_req(pb_msg_t * msg) {
+ pb_cmd_magic_t * cmd = msg->cmd;
+ // return early if magic has wrong size
+ if (cmd->_magic_size != sizeof(pb_cmd_magic_req)) return;
+ // // return early if magic doesn't match
+ if (pb_memcmp(cmd->magic, pb_cmd_magic_req, sizeof(pb_cmd_magic_req)) != 0) return;
+
+ // FIXME: this should be removed (see handover: RP2040 I2C limitations)
+ pb_mod_blocking_delay_ms(2000);
+
+ pb_buf_t buf = pb_send_magic_res();
+ pb_send_reply(msg, &buf);
+ pb_buf_free(&buf);
+}
+
+__weak void pb_route_cmd_magic_res(pb_msg_t * msg) { }
+