From 3d12ab33e320bf46f5b3004e4308cbb8987fdbf4 Mon Sep 17 00:00:00 2001 From: XANTRONIX Development Date: Sat, 1 Aug 2020 17:13:02 -0400 Subject: [PATCH] Implement replies to TEST frames --- src/server.c | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/src/server.c b/src/server.c index 5adbb5a..42661f9 100644 --- a/src/server.c +++ b/src/server.c @@ -1140,6 +1140,18 @@ static int reply_ua(patty_ax25_if *iface, return reply_to(iface, frame, &reply); } +static int reply_test(patty_ax25_if *iface, + patty_ax25_frame *frame) { + patty_ax25_frame reply = { + .control = PATTY_AX25_FRAME_UA | (PATTY_AX25_FRAME_FINAL << 4), + .proto = PATTY_AX25_PROTO_NONE, + .info = frame->info, + .infolen = frame->infolen + }; + + return reply_to(iface, frame, &reply); +} + static int handle_frmr(patty_ax25_server *server, patty_ax25_if *iface, patty_ax25_sock *sock, @@ -1227,6 +1239,12 @@ error_client_by_sock: return -1; } +static int handle_test(patty_ax25_server *server, + patty_ax25_if *iface, + patty_ax25_frame *frame) { + return reply_test(iface, frame); +} + static int handle_ua(patty_ax25_server *server, patty_ax25_if *iface, patty_ax25_sock *sock, @@ -1586,6 +1604,7 @@ static int handle_frame(patty_ax25_server *server, case PATTY_AX25_FRAME_XID: return handle_xid(server, iface, &frame, buf, offset, len); case PATTY_AX25_FRAME_SABM: case PATTY_AX25_FRAME_SABME: return handle_sabm(server, iface, &frame); + case PATTY_AX25_FRAME_TEST: return handle_test(server, iface, &frame); case PATTY_AX25_FRAME_UA: return handle_ua(server, iface, sock, &frame); case PATTY_AX25_FRAME_DM: return handle_dm(server, iface, sock, &frame); case PATTY_AX25_FRAME_DISC: return handle_disc(server, iface, sock, &frame);