aboutsummaryrefslogtreecommitdiff
path: root/robot
diff options
context:
space:
mode:
authorlonkaars <loek@pipeframe.xyz>2022-05-25 23:36:43 +0200
committerlonkaars <loek@pipeframe.xyz>2022-05-25 23:36:43 +0200
commite63abbdff3408c17b45c9032e7f7ba0199b43bd0 (patch)
tree382cd392991179dc1e5e045494269334593ba5c9 /robot
parent4ebf24f2c973693d1a05d6cfc7094d46d71b67ae (diff)
struct packing and dynamic size calculation
Diffstat (limited to 'robot')
-rw-r--r--robot/sercomm.c42
-rw-r--r--robot/sim.c29
-rw-r--r--robot/tests/mcfg.binbin0 -> 11 bytes
3 files changed, 26 insertions, 45 deletions
diff --git a/robot/sercomm.c b/robot/sercomm.c
index 9e40b0e..293e3c6 100644
--- a/robot/sercomm.c
+++ b/robot/sercomm.c
@@ -47,8 +47,8 @@ void w2_sercomm_append_msg(w2_s_bin *data) {
g_w2_sercomm_index = next_index;
}
-void w2_scmd_ping_rx(w2_s_bin *data) {
- w2_s_cmd_ping_rx *message = malloc(w2_scmd_length(data->data, data->bytes));
+void w2_cmd_ping_rx(w2_s_bin *data) {
+ w2_s_cmd_ping_rx *message = malloc(w2_cmd_sizeof(data->data, data->bytes));
memcpy(message, data->data, data->bytes);
size_t return_size = sizeof(w2_s_cmd_ping_tx);
@@ -65,34 +65,34 @@ void w2_scmd_ping_rx(w2_s_bin *data) {
free(return_message_bin);
}
-void w2_scmd_mode_rx(w2_s_bin *data) { return; }
+void w2_cmd_mode_rx(w2_s_bin *data) { return; }
-void w2_scmd_sped_rx(w2_s_bin *data) { return; }
+void w2_cmd_sped_rx(w2_s_bin *data) { return; }
-void w2_scmd_dirc_rx(w2_s_bin *data) { return; }
+void w2_cmd_dirc_rx(w2_s_bin *data) { return; }
-void w2_scmd_cord_rx(w2_s_bin *data) { return; }
+void w2_cmd_cord_rx(w2_s_bin *data) { return; }
-void w2_scmd_bomd_rx(w2_s_bin *data) { return; }
+void w2_cmd_bomd_rx(w2_s_bin *data) { return; }
-void w2_scmd_sres_rx(w2_s_bin *data) { return; }
+void w2_cmd_sres_rx(w2_s_bin *data) { return; }
-void w2_scmd_mcfg_rx(w2_s_bin *data) { return; }
+void w2_cmd_mcfg_rx(w2_s_bin *data) { return; }
-void w2_scmd_sens_rx(w2_s_bin *data) { return; }
+void w2_cmd_sens_rx(w2_s_bin *data) { return; }
-void w2_scmd_info_rx(w2_s_bin *data) { return; }
+void w2_cmd_info_rx(w2_s_bin *data) { return; }
-void w2_scmd_disp_rx(w2_s_bin *data) { return; }
+void w2_cmd_disp_rx(w2_s_bin *data) { return; }
-void w2_scmd_play_rx(w2_s_bin *data) { return; }
+void w2_cmd_play_rx(w2_s_bin *data) { return; }
-void w2_scmd_cled_rx(w2_s_bin *data) { return; }
+void w2_cmd_cled_rx(w2_s_bin *data) { return; }
-void w2_scmd_ping_tx(w2_s_bin *data) {}
-void w2_scmd_expt_tx(w2_s_bin *data) {}
-void w2_scmd_mode_tx(w2_s_bin *data) {}
-void w2_scmd_cord_tx(w2_s_bin *data) {}
-void w2_scmd_bomd_tx(w2_s_bin *data) {}
-void w2_scmd_sens_tx(w2_s_bin *data) {}
-void w2_scmd_info_tx(w2_s_bin *data) {}
+void w2_cmd_ping_tx(w2_s_bin *data) {}
+void w2_cmd_expt_tx(w2_s_bin *data) {}
+void w2_cmd_mode_tx(w2_s_bin *data) {}
+void w2_cmd_cord_tx(w2_s_bin *data) {}
+void w2_cmd_bomd_tx(w2_s_bin *data) {}
+void w2_cmd_sens_tx(w2_s_bin *data) {}
+void w2_cmd_info_tx(w2_s_bin *data) {}
diff --git a/robot/sim.c b/robot/sim.c
index 57e0ef5..0cde6a0 100644
--- a/robot/sim.c
+++ b/robot/sim.c
@@ -38,7 +38,6 @@ static const char* const W2_CMD_DIRECTIONS[] = {
void time_reset() {
simprintfunc("time_reset", "");
clock_gettime(CLOCK_MONOTONIC, &reference_time);
- return;
}
unsigned long get_ms() {
@@ -51,27 +50,22 @@ unsigned long get_ms() {
void red_led(unsigned char on) {
simprintfunc("red_led", "%i", on);
- return;
}
void green_led(unsigned char on) {
simprintfunc("green_led", "%i", on);
- return;
}
void clear() {
simprintfunc("clear", "");
- return;
}
void play(const char* melody) {
simprintfunc("play", "\"%s\"", melody);
- return;
}
void serial_set_baud_rate(unsigned int rate) {
simprintfunc("serial_set_baud_rate", "%u", rate);
- return;
}
void serial_send(char* message, unsigned int length) {
@@ -81,25 +75,16 @@ void serial_send(char* message, unsigned int length) {
return;
}
if (!DBG_ENABLE_PRINTFUNC) return;
+
simprintfunc("serial_send", "<see below>, %u", length);
- unsigned int bytes = 0;
- simprintf("");
- for (unsigned int byte = 0; byte < length; byte++) {
- if (bytes > DBG_BYTES_PER_LINE) {
- bytes = 0;
- printf("\n");
- simprintf("");
- }
- printf("%02x ", message[byte] & 0xff);
- bytes++;
- }
- printf("\n");
- return;
+
+ w2_s_bin *bin = w2_bin_s_alloc(length, (uint8_t*) message);
+ w2_sim_print_serial(bin);
+ free(bin);
}
void serial_receive_ring(char* buffer, unsigned char size) {
simprintfunc("serial_receive_ring", "0x%016lx, %u", (unsigned long) buffer, size);
- return;
}
unsigned char serial_get_received_bytes() {
@@ -118,16 +103,12 @@ void w2_sim_setup(int argc, char **argv) {
term.c_cc[VTIME] = 0;
term.c_cc[VMIN] = 0;
tcsetattr(STDIN_FILENO, 0, &term);
-
- return;
}
void w2_sim_cycle_begin() {
// read bytes from stdin
while(read(STDIN_FILENO, (g_w2_serial_buffer + sizeof(char) * g_w2_serial_buffer_head), 1) > 0)
g_w2_serial_buffer_head = (g_w2_serial_buffer_head + 1) % W2_SERIAL_READ_BUFFER_SIZE;
-
- return;
}
void w2_sim_print_serial(w2_s_bin *data) {
diff --git a/robot/tests/mcfg.bin b/robot/tests/mcfg.bin
new file mode 100644
index 0000000..a43ecf8
--- /dev/null
+++ b/robot/tests/mcfg.bin
Binary files differ