FreeCalypso > hg > freecalypso-sw
view rvinterf/lowlevel/logsent.c @ 1008:5f919af515f1
rvinterf: beginning of support for new TCH and KEEPALIVE RVTMUX channels
author | Mychaela Falconia <falcon@ivan.Harhan.ORG> |
---|---|
date | Sun, 20 Mar 2016 19:59:19 +0000 |
parents | da9a36515da6 |
children |
line wrap: on
line source
/* * This module implements the logging of sent packets */ #include <sys/types.h> #include <stdio.h> #include <string.h> #include <strings.h> #include "../include/pktmux.h" #include "../include/limits.h" static void log_sent_ati(pkt, pktlen) u_char *pkt; { char buf[MAX_PKT_TO_TARGET*4+10]; int i, c; char *dp; strcpy(buf, "Sent to ATI: "); dp = buf + 13; for (i = 1; i < pktlen; i++) { c = pkt[i]; if (c & 0x80) { *dp++ = 'M'; *dp++ = '-'; c &= 0x7F; } if (c < 0x20) { *dp++ = '^'; *dp++ = c + '@'; } else if (c == 0x7F) { *dp++ = '^'; *dp++ = '?'; } else *dp++ = c; } *dp = '\0'; output_line(buf); } static void log_sent_gpf(pkt, pktlen) u_char *pkt; { char buf[MAX_PKT_TO_TARGET*4+30]; strcpy(buf, "Sent "); format_g23_packet(pkt, pktlen, buf + 5); output_line(buf); } static void log_sent_other(pkt, pktlen) u_char *pkt; { char buf[MAX_PKT_TO_TARGET*3+5]; int i; char *dp; dp = buf; strcpy(dp, "Sent"); dp += 4; for (i = 0; i < pktlen; i++) { sprintf(dp, " %02X", pkt[i]); dp += 3; } *dp = '\0'; output_line(buf); } log_sent_packet(pkt, pktlen) u_char *pkt; { switch (pkt[0]) { case RVT_L23_HEADER: log_sent_gpf(pkt, pktlen); return; case RVT_AT_HEADER: log_sent_ati(pkt, pktlen); return; default: log_sent_other(pkt, pktlen); } }