# HG changeset patch # User Mychaela Falconia # Date 1715634418 0 # Node ID 7c50864deaff8f2c9208428d2eab58b2e9576aef # Parent 4104b0390fab53c427c8f8afd3e5e09c0a2a50b6 amrts-pcm8-compact program written diff -r 4104b0390fab -r 7c50864deaff .hgignore --- a/.hgignore Mon May 13 07:21:09 2024 +0000 +++ b/.hgignore Mon May 13 21:06:58 2024 +0000 @@ -73,6 +73,7 @@ ^libtwamr/namespace\.h$ +^miscutil/amrts-pcm8-compact$ ^miscutil/gsmrec-dump$ ^miscutil/pcm16-check13$ ^miscutil/pcm16-raw2wav$ diff -r 4104b0390fab -r 7c50864deaff miscutil/Makefile --- a/miscutil/Makefile Mon May 13 07:21:09 2024 +0000 +++ b/miscutil/Makefile Mon May 13 21:06:58 2024 +0000 @@ -1,5 +1,5 @@ -PROGS= gsmrec-dump pcm16-check13 pcm16-raw2wav pcm16-to-alaw pcm16-to-ulaw \ - pcm16-wav2raw pcm8-to-pcm16 +PROGS= amrts-pcm8-compact gsmrec-dump pcm16-check13 pcm16-raw2wav \ + pcm16-to-alaw pcm16-to-ulaw pcm16-wav2raw pcm8-to-pcm16 LIBEFR= ../libgsmefr/libgsmefr.a ../libgsmfr2/libgsmfr2.a LIBTEST=../libtest/libtest.a @@ -7,6 +7,9 @@ all: ${PROGS} +amrts-pcm8-compact: amrts-pcm8-compact.c + ${CC} ${CFLAGS} -o $@ $@.c + gsmrec-dump: gsmrec-dump.o ${LIBTEST} ${LIBEFR} ${CC} ${CFLAGS} -o $@ gsmrec-dump.o ${LIBTEST} ${LIBEFR} diff -r 4104b0390fab -r 7c50864deaff miscutil/amrts-pcm8-compact.c --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/miscutil/amrts-pcm8-compact.c Mon May 13 21:06:58 2024 +0000 @@ -0,0 +1,55 @@ +/* + * The set of AMR test sequences shipped by 3GPP as TS 26.074 includes + * not only linear PCM (13-bit left-justified) and AMR-encoded files, + * but also 8-bit PCM sequences in both A-law and mu-law. However, + * those PCM8 sequences are shipped in a stupid and inconvenient format: + * each 8-bit PCM sample is expanded to a 16-bit word, written in LE + * byte order. This utility converts a PCM8 test sequence file + * from this weird format into sane PCM8 format with one byte per sample. + * For this conversion, it does not matter whether the PCM8 test sequence + * in question is A-law or mu-law. + */ + +#include +#include + +main(argc, argv) + char **argv; +{ + FILE *inf, *outf; + int cdat, cpad; + + if (argc != 3) { + fprintf(stderr, "usage: %s in-file out-file\n", argv[0]); + exit(1); + } + inf = fopen(argv[1], "r"); + if (!inf) { + perror(argv[1]); + exit(1); + } + outf = fopen(argv[2], "w"); + if (!outf) { + perror(argv[2]); + exit(1); + } + for (;;) { + cdat = getc(inf); + if (cdat < 0) + break; + cpad = getc(inf); + if (cpad < 0) { + fprintf(stderr, "error: %s has odd length\n", argv[1]); + exit(1); + } + if (cpad != 0) { + fprintf(stderr, + "error: presumed padding byte in %s is not 0\n", + argv[1]); + exit(1); + } + putc(cdat, outf); + } + fclose(outf); + exit(0); +}