#include #include #include #include #include #include #include static void usage(int argc, char **argv, const char *message, ...) { if (message) { va_list args; va_start(args, message); vfprintf(stderr, message, args); fprintf(stderr, "\n"); va_end(args); } fprintf(stderr, "usage: %s kiss.cap\n", argv[0]); exit(1); } static int callsign_fprint(FILE *stream, const patty_ax25_address *address) { fprintf(stream, "%s", address->callsign); if (address->ssid) { fprintf(stream, "/%d", address->ssid); } return 0; } #define printable(c) \ (c >= 0x20 && c < 0x7f) static int hexdump_fprint(FILE *stream, void *data, size_t len) { size_t i; for (i=0; isrc); fprintf(stream, " > "); for (i=0; ihops; i++) { callsign_fprint(stream, &frame->repeaters[i]); fprintf(stream, " > "); } callsign_fprint(stream, &frame->dest); return 0; } static int frame_fprint(FILE *stream, const patty_ax25_frame *frame, void *data, size_t len) { if (address_fprint(stream, frame) < 0) { goto error_io; } if (frame->type == PATTY_AX25_FRAME_INFO) { if (fprintf(stream, " poll %d ns %d nr %d", PATTY_AX25_CONTROL_POLL(frame->control), PATTY_AX25_CONTROL_SEQ_SEND(frame->control), PATTY_AX25_CONTROL_SEQ_RECV(frame->control)) < 0) { goto error_io; } } if (fprintf(stream, " proto %02x %ld bytes\n", frame->proto, len) < 0) { goto error_io; } if (hexdump_fprint(stream, data, len) < 0) { goto error_io; } return 0; error_io: return -1; } int main(int argc, char **argv) { patty_kiss_tnc *tnc; ssize_t len; void *data; int port; if (argc != 2) { usage(argc, argv, "No TNC device provided"); } if ((tnc = patty_kiss_tnc_open(argv[1], 330)) == NULL) { perror("Unable to open TNC"); goto error_kiss_tnc_open; } while ((len = patty_kiss_tnc_recv(tnc, &data, &port)) > 0) { patty_ax25_frame frame; if (patty_ax25_frame_decode(&frame, data, len) < 0) { perror("Unable to decode frame"); goto error_ax25_frame_decode; } if (frame_fprint(stderr, &frame, data, len) < 0) { perror("Unable to print frame"); goto error_frame_fprint; } } patty_kiss_tnc_close(tnc); return 0; error_frame_fprint: error_ax25_frame_decode: patty_kiss_tnc_close(tnc); error_kiss_tnc_open: return 127; }