1 /*
2 ** Copyright (C) 1999-2013 Erik de Castro Lopo <erikd@mega-nerd.com>
3 **
4 ** This program is free software; you can redistribute it and/or modify
5 ** it under the terms of the GNU Lesser General Public License as published by
6 ** the Free Software Foundation; either version 2.1 of the License, or
7 ** (at your option) any later version.
8 **
9 ** This program is distributed in the hope that it will be useful,
10 ** but WITHOUT ANY WARRANTY; without even the implied warranty of
11 ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 ** GNU Lesser General Public License for more details.
13 **
14 ** You should have received a copy of the GNU Lesser General Public License
15 ** along with this program; if not, write to the Free Software
16 ** Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
17 */
18
19 #include "sfconfig.h"
20
21 #include <math.h>
22 #include <limits.h>
23
24 #include "sndfile.h"
25 #include "common.h"
26
27 static sf_count_t alaw_read_alaw2s (SF_PRIVATE *psf, short *ptr, sf_count_t len) ;
28 static sf_count_t alaw_read_alaw2i (SF_PRIVATE *psf, int *ptr, sf_count_t len) ;
29 static sf_count_t alaw_read_alaw2f (SF_PRIVATE *psf, float *ptr, sf_count_t len) ;
30 static sf_count_t alaw_read_alaw2d (SF_PRIVATE *psf, double *ptr, sf_count_t len) ;
31
32 static sf_count_t alaw_write_s2alaw (SF_PRIVATE *psf, const short *ptr, sf_count_t len) ;
33 static sf_count_t alaw_write_i2alaw (SF_PRIVATE *psf, const int *ptr, sf_count_t len) ;
34 static sf_count_t alaw_write_f2alaw (SF_PRIVATE *psf, const float *ptr, sf_count_t len) ;
35 static sf_count_t alaw_write_d2alaw (SF_PRIVATE *psf, const double *ptr, sf_count_t len) ;
36
37 static void alaw2s_array (unsigned char *buffer, int count, short *ptr) ;
38 static void alaw2i_array (unsigned char *buffer, int count, int *ptr) ;
39 static void alaw2f_array (unsigned char *buffer, int count, float *ptr, float normfact) ;
40 static void alaw2d_array (unsigned char *buffer, int count, double *ptr, double normfact) ;
41
42 static void s2alaw_array (const short *buffer, int count, unsigned char *ptr) ;
43 static void i2alaw_array (const int *buffer, int count, unsigned char *ptr) ;
44 static void f2alaw_array (const float *buffer, int count, unsigned char *ptr, float normfact) ;
45 static void d2alaw_array (const double *buffer, int count, unsigned char *ptr, double normfact) ;
46
47
48 int
alaw_init(SF_PRIVATE * psf)49 alaw_init (SF_PRIVATE *psf)
50 {
51 if (psf->file.mode == SFM_READ || psf->file.mode == SFM_RDWR)
52 { psf->read_short = alaw_read_alaw2s ;
53 psf->read_int = alaw_read_alaw2i ;
54 psf->read_float = alaw_read_alaw2f ;
55 psf->read_double = alaw_read_alaw2d ;
56 } ;
57
58 if (psf->file.mode == SFM_WRITE || psf->file.mode == SFM_RDWR)
59 { psf->write_short = alaw_write_s2alaw ;
60 psf->write_int = alaw_write_i2alaw ;
61 psf->write_float = alaw_write_f2alaw ;
62 psf->write_double = alaw_write_d2alaw ;
63 } ;
64
65 psf->bytewidth = 1 ;
66 psf->blockwidth = psf->sf.channels ;
67
68 if (psf->filelength > psf->dataoffset)
69 psf->datalength = (psf->dataend) ? psf->dataend - psf->dataoffset : psf->filelength - psf->dataoffset ;
70 else
71 psf->datalength = 0 ;
72
73 psf->sf.frames = psf->blockwidth > 0 ? psf->datalength / psf->blockwidth : 0 ;
74
75 return 0 ;
76 } /* alaw_init */
77
78 /*==============================================================================
79 * Private static functions and data.
80 */
81
82 static
83 short alaw_decode [256] =
84 { -5504, -5248, -6016, -5760, -4480, -4224, -4992, -4736,
85 -7552, -7296, -8064, -7808, -6528, -6272, -7040, -6784,
86 -2752, -2624, -3008, -2880, -2240, -2112, -2496, -2368,
87 -3776, -3648, -4032, -3904, -3264, -3136, -3520, -3392,
88 -22016, -20992, -24064, -23040, -17920, -16896, -19968, -18944,
89 -30208, -29184, -32256, -31232, -26112, -25088, -28160, -27136,
90 -11008, -10496, -12032, -11520, -8960, -8448, -9984, -9472,
91 -15104, -14592, -16128, -15616, -13056, -12544, -14080, -13568,
92 -344, -328, -376, -360, -280, -264, -312, -296,
93 -472, -456, -504, -488, -408, -392, -440, -424,
94 -88, -72, -120, -104, -24, -8, -56, -40,
95 -216, -200, -248, -232, -152, -136, -184, -168,
96 -1376, -1312, -1504, -1440, -1120, -1056, -1248, -1184,
97 -1888, -1824, -2016, -1952, -1632, -1568, -1760, -1696,
98 -688, -656, -752, -720, -560, -528, -624, -592,
99 -944, -912, -1008, -976, -816, -784, -880, -848,
100 5504, 5248, 6016, 5760, 4480, 4224, 4992, 4736,
101 7552, 7296, 8064, 7808, 6528, 6272, 7040, 6784,
102 2752, 2624, 3008, 2880, 2240, 2112, 2496, 2368,
103 3776, 3648, 4032, 3904, 3264, 3136, 3520, 3392,
104 22016, 20992, 24064, 23040, 17920, 16896, 19968, 18944,
105 30208, 29184, 32256, 31232, 26112, 25088, 28160, 27136,
106 11008, 10496, 12032, 11520, 8960, 8448, 9984, 9472,
107 15104, 14592, 16128, 15616, 13056, 12544, 14080, 13568,
108 344, 328, 376, 360, 280, 264, 312, 296,
109 472, 456, 504, 488, 408, 392, 440, 424,
110 88, 72, 120, 104, 24, 8, 56, 40,
111 216, 200, 248, 232, 152, 136, 184, 168,
112 1376, 1312, 1504, 1440, 1120, 1056, 1248, 1184,
113 1888, 1824, 2016, 1952, 1632, 1568, 1760, 1696,
114 688, 656, 752, 720, 560, 528, 624, 592,
115 944, 912, 1008, 976, 816, 784, 880, 848
116 } ; /* alaw_decode */
117
118 static
119 unsigned char alaw_encode [2048 + 1] =
120 { 0xd5, 0xd4, 0xd7, 0xd6, 0xd1, 0xd0, 0xd3, 0xd2, 0xdd, 0xdc, 0xdf, 0xde,
121 0xd9, 0xd8, 0xdb, 0xda, 0xc5, 0xc4, 0xc7, 0xc6, 0xc1, 0xc0, 0xc3, 0xc2,
122 0xcd, 0xcc, 0xcf, 0xce, 0xc9, 0xc8, 0xcb, 0xca, 0xf5, 0xf5, 0xf4, 0xf4,
123 0xf7, 0xf7, 0xf6, 0xf6, 0xf1, 0xf1, 0xf0, 0xf0, 0xf3, 0xf3, 0xf2, 0xf2,
124 0xfd, 0xfd, 0xfc, 0xfc, 0xff, 0xff, 0xfe, 0xfe, 0xf9, 0xf9, 0xf8, 0xf8,
125 0xfb, 0xfb, 0xfa, 0xfa, 0xe5, 0xe5, 0xe5, 0xe5, 0xe4, 0xe4, 0xe4, 0xe4,
126 0xe7, 0xe7, 0xe7, 0xe7, 0xe6, 0xe6, 0xe6, 0xe6, 0xe1, 0xe1, 0xe1, 0xe1,
127 0xe0, 0xe0, 0xe0, 0xe0, 0xe3, 0xe3, 0xe3, 0xe3, 0xe2, 0xe2, 0xe2, 0xe2,
128 0xed, 0xed, 0xed, 0xed, 0xec, 0xec, 0xec, 0xec, 0xef, 0xef, 0xef, 0xef,
129 0xee, 0xee, 0xee, 0xee, 0xe9, 0xe9, 0xe9, 0xe9, 0xe8, 0xe8, 0xe8, 0xe8,
130 0xeb, 0xeb, 0xeb, 0xeb, 0xea, 0xea, 0xea, 0xea, 0x95, 0x95, 0x95, 0x95,
131 0x95, 0x95, 0x95, 0x95, 0x94, 0x94, 0x94, 0x94, 0x94, 0x94, 0x94, 0x94,
132 0x97, 0x97, 0x97, 0x97, 0x97, 0x97, 0x97, 0x97, 0x96, 0x96, 0x96, 0x96,
133 0x96, 0x96, 0x96, 0x96, 0x91, 0x91, 0x91, 0x91, 0x91, 0x91, 0x91, 0x91,
134 0x90, 0x90, 0x90, 0x90, 0x90, 0x90, 0x90, 0x90, 0x93, 0x93, 0x93, 0x93,
135 0x93, 0x93, 0x93, 0x93, 0x92, 0x92, 0x92, 0x92, 0x92, 0x92, 0x92, 0x92,
136 0x9d, 0x9d, 0x9d, 0x9d, 0x9d, 0x9d, 0x9d, 0x9d, 0x9c, 0x9c, 0x9c, 0x9c,
137 0x9c, 0x9c, 0x9c, 0x9c, 0x9f, 0x9f, 0x9f, 0x9f, 0x9f, 0x9f, 0x9f, 0x9f,
138 0x9e, 0x9e, 0x9e, 0x9e, 0x9e, 0x9e, 0x9e, 0x9e, 0x99, 0x99, 0x99, 0x99,
139 0x99, 0x99, 0x99, 0x99, 0x98, 0x98, 0x98, 0x98, 0x98, 0x98, 0x98, 0x98,
140 0x9b, 0x9b, 0x9b, 0x9b, 0x9b, 0x9b, 0x9b, 0x9b, 0x9a, 0x9a, 0x9a, 0x9a,
141 0x9a, 0x9a, 0x9a, 0x9a, 0x85, 0x85, 0x85, 0x85, 0x85, 0x85, 0x85, 0x85,
142 0x85, 0x85, 0x85, 0x85, 0x85, 0x85, 0x85, 0x85, 0x84, 0x84, 0x84, 0x84,
143 0x84, 0x84, 0x84, 0x84, 0x84, 0x84, 0x84, 0x84, 0x84, 0x84, 0x84, 0x84,
144 0x87, 0x87, 0x87, 0x87, 0x87, 0x87, 0x87, 0x87, 0x87, 0x87, 0x87, 0x87,
145 0x87, 0x87, 0x87, 0x87, 0x86, 0x86, 0x86, 0x86, 0x86, 0x86, 0x86, 0x86,
146 0x86, 0x86, 0x86, 0x86, 0x86, 0x86, 0x86, 0x86, 0x81, 0x81, 0x81, 0x81,
147 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81,
148 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80,
149 0x80, 0x80, 0x80, 0x80, 0x83, 0x83, 0x83, 0x83, 0x83, 0x83, 0x83, 0x83,
150 0x83, 0x83, 0x83, 0x83, 0x83, 0x83, 0x83, 0x83, 0x82, 0x82, 0x82, 0x82,
151 0x82, 0x82, 0x82, 0x82, 0x82, 0x82, 0x82, 0x82, 0x82, 0x82, 0x82, 0x82,
152 0x8d, 0x8d, 0x8d, 0x8d, 0x8d, 0x8d, 0x8d, 0x8d, 0x8d, 0x8d, 0x8d, 0x8d,
153 0x8d, 0x8d, 0x8d, 0x8d, 0x8c, 0x8c, 0x8c, 0x8c, 0x8c, 0x8c, 0x8c, 0x8c,
154 0x8c, 0x8c, 0x8c, 0x8c, 0x8c, 0x8c, 0x8c, 0x8c, 0x8f, 0x8f, 0x8f, 0x8f,
155 0x8f, 0x8f, 0x8f, 0x8f, 0x8f, 0x8f, 0x8f, 0x8f, 0x8f, 0x8f, 0x8f, 0x8f,
156 0x8e, 0x8e, 0x8e, 0x8e, 0x8e, 0x8e, 0x8e, 0x8e, 0x8e, 0x8e, 0x8e, 0x8e,
157 0x8e, 0x8e, 0x8e, 0x8e, 0x89, 0x89, 0x89, 0x89, 0x89, 0x89, 0x89, 0x89,
158 0x89, 0x89, 0x89, 0x89, 0x89, 0x89, 0x89, 0x89, 0x88, 0x88, 0x88, 0x88,
159 0x88, 0x88, 0x88, 0x88, 0x88, 0x88, 0x88, 0x88, 0x88, 0x88, 0x88, 0x88,
160 0x8b, 0x8b, 0x8b, 0x8b, 0x8b, 0x8b, 0x8b, 0x8b, 0x8b, 0x8b, 0x8b, 0x8b,
161 0x8b, 0x8b, 0x8b, 0x8b, 0x8a, 0x8a, 0x8a, 0x8a, 0x8a, 0x8a, 0x8a, 0x8a,
162 0x8a, 0x8a, 0x8a, 0x8a, 0x8a, 0x8a, 0x8a, 0x8a, 0xb5, 0xb5, 0xb5, 0xb5,
163 0xb5, 0xb5, 0xb5, 0xb5, 0xb5, 0xb5, 0xb5, 0xb5, 0xb5, 0xb5, 0xb5, 0xb5,
164 0xb5, 0xb5, 0xb5, 0xb5, 0xb5, 0xb5, 0xb5, 0xb5, 0xb5, 0xb5, 0xb5, 0xb5,
165 0xb5, 0xb5, 0xb5, 0xb5, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4,
166 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4,
167 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4,
168 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7,
169 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7,
170 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb6, 0xb6, 0xb6, 0xb6,
171 0xb6, 0xb6, 0xb6, 0xb6, 0xb6, 0xb6, 0xb6, 0xb6, 0xb6, 0xb6, 0xb6, 0xb6,
172 0xb6, 0xb6, 0xb6, 0xb6, 0xb6, 0xb6, 0xb6, 0xb6, 0xb6, 0xb6, 0xb6, 0xb6,
173 0xb6, 0xb6, 0xb6, 0xb6, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1,
174 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1,
175 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1,
176 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0,
177 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0,
178 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb3, 0xb3, 0xb3, 0xb3,
179 0xb3, 0xb3, 0xb3, 0xb3, 0xb3, 0xb3, 0xb3, 0xb3, 0xb3, 0xb3, 0xb3, 0xb3,
180 0xb3, 0xb3, 0xb3, 0xb3, 0xb3, 0xb3, 0xb3, 0xb3, 0xb3, 0xb3, 0xb3, 0xb3,
181 0xb3, 0xb3, 0xb3, 0xb3, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2,
182 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2,
183 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2,
184 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd,
185 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd,
186 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbc, 0xbc, 0xbc, 0xbc,
187 0xbc, 0xbc, 0xbc, 0xbc, 0xbc, 0xbc, 0xbc, 0xbc, 0xbc, 0xbc, 0xbc, 0xbc,
188 0xbc, 0xbc, 0xbc, 0xbc, 0xbc, 0xbc, 0xbc, 0xbc, 0xbc, 0xbc, 0xbc, 0xbc,
189 0xbc, 0xbc, 0xbc, 0xbc, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf,
190 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf,
191 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf,
192 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe,
193 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe,
194 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xb9, 0xb9, 0xb9, 0xb9,
195 0xb9, 0xb9, 0xb9, 0xb9, 0xb9, 0xb9, 0xb9, 0xb9, 0xb9, 0xb9, 0xb9, 0xb9,
196 0xb9, 0xb9, 0xb9, 0xb9, 0xb9, 0xb9, 0xb9, 0xb9, 0xb9, 0xb9, 0xb9, 0xb9,
197 0xb9, 0xb9, 0xb9, 0xb9, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8,
198 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8,
199 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8,
200 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb,
201 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb,
202 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xba, 0xba, 0xba, 0xba,
203 0xba, 0xba, 0xba, 0xba, 0xba, 0xba, 0xba, 0xba, 0xba, 0xba, 0xba, 0xba,
204 0xba, 0xba, 0xba, 0xba, 0xba, 0xba, 0xba, 0xba, 0xba, 0xba, 0xba, 0xba,
205 0xba, 0xba, 0xba, 0xba, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5,
206 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5,
207 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5,
208 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5,
209 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5,
210 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa4, 0xa4, 0xa4, 0xa4,
211 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4,
212 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4,
213 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4,
214 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4,
215 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4,
216 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7,
217 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7,
218 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7,
219 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7,
220 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7,
221 0xa7, 0xa7, 0xa7, 0xa7, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6,
222 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6,
223 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6,
224 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6,
225 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6,
226 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa1, 0xa1, 0xa1, 0xa1,
227 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1,
228 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1,
229 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1,
230 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1,
231 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1,
232 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0,
233 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0,
234 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0,
235 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0,
236 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0,
237 0xa0, 0xa0, 0xa0, 0xa0, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3,
238 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3,
239 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3,
240 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3,
241 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3,
242 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa2, 0xa2, 0xa2, 0xa2,
243 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2,
244 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2,
245 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2,
246 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2,
247 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2,
248 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad,
249 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad,
250 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad,
251 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad,
252 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad,
253 0xad, 0xad, 0xad, 0xad, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac,
254 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac,
255 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac,
256 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac,
257 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac,
258 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xaf, 0xaf, 0xaf, 0xaf,
259 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf,
260 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf,
261 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf,
262 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf,
263 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf,
264 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae,
265 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae,
266 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae,
267 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae,
268 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae,
269 0xae, 0xae, 0xae, 0xae, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9,
270 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9,
271 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9,
272 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9,
273 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9,
274 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa8, 0xa8, 0xa8, 0xa8,
275 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8,
276 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8,
277 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8,
278 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8,
279 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8,
280 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab,
281 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab,
282 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab,
283 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab,
284 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab,
285 0xab, 0xab, 0xab, 0xab, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
286 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
287 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
288 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
289 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
290 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa
291 } ; /* alaw_encode */
292
293 static inline void
alaw2s_array(unsigned char * buffer,int count,short * ptr)294 alaw2s_array (unsigned char *buffer, int count, short *ptr)
295 { for (int i = 0 ; i < count ; i++)
296 ptr [i] = alaw_decode [(int) buffer [i]] ;
297 } /* alaw2s_array */
298
299 static inline void
alaw2i_array(unsigned char * buffer,int count,int * ptr)300 alaw2i_array (unsigned char *buffer, int count, int *ptr)
301 { for (int i = 0 ; i < count ; i++)
302 ptr [i] = ((uint32_t) alaw_decode [(int) buffer [i]]) << 16 ;
303 } /* alaw2i_array */
304
305 static inline void
alaw2f_array(unsigned char * buffer,int count,float * ptr,float normfact)306 alaw2f_array (unsigned char *buffer, int count, float *ptr, float normfact)
307 { for (int i = 0 ; i < count ; i++)
308 ptr [i] = normfact * alaw_decode [(int) buffer [i]] ;
309 } /* alaw2f_array */
310
311 static inline void
alaw2d_array(unsigned char * buffer,int count,double * ptr,double normfact)312 alaw2d_array (unsigned char *buffer, int count, double *ptr, double normfact)
313 { for (int i = 0 ; i < count ; i++)
314 ptr [i] = normfact * alaw_decode [(int) buffer [i]] ;
315 } /* alaw2d_array */
316
317 static inline void
s2alaw_array(const short * ptr,int count,unsigned char * buffer)318 s2alaw_array (const short *ptr, int count, unsigned char *buffer)
319 { for (int i = 0 ; i < count ; i++)
320 { if (ptr [i] >= 0)
321 buffer [i] = alaw_encode [ptr [i] / 16] ;
322 else
323 buffer [i] = 0x7F & alaw_encode [ptr [i] / -16] ;
324 } ;
325 } /* s2alaw_array */
326
327 static inline void
i2alaw_array(const int * ptr,int count,unsigned char * buffer)328 i2alaw_array (const int *ptr, int count, unsigned char *buffer)
329 { for (int i = 0 ; i < count ; i++)
330 { if (ptr [i] == INT_MIN)
331 buffer [i] = alaw_encode [INT_MAX >> (16 + 4)] ;
332 else if (ptr [i] >= 0)
333 buffer [i] = alaw_encode [ptr [i] >> (16 + 4)] ;
334 else
335 buffer [i] = 0x7F & alaw_encode [- ptr [i] >> (16 + 4)] ;
336 } ;
337 } /* i2alaw_array */
338
339 static inline void
f2alaw_array(const float * ptr,int count,unsigned char * buffer,float normfact)340 f2alaw_array (const float *ptr, int count, unsigned char *buffer, float normfact)
341 { for (int i = 0 ; i < count ; i++)
342 { if (ptr [i] >= 0)
343 buffer [i] = alaw_encode [psf_lrintf (normfact * ptr [i])] ;
344 else
345 buffer [i] = 0x7F & alaw_encode [- psf_lrintf (normfact * ptr [i])] ;
346 } ;
347 } /* f2alaw_array */
348
349 static inline void
d2alaw_array(const double * ptr,int count,unsigned char * buffer,double normfact)350 d2alaw_array (const double *ptr, int count, unsigned char *buffer, double normfact)
351 { for (int i = 0 ; i < count ; i++)
352 { if (!isfinite (ptr [i]))
353 buffer [i] = 0 ;
354 else if (ptr [i] >= 0)
355 buffer [i] = alaw_encode [psf_lrint (normfact * ptr [i])] ;
356 else
357 buffer [i] = 0x7F & alaw_encode [- psf_lrint (normfact * ptr [i])] ;
358 } ;
359 } /* d2alaw_array */
360
361 /*==============================================================================
362 */
363
364 static sf_count_t
alaw_read_alaw2s(SF_PRIVATE * psf,short * ptr,sf_count_t len)365 alaw_read_alaw2s (SF_PRIVATE *psf, short *ptr, sf_count_t len)
366 { BUF_UNION ubuf ;
367 int bufferlen, readcount ;
368 sf_count_t total = 0 ;
369
370 bufferlen = ARRAY_LEN (ubuf.ucbuf) ;
371
372 while (len > 0)
373 { if (len < bufferlen)
374 bufferlen = (int) len ;
375 readcount = (int) psf_fread (ubuf.ucbuf, 1, bufferlen, psf) ;
376 alaw2s_array (ubuf.ucbuf, readcount, ptr + total) ;
377 total += readcount ;
378 if (readcount < bufferlen)
379 break ;
380 len -= readcount ;
381 } ;
382
383 return total ;
384 } /* alaw_read_alaw2s */
385
386 static sf_count_t
alaw_read_alaw2i(SF_PRIVATE * psf,int * ptr,sf_count_t len)387 alaw_read_alaw2i (SF_PRIVATE *psf, int *ptr, sf_count_t len)
388 { BUF_UNION ubuf ;
389 int bufferlen, readcount ;
390 sf_count_t total = 0 ;
391
392 bufferlen = ARRAY_LEN (ubuf.ucbuf) ;
393
394 while (len > 0)
395 { if (len < bufferlen)
396 bufferlen = (int) len ;
397 readcount = (int) psf_fread (ubuf.ucbuf, 1, bufferlen, psf) ;
398 alaw2i_array (ubuf.ucbuf, readcount, ptr + total) ;
399 total += readcount ;
400 if (readcount < bufferlen)
401 break ;
402 len -= readcount ;
403 } ;
404
405 return total ;
406 } /* alaw_read_alaw2i */
407
408 static sf_count_t
alaw_read_alaw2f(SF_PRIVATE * psf,float * ptr,sf_count_t len)409 alaw_read_alaw2f (SF_PRIVATE *psf, float *ptr, sf_count_t len)
410 { BUF_UNION ubuf ;
411 int bufferlen, readcount ;
412 sf_count_t total = 0 ;
413 float normfact ;
414
415 normfact = (psf->norm_float == SF_TRUE) ? 1.0 / ((float) 0x8000) : 1.0 ;
416
417 bufferlen = ARRAY_LEN (ubuf.ucbuf) ;
418
419 while (len > 0)
420 { if (len < bufferlen)
421 bufferlen = (int) len ;
422 readcount = (int) psf_fread (ubuf.ucbuf, 1, bufferlen, psf) ;
423 alaw2f_array (ubuf.ucbuf, readcount, ptr + total, normfact) ;
424 total += readcount ;
425 if (readcount < bufferlen)
426 break ;
427 len -= readcount ;
428 } ;
429
430 return total ;
431 } /* alaw_read_alaw2f */
432
433 static sf_count_t
alaw_read_alaw2d(SF_PRIVATE * psf,double * ptr,sf_count_t len)434 alaw_read_alaw2d (SF_PRIVATE *psf, double *ptr, sf_count_t len)
435 { BUF_UNION ubuf ;
436 int bufferlen, readcount ;
437 sf_count_t total = 0 ;
438 double normfact ;
439
440 normfact = (psf->norm_double) ? 1.0 / ((double) 0x8000) : 1.0 ;
441 bufferlen = ARRAY_LEN (ubuf.ucbuf) ;
442
443 while (len > 0)
444 { if (len < bufferlen)
445 bufferlen = (int) len ;
446 readcount = (int) psf_fread (ubuf.ucbuf, 1, bufferlen, psf) ;
447 alaw2d_array (ubuf.ucbuf, readcount, ptr + total, normfact) ;
448 total += readcount ;
449 if (readcount < bufferlen)
450 break ;
451 len -= readcount ;
452 } ;
453
454 return total ;
455 } /* alaw_read_alaw2d */
456
457 /*=============================================================================================
458 */
459
460 static sf_count_t
alaw_write_s2alaw(SF_PRIVATE * psf,const short * ptr,sf_count_t len)461 alaw_write_s2alaw (SF_PRIVATE *psf, const short *ptr, sf_count_t len)
462 { BUF_UNION ubuf ;
463 int bufferlen, writecount ;
464 sf_count_t total = 0 ;
465
466 bufferlen = ARRAY_LEN (ubuf.ucbuf) ;
467
468 while (len > 0)
469 { if (len < bufferlen)
470 bufferlen = (int) len ;
471 s2alaw_array (ptr + total, bufferlen, ubuf.ucbuf) ;
472 writecount = (int) psf_fwrite (ubuf.ucbuf, 1, bufferlen, psf) ;
473 total += writecount ;
474 if (writecount < bufferlen)
475 break ;
476 len -= writecount ;
477 } ;
478
479 return total ;
480 } /* alaw_write_s2alaw */
481
482 static sf_count_t
alaw_write_i2alaw(SF_PRIVATE * psf,const int * ptr,sf_count_t len)483 alaw_write_i2alaw (SF_PRIVATE *psf, const int *ptr, sf_count_t len)
484 { BUF_UNION ubuf ;
485 int bufferlen, writecount ;
486 sf_count_t total = 0 ;
487
488 bufferlen = ARRAY_LEN (ubuf.ucbuf) ;
489
490 while (len > 0)
491 { if (len < bufferlen)
492 bufferlen = (int) len ;
493 i2alaw_array (ptr + total, bufferlen, ubuf.ucbuf) ;
494 writecount = (int) psf_fwrite (ubuf.ucbuf, 1, bufferlen, psf) ;
495 total += writecount ;
496 if (writecount < bufferlen)
497 break ;
498 len -= writecount ;
499 } ;
500
501 return total ;
502 } /* alaw_write_i2alaw */
503
504 static sf_count_t
alaw_write_f2alaw(SF_PRIVATE * psf,const float * ptr,sf_count_t len)505 alaw_write_f2alaw (SF_PRIVATE *psf, const float *ptr, sf_count_t len)
506 { BUF_UNION ubuf ;
507 int bufferlen, writecount ;
508 sf_count_t total = 0 ;
509 float normfact ;
510
511 normfact = (psf->norm_float == SF_TRUE) ? (1.0 * 0x7FFF) / 16.0 : 1.0 / 16 ;
512
513 bufferlen = ARRAY_LEN (ubuf.ucbuf) ;
514
515 while (len > 0)
516 { if (len < bufferlen)
517 bufferlen = (int) len ;
518 f2alaw_array (ptr + total, bufferlen, ubuf.ucbuf, normfact) ;
519 writecount = (int) psf_fwrite (ubuf.ucbuf, 1, bufferlen, psf) ;
520 total += writecount ;
521 if (writecount < bufferlen)
522 break ;
523 len -= writecount ;
524 } ;
525
526 return total ;
527 } /* alaw_write_f2alaw */
528
529 static sf_count_t
alaw_write_d2alaw(SF_PRIVATE * psf,const double * ptr,sf_count_t len)530 alaw_write_d2alaw (SF_PRIVATE *psf, const double *ptr, sf_count_t len)
531 { BUF_UNION ubuf ;
532 int bufferlen, writecount ;
533 sf_count_t total = 0 ;
534 double normfact ;
535
536 normfact = (psf->norm_double) ? (1.0 * 0x7FFF) / 16.0 : 1.0 / 16.0 ;
537
538 bufferlen = ARRAY_LEN (ubuf.ucbuf) ;
539
540 while (len > 0)
541 { if (len < bufferlen)
542 bufferlen = (int) len ;
543 d2alaw_array (ptr + total, bufferlen, ubuf.ucbuf, normfact) ;
544 writecount = (int) psf_fwrite (ubuf.ucbuf, 1, bufferlen, psf) ;
545 total += writecount ;
546 if (writecount < bufferlen)
547 break ;
548 len -= writecount ;
549 } ;
550
551 return total ;
552 } /* alaw_write_d2alaw */
553
554