Coverage Report

Created: 2025-10-12 06:44

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/flac/src/libFLAC/bitwriter.c
Line
Count
Source
1
/* libFLAC - Free Lossless Audio Codec library
2
 * Copyright (C) 2000-2009  Josh Coalson
3
 * Copyright (C) 2011-2025  Xiph.Org Foundation
4
 *
5
 * Redistribution and use in source and binary forms, with or without
6
 * modification, are permitted provided that the following conditions
7
 * are met:
8
 *
9
 * - Redistributions of source code must retain the above copyright
10
 * notice, this list of conditions and the following disclaimer.
11
 *
12
 * - Redistributions in binary form must reproduce the above copyright
13
 * notice, this list of conditions and the following disclaimer in the
14
 * documentation and/or other materials provided with the distribution.
15
 *
16
 * - Neither the name of the Xiph.org Foundation nor the names of its
17
 * contributors may be used to endorse or promote products derived from
18
 * this software without specific prior written permission.
19
 *
20
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21
 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
23
 * A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR
24
 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
25
 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
26
 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
27
 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
28
 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
29
 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
30
 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31
 */
32
33
#ifdef HAVE_CONFIG_H
34
#  include <config.h>
35
#endif
36
37
#include <stdlib.h>
38
#include <string.h>
39
#include "private/bitwriter.h"
40
#include "private/crc.h"
41
#include "private/format.h"
42
#include "private/macros.h"
43
#include "private/stream_encoder.h"
44
#include "FLAC/assert.h"
45
#include "share/alloc.h"
46
#include "share/compat.h"
47
#include "share/endswap.h"
48
49
/* Things should be fastest when this matches the machine word size */
50
/* WATCHOUT: if you change this you must also change the following #defines down to SWAP_BE_WORD_TO_HOST below to match */
51
/* WATCHOUT: there are a few places where the code will not work unless bwword is >= 32 bits wide */
52
53
#if (ENABLE_64_BIT_WORDS == 0)
54
55
typedef FLAC__uint32 bwword;
56
typedef FLAC__uint64 FLAC__bwtemp;
57
#define FLAC__BYTES_PER_WORD 4    /* sizeof bwword */
58
#define FLAC__BITS_PER_WORD 32
59
#define FLAC__TEMP_BITS 64
60
#define FLAC__HALF_TEMP_BITS 32
61
/* SWAP_BE_WORD_TO_HOST swaps bytes in a bwword (which is always big-endian) if necessary to match host byte order */
62
#if WORDS_BIGENDIAN
63
#define SWAP_BE_WORD_TO_HOST(x) (x)
64
#else
65
#define SWAP_BE_WORD_TO_HOST(x) ENDSWAP_32(x)
66
#endif
67
68
#else
69
70
typedef FLAC__uint64 bwword;
71
typedef FLAC__uint64 FLAC__bwtemp;
72
6.82k
#define FLAC__BYTES_PER_WORD 8    /* sizeof bwword */
73
624M
#define FLAC__BITS_PER_WORD 64
74
0
#define FLAC__TEMP_BITS 64
75
0
#define FLAC__HALF_TEMP_BITS 32
76
/* SWAP_BE_WORD_TO_HOST swaps bytes in a bwword (which is always big-endian) if necessary to match host byte order */
77
#if WORDS_BIGENDIAN
78
#define SWAP_BE_WORD_TO_HOST(x) (x)
79
#else
80
44.3M
#define SWAP_BE_WORD_TO_HOST(x) ENDSWAP_64(x)
81
#endif
82
83
#endif
84
85
/*
86
 * The default capacity here doesn't matter too much.  The buffer always grows
87
 * to hold whatever is written to it.  Usually the encoder will stop adding at
88
 * a frame or metadata block, then write that out and clear the buffer for the
89
 * next one.
90
 */
91
static const uint32_t FLAC__BITWRITER_DEFAULT_CAPACITY = 32768u / sizeof(bwword); /* size in words */
92
/* When growing, increment with 1/4th at a time */
93
static const uint32_t FLAC__BITWRITER_DEFAULT_GROW_FRACTION = 2; /* means grow by >> 2 (1/4th) of current size */
94
95
14.2k
#define FLAC__WORDS_TO_BITS(words) ((words) * FLAC__BITS_PER_WORD)
96
14.2k
#define FLAC__TOTAL_BITS(bw) (FLAC__WORDS_TO_BITS((bw)->words) + (bw)->bits)
97
98
struct FLAC__BitWriter {
99
  bwword *buffer;
100
  bwword accum; /* accumulator; bits are right-justified; when full, accum is appended to buffer */
101
  uint32_t capacity; /* capacity of buffer in words */
102
  uint32_t words; /* # of complete words in buffer */
103
  uint32_t bits; /* # of used bits in accum */
104
};
105
106
/* * WATCHOUT: The current implementation only grows the buffer. */
107
#ifndef __SUNPRO_C
108
static
109
#endif
110
FLAC__bool bitwriter_grow_(FLAC__BitWriter *bw, uint32_t bits_to_add)
111
20.5k
{
112
20.5k
  uint32_t new_capacity;
113
20.5k
  bwword *new_buffer;
114
115
20.5k
  FLAC__ASSERT(0 != bw);
116
20.5k
  FLAC__ASSERT(0 != bw->buffer);
117
118
  /* calculate total words needed to store 'bits_to_add' additional bits */
119
20.5k
  new_capacity = bw->words + ((bw->bits + bits_to_add + FLAC__BITS_PER_WORD - 1) / FLAC__BITS_PER_WORD);
120
121
  /* it's possible (due to pessimism in the growth estimation that
122
   * leads to this call) that we don't actually need to grow
123
   */
124
20.5k
  if(bw->capacity >= new_capacity)
125
20.0k
    return true;
126
127
479
  if(new_capacity * sizeof(bwword) > (1u << FLAC__STREAM_METADATA_LENGTH_LEN))
128
    /* Requested new capacity is larger than the largest possible metadata block,
129
     * which is also larger than the largest sane framesize. That means something
130
     * went very wrong somewhere and previous checks failed.
131
     * To prevent chrashing, give up */
132
3
    return false;
133
134
  /* As reallocation can be quite expensive, grow exponentially */
135
476
  if((new_capacity - bw->capacity) < (bw->capacity >> FLAC__BITWRITER_DEFAULT_GROW_FRACTION))
136
193
    new_capacity = bw->capacity + (bw->capacity >> FLAC__BITWRITER_DEFAULT_GROW_FRACTION);
137
138
  /* make sure we got everything right */
139
476
  FLAC__ASSERT(new_capacity > bw->capacity);
140
476
  FLAC__ASSERT(new_capacity >= bw->words + ((bw->bits + bits_to_add + FLAC__BITS_PER_WORD - 1) / FLAC__BITS_PER_WORD));
141
142
476
  new_buffer = safe_realloc_nofree_mul_2op_(bw->buffer, sizeof(bwword), /*times*/new_capacity);
143
476
  if(new_buffer == 0)
144
0
    return false;
145
476
  bw->buffer = new_buffer;
146
476
  bw->capacity = new_capacity;
147
476
  return true;
148
476
}
149
150
151
/***********************************************************************
152
 *
153
 * Class constructor/destructor
154
 *
155
 ***********************************************************************/
