add uart support

This commit is contained in:
smayzy 2026-04-26 20:31:43 +02:00
parent 5aa878d289
commit cf82ec5071

View File

@ -11,6 +11,7 @@
#include <sys/socket.h> #include <sys/socket.h>
#include <net/if.h> #include <net/if.h>
#include <fcntl.h> #include <fcntl.h>
#include <termios.h>
const int digit_bitmaps[10][5][3] = { const int digit_bitmaps[10][5][3] = {
{{1,1,1},{1,0,1},{1,0,1},{1,0,1},{1,1,1}}, // 0 {{1,1,1},{1,0,1},{1,0,1},{1,0,1},{1,1,1}}, // 0
@ -60,6 +61,11 @@ typedef struct{
char title[30]; char title[30];
} StStr; } StStr;
typedef struct {
char linebuf[128];
int linepos;
} SerialParser;
typedef struct { typedef struct {
StInt speed; StInt speed;
StInt rpm; StInt rpm;
@ -124,6 +130,31 @@ void read_can(Tel *t, int soc) {
} }
} }
void read_uart(Tel *t, int fd, SerialParser *uart_str) {
char buf[128];
int n = read(fd, buf, sizeof(buf));
if (n > 0) {
for (int i = 0; i < n; i++) {
char c = buf[i];
if (c == '\n') {
uart_str->linebuf[uart_str->linepos] = '\0';
float tmp_v, tmp_a;
if (sscanf(uart_str->linebuf, "%f,%f", &tmp_v, &tmp_a) == 2) {
//t->v = tmp_v;
//t->a = tmp_a;
}
uart_str->linepos = 0;
}
if (uart_str->linepos < (int)sizeof(uart_str->linebuf) - 1) {
uart_str->linebuf[uart_str->linepos++] = c;
} else {
uart_str->linepos = 0; // drop line to prevent overflow
}
}
}
}
long now_ms(void) { long now_ms(void) {
struct timespec ts; struct timespec ts;
clock_gettime(CLOCK_MONOTONIC, &ts); clock_gettime(CLOCK_MONOTONIC, &ts);
@ -361,11 +392,16 @@ int main(int argc, char **argv) {
int fake_data = 0; int fake_data = 0;
int use_can = 0; int use_can = 0;
int soc = 0; int soc = 0;
int use_uart = 0;
int uart_fd = 0;
struct sockaddr_can addr; struct sockaddr_can addr;
struct ifreq ifr; struct ifreq ifr;
struct termios uart_str;
SerialParser uart_parser = {0};
while ((option = getopt(argc, argv, "d:hfc")) !=-1) { while ((option = getopt(argc, argv, "d:hfcu")) !=-1) {
switch (option) { switch (option) {
case 'd' : case 'd' :
delay = atoi(optarg); delay = atoi(optarg);
@ -379,8 +415,11 @@ int main(int argc, char **argv) {
case 'c' : case 'c' :
use_can = 1; use_can = 1;
break; break;
case 'u' :
use_uart = 1;
break;
case 'h' : case 'h' :
printf("Usage: ./cocomobile-tui [-d int <ms multiplier>] [-h <help>] [-f <random data generation>] [-c <enable can>]\n"); printf("Usage: ./cocomobile-tui [-d int <ms multiplier>] [-h <help>] [-f <random data generation>] [-c <enable can>] [-u <enable uart connection>]\n");
return(0); return(0);
} }
} }
@ -407,6 +446,25 @@ int main(int argc, char **argv) {
} }
} }
if (use_uart) {
uart_fd = open("/dev/ttyACM0", O_RDWR | O_NOCTTY | O_NONBLOCK);
if (uart_fd < 0) {
perror("uart open error");
return 1;
}
tcgetattr(uart_fd, &uart_str);
uart_str.c_cflag &= ~CSIZE; // clear bit size
uart_str.c_cflag |= (CLOCAL | CREAD | CS8 | B115200);
uart_str.c_lflag = 0; // raw mode
uart_str.c_iflag = 0;
uart_str.c_oflag = 0;
tcsetattr(uart_fd, TCSAFLUSH, &uart_str); // aplly settings
}
initscr(); initscr();
noecho(); noecho();
cbreak(); cbreak();
@ -481,6 +539,7 @@ int main(int argc, char **argv) {
get_fake_data(&tel); get_fake_data(&tel);
} else { } else {
if (use_can) read_can(&tel, soc); if (use_can) read_can(&tel, soc);
if (use_uart) read_uart(&tel, uart_fd, &uart_parser);
} }
break; break;
} }