view libtwamr/prm2bits.c @ 536:a3300483ae74

doc/FR1-library-API: document return value from gsmfr_tfo_xfrm_*
author Mychaela Falconia <falcon@freecalypso.org>
date Sat, 21 Sep 2024 20:48:58 +0000
parents ffd48f0a2ab5
children
line wrap: on
line source

/*
 * A cleaner reimplementation of AMR Prm2bits() function.
 */

#include "typedef.h"
#include "namespace.h"
#include "bitno.h"
#include "prm2bits.h"

void Prm2bits(enum Mode mode, const Word16 prm[], Word16 bits[])
{
	const Word16 *t = bitno[mode];
	unsigned nparam = prmno[mode];
	unsigned n, p, mask;
	Word16 *b = bits;

	for (n = 0; n < nparam; n++) {
		p = prm[n];
		mask = 1 << (*t++ - 1);
		for (; mask; mask >>= 1) {
			if (p & mask)
				*b++ = 1;
			else
				*b++ = 0;
		}
	}
}