changeset 817:9706832b740b

fc-tmsh: ETM_BSIM response handling implemented
author Mychaela Falconia <falcon@freecalypso.org>
date Sat, 15 May 2021 01:00:52 +0000
parents b3724fe6c581
children cf30ebf626bb
files rvinterf/tmsh/Makefile rvinterf/tmsh/bsimresp.c rvinterf/tmsh/etmbasic.c
diffstat 3 files changed, 88 insertions(+), 3 deletions(-) [+]
line wrap: on
line diff
--- a/rvinterf/tmsh/Makefile	Fri May 14 17:16:43 2021 +0000
+++ b/rvinterf/tmsh/Makefile	Sat May 15 01:00:52 2021 +0000
@@ -2,9 +2,9 @@
 CFLAGS=	-O2
 CPPFLAGS=-I../include
 PROG=	fc-tmsh
-OBJS=	abb.o abbtm3.o audiocmd.o audioresp.o bsimcmd.o etmbasic.o ffs2.o \
-	ffs2resp.o init.o l1cmd.o l1resp.o main.o misc.o omr.o omw.o oneshot.o \
-	pktsort.o rftablechk.o saverftab.o tmcore.o usercmd.o
+OBJS=	abb.o abbtm3.o audiocmd.o audioresp.o bsimcmd.o bsimresp.o etmbasic.o \
+	ffs2.o ffs2resp.o init.o l1cmd.o l1resp.o main.o misc.o omr.o omw.o \
+	oneshot.o pktsort.o rftablechk.o saverftab.o tmcore.o usercmd.o
 LIBS=	../libasync/libasync.a ../libinterf/libinterf.a \
 	../../librftab/librftab.a
 
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/rvinterf/tmsh/bsimresp.c	Sat May 15 01:00:52 2021 +0000
@@ -0,0 +1,80 @@
+/*
+ * Handling of ETM_BSIM responses (FreeCalypso addition to fw)
+ */
+
+#include <sys/types.h>
+#include <stdio.h>
+#include "bsim_etm_cmd.h"
+
+extern u_char rvi_msg[];
+extern int rvi_msg_len;
+
+static char *cmd_names[] = {
+	"query", "disch", "start", "ci2cv", "complete", "ichg", "start-enable"
+};
+
+static void
+handle_bsim_error()
+{
+	char *errstr;
+	char msg[80];
+
+	if (rvi_msg_len != 6) {
+		print_etm_pkt_raw("ETM_BSIM long error packet");
+		return;
+	}
+	switch (rvi_msg[3]) {
+	case BSIM_ERR_BAD_CMD:
+		errstr = "bad command opcode";
+		break;
+	case BSIM_ERR_WRONG_STATE:
+		errstr = "wrong state";
+		break;
+	case BSIM_ERR_INV_PERCENT:
+		errstr = "invalid percent";
+		break;
+	case BSIM_ERR_INV_DISCHARGE:
+		errstr = "invalid discharge";
+		break;
+	default:
+		errstr = "unknown";
+	}
+	sprintf(msg, "bsim %s error 0x%02X (%s)", cmd_names[rvi_msg[4]],
+		rvi_msg[3], errstr);
+	async_msg_output(msg);
+}
+
+void
+handle_bsim_response()
+{
+	char msg[80];
+
+	if (rvi_msg_len == 5 && rvi_msg[3] == 0x3C) {
+		async_msg_output("bsim: ETM_NOSYS response");
+		return;
+	}
+	if (rvi_msg_len < 6) {
+		print_etm_pkt_raw("ETM_BSIM response too short");
+		return;
+	}
+	if (rvi_msg[4] > BSIM_CMD_START_ENABLE) {
+		print_etm_pkt_raw("ETM_BSIM unknown opcode");
+		return;
+	}
+	if (rvi_msg[3]) {
+		handle_bsim_error();
+		return;
+	}
+	if (rvi_msg_len == 6) {
+		sprintf(msg, "bsim %s OK", cmd_names[rvi_msg[4]]);
+		async_msg_output(msg);
+		return;
+	}
+	if (rvi_msg[4] == BSIM_CMD_QUERY && rvi_msg_len == 9) {
+		sprintf(msg, "bsim: state=%u percent=%u start_enable=%u",
+			rvi_msg[5], rvi_msg[6], rvi_msg[7]);
+		async_msg_output(msg);
+		return;
+	}
+	print_etm_pkt_raw("ETM_BSIM response wrong length");
+}
--- a/rvinterf/tmsh/etmbasic.c	Fri May 14 17:16:43 2021 +0000
+++ b/rvinterf/tmsh/etmbasic.c	Sat May 15 01:00:52 2021 +0000
@@ -67,6 +67,11 @@
 			goto runt;
 		etm_audio_msg_rx();
 		return;
+	case ETM_BSIM:
+		if (rvi_msg_len < 5)
+			goto runt;
+		handle_bsim_response();
+		return;
 	/* TM3 */
 	case MEM_READ:
 		if (rvi_msg_len < 5)