view uptools/libcoding/gsm7_unpack.c @ 855:ea458ee48691

rvinterf/l1filter: new program written, compiles
author Mychaela Falconia <falcon@freecalypso.org>
date Tue, 09 Nov 2021 23:14:22 +0000
parents d29b45c4c8db
children
line wrap: on
line source

/*
 * This library module implements unpacking of GSM 7-bit data
 * from packed octets.
 */

#include <sys/types.h>

static u_char shift[8] = {0, 7, 6, 5, 4, 3, 2, 1};

gsm7_unpack(inbuf, outbuf, nseptets)
	u_char *inbuf, *outbuf;
	unsigned nseptets;
{
	u_char *inp = inbuf, *outp = outbuf;
	unsigned n;

	for (n = 0; n < nseptets; n++) {
		*outp++ = (((inp[1] << 8) | inp[0]) >> shift[n&7]) & 0x7F;
		if (n & 7)
			inp++;
	}
}