changeset 382:4307b57229d3

miscprog: tone-convert written, compiles
author Mychaela Falconia <falcon@freecalypso.org>
date Wed, 10 Nov 2021 00:04:12 +0000
parents ca75ac283888
children 97a294f69426
files .hgignore miscprog/Makefile miscprog/tone-convert.c
diffstat 3 files changed, 51 insertions(+), 1 deletions(-) [+]
line wrap: on
line diff
--- a/.hgignore	Tue Nov 09 18:49:09 2021 +0000
+++ b/.hgignore	Wed Nov 10 00:04:12 2021 +0000
@@ -55,6 +55,7 @@
 ^miscprog/pircksum2$
 ^miscprog/pirimei$
 ^miscprog/rfcap-grep$
+^miscprog/tone-convert$
 
 ^mot931c/emu$
 ^mot931c/ptydump$
--- a/miscprog/Makefile	Tue Nov 09 18:49:09 2021 +0000
+++ b/miscprog/Makefile	Wed Nov 10 00:04:12 2021 +0000
@@ -4,7 +4,8 @@
 	memwrite-grep mokosrec2bin osmo2psi pirbattextr pircalextr pircksum \
 	pircksum2 rfcap-grep
 CRYPTO=	imeibrute pirimei
-PROGS=	${STD} ${CRYPTO}
+MATH=	tone-convert
+PROGS=	${STD} ${CRYPTO} ${MATH}
 
 all:	${PROGS}
 
@@ -14,6 +15,9 @@
 ${CRYPTO}:
 	${CC} ${CFLAGS} -o $@ $@.c -lcrypto
 
+${MATH}:
+	${CC} ${CFLAGS} -o $@ $@.c -lm
+
 atsc:		atsc.c
 calextract:	calextract.c
 cinitdump:	cinitdump.c
@@ -31,6 +35,7 @@
 pircksum2:	pircksum2.c
 pirimei:	pirimei.c
 rfcap-grep:	rfcap-grep.c
+tone-convert:	tone-convert.c
 
 clean:
 	rm -f ${PROGS} *.o *errs *.out
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/miscprog/tone-convert.c	Wed Nov 10 00:04:12 2021 +0000
@@ -0,0 +1,44 @@
+/*
+ * This command line utility converts a Calypso DSP tone specification from
+ * frequency in Hz and amplitude in dBfs into the 16-bit tone control word
+ * that would go into the DSP for the keybeep or tones audio task.
+ *
+ * The conversion is done in exactly the same way how RiViera Audio Service
+ * does it, allowing the possibility of reconstructing Audio Service API
+ * input values from DSP tone control words captured in L1 traces.
+ */
+
+#include <math.h>
+#include <stdio.h>
+#include <stdlib.h>
+
+main(argc, argv)
+	char **argv;
+{
+	int freq_hz, ampl_dbfs;
+	double frequency_index, frequency_beep;
+	double amplitude_beep, amplitude, amplitude_index;
+	unsigned output;
+
+	if (argc != 3) {
+		fprintf(stderr, "usage: %s freq ampl\n", argv[0]);
+		exit(1);
+	}
+	freq_hz = atoi(argv[1]);
+	ampl_dbfs = atoi(argv[2]);
+
+	/* code from RiViera Audio Service */
+	/* frequency computation */
+	frequency_beep = (double) freq_hz;
+	frequency_index = (256 * cos(6.283185*(frequency_beep/8000)));
+	/* amplitude computation */
+	amplitude_beep = (double) ampl_dbfs;
+	amplitude      = exp((amplitude_beep*0.115129)+(5.544625));
+	amplitude_index = amplitude * sin(6.283185*(frequency_beep/8000));
+	/* output word */
+	output = (unsigned)((((unsigned)(frequency_index))<<8) |
+			    ((unsigned)(amplitude_index)));
+
+	printf("0x%04X\n", output);
+	exit(0);
+}