FreeCalypso > hg > freecalypso-tools
view rvinterf/lowlevel/logsent.c @ 752:c79aaed75bd8
compile-fc-batt: allow possible third field in source lines
Battery tables maintained in the fc-battery-conf repository will now
have a third field added, defining thresholds for the battery bars icon,
and there will be a new utility to compile them into the new
/etc/batterytab2 file read by the FC Tourmaline version of our
FCHG driver. For backward compatibility with the original Magnetite
version of FCHG, compile-fc-batt remains the tool for compiling the
original /etc/batterytab file format, and it needs to ignore the
newly added third field in battery table sources.
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Thu, 05 Nov 2020 20:37:55 +0000 |
parents | e7502631a0f9 |
children | a1065c17429c |
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); } }