FreeCalypso > hg > freecalypso-tools
diff rvinterf/asyncshell/sendsp.c @ 0:e7502631a0f9
initial import from freecalypso-sw rev 1033:5ab737ac3ad7
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Sat, 11 Jun 2016 00:13:35 +0000 |
parents | |
children | d43d82cbfb85 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/rvinterf/asyncshell/sendsp.c Sat Jun 11 00:13:35 2016 +0000 @@ -0,0 +1,82 @@ +/* + * Functions for sending GPF system primitives to the target + */ + +#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_gpf_sysprim(stackdest, primstr) + char *stackdest, *primstr; +{ + unsigned intlen; + u_char sendpkt[MAX_PKT_TO_TARGET+1]; + unsigned pktlen; + + if (strlen(stackdest) > 4) { + printf( + "error: stack destination arg may not exceed 4 characters\n"); + return(1); + } + intlen = 12 + strlen(primstr); + pktlen = intlen + 4; + if (pktlen > MAX_PKT_TO_TARGET) { + printf("error: max pkt to target limit exceeded\n"); + return(1); + } + /* fill out the packet */ + sendpkt[0] = RVT_L23_HEADER; + sendpkt[1] = 0xB7; /* system prim */ + sendpkt[2] = intlen; + sendpkt[3] = intlen >> 8; + /* send zeros for the timestamp */ + sendpkt[4] = 0; + sendpkt[5] = 0; + sendpkt[6] = 0; + sendpkt[7] = 0; + /* as far as TI's sw is concerned, we are PCO */ + sendpkt[8] = 'P'; + sendpkt[9] = 'C'; + sendpkt[10] = 'O'; + sendpkt[11] = ' '; + sprintf(sendpkt + 12, "%-4s%s", stackdest, primstr); + /* send it! */ + send_pkt_to_target(sendpkt, pktlen); + return(0); +} + +void +cmd_sp_interactive(args) + char *args; +{ + char *cp, *np; + + for (cp = args; isspace(*cp); cp++) + ; + if (!*cp) { +err: printf("error: two arguments required\n"); + return; + } + for (np = cp; *cp && !isspace(*cp); cp++) + ; + if (!*cp) + goto err; + *cp++ = '\0'; + while (isspace(*cp)) + cp++; + if (!*cp) + goto err; + gpf_rx_control(1); + send_gpf_sysprim(np, cp); +} + +cmd_sp_oneshot(argc, argv) + char **argv; +{ + return send_gpf_sysprim(argv[1], argv[2]); +}