aboutsummaryrefslogtreecommitdiff
path: root/robot/sim.c
diff options
context:
space:
mode:
authorlonkaars <loek@pipeframe.xyz>2022-05-24 21:04:12 +0200
committerlonkaars <loek@pipeframe.xyz>2022-05-24 21:04:12 +0200
commit7e3ece64cd5138081263413461dc6856a668bfae (patch)
treebb380a2023b3fc3abd4e6255e262ee9931731597 /robot/sim.c
parent92c394b44cc846ba044c2862b4f08eadc2160805 (diff)
sim reading serial in from stdin working
Diffstat (limited to 'robot/sim.c')
-rw-r--r--robot/sim.c30
1 files changed, 29 insertions, 1 deletions
diff --git a/robot/sim.c b/robot/sim.c
index 554b174..47c0c78 100644
--- a/robot/sim.c
+++ b/robot/sim.c
@@ -2,10 +2,15 @@
#include <time.h>
#include <string.h>
#include <stdint.h>
+#include <termios.h>
+#include <unistd.h>
#include "sim.h"
+#include "consts.h"
+#include "sercomm.h"
struct timespec reference_time; // NOLINT
+bool g_w2_sim_headless = false;
void time_reset() {
simprintfunc("time_reset", "");
@@ -70,6 +75,29 @@ void serial_receive_ring(char* buffer, unsigned char size) {
unsigned char serial_get_received_bytes() {
simprintfunc("serial_get_received_bytes", "");
- return 0;
+ return g_w2_serial_buffer_head;
+}
+
+void w2_sim_setup(int argc, char **argv) {
+ if (argc > 1 && strcmp(argv[1], "headless") == 0)
+ g_w2_sim_headless = true;
+
+ // disable echo and enable raw mode
+ struct termios term;
+ tcgetattr(STDIN_FILENO, &term);
+ term.c_lflag &= ~(ECHO | ICANON);
+ 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;
}