156
157
FLAC__BitWriter *FLAC__bitwriter_new(void)
158
7.11k
{
159
7.11k
  FLAC__BitWriter *bw = calloc(1, sizeof(FLAC__BitWriter));
160
  /* note that calloc() sets all members to 0 for us */
161
7.11k
  return bw;
162
7.11k
}
163
164
void FLAC__bitwriter_delete(FLAC__BitWriter *bw)
165
7.11k
{
166
7.11k
  FLAC__ASSERT(0 != bw);
167
168
7.11k
  FLAC__bitwriter_free(bw);
169
7.11k
  free(bw);
170
7.11k
}
171
172
/***********************************************************************
173
 *
174
 * Public class methods
175
 *
176
 ***********************************************************************/
177
178
FLAC__bool FLAC__bitwriter_init(FLAC__BitWriter *bw)
179
7.11k
{
180
7.11k
  FLAC__ASSERT(0 != bw);
181
182
7.11k
  bw->words = bw->bits = 0;
183
7.11k
  bw->capacity = FLAC__BITWRITER_DEFAULT_CAPACITY;
184
7.11k
  bw->buffer = malloc(sizeof(bwword) * bw->capacity);
185
7.11k
  if(bw->buffer == 0)
186
0
    return false;
187
188
7.11k
  return true;
189
7.11k
}
190
191
void FLAC__bitwriter_free(FLAC__BitWriter *bw)
192
7.11k
{
193
7.11k
  FLAC__ASSERT(0 != bw);
194
195
7.11k
  if(0 != bw->buffer)
196
7.11k
    free(bw->buffer);
197
7.11k
  bw->buffer = 0;
198
7.11k
  bw->capacity = 0;
199
7.11k
  bw->words = bw->bits = 0;
200
7.11k
}
201
202
void FLAC__bitwriter_clear(FLAC__BitWriter *bw)
203
0
{
204
0
  bw->words = bw->bits = 0;
205
0
}
206
207
FLAC__bool FLAC__bitwriter_get_write_crc16(FLAC__BitWriter *bw, FLAC__uint16 *crc)
208
0
{
209
0
  const FLAC__byte *buffer;
210
0
  size_t bytes;
211
212
0
  FLAC__ASSERT((bw->bits & 7) == 0); /* assert that we're byte-aligned */
213
214
0
  if(!FLAC__bitwriter_get_buffer(bw, &buffer, &bytes))
215
0
    return false;
216
217
0
  *crc = (FLAC__uint16)FLAC__crc16(buffer, bytes);
218
0
  FLAC__bitwriter_release_buffer(bw);
219
0
  return true;
220
0
}
221
222
FLAC__bool FLAC__bitwriter_get_write_crc8(FLAC__BitWriter *bw, FLAC__byte *crc)
223
0
{
224
0
  const FLAC__byte *buffer;
225
0
  size_t bytes;
226
227
0
  FLAC__ASSERT((bw->bits & 7) == 0); /* assert that we're byte-aligned */
228
229
0
  if(!FLAC__bitwriter_get_buffer(bw, &buffer, &bytes))
230
0
    return false;
231
232
0
  *crc = FLAC__crc8(buffer, bytes);
233
0
  FLAC__bitwriter_release_buffer(bw);
234
0
  return true;
235
0
}
236
237
FLAC__bool FLAC__bitwriter_is_byte_aligned(const FLAC__BitWriter *bw)
238
13.9k
{
239
13.9k
  return ((bw->bits & 7) == 0);
240
13.9k
}
241
242
uint32_t FLAC__bitwriter_get_input_bits_unconsumed(const FLAC__BitWriter *bw)
243
14.2k
{
244
14.2k
  return FLAC__TOTAL_BITS(bw);
245
14.2k
}
246
247
FLAC__bool FLAC__bitwriter_get_buffer(FLAC__BitWriter *bw, const FLAC__byte **buffer, size_t *bytes)
248
6.82k
{
249
6.82k
  FLAC__ASSERT((bw->bits & 7) == 0);
250
  /* double protection */
251
6.82k
  if(bw->bits & 7)
252
0
    return false;
253
  /* if we have bits in the accumulator we have to flush those to the buffer first */
254
6.82k
  if(bw->bits) {
255
5.17k
    FLAC__ASSERT(bw->words <= bw->capacity);
256
5.17k
    if(bw->words == bw->capacity && !bitwriter_grow_(bw, FLAC__BITS_PER_WORD))
257
0
      return false;
258
    /* append bits as complete word to buffer, but don't change bw->accum or bw->bits */
259
5.17k
    bw->buffer[bw->words] = SWAP_BE_WORD_TO_HOST(bw->accum << (FLAC__BITS_PER_WORD-bw->bits));
260
5.17k
  }
261
  /* now we can just return what we have */
262
6.82k
  *buffer = (FLAC__byte*)bw->buffer;
263
6.82k
  *bytes = (FLAC__BYTES_PER_WORD * bw->words) + (bw->bits >> 3);
264
6.82k
  return true;
265
6.82k
}
266
267
void FLAC__bitwriter_release_buffer(FLAC__BitWriter *bw)
268
0
{
269
  /* nothing to do.  in the future, strict checking of a 'writer-is-in-
270
   * get-mode' flag could be added everywhere and then cleared here
271
   */
272
0
  (void)bw;
273
0
}
274
275
inline FLAC__bool FLAC__bitwriter_write_zeroes(FLAC__BitWriter *bw, uint32_t bits)
276
389k
{
277
389k
  uint32_t n;
278
279
389k
  FLAC__ASSERT(0 != bw);
280
389k
  FLAC__ASSERT(0 != bw->buffer);
281
282
389k
  if(bits == 0)
283
764
    return true;
284
  /* slightly pessimistic size check but faster than "<= bw->words + (bw->bits+bits+FLAC__BITS_PER_WORD-1)/FLAC__BITS_PER_WORD" */
285
389k
  if(bw->capacity <= bw->words + bits && !bitwriter_grow_(bw, bits))
286
3
    return false;
287
  /* first part gets to word alignment */
288
389k
  if(bw->bits) {
289
389k
    n = flac_min(FLAC__BITS_PER_WORD - bw->bits, bits);
290
389k
    bw->accum <<= n;
291
389k
    bits -= n;
292
389k
    bw->bits += n;
293
389k
    if(bw->bits == FLAC__BITS_PER_WORD) {
294
198k
      bw->buffer[bw->words++] = SWAP_BE_WORD_TO_HOST(bw->accum);
295
198k
      bw->bits = 0;
296
198k
    }
297
190k
    else
298
190k
      return true;
299
389k
  }
300
  /* do whole words */
301
136M
  while(bits >= FLAC__BITS_PER_WORD) {
302
135M
    bw->buffer[bw->words++] = 0;
303
135M
    bits -= FLAC__BITS_PER_WORD;
304
135M
  }
305
  /* do any leftovers */
306
198k
  if(bits > 0) {
307
9.39k
    bw->accum = 0;
308
9.39k
    bw->bits = bits;
309
9.39k
  }
310
198k
  return true;
311
389k
}
312
313
static inline FLAC__bool FLAC__bitwriter_write_raw_uint32_nocheck(FLAC__BitWriter *bw, FLAC__uint32 val, uint32_t bits)
314
351M
{
315
351M
  register uint32_t left;
316
317
  /* WATCHOUT: code does not work with <32bit words; we can make things much faster with this assertion */
318
351M
  FLAC__ASSERT(FLAC__BITS_PER_WORD >= 32);
319
320
351M
  if(bw == 0 || bw->buffer == 0)
321
0
    return false;
322
323
351M
  if (bits > 32)
324
0
    return false;
325
326
351M
  if(bits == 0)
327
0
    return true;
328
329
351M
  FLAC__ASSERT((bits == 32) || (val>>bits == 0));
330
331
  /* slightly pessimistic size check but faster than "<= bw->words + (bw->bits+bits+FLAC__BITS_PER_WORD-1)/FLAC__BITS_PER_WORD" */
332
351M
  if(bw->capacity <= bw->words + bits && !bitwriter_grow_(bw, bits))
333
0
    return false;
334
335
351M
  left = FLAC__BITS_PER_WORD - bw->bits;
336
351M
  if(bits < left) {
337
307M
    bw->accum <<= bits;
338
307M
    bw->accum |= val;
339
307M
    bw->bits += bits;
340
307M
  }
341
44.1M
  else if(bw->bits) { /* WATCHOUT: if bw->bits == 0, left==FLAC__BITS_PER_WORD and bw->accum<<=left is a NOP instead of setting to 0 */
342
44.1M
    bw->accum <<= left;
343
44.1M
    bw->accum |= val >> (bw->bits = bits - left);
344
44.1M
    bw->buffer[bw->words++] = SWAP_BE_WORD_TO_HOST(bw->accum);
345
44.1M
    bw->accum = val; /* unused top bits can contain garbage */
346
44.1M
  }
347
0
  else { /* at this point bits == FLAC__BITS_PER_WORD == 32  and  bw->bits == 0 */
348
0
    bw->buffer[bw->words++] = SWAP_BE_WORD_TO_HOST((bwword)val);
349
0
  }
350
351
351M
  return true;
352
351M
}
353
354
inline FLAC__bool FLAC__bitwriter_write_raw_uint32(FLAC__BitWriter *bw, FLAC__uint32 val, uint32_t bits)
355
848k
{
356
  /* check that unused bits are unset */
357
848k
  if((bits < 32) && (val>>bits != 0))
358
0
    return false;
359
360
848k
  return FLAC__bitwriter_write_raw_uint32_nocheck(bw, val, bits);
361
848k
}
362
363
inline FLAC__bool FLAC__bitwriter_write_raw_int32(FLAC__BitWriter *bw, FLAC__int32 val, uint32_t bits)
364
0
{
365
  /* zero-out unused bits */
366
0
  if(bits < 32)
367
0
    val &= (~(0xffffffff << bits));
368
369
0
  return FLAC__bitwriter_write_raw_uint32_nocheck(bw, (FLAC__uint32)val, bits);
370
0
}
371
372
inline FLAC__bool FLAC__bitwriter_write_raw_uint64(FLAC__BitWriter *bw, FLAC__uint64 val, uint32_t bits)
373
390k
{
374
  /* this could be a little faster but it's not used for much */
375
390k
  if(bits > 32) {
376
390k
    return
377
390k
      FLAC__bitwriter_write_raw_uint32(bw, (FLAC__uint32)(val>>32), bits-32) &&
378
390k
      FLAC__bitwriter_write_raw_uint32_nocheck(bw, (FLAC__uint32)val, 32);
379
390k
  }
380
0
  else
381
0
    return FLAC__bitwriter_write_raw_uint32(bw, (FLAC__uint32)val, bits);
382
390k
}
383
384
inline FLAC__bool FLAC__bitwriter_write_raw_int64(FLAC__BitWriter *bw, FLAC__int64 val, uint32_t bits)
385
0
{
386
0
  FLAC__uint64 uval = val;
387
  /* zero-out unused bits */
388
0
  if(bits < 64)
389
0
    uval &= (~(UINT64_MAX << bits));
390
0
  return FLAC__bitwriter_write_raw_uint64(bw, uval, bits);
391
0
}
392
393
inline FLAC__bool FLAC__bitwriter_write_raw_uint32_little_endian(FLAC__BitWriter *bw, FLAC__uint32 val)
394
27.9k
{
395
  /* this doesn't need to be that fast as currently it is only used for vorbis comments */
396
397
27.9k
  if(!FLAC__bitwriter_write_raw_uint32_nocheck(bw, val & 0xff, 8))
398
0
    return false;
399
27.9k
  if(!FLAC__bitwriter_write_raw_uint32_nocheck(bw, (val>>8) & 0xff, 8))
400
0
    return false;
401
27.9k
  if(!FLAC__bitwriter_write_raw_uint32_nocheck(bw, (val>>16) & 0xff, 8))
402
0
    return false;
403
27.9k
  if(!FLAC__bitwriter_write_raw_uint32_nocheck(bw, val>>24, 8))
404
0
    return false;
405
406
27.9k
  return true;
407
27.9k
}
408
409
inline FLAC__bool FLAC__bitwriter_write_byte_block(FLAC__BitWriter *bw, const FLAC__byte vals[], uint32_t nvals)
410
45.9k
{
411
45.9k
  uint32_t i;
412
413
  /* grow capacity upfront to prevent constant reallocation during writes */
414
45.9k
  if(bw->capacity <= bw->words + nvals / (FLAC__BITS_PER_WORD / 8) + 1 && !bitwriter_grow_(bw, nvals * 8))
415
0
    return false;
416
417
  /* this could be faster but currently we don't need it to be since it's only used for writing metadata */
418
350M
  for(i = 0; i < nvals; i++) {
419
350M
    if(!FLAC__bitwriter_write_raw_uint32_nocheck(bw, (FLAC__uint32)(vals[i]), 8))
420
0
      return false;
421
350M
  }
422
423
45.9k
  return true;
424
45.9k
}
425
426
FLAC__bool FLAC__bitwriter_write_unary_unsigned(FLAC__BitWriter *bw, uint32_t val)
427
0
{
428
0
  if(val < 32)
429
0
    return FLAC__bitwriter_write_raw_uint32_nocheck(bw, 1, ++val);
430
0
  else
431
0
    return
432
0
      FLAC__bitwriter_write_zeroes(bw, val) &&
433
0
      FLAC__bitwriter_write_raw_uint32_nocheck(bw, 1, 1);
434
0
}
435
436
#if 0 /* UNUSED */
437
uint32_t FLAC__bitwriter_rice_bits(FLAC__int32 val, uint32_t parameter)
438
{
439
  FLAC__uint32 uval;
440
441
  FLAC__ASSERT(parameter < 32);
442
443
  /* fold signed to uint32_t; actual formula is: negative(v)? -2v-1 : 2v */
444
  uval = val;
445
  uval <<= 1;
446
  uval ^= (val>>31);
447
448
  return 1 + parameter + (uval >> parameter);
449
}
450
451
uint32_t FLAC__bitwriter_golomb_bits_signed(int val, uint32_t parameter)
452
{
453
  uint32_t bits, msbs, uval;
454
  uint32_t k;
455
456
  FLAC__ASSERT(parameter > 0);
457
458
  /* fold signed to uint32_t */
459
  if(val < 0)
460
    uval = (uint32_t)(((-(++val)) << 1) + 1);
461
  else
462
    uval = (uint32_t)(val << 1);
463
464
  k = FLAC__bitmath_ilog2(parameter);
465
  if(parameter == 1u<<k) {
466
    FLAC__ASSERT(k <= 30);
467
468
    msbs = uval >> k;
469
    bits = 1 + k + msbs;
470
  }
471
  else {
472
    uint32_t q, r, d;
473
474
    d = (1 << (k+1)) - parameter;
475
    q = uval / parameter;
476
    r = uval - (q * parameter);
477
478
    bits = 1 + q + k;
479
    if(r >= d)
480
      bits++;
481
  }
482
  return bits;
483
}
484
485
uint32_t FLAC__bitwriter_golomb_bits_unsigned(uint32_t uval, uint32_t parameter)
486
{
487
  uint32_t bits, msbs;
488
  uint32_t k;
489
490
  FLAC__ASSERT(parameter > 0);
491
492
  k = FLAC__bitmath_ilog2(parameter);
493
  if(parameter == 1u<<k) {
494
    FLAC__ASSERT(k <= 30);
495
496
    msbs = uval >> k;
497
    bits = 1 + k + msbs;
498
  }
499
  else {
500
    uint32_t q, r, d;
501
502
    d = (1 << (k+1)) - parameter;
503
    q = uval / parameter;
504
    r = uval - (q * parameter);
505
506
    bits = 1 + q + k;
507
    if(r >= d)
508
      bits++;
509
  }
510
  return bits;
511
}
512
513
FLAC__bool FLAC__bitwriter_write_rice_signed(FLAC__BitWriter *bw, FLAC__int32 val, uint32_t parameter)
514
{
515
  uint32_t total_bits, interesting_bits, msbs;
516
  FLAC__uint32 uval, pattern;
517
518
  FLAC__ASSERT(0 != bw);
519
  FLAC__ASSERT(0 != bw->buffer);
520
  FLAC__ASSERT(parameter < 32);
521
522
  /* fold signed to uint32_t; actual formula is: negative(v)? -2v-1 : 2v */
523
  uval = val;
524
  uval <<= 1;
525
  uval ^= (val>>31);
526
527
  msbs = uval >> parameter;
528
  interesting_bits = 1 + parameter;
529
  total_bits = interesting_bits + msbs;
530
  pattern = 1 << parameter; /* the unary end bit */
531
  pattern |= (uval & ((1<<parameter)-1)); /* the binary LSBs */
532
533
  if(total_bits <= 32)
534
    return FLAC__bitwriter_write_raw_uint32(bw, pattern, total_bits);
535
  else
536
    return
537
      FLAC__bitwriter_write_zeroes(bw, msbs) && /* write the unary MSBs */
538
      FLAC__bitwriter_write_raw_uint32(bw, pattern, interesting_bits); /* write the unary end bit and binary LSBs */
539
}
540
#endif /* UNUSED */
541
542
#if (ENABLE_64_BIT_WORDS == 0)
543
544
#define WIDE_ACCUM_TO_BW {  \
545
  bw->accum = wide_accum >> FLAC__HALF_TEMP_BITS;  \
