FreeCalypso > hg > freecalypso-tools
view rvinterf/lowlevel/logsent.c @ 906:94890123a74f
tchtools: new program fc-efr2tch
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Wed, 28 Dec 2022 10:05:46 +0000 |
parents | a1065c17429c |
children | 4e243402f453 |
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" extern int no_output, verbose; extern FILE *logF; 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; { if (no_output && !logF) return; switch (pkt[0]) { case RVT_L23_HEADER: log_sent_gpf(pkt, pktlen); return; case RVT_AT_HEADER: log_sent_ati(pkt, pktlen); return; case RVT_TCH_HEADER: if (verbose) goto generic; tch_inc_count_tx(); return; default: generic: log_sent_other(pkt, pktlen); } }