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)