changeset 786:b761029f9c03

simagent: spenh command implemented
author Mychaela Falconia <falcon@freecalypso.org>
date Sat, 13 Mar 2021 22:41:33 +0000
parents 56506e9165bc
children ae237e4e8d9b
files target-utils/simagent/cmdtab.c target-utils/simagent/spenh.c
diffstat 2 files changed, 37 insertions(+), 0 deletions(-) [+]
line wrap: on
line diff
--- a/target-utils/simagent/cmdtab.c	Sat Mar 13 22:17:39 2021 +0000
+++ b/target-utils/simagent/cmdtab.c	Sat Mar 13 22:41:33 2021 +0000
@@ -11,6 +11,7 @@
 extern void cmd_sertimeout();
 extern void cmd_set_spenh();
 extern void cmd_sim_up();
+extern void cmd_spenh();
 extern void cmd_tx();
 extern void cmd_w8();
 extern void cmd_w16();
@@ -37,6 +38,7 @@
 	{"sertimeout", cmd_sertimeout},
 	{"set-spenh", cmd_set_spenh},
 	{"sim-up", cmd_sim_up},
+	{"spenh", cmd_spenh},
 	{"tx", cmd_tx},
 	{"w8", cmd_w8},
 	{"w16", cmd_w16},
--- a/target-utils/simagent/spenh.c	Sat Mar 13 22:17:39 2021 +0000
+++ b/target-utils/simagent/spenh.c	Sat Mar 13 22:41:33 2021 +0000
@@ -3,8 +3,43 @@
 #include "types.h"
 #include "simregs.h"
 
+extern int sim_if_state;
 extern u16 conf1_reg;
 
+const u8 pts_for_spenh[4] = {0xFF, 0x10, 0x94, 0x7B};
+
+void
+cmd_spenh()
+{
+	int rc;
+	unsigned count;
+
+	if (sim_if_state != 2) {
+		printf("ERROR: SIM interface is not up\n");
+		return;
+	}
+	if (conf1_reg & SIM_CONF1_ETU) {
+		printf("ERROR: speed enhancement is already on\n");
+		return;
+	}
+	rc = flush_rx_fifo();
+	if (rc < 0)
+		return;
+	rc = send_to_sim(pts_for_spenh, 4);
+	if (rc < 0)
+		return;
+	for (count = 0; count < 4; count++) {
+		rc = rx_sim_byte_hl();
+		if (rc < 0)
+			return;
+		if (rc != pts_for_spenh[count]) {
+			printf("ERROR: PTS response does not match request\n");
+			return;
+		}
+	}
+	SIMREGS.conf1 = conf1_reg |= SIM_CONF1_ETU;
+}
+
 void
 cmd_set_spenh(argbulk)
 	char *argbulk;