546
  bw->buffer[bw->words++] = SWAP_BE_WORD_TO_HOST(bw->accum); \
547
  wide_accum <<= FLAC__HALF_TEMP_BITS;  \
548
  bitpointer += FLAC__HALF_TEMP_BITS;  \
549
}
550
551
#else
552
553
0
#define WIDE_ACCUM_TO_BW {  \
554
0
  FLAC__ASSERT(bw->bits % FLAC__HALF_TEMP_BITS == 0);  \
555
0
  if(bw->bits == 0) {  \
556
0
    bw->accum = wide_accum >> FLAC__HALF_TEMP_BITS;  \
557
0
    wide_accum <<= FLAC__HALF_TEMP_BITS;  \
558
0
    bw->bits = FLAC__HALF_TEMP_BITS;  \
559
0
  }  \
560
0
  else {  \
561
0
    bw->accum <<= FLAC__HALF_TEMP_BITS;  \
562
0
    bw->accum += wide_accum >> FLAC__HALF_TEMP_BITS;  \
563
0
    bw->buffer[bw->words++] = SWAP_BE_WORD_TO_HOST(bw->accum);  \
564
0
    wide_accum <<= FLAC__HALF_TEMP_BITS;  \
565
0
    bw->bits = 0;  \
566
0
  }  \
