3  * l1oip_codec.c  generic codec using lookup table
 
   4  *  -> conversion from a-Law to u-Law
 
   5  *  -> conversion from u-Law to a-Law
 
   6  *  -> compression by reducing the number of sample resolution to 4
 
   8  * NOTE: It is not compatible with any standard codec like ADPCM.
 
  10  * Author       Andreas Eversberg (jolly@eversberg.eu)
 
  12  * This program is free software; you can redistribute it and/or modify
 
  13  * it under the terms of the GNU General Public License as published by
 
  14  * the Free Software Foundation; either version 2, or (at your option)
 
  17  * This program is distributed in the hope that it will be useful,
 
  18  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 
  19  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
  20  * GNU General Public License for more details.
 
  22  * You should have received a copy of the GNU General Public License
 
  23  * along with this program; if not, write to the Free Software
 
  24  * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 
  33 The volume is increased to increase the dynamic range of the audio signal.
 
  34 Each sample is converted to a-LAW with only 16 steps of level resolution.
 
  35 A pair of two samples are stored in one byte.
 
  37 The first byte is stored in the upper bits, the second byte is stored in the
 
  40 To speed up compression and decompression, two lookup tables are formed:
 
  42 - 16 bits index for two samples (law encoded) with 8 bit compressed result.
 
  43 - 8 bits index for one compressed data with 16 bits decompressed result.
 
  45 NOTE: The bytes are handled as they are law-encoded.
 
  49 #include <linux/vmalloc.h>
 
  50 #include <linux/mISDNif.h>
 
  53 /* definitions of codec. don't use calculations, code may run slower. */
 
  56 static u16 *table_dec;
 
  60 static u8 alaw_to_ulaw[256] =
 
  62         0xab, 0x2b, 0xe3, 0x63, 0x8b, 0x0b, 0xc9, 0x49,
 
  63         0xba, 0x3a, 0xf6, 0x76, 0x9b, 0x1b, 0xd7, 0x57,
 
  64         0xa3, 0x23, 0xdd, 0x5d, 0x83, 0x03, 0xc1, 0x41,
 
  65         0xb2, 0x32, 0xeb, 0x6b, 0x93, 0x13, 0xcf, 0x4f,
 
  66         0xaf, 0x2f, 0xe7, 0x67, 0x8f, 0x0f, 0xcd, 0x4d,
 
  67         0xbe, 0x3e, 0xfe, 0x7e, 0x9f, 0x1f, 0xdb, 0x5b,
 
  68         0xa7, 0x27, 0xdf, 0x5f, 0x87, 0x07, 0xc5, 0x45,
 
  69         0xb6, 0x36, 0xef, 0x6f, 0x97, 0x17, 0xd3, 0x53,
 
  70         0xa9, 0x29, 0xe1, 0x61, 0x89, 0x09, 0xc7, 0x47,
 
  71         0xb8, 0x38, 0xf2, 0x72, 0x99, 0x19, 0xd5, 0x55,
 
  72         0xa1, 0x21, 0xdc, 0x5c, 0x81, 0x01, 0xbf, 0x3f,
 
  73         0xb0, 0x30, 0xe9, 0x69, 0x91, 0x11, 0xce, 0x4e,
 
  74         0xad, 0x2d, 0xe5, 0x65, 0x8d, 0x0d, 0xcb, 0x4b,
 
  75         0xbc, 0x3c, 0xfa, 0x7a, 0x9d, 0x1d, 0xd9, 0x59,
 
  76         0xa5, 0x25, 0xde, 0x5e, 0x85, 0x05, 0xc3, 0x43,
 
  77         0xb4, 0x34, 0xed, 0x6d, 0x95, 0x15, 0xd1, 0x51,
 
  78         0xac, 0x2c, 0xe4, 0x64, 0x8c, 0x0c, 0xca, 0x4a,
 
  79         0xbb, 0x3b, 0xf8, 0x78, 0x9c, 0x1c, 0xd8, 0x58,
 
  80         0xa4, 0x24, 0xde, 0x5e, 0x84, 0x04, 0xc2, 0x42,
 
  81         0xb3, 0x33, 0xec, 0x6c, 0x94, 0x14, 0xd0, 0x50,
 
  82         0xb0, 0x30, 0xe8, 0x68, 0x90, 0x10, 0xce, 0x4e,
 
  83         0xbf, 0x3f, 0xfe, 0x7e, 0xa0, 0x20, 0xdc, 0x5c,
 
  84         0xa8, 0x28, 0xe0, 0x60, 0x88, 0x08, 0xc6, 0x46,
 
  85         0xb7, 0x37, 0xf0, 0x70, 0x98, 0x18, 0xd4, 0x54,
 
  86         0xaa, 0x2a, 0xe2, 0x62, 0x8a, 0x0a, 0xc8, 0x48,
 
  87         0xb9, 0x39, 0xf4, 0x74, 0x9a, 0x1a, 0xd6, 0x56,
 
  88         0xa2, 0x22, 0xdd, 0x5d, 0x82, 0x02, 0xc0, 0x40,
 
  89         0xb1, 0x31, 0xea, 0x6a, 0x92, 0x12, 0xcf, 0x4f,
 
  90         0xae, 0x2e, 0xe6, 0x66, 0x8e, 0x0e, 0xcc, 0x4c,
 
  91         0xbd, 0x3d, 0xfc, 0x7c, 0x9e, 0x1e, 0xda, 0x5a,
 
  92         0xa6, 0x26, 0xdf, 0x5f, 0x86, 0x06, 0xc4, 0x44,
 
  93         0xb5, 0x35, 0xee, 0x6e, 0x96, 0x16, 0xd2, 0x52
 
  97 static u8 ulaw_to_alaw[256] =
 
  99         0xab, 0x55, 0xd5, 0x15, 0x95, 0x75, 0xf5, 0x35,
 
 100         0xb5, 0x45, 0xc5, 0x05, 0x85, 0x65, 0xe5, 0x25,
 
 101         0xa5, 0x5d, 0xdd, 0x1d, 0x9d, 0x7d, 0xfd, 0x3d,
 
 102         0xbd, 0x4d, 0xcd, 0x0d, 0x8d, 0x6d, 0xed, 0x2d,
 
 103         0xad, 0x51, 0xd1, 0x11, 0x91, 0x71, 0xf1, 0x31,
 
 104         0xb1, 0x41, 0xc1, 0x01, 0x81, 0x61, 0xe1, 0x21,
 
 105         0x59, 0xd9, 0x19, 0x99, 0x79, 0xf9, 0x39, 0xb9,
 
 106         0x49, 0xc9, 0x09, 0x89, 0x69, 0xe9, 0x29, 0xa9,
 
 107         0xd7, 0x17, 0x97, 0x77, 0xf7, 0x37, 0xb7, 0x47,
 
 108         0xc7, 0x07, 0x87, 0x67, 0xe7, 0x27, 0xa7, 0xdf,
 
 109         0x9f, 0x7f, 0xff, 0x3f, 0xbf, 0x4f, 0xcf, 0x0f,
 
 110         0x8f, 0x6f, 0xef, 0x2f, 0x53, 0x13, 0x73, 0x33,
 
 111         0xb3, 0x43, 0xc3, 0x03, 0x83, 0x63, 0xe3, 0x23,
 
 112         0xa3, 0x5b, 0xdb, 0x1b, 0x9b, 0x7b, 0xfb, 0x3b,
 
 113         0xbb, 0xbb, 0x4b, 0x4b, 0xcb, 0xcb, 0x0b, 0x0b,
 
 114         0x8b, 0x8b, 0x6b, 0x6b, 0xeb, 0xeb, 0x2b, 0x2b,
 
 115         0xab, 0x54, 0xd4, 0x14, 0x94, 0x74, 0xf4, 0x34,
 
 116         0xb4, 0x44, 0xc4, 0x04, 0x84, 0x64, 0xe4, 0x24,
 
 117         0xa4, 0x5c, 0xdc, 0x1c, 0x9c, 0x7c, 0xfc, 0x3c,
 
 118         0xbc, 0x4c, 0xcc, 0x0c, 0x8c, 0x6c, 0xec, 0x2c,
 
 119         0xac, 0x50, 0xd0, 0x10, 0x90, 0x70, 0xf0, 0x30,
 
 120         0xb0, 0x40, 0xc0, 0x00, 0x80, 0x60, 0xe0, 0x20,
 
 121         0x58, 0xd8, 0x18, 0x98, 0x78, 0xf8, 0x38, 0xb8,
 
 122         0x48, 0xc8, 0x08, 0x88, 0x68, 0xe8, 0x28, 0xa8,
 
 123         0xd6, 0x16, 0x96, 0x76, 0xf6, 0x36, 0xb6, 0x46,
 
 124         0xc6, 0x06, 0x86, 0x66, 0xe6, 0x26, 0xa6, 0xde,
 
 125         0x9e, 0x7e, 0xfe, 0x3e, 0xbe, 0x4e, 0xce, 0x0e,
 
 126         0x8e, 0x6e, 0xee, 0x2e, 0x52, 0x12, 0x72, 0x32,
 
 127         0xb2, 0x42, 0xc2, 0x02, 0x82, 0x62, 0xe2, 0x22,
 
 128         0xa2, 0x5a, 0xda, 0x1a, 0x9a, 0x7a, 0xfa, 0x3a,
 
 129         0xba, 0xba, 0x4a, 0x4a, 0xca, 0xca, 0x0a, 0x0a,
 
 130         0x8a, 0x8a, 0x6a, 0x6a, 0xea, 0xea, 0x2a, 0x2a
 
 133 /* alaw -> 4bit compression */
 
 134 static u8 alaw_to_4bit[256] = {
 
 135         0x0e, 0x01, 0x0a, 0x05, 0x0f, 0x00, 0x0c, 0x03,
 
 136         0x0d, 0x02, 0x08, 0x07, 0x0f, 0x00, 0x0b, 0x04,
 
 137         0x0e, 0x01, 0x0a, 0x05, 0x0f, 0x00, 0x0c, 0x03,
 
 138         0x0d, 0x02, 0x09, 0x06, 0x0f, 0x00, 0x0b, 0x04,
 
 139         0x0e, 0x01, 0x0a, 0x05, 0x0f, 0x00, 0x0c, 0x03,
 
 140         0x0d, 0x02, 0x08, 0x07, 0x0f, 0x00, 0x0b, 0x04,
 
 141         0x0e, 0x01, 0x0a, 0x05, 0x0f, 0x00, 0x0c, 0x03,
 
 142         0x0d, 0x02, 0x09, 0x06, 0x0f, 0x00, 0x0b, 0x04,
 
 143         0x0e, 0x01, 0x0a, 0x05, 0x0f, 0x00, 0x0c, 0x03,
 
 144         0x0d, 0x02, 0x08, 0x07, 0x0f, 0x00, 0x0b, 0x04,
 
 145         0x0e, 0x01, 0x0a, 0x05, 0x0f, 0x00, 0x0d, 0x02,
 
 146         0x0e, 0x02, 0x09, 0x06, 0x0f, 0x00, 0x0b, 0x04,
 
 147         0x0e, 0x01, 0x0a, 0x05, 0x0f, 0x00, 0x0c, 0x03,
 
 148         0x0d, 0x02, 0x08, 0x07, 0x0f, 0x00, 0x0b, 0x04,
 
 149         0x0e, 0x01, 0x0a, 0x05, 0x0f, 0x00, 0x0c, 0x03,
 
 150         0x0d, 0x02, 0x09, 0x06, 0x0f, 0x00, 0x0b, 0x04,
 
 151         0x0e, 0x01, 0x0a, 0x05, 0x0f, 0x00, 0x0c, 0x03,
 
 152         0x0d, 0x02, 0x08, 0x07, 0x0f, 0x00, 0x0b, 0x04,
 
 153         0x0e, 0x01, 0x0a, 0x05, 0x0f, 0x00, 0x0c, 0x03,
 
 154         0x0d, 0x02, 0x09, 0x06, 0x0f, 0x00, 0x0b, 0x04,
 
 155         0x0e, 0x02, 0x09, 0x06, 0x0f, 0x00, 0x0b, 0x04,
 
 156         0x0d, 0x02, 0x08, 0x07, 0x0f, 0x01, 0x0a, 0x05,
 
 157         0x0e, 0x01, 0x0a, 0x05, 0x0f, 0x00, 0x0c, 0x03,
 
 158         0x0d, 0x02, 0x09, 0x07, 0x0f, 0x00, 0x0b, 0x04,
 
 159         0x0e, 0x01, 0x0a, 0x05, 0x0f, 0x00, 0x0c, 0x03,
 
 160         0x0d, 0x02, 0x08, 0x07, 0x0f, 0x00, 0x0b, 0x04,
 
 161         0x0e, 0x01, 0x0a, 0x05, 0x0f, 0x00, 0x0c, 0x03,
 
 162         0x0d, 0x02, 0x09, 0x06, 0x0f, 0x00, 0x0b, 0x04,
 
 163         0x0e, 0x01, 0x0a, 0x05, 0x0f, 0x00, 0x0c, 0x03,
 
 164         0x0d, 0x02, 0x08, 0x07, 0x0f, 0x00, 0x0b, 0x04,
 
 165         0x0e, 0x01, 0x0a, 0x05, 0x0f, 0x00, 0x0c, 0x03,
 
 166         0x0d, 0x02, 0x09, 0x06, 0x0f, 0x00, 0x0b, 0x04,
 
 169 /* 4bit -> alaw decompression */
 
 170 static u8 _4bit_to_alaw[16] = {
 
 171         0x5d, 0x51, 0xd9, 0xd7, 0x5f, 0x53, 0xa3, 0x4b,
 
 172         0x2a, 0x3a, 0x22, 0x2e, 0x26, 0x56, 0x20, 0x2c,
 
 175 /* ulaw -> 4bit compression */
 
 176 static u8 ulaw_to_4bit[256] = {
 
 177         0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 
 178         0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 
 179         0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 
 180         0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
 
 181         0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01,
 
 182         0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01, 0x01,
 
 183         0x02, 0x02, 0x02, 0x02, 0x02, 0x02, 0x02, 0x02,
 
 184         0x02, 0x02, 0x02, 0x02, 0x02, 0x02, 0x02, 0x02,
 
 185         0x03, 0x03, 0x03, 0x03, 0x03, 0x03, 0x03, 0x03,
 
 186         0x03, 0x03, 0x03, 0x03, 0x03, 0x03, 0x04, 0x04,
 
 187         0x04, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04, 0x04,
 
 188         0x04, 0x04, 0x04, 0x04, 0x05, 0x05, 0x05, 0x05,
 
 189         0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05, 0x05,
 
 190         0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06, 0x06,
 
 191         0x07, 0x07, 0x07, 0x07, 0x07, 0x07, 0x07, 0x07,
 
 192         0x07, 0x07, 0x07, 0x07, 0x07, 0x07, 0x07, 0x08,
 
 193         0x0f, 0x0f, 0x0f, 0x0f, 0x0f, 0x0f, 0x0f, 0x0f,
 
 194         0x0f, 0x0f, 0x0f, 0x0f, 0x0f, 0x0f, 0x0f, 0x0f,
 
 195         0x0f, 0x0f, 0x0f, 0x0f, 0x0f, 0x0f, 0x0f, 0x0f,
 
 196         0x0f, 0x0f, 0x0f, 0x0f, 0x0f, 0x0f, 0x0f, 0x0f,
 
 197         0x0f, 0x0e, 0x0e, 0x0e, 0x0e, 0x0e, 0x0e, 0x0e,
 
 198         0x0e, 0x0e, 0x0e, 0x0e, 0x0e, 0x0e, 0x0e, 0x0e,
 
 199         0x0e, 0x0d, 0x0d, 0x0d, 0x0d, 0x0d, 0x0d, 0x0d,
 
 200         0x0d, 0x0d, 0x0d, 0x0d, 0x0d, 0x0d, 0x0d, 0x0d,
 
 201         0x0c, 0x0c, 0x0c, 0x0c, 0x0c, 0x0c, 0x0c, 0x0c,
 
 202         0x0c, 0x0c, 0x0c, 0x0c, 0x0c, 0x0c, 0x0b, 0x0b,
 
 203         0x0b, 0x0b, 0x0b, 0x0b, 0x0b, 0x0b, 0x0b, 0x0b,
 
 204         0x0b, 0x0b, 0x0b, 0x0b, 0x0a, 0x0a, 0x0a, 0x0a,
 
 205         0x0a, 0x0a, 0x0a, 0x0a, 0x0a, 0x0a, 0x0a, 0x0a,
 
 206         0x09, 0x09, 0x09, 0x09, 0x09, 0x09, 0x09, 0x09,
 
 207         0x09, 0x08, 0x08, 0x08, 0x08, 0x08, 0x08, 0x08,
 
 208         0x08, 0x08, 0x08, 0x08, 0x08, 0x08, 0x08, 0x08,
 
 211 /* 4bit -> ulaw decompression */
 
 212 static u8 _4bit_to_ulaw[16] = {
 
 213         0x11, 0x21, 0x31, 0x40, 0x4e, 0x5c, 0x68, 0x71,
 
 214         0xfe, 0xef, 0xe7, 0xdb, 0xcd, 0xbf, 0xaf, 0x9f,
 
 219  * Compresses data to the result buffer
 
 220  * The result size must be at least half of the input buffer.
 
 221  * The number of samples also must be even!
 
 224 l1oip_law_to_4bit(u8 *data, int len, u8 *result, u32 *state)
 
 226         int ii, i = 0, o = 0;
 
 231         /* send saved byte and first input byte */
 
 233                 *result++ = table_com[(((*state)<<8)&0xff00) | (*data++)];
 
 241                 *result++ = table_com[(data[0]<<8) | (data[1])];
 
 247         /* if len has an odd number, we save byte for next call */
 
 249                 *state = 0x100 + *data;
 
 256 /* Decompress data to the result buffer
 
 257  * The result size must be the number of sample in packet. (2 * input data)
 
 258  * The number of samples in the result are even!
 
 261 l1oip_4bit_to_law(u8 *data, int len, u8 *result)
 
 267                 r = table_dec[*data++];
 
 281 l1oip_alaw_to_ulaw(u8 *data, int len, u8 *result)
 
 286                 *result++ = alaw_to_ulaw[*data++];
 
 294 l1oip_ulaw_to_alaw(u8 *data, int len, u8 *result)
 
 299                 *result++ = ulaw_to_alaw[*data++];
 
 308  * generate/free compression and decompression table
 
 311 l1oip_4bit_free(void)
 
 322 l1oip_4bit_alloc(int ulaw)
 
 324         int i1, i2, c, sample;
 
 326         /* in case, it is called again */
 
 330         /* alloc conversion tables */
 
 331         table_com = vmalloc(65536);
 
 332         table_dec = vmalloc(512);
 
 333         if (!table_com | !table_dec) {
 
 337         memset(table_com, 0, 65536);
 
 338         memset(table_dec, 0, 512);
 
 339         /* generate compression table */
 
 343                         c = ulaw_to_4bit[i1];
 
 345                         c = alaw_to_4bit[i1];
 
 348                         table_com[(i1<<8) | i2] |= (c<<4);
 
 349                         table_com[(i2<<8) | i1] |= c;
 
 355         /* generate decompression table */
 
 359                         sample = _4bit_to_ulaw[i1];
 
 361                         sample = _4bit_to_alaw[i1];
 
 364                         table_dec[(i1<<4) | i2] |= (sample<<8);
 
 365                         table_dec[(i2<<4) | i1] |= sample;