dsd2pcm: move the bit reversing code to a generic library
Instead of doing run-time initialisation, use a constant lookup table.
This commit is contained in:
parent
08ce24ec3f
commit
c1d0a8b5ce
@ -227,6 +227,7 @@ src_mpd_SOURCES = \
|
|||||||
$(MIXER_API_SRC) \
|
$(MIXER_API_SRC) \
|
||||||
src/util/list.h \
|
src/util/list.h \
|
||||||
src/util/list_sort.c src/util/list_sort.h \
|
src/util/list_sort.c src/util/list_sort.h \
|
||||||
|
src/util/bit_reverse.c src/util/bit_reverse.h \
|
||||||
src/glib_socket.h \
|
src/glib_socket.h \
|
||||||
src/notify.c \
|
src/notify.c \
|
||||||
src/audio_config.c src/audio_config.h \
|
src/audio_config.c src/audio_config.h \
|
||||||
@ -1174,6 +1175,7 @@ test_run_normalize_LDADD = \
|
|||||||
$(GLIB_LIBS)
|
$(GLIB_LIBS)
|
||||||
|
|
||||||
test_run_convert_SOURCES = test/run_convert.c \
|
test_run_convert_SOURCES = test/run_convert.c \
|
||||||
|
src/util/bit_reverse.c \
|
||||||
src/dsd2pcm/dsd2pcm.c \
|
src/dsd2pcm/dsd2pcm.c \
|
||||||
src/fifo_buffer.c \
|
src/fifo_buffer.c \
|
||||||
src/audio_format.c \
|
src/audio_format.c \
|
||||||
@ -1272,6 +1274,7 @@ if HAVE_CXX
|
|||||||
noinst_PROGRAMS += src/dsd2pcm/dsd2pcm
|
noinst_PROGRAMS += src/dsd2pcm/dsd2pcm
|
||||||
|
|
||||||
src_dsd2pcm_dsd2pcm_SOURCES = \
|
src_dsd2pcm_dsd2pcm_SOURCES = \
|
||||||
|
src/util/bit_reverse.c \
|
||||||
src/dsd2pcm/dsd2pcm.c src/dsd2pcm/dsd2pcm.h \
|
src/dsd2pcm/dsd2pcm.c src/dsd2pcm/dsd2pcm.h \
|
||||||
src/dsd2pcm/noiseshape.c src/dsd2pcm/noiseshape.h \
|
src/dsd2pcm/noiseshape.c src/dsd2pcm/noiseshape.h \
|
||||||
src/dsd2pcm/main.cpp
|
src/dsd2pcm/main.cpp
|
||||||
|
@ -1,3 +1,5 @@
|
|||||||
|
#include "util/bit_reverse.h"
|
||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
@ -84,7 +86,6 @@ static const double htaps[HTAPS] = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
static float ctables[CTABLES][256];
|
static float ctables[CTABLES][256];
|
||||||
static unsigned char bitreverse[256];
|
|
||||||
static int precalculated = 0;
|
static int precalculated = 0;
|
||||||
|
|
||||||
static void precalc(void)
|
static void precalc(void)
|
||||||
@ -92,11 +93,6 @@ static void precalc(void)
|
|||||||
int t, e, m, k;
|
int t, e, m, k;
|
||||||
double acc;
|
double acc;
|
||||||
if (precalculated) return;
|
if (precalculated) return;
|
||||||
for (t=0, e=0; t<256; ++t) {
|
|
||||||
bitreverse[t] = e;
|
|
||||||
for (m=128; m && !((e^=m)&m); m>>=1)
|
|
||||||
;
|
|
||||||
}
|
|
||||||
for (t=0; t<CTABLES; ++t) {
|
for (t=0; t<CTABLES; ++t) {
|
||||||
k = HTAPS - t*8;
|
k = HTAPS - t*8;
|
||||||
if (k>8) k=8;
|
if (k>8) k=8;
|
||||||
@ -170,10 +166,10 @@ extern void dsd2pcm_translate(
|
|||||||
lsbf = lsbf ? 1 : 0;
|
lsbf = lsbf ? 1 : 0;
|
||||||
while (samples-- > 0) {
|
while (samples-- > 0) {
|
||||||
bite1 = *src & 0xFFu;
|
bite1 = *src & 0xFFu;
|
||||||
if (lsbf) bite1 = bitreverse[bite1];
|
if (lsbf) bite1 = bit_reverse(bite1);
|
||||||
ptr->fifo[ffp] = bite1; src += src_stride;
|
ptr->fifo[ffp] = bite1; src += src_stride;
|
||||||
p = ptr->fifo + ((ffp-CTABLES) & FIFOMASK);
|
p = ptr->fifo + ((ffp-CTABLES) & FIFOMASK);
|
||||||
*p = bitreverse[*p & 0xFF];
|
*p = bit_reverse(*p);
|
||||||
acc = 0;
|
acc = 0;
|
||||||
for (i=0; i<CTABLES; ++i) {
|
for (i=0; i<CTABLES; ++i) {
|
||||||
bite1 = ptr->fifo[(ffp -i) & FIFOMASK] & 0xFF;
|
bite1 = ptr->fifo[(ffp -i) & FIFOMASK] & 0xFF;
|
||||||
|
31
src/util/bit_reverse.c
Normal file
31
src/util/bit_reverse.c
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2003-2012 The Music Player Daemon Project
|
||||||
|
* http://www.musicpd.org
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along
|
||||||
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "bit_reverse.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @see http://graphics.stanford.edu/~seander/bithacks.html#BitReverseTable
|
||||||
|
*/
|
||||||
|
const uint8_t bit_reverse_table[256] =
|
||||||
|
{
|
||||||
|
#define R2(n) n, n + 2*64, n + 1*64, n + 3*64
|
||||||
|
#define R4(n) R2(n), R2(n + 2*16), R2(n + 1*16), R2(n + 3*16)
|
||||||
|
#define R6(n) R4(n), R4(n + 2*4 ), R4(n + 1*4 ), R4(n + 3*4 )
|
||||||
|
R6(0), R6(2), R6(1), R6(3)
|
||||||
|
};
|
35
src/util/bit_reverse.h
Normal file
35
src/util/bit_reverse.h
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2003-2012 The Music Player Daemon Project
|
||||||
|
* http://www.musicpd.org
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along
|
||||||
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef MPD_BIT_REVERSE_H
|
||||||
|
#define MPD_BIT_REVERSE_H
|
||||||
|
|
||||||
|
#include <glib.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
|
extern const uint8_t bit_reverse_table[256];
|
||||||
|
|
||||||
|
G_GNUC_CONST
|
||||||
|
static inline uint8_t
|
||||||
|
bit_reverse(uint8_t x)
|
||||||
|
{
|
||||||
|
return bit_reverse_table[x];
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
Loading…
Reference in New Issue
Block a user