567
0
  bitpointer += FLAC__HALF_TEMP_BITS;  \
568
0
}
569
570
#endif
571
572
FLAC__bool FLAC__bitwriter_write_rice_signed_block(FLAC__BitWriter *bw, const FLAC__int32 *vals, uint32_t nvals, uint32_t parameter)
573
0
{
574
0
  const FLAC__uint32 mask1 = (FLAC__uint32)0xffffffff << parameter; /* we val|=mask1 to set the stop bit above it... */
575
0
  const FLAC__uint32 mask2 = (FLAC__uint32)0xffffffff >> (31-parameter); /* ...then mask off the bits above the stop bit with val&=mask2 */
576
0
  FLAC__uint32 uval;
577
0
  const uint32_t lsbits = 1 + parameter;
578
0
  uint32_t msbits, total_bits;
579
0
  FLAC__bwtemp wide_accum = 0;
580
0
  FLAC__uint32 bitpointer = FLAC__TEMP_BITS;
581
582
0
  FLAC__ASSERT(0 != bw);
583
0
  FLAC__ASSERT(0 != bw->buffer);
584
0
  FLAC__ASSERT(parameter < 31);
585
  /* WATCHOUT: code does not work with <32bit words; we can make things much faster with this assertion */
586
0
  FLAC__ASSERT(FLAC__BITS_PER_WORD >= 32);
587
#if (ENABLE_64_BIT_WORDS == 0)
588
  if(bw->bits > 0) {
589
    bitpointer -= bw->bits;
590
    wide_accum = (FLAC__bwtemp)(bw->accum) << bitpointer;
591
    bw->bits = 0;
592
  }
593
#else
594
0
  if(bw->bits > 0 && bw->bits < FLAC__HALF_TEMP_BITS) {
595
0
    bitpointer -= bw->bits;
596
0
    wide_accum = bw->accum << bitpointer;
597
0
    bw->bits = 0;
598
0
  }
599
0
  else if(bw->bits > FLAC__HALF_TEMP_BITS) {
600
0
    bitpointer -= (bw->bits - FLAC__HALF_TEMP_BITS);
601
0
    wide_accum = bw->accum << bitpointer;
602
0
    bw->accum >>= (bw->bits - FLAC__HALF_TEMP_BITS);
603
0
    bw->bits = FLAC__HALF_TEMP_BITS;
604
0
  }
605
0
#endif
606
607
  /* Reserve one FLAC__TEMP_BITS per symbol, so checks for space are only necessary when very large symbols are encountered
608
   * this might be considered wasteful, but is only at most 8kB more than necessary for a blocksize of 4096 */
609
0
  if(bw->capacity * FLAC__BITS_PER_WORD <= bw->words * FLAC__BITS_PER_WORD + nvals * FLAC__TEMP_BITS + bw->bits && !bitwriter_grow_(bw, nvals * FLAC__TEMP_BITS))
610
0
    return false;
611
612
0
  while(nvals) {
613
    /* fold signed to uint32_t; actual formula is: negative(v)? -2v-1 : 2v */
614
0
    uval = *vals;
615
0
    uval <<= 1;
616
0
    uval ^= (*vals>>31);
617
618
0
    msbits = uval >> parameter;
619
0
    total_bits = lsbits + msbits;
620
621
0
    uval |= mask1; /* set stop bit */
622
0
    uval &= mask2; /* mask off unused top bits */
623
624
625
0
    if(total_bits <= bitpointer) {
626
      /* There is room enough to store the symbol whole at once */
627
0
      wide_accum |= (FLAC__bwtemp)(uval) << (bitpointer - total_bits);
628
0
      bitpointer -= total_bits;
629
0
      if(bitpointer <= FLAC__HALF_TEMP_BITS) {
630
        /* A word is finished, copy the upper 32 bits of the wide_accum */
631
0
        WIDE_ACCUM_TO_BW
632
0
      }
633
0
    }
634
0
    else {
635
      /* The symbol needs to be split. This code isn't used often */
636
      /* First check for space in the bitwriter */
637
0
      if(total_bits > FLAC__TEMP_BITS) {
638
0
        FLAC__uint32 oversize_in_bits = total_bits - FLAC__TEMP_BITS;
639
0
        FLAC__uint32 capacity_needed = bw->words * FLAC__BITS_PER_WORD + bw->bits + nvals * FLAC__TEMP_BITS + oversize_in_bits;
640
0
        if(bw->capacity * FLAC__BITS_PER_WORD <= capacity_needed && !bitwriter_grow_(bw, nvals * FLAC__TEMP_BITS + oversize_in_bits))
641
0
          return false;
642
0
      }
643
0
      if(msbits > bitpointer) {
644
        /* We have a lot of 0 bits to write, first align with bitwriter word */
645
0
        msbits -= bitpointer - FLAC__HALF_TEMP_BITS;
646
0
        bitpointer = FLAC__HALF_TEMP_BITS;
647
0
        WIDE_ACCUM_TO_BW
648
0
        while(msbits > bitpointer) {
649
          /* As the accumulator is already zero, we only need to
650
           * assign zeroes to the bitbuffer */
651
0
          WIDE_ACCUM_TO_BW
652
0
          bitpointer -= FLAC__HALF_TEMP_BITS;
653
0
          msbits -= FLAC__HALF_TEMP_BITS;
654
0
        }
655
        /* The remaining bits are zero, and the accumulator already is zero,
656
         * so just subtract the number of bits from bitpointer. When storing,
657
         * we can also just store 0 */
658
0
        bitpointer -= msbits;
659
0
        if(bitpointer <= FLAC__HALF_TEMP_BITS)
660
0
          WIDE_ACCUM_TO_BW
661
0
      }
662
0
      else {
663
0
        bitpointer -= msbits;
664
0
        if(bitpointer <= FLAC__HALF_TEMP_BITS)
665
0
          WIDE_ACCUM_TO_BW
666
0
      }
667
      /* The lsbs + stop bit always fit 32 bit, so this code mirrors the code above */
668
0
                        wide_accum |= (FLAC__bwtemp)(uval) << (bitpointer - lsbits);
669
0
                        bitpointer -= lsbits;
670
0
                        if(bitpointer <= FLAC__HALF_TEMP_BITS) {
671
                                /* A word is finished, copy the upper 32 bits of the wide_accum */
672
0
                                WIDE_ACCUM_TO_BW
673
0
                        }
674
0
    }
675
0
    vals++;
676
0
    nvals--;
677
0
  }
678
  /* Now fixup remainder of wide_accum */
679
#if (ENABLE_64_BIT_WORDS == 0)
680
  if(bitpointer < FLAC__TEMP_BITS) {
681
    bw->accum = wide_accum >> bitpointer;
682
    bw->bits = FLAC__TEMP_BITS - bitpointer;
683
  }
684
#else
685
0
  if(bitpointer < FLAC__TEMP_BITS) {
686
0
    if(bw->bits == 0) {
687
0
      bw->accum = wide_accum >> bitpointer;
688
0
      bw->bits = FLAC__TEMP_BITS - bitpointer;
689
0
    }
690
0
    else if (bw->bits == FLAC__HALF_TEMP_BITS) {
691
0
      bw->accum <<= FLAC__TEMP_BITS - bitpointer;
692
0
      bw->accum |= (wide_accum >> bitpointer);
693
0
      bw->bits = FLAC__HALF_TEMP_BITS + FLAC__TEMP_BITS - bitpointer;
694
0
    }
695
0
    else {
696
0
      FLAC__ASSERT(0);
697
0
    }
698
0
  }
699
0
#endif
700
701
702
0
  return true;
703
0
}
704
705
#if 0 /* UNUSED */
706
FLAC__bool FLAC__bitwriter_write_golomb_signed(FLAC__BitWriter *bw, int val, uint32_t parameter)
707
{
708
  uint32_t total_bits, msbs, uval;
709
  uint32_t k;
710
711
  FLAC__ASSERT(0 != bw);
712
  FLAC__ASSERT(0 != bw->buffer);
713
  FLAC__ASSERT(parameter > 0);
714
715
  /* fold signed to uint32_t */
716
  if(val < 0)
717
    uval = (uint32_t)(((-(++val)) << 1) + 1);
718
  else
719
    uval = (uint32_t)(val << 1);
720
721
  k = FLAC__bitmath_ilog2(parameter);
722
  if(parameter == 1u<<k) {
723
    uint32_t pattern;
724
725
    FLAC__ASSERT(k <= 30);
726
727
    msbs = uval >> k;
728
    total_bits = 1 + k + msbs;
729
    pattern = 1 << k; /* the unary end bit */
730
    pattern |= (uval & ((1u<<k)-1)); /* the binary LSBs */
731
732
    if(total_bits <= 32) {
733
      if(!FLAC__bitwriter_write_raw_uint32(bw, pattern, total_bits))
734
        return false;
735
    }
736
    else {
737
      /* write the unary MSBs */
738
      if(!FLAC__bitwriter_write_zeroes(bw, msbs))
739
        return false;
740
      /* write the unary end bit and binary LSBs */
741
      if(!FLAC__bitwriter_write_raw_uint32(bw, pattern, k+1))
742
        return false;
743
    }
744
  }
745
  else {
746
    uint32_t q, r, d;
747
748
    d = (1 << (k+1)) - parameter;
749
    q = uval / parameter;
750
    r = uval - (q * parameter);
751
    /* write the unary MSBs */
752
    if(!FLAC__bitwriter_write_zeroes(bw, q))
753
      return false;
754
    /* write the unary end bit */
755
    if(!FLAC__bitwriter_write_raw_uint32(bw, 1, 1))
756
      return false;
757
    /* write the binary LSBs */
758
    if(r >= d) {
759
      if(!FLAC__bitwriter_write_raw_uint32(bw, r+d, k+1))
760
        return false;
761
    }
762
    else {
763
      if(!FLAC__bitwriter_write_raw_uint32(bw, r, k))
764
        return false;
765
    }
766
  }
767
  return true;
768
}
769
770
FLAC__bool FLAC__bitwriter_write_golomb_unsigned(FLAC__BitWriter *bw, uint32_t uval, uint32_t parameter)
771
{
772
  uint32_t total_bits, msbs;
773
  uint32_t k;
774
775
  FLAC__ASSERT(0 != bw);
776
  FLAC__ASSERT(0 != bw->buffer);
777
  FLAC__ASSERT(parameter > 0);
778
779
  k = FLAC__bitmath_ilog2(parameter);
780
  if(parameter == 1u<<k) {
781
    uint32_t pattern;
782
783
    FLAC__ASSERT(k <= 30);
784
785
    msbs = uval >> k;
786
    total_bits = 1 + k + msbs;
787
    pattern = 1 << k; /* the unary end bit */
788
    pattern |= (uval & ((1u<<k)-1)); /* the binary LSBs */
789
790
    if(total_bits <= 32) {
791
      if(!FLAC__bitwriter_write_raw_uint32(bw, pattern, total_bits))
792
        return false;
793
    }
794
    else {
795
      /* write the unary MSBs */
796
      if(!FLAC__bitwriter_write_zeroes(bw, msbs))
797
        return false;
798
      /* write the unary end bit and binary LSBs */
799
      if(!FLAC__bitwriter_write_raw_uint32(bw, pattern, k+1))
800
        return false;
801
    }
802
  }
803
  else {
804
    uint32_t q, r, d;
805
806
    d = (1 << (k+1)) - parameter;
807
    q = uval / parameter;
808
    r = uval - (q * parameter);
809
    /* write the unary MSBs */
810
    if(!FLAC__bitwriter_write_zeroes(bw, q))
811
      return false;
812
    /* write the unary end bit */
813
    if(!FLAC__bitwriter_write_raw_uint32(bw, 1, 1))
814
      return false;
815
    /* write the binary LSBs */
816
    if(r >= d) {
817
      if(!FLAC__bitwriter_write_raw_uint32(bw, r+d, k+1))
818
        return false;
819
    }
820
    else {
821
      if(!FLAC__bitwriter_write_raw_uint32(bw, r, k))
822
        return false;
823
    }
824
  }
825
  return true;
826
}
827
#endif /* UNUSED */
828
829
FLAC__bool FLAC__bitwriter_write_utf8_uint32(FLAC__BitWriter *bw, FLAC__uint32 val)
830
0
{
831
0
  FLAC__bool ok = 1;
832
833
0
  FLAC__ASSERT(0 != bw);
834
0
  FLAC__ASSERT(0 != bw->buffer);
835
836
0
  if((val & 0x80000000) != 0) /* this version only handles 31 bits */
837
0
    return false;
838
839
0
  if(val < 0x80) {
840
0
    return FLAC__bitwriter_write_raw_uint32_nocheck(bw, val, 8);
841
0
  }
842
0
  else if(val < 0x800) {
843
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0xC0 | (val>>6), 8);
844
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | (val&0x3F), 8);
845
0
  }
846
0
  else if(val < 0x10000) {
847
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0xE0 | (val>>12), 8);
848
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | ((val>>6)&0x3F), 8);
849
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | (val&0x3F), 8);
850
0
  }
851
0
  else if(val < 0x200000) {
852
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0xF0 | (val>>18), 8);
853
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | ((val>>12)&0x3F), 8);
854
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | ((val>>6)&0x3F), 8);
855
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | (val&0x3F), 8);
856
0
  }
857
0
  else if(val < 0x4000000) {
858
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0xF8 | (val>>24), 8);
859
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | ((val>>18)&0x3F), 8);
860
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | ((val>>12)&0x3F), 8);
861
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | ((val>>6)&0x3F), 8);
862
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | (val&0x3F), 8);
863
0
  }
864
0
  else {
865
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0xFC | (val>>30), 8);
866
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | ((val>>24)&0x3F), 8);
867
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | ((val>>18)&0x3F), 8);
868
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | ((val>>12)&0x3F), 8);
869
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | ((val>>6)&0x3F), 8);
870
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | (val&0x3F), 8);
871
0
  }
872
873
0
  return ok;
874
0
}
875
876
FLAC__bool FLAC__bitwriter_write_utf8_uint64(FLAC__BitWriter *bw, FLAC__uint64 val)
877
0
{
878
0
  FLAC__bool ok = 1;
879
880
0
  FLAC__ASSERT(0 != bw);
881
0
  FLAC__ASSERT(0 != bw->buffer);
882
883
0
  if((val & FLAC__U64L(0xFFFFFFF000000000)) != 0) /* this version only handles 36 bits */
884
0
    return false;
885
886
0
  if(val < 0x80) {
887
0
    return FLAC__bitwriter_write_raw_uint32_nocheck(bw, (FLAC__uint32)val, 8);
888
0
  }
889
0
  else if(val < 0x800) {
890
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0xC0 | (FLAC__uint32)(val>>6), 8);
891
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | (FLAC__uint32)(val&0x3F), 8);
892
0
  }
893
0
  else if(val < 0x10000) {
894
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0xE0 | (FLAC__uint32)(val>>12), 8);
895
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | (FLAC__uint32)((val>>6)&0x3F), 8);
896
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | (FLAC__uint32)(val&0x3F), 8);
897
0
  }
898
0
  else if(val < 0x200000) {
899
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0xF0 | (FLAC__uint32)(val>>18), 8);
900
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | (FLAC__uint32)((val>>12)&0x3F), 8);
901
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | (FLAC__uint32)((val>>6)&0x3F), 8);
902
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | (FLAC__uint32)(val&0x3F), 8);
903
0
  }
904
0
  else if(val < 0x4000000) {
905
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0xF8 | (FLAC__uint32)(val>>24), 8);
906
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | (FLAC__uint32)((val>>18)&0x3F), 8);
907
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | (FLAC__uint32)((val>>12)&0x3F), 8);
908
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | (FLAC__uint32)((val>>6)&0x3F), 8);
909
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | (FLAC__uint32)(val&0x3F), 8);
910
0
  }
911
0
  else if(val < 0x80000000) {
912
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0xFC | (FLAC__uint32)(val>>30), 8);
913
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | (FLAC__uint32)((val>>24)&0x3F), 8);
914
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | (FLAC__uint32)((val>>18)&0x3F), 8);
915
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | (FLAC__uint32)((val>>12)&0x3F), 8);
916
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | (FLAC__uint32)((val>>6)&0x3F), 8);
917
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | (FLAC__uint32)(val&0x3F), 8);
918
0
  }
919
0
  else {
920
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0xFE, 8);
921
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | (FLAC__uint32)((val>>30)&0x3F), 8);
922
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | (FLAC__uint32)((val>>24)&0x3F), 8);
923
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | (FLAC__uint32)((val>>18)&0x3F), 8);
924
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | (FLAC__uint32)((val>>12)&0x3F), 8);
925
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | (FLAC__uint32)((val>>6)&0x3F), 8);
926
0
    ok &= FLAC__bitwriter_write_raw_uint32_nocheck(bw, 0x80 | (FLAC__uint32)(val&0x3F), 8);
927
0
  }
928
929
0
  return ok;
930
0
}
931
932
FLAC__bool FLAC__bitwriter_zero_pad_to_byte_boundary(FLAC__BitWriter *bw)
933
0
{
934
  /* 0-pad to byte boundary */
935
0
  if(bw->bits & 7u)
936
0
    return FLAC__bitwriter_write_zeroes(bw, 8 - (bw->bits & 7u));
937
0
  else
938
0
    return true;
939
0
}
940
941
/* These functions are declared inline in this file but are also callable as
942
 * externs from elsewhere.
943
 * According to the C99 spec, section 6.7.4, simply providing a function
944
 * prototype in a header file without 'inline' and making the function inline
945
 * in this file should be sufficient.
946
 * Unfortunately, the Microsoft VS compiler doesn't pick them up externally. To
947
 * fix that we add extern declarations here.
948
 */
949
extern FLAC__bool FLAC__bitwriter_write_zeroes(FLAC__BitWriter *bw, uint32_t bits);
950
extern FLAC__bool FLAC__bitwriter_write_raw_uint32(FLAC__BitWriter *bw, FLAC__uint32 val, uint32_t bits);
951
extern FLAC__bool FLAC__bitwriter_write_raw_int32(FLAC__BitWriter *bw, FLAC__int32 val, uint32_t bits);
952
extern FLAC__bool FLAC__bitwriter_write_raw_uint64(FLAC__BitWriter *bw, FLAC__uint64 val, uint32_t bits);
953
extern FLAC__bool FLAC__bitwriter_write_raw_int64(FLAC__BitWriter *bw, FLAC__int64 val, uint32_t bits);
954
extern FLAC__bool FLAC__bitwriter_write_raw_uint32_little_endian(FLAC__BitWriter *bw, FLAC__uint32 val);
955
extern FLAC__bool FLAC__bitwriter_write_byte_block(FLAC__BitWriter *bw, const FLAC__byte vals[], uint32_t nvals);