view libgsmfr2/tfo_dtxd.c @ 604:54f0f1b74c25

libgsmhr1 TFO: require BFI=0 and SID=0 for homing In order for a received frame to be recognized as DHF, we need not only the correct bit pattern, but also BFI=0 and SID=0. The BFI=0 requirement should be obvious, while the SID=0 requirement is needed only for HR codec. With FR and EFR, SID classification comes from the payload bits and no separate check is needed - but in HR we get an out-of-band SID ternary flag. When SID=1, no payload bits are used at all; when SID=2, we use only the first 33 bits of the payload. Therefore, it is proper to conditionalize DHF acceptance on SID=0. We already implemented this logic in the just finished full decoder; now bring TFO code into agreement.
author Mychaela Falconia <falcon@freecalypso.org>
date Thu, 04 Dec 2025 19:40:35 +0000
parents 5a3535470c95
children
line wrap: on
line source

/*
 * The function implemented in this module is a post-processor to be invoked
 * after Rx DTX preproc functions if the Rx DTX handler block is used as a
 * TFO transform with DTXd enabled.  It selectively transforms certain
 * preproc output frames (CN and silence frames specifically) into SID,
 * thereby allowing the network operator to reap the benefits of DTX on
 * the radio downlink leg.
 */

#include <stdint.h>
#include "tw_gsmfr.h"
#include "pp_state.h"

int gsmfr_tfo_xfrm_dtxd(struct gsmfr_preproc_state *st, uint8_t *frame)
{
	uint8_t *p, sub;

	if (!st->dtxd_sid_flag)
		return 1;	/* SP=1: output is a speech frame */
	/* turn the output frame into SID */
	p = frame + 5;		/* skip magic+LARc */
	for (sub = 0; sub < 4; sub++) {
		*p++ = 0;
		*p++ &= 0x1F;	/* upper 5 bits of Xmaxc field */
		*p++ &= 0x80;	/* and the lsb spilling into the next byte */
		*p++ = 0;
		*p++ = 0;
		*p++ = 0;
		*p++ = 0;
	}
	return 0;		/* SP=0: output is SID */
}