changeset 513:03a40ac2e931

libgsmhr1: implement validation for *.cod frames
author Mychaela Falconia <falcon@freecalypso.org>
date Sun, 25 Aug 2024 19:00:03 +0000
parents 4f0ab833bec0
children 67b13a6a63c9
files libgsmhr1/Makefile libgsmhr1/paramval_cod.c
diffstat 2 files changed, 22 insertions(+), 2 deletions(-) [+]
line wrap: on
line diff
--- a/libgsmhr1/Makefile	Sun Aug 25 18:42:27 2024 +0000
+++ b/libgsmhr1/Makefile	Sun Aug 25 19:00:03 2024 +0000
@@ -1,6 +1,7 @@
 OBJS=	dhf_packed.o dhf_params.o enc_out_order.o mathdp31.o mathhalf.o \
-	pack_frame.o paramval_common.o rtp_in.o rtp_in_direct.o sid_detect.o \
-	sid_reset.o sp_rom.o twts002_in.o twts002_out.o unpack_frame.o
+	pack_frame.o paramval_cod.o paramval_common.o rtp_in.o rtp_in_direct.o \
+	sid_detect.o sid_reset.o sp_rom.o twts002_in.o twts002_out.o \
+	unpack_frame.o
 HDRS=	enc_out_order.h mathdp31.h mathhalf.h namespace.h sp_rom.h tw_gsmhr.h \
 	typedefs.h
 LIB=	libgsmhr1.a
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/libgsmhr1/paramval_cod.c	Sun Aug 25 19:00:03 2024 +0000
@@ -0,0 +1,19 @@
+/*
+ * The function implemented in this module examines a frame of 20 int16_t words
+ * that corresponds to GSM-HR encoder output format, and checks if the unused
+ * upper bits of each int16_t word are cleared as they should be.
+ * This function should be used when reading from ETSI-format *.cod files,
+ * to guard against reading garbage or wrong endian.
+ */
+
+#include <stdint.h>
+#include "tw_gsmhr.h"
+
+int gsmhr_check_encoder_params(const int16_t *params)
+{
+	if (params[18] & 0xFFFE)
+		return -1;
+	if (params[19] & 0xFFFE)
+		return -1;
+	return gsmhr_check_common_params(params);
+}