FreeCalypso > hg > freecalypso-sw
changeset 879:4661b84260a0
fc-shell: AT-over-RVTMUX command sending implemented
| author | Space Falcon <falcon@ivan.Harhan.ORG> | 
|---|---|
| date | Mon, 01 Jun 2015 00:19:28 +0000 | 
| parents | 89c70b89dca5 | 
| children | 136fa1ccd591 | 
| files | rvinterf/asyncshell/Makefile rvinterf/asyncshell/at.c rvinterf/asyncshell/pktsort.c rvinterf/asyncshell/usercmd.c | 
| diffstat | 4 files changed, 53 insertions(+), 2 deletions(-) [+] | 
line wrap: on
 line diff
--- a/rvinterf/asyncshell/Makefile Sun May 31 08:02:36 2015 +0000 +++ b/rvinterf/asyncshell/Makefile Mon Jun 01 00:19:28 2015 +0000 @@ -1,7 +1,7 @@ CC= gcc CFLAGS= -O2 -I../include PROG= fc-shell -OBJS= init.o main.o pktsort.o rxctl.o sendsp.o usercmd.o +OBJS= at.o init.o main.o pktsort.o rxctl.o sendsp.o usercmd.o LIBS= ../libasync/libasync.a ../libg23/libg23.a INSTBIN=/usr/local/bin
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/rvinterf/asyncshell/at.c Mon Jun 01 00:19:28 2015 +0000 @@ -0,0 +1,45 @@ +/* + * Functions for the AT-over-RVTMUX interface + */ + +#include <sys/types.h> +#include <stdio.h> +#include <ctype.h> +#include <string.h> +#include <strings.h> +#include <stdlib.h> +#include "pktmux.h" +#include "limits.h" + +send_string_to_ati(str) + char *str; +{ + unsigned len; + u_char sendpkt[MAX_PKT_TO_TARGET+1]; + + len = strlen(str); + if (len + 1 > MAX_PKT_TO_TARGET) { + printf("error: max pkt to target limit exceeded\n"); + return(1); + } + /* fill out the packet */ + sendpkt[0] = RVT_AT_HEADER; + strcpy(sendpkt + 1, str); + /* send it! */ + send_pkt_to_target(sendpkt, len + 1); + return(0); +} + +void +cmd_sendat(arg) + char *arg; +{ + while (isspace(*arg)) + arg++; + if (!*arg) { + printf("error: missing string argument\n"); + return; + } + ati_rx_control(1); + send_string_to_ati(arg); +}
--- a/rvinterf/asyncshell/pktsort.c Sun May 31 08:02:36 2015 +0000 +++ b/rvinterf/asyncshell/pktsort.c Mon Jun 01 00:19:28 2015 +0000 @@ -54,7 +54,7 @@ char buf[MAX_PKT_FROM_TARGET*4+2]; strcpy(buf, "ATI: "); - safe_print_trace(rvi_msg + 2, rvi_msg_len - 2, buf); + safe_print_trace(rvi_msg + 2, rvi_msg_len - 2, buf + 5); async_msg_output(buf); }
--- a/rvinterf/asyncshell/usercmd.c Sun May 31 08:02:36 2015 +0000 +++ b/rvinterf/asyncshell/usercmd.c Mon Jun 01 00:19:28 2015 +0000 @@ -13,6 +13,7 @@ extern void cmd_disable(); extern void cmd_enable(); +extern void cmd_sendat(); extern void cmd_sendsp(); void @@ -31,6 +32,7 @@ {"exit", cmd_exit}, {"quit", cmd_exit}, {"sp", cmd_sendsp}, + {"str", cmd_sendat}, {0, 0} }; @@ -44,6 +46,10 @@ ; if (!*cp || *cp == '#') return; + if (!strncmp(cp, "AT", 2) || !strncmp(cp, "at", 2)) { + cmd_sendat(cp); + return; + } for (np = cp; *cp && !isspace(*cp); cp++) ; if (*cp)
