FreeCalypso > hg > freecalypso-tools
diff uptools/libcoding/gsm7_pack.c @ 357:15120d15cab5
uptools/libcoding: septet to octet packing function implemented
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Wed, 07 Feb 2018 06:50:14 +0000 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/uptools/libcoding/gsm7_pack.c Wed Feb 07 06:50:14 2018 +0000 @@ -0,0 +1,22 @@ +/* + * This library module implements the function for packing septets into octets. + */ + +#include <sys/types.h> + +gsm7_pack(inbuf, outbuf, noctets) + u_char *inbuf, *outbuf; + unsigned noctets; +{ + u_char *ip = inbuf, *op = outbuf; + unsigned n, c; + + for (n = 0; n < noctets; n++) { + c = n % 7; + *op++ = ((ip[1] << 7) | ip[0]) >> c; + if (c == 6) + ip += 2; + else + ip += 1; + } +}