mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-24 18:02:02 +01:00
audio/mp3: Move t_mpeg1_header to Go
This commit is contained in:
parent
a0af1595de
commit
ab8a9a1e36
@ -17,8 +17,6 @@
|
||||
package mp3
|
||||
|
||||
// #include "pdmp3.h"
|
||||
//
|
||||
// extern t_mpeg1_header g_frame_header;
|
||||
import "C"
|
||||
|
||||
import (
|
||||
@ -37,7 +35,7 @@ func decodeL3() error {
|
||||
out := make([]uint32, 576)
|
||||
// Number of channels(1 for mono and 2 for stereo)
|
||||
nch := 2
|
||||
if C.g_frame_header.mode == C.mpeg1_mode_single_channel {
|
||||
if theMPEG1FrameHeader.mode == mpeg1ModeSingleChannel {
|
||||
nch = 1
|
||||
}
|
||||
for gr := 0; gr < 2; gr++ {
|
||||
@ -64,7 +62,7 @@ func decodeL3() error {
|
||||
|
||||
func audioWriteRaw(samples []uint32) error {
|
||||
nch := 2
|
||||
if C.g_frame_header.mode == C.mpeg1_mode_single_channel {
|
||||
if theMPEG1FrameHeader.mode == mpeg1ModeSingleChannel {
|
||||
nch = 1
|
||||
}
|
||||
s := make([]uint8, len(samples)*2*nch)
|
||||
|
@ -17,8 +17,6 @@
|
||||
package mp3
|
||||
|
||||
// #include "pdmp3.h"
|
||||
//
|
||||
// extern t_mpeg1_header g_frame_header;
|
||||
import "C"
|
||||
|
||||
import (
|
||||
@ -102,7 +100,7 @@ var (
|
||||
|
||||
func l3Requantize(gr int, ch int) {
|
||||
/* Setup sampling frequency index */
|
||||
sfreq := C.g_frame_header.sampling_frequency
|
||||
sfreq := theMPEG1FrameHeader.sampling_frequency
|
||||
/* Determine type of block to process */
|
||||
if (theMPEG1SideInfo.win_switch_flag[gr][ch] == 1) && (theMPEG1SideInfo.block_type[gr][ch] == 2) { /* Short blocks */
|
||||
/* Check if the first two subbands
|
||||
@ -177,7 +175,7 @@ func l3Requantize(gr int, ch int) {
|
||||
func l3Reorder(gr int, ch int) {
|
||||
re := make([]float32, 576)
|
||||
|
||||
sfreq := C.g_frame_header.sampling_frequency /* Setup sampling freq index */
|
||||
sfreq := theMPEG1FrameHeader.sampling_frequency /* Setup sampling freq index */
|
||||
/* Only reorder short blocks */
|
||||
if (theMPEG1SideInfo.win_switch_flag[gr][ch] == 1) && (theMPEG1SideInfo.block_type[gr][ch] == 2) { /* Short blocks */
|
||||
/* Check if the first two subbands
|
||||
@ -232,7 +230,7 @@ func stereoProcessIntensityLong(gr int, sfb int) {
|
||||
/* Check that((is_pos[sfb]=scalefac) != 7) => no intensity stereo */
|
||||
is_pos := theMPEG1MainData.scalefac_l[gr][0][sfb]
|
||||
if is_pos != 7 {
|
||||
sfreq := C.g_frame_header.sampling_frequency /* Setup sampling freq index */
|
||||
sfreq := theMPEG1FrameHeader.sampling_frequency /* Setup sampling freq index */
|
||||
sfb_start := sfBandIndicesSet[sfreq].l[sfb]
|
||||
sfb_stop := sfBandIndicesSet[sfreq].l[sfb+1]
|
||||
if is_pos == 6 { /* tan((6*PI)/12 = PI/2) needs special treatment! */
|
||||
@ -253,7 +251,7 @@ func stereoProcessIntensityLong(gr int, sfb int) {
|
||||
func stereoProcessIntensityShort(gr int, sfb int) {
|
||||
is_ratio_l := float32(0)
|
||||
is_ratio_r := float32(0)
|
||||
sfreq := C.g_frame_header.sampling_frequency /* Setup sampling freq index */
|
||||
sfreq := theMPEG1FrameHeader.sampling_frequency /* Setup sampling freq index */
|
||||
/* The window length */
|
||||
win_len := sfBandIndicesSet[sfreq].s[sfb+1] - sfBandIndicesSet[sfreq].s[sfb]
|
||||
/* The three windows within the band has different scalefactors */
|
||||
@ -282,11 +280,11 @@ func stereoProcessIntensityShort(gr int, sfb int) {
|
||||
|
||||
func l3Stereo(gr int) {
|
||||
/* Do nothing if joint stereo is not enabled */
|
||||
if (C.g_frame_header.mode != 1) || (C.g_frame_header.mode_extension == 0) {
|
||||
if (theMPEG1FrameHeader.mode != 1) || (theMPEG1FrameHeader.mode_extension == 0) {
|
||||
return
|
||||
}
|
||||
/* Do Middle/Side("normal") stereo processing */
|
||||
if (C.g_frame_header.mode_extension & 0x2) != 0 {
|
||||
if (theMPEG1FrameHeader.mode_extension & 0x2) != 0 {
|
||||
/* Determine how many frequency lines to transform */
|
||||
i := 0
|
||||
if theMPEG1SideInfo.count1[gr][0] > theMPEG1SideInfo.count1[gr][1] {
|
||||
@ -303,9 +301,9 @@ func l3Stereo(gr int) {
|
||||
}
|
||||
}
|
||||
/* Do intensity stereo processing */
|
||||
if (C.g_frame_header.mode_extension & 0x1) != 0 {
|
||||
if (theMPEG1FrameHeader.mode_extension & 0x1) != 0 {
|
||||
/* Setup sampling frequency index */
|
||||
sfreq := C.g_frame_header.sampling_frequency
|
||||
sfreq := theMPEG1FrameHeader.sampling_frequency
|
||||
/* First band that is intensity stereo encoded is first band scale factor
|
||||
* band on or above count1 frequency line. N.B.: Intensity stereo coding is
|
||||
* only done for higher subbands, but logic is here for lower subbands. */
|
||||
@ -562,7 +560,7 @@ func l3SubbandSynthesis(gr int, ch int, out []uint32) {
|
||||
|
||||
/* Number of channels(1 for mono and 2 for stereo) */
|
||||
nch := 2
|
||||
if C.g_frame_header.mode == C.mpeg1_mode_single_channel {
|
||||
if theMPEG1FrameHeader.mode == mpeg1ModeSingleChannel {
|
||||
nch = 1
|
||||
}
|
||||
/* Setup the n_win windowing vector and the v_vec intermediate vector */
|
||||
|
@ -17,8 +17,6 @@
|
||||
package mp3
|
||||
|
||||
// #include "pdmp3.h"
|
||||
//
|
||||
// extern t_mpeg1_header g_frame_header;
|
||||
import "C"
|
||||
|
||||
import (
|
||||
@ -34,15 +32,15 @@ var mpeg1_scalefac_sizes = [16][2]int{
|
||||
func readMainL3() error {
|
||||
/* Number of channels(1 for mono and 2 for stereo) */
|
||||
nch := 2
|
||||
if C.g_frame_header.mode == C.mpeg1_mode_single_channel {
|
||||
if theMPEG1FrameHeader.mode == mpeg1ModeSingleChannel {
|
||||
nch = 1
|
||||
}
|
||||
|
||||
/* Calculate header audio data size */
|
||||
framesize := (144*
|
||||
g_mpeg1_bitrates[C.g_frame_header.layer-1][C.g_frame_header.bitrate_index])/
|
||||
g_sampling_frequency[C.g_frame_header.sampling_frequency] +
|
||||
int(C.g_frame_header.padding_bit)
|
||||
g_mpeg1_bitrates[theMPEG1FrameHeader.layer-1][theMPEG1FrameHeader.bitrate_index])/
|
||||
g_sampling_frequency[theMPEG1FrameHeader.sampling_frequency] +
|
||||
int(theMPEG1FrameHeader.padding_bit)
|
||||
|
||||
if framesize > 2000 {
|
||||
return fmt.Errorf("mp3: framesize = %d", framesize)
|
||||
@ -55,7 +53,7 @@ func readMainL3() error {
|
||||
/* Main data size is the rest of the frame,including ancillary data */
|
||||
main_data_size := framesize - sideinfo_size - 4 /* sync+header */
|
||||
/* CRC is 2 bytes */
|
||||
if C.g_frame_header.protection_bit == 0 {
|
||||
if theMPEG1FrameHeader.protection_bit == 0 {
|
||||
main_data_size -= 2
|
||||
}
|
||||
/* Assemble main data buffer with data from this frame and the previous
|
||||
|
@ -59,8 +59,6 @@ g_sampling_frequency[3] = { 44100 * Hz,48000 * Hz,32000 * Hz };
|
||||
|
||||
unsigned synth_init = 1;
|
||||
|
||||
t_mpeg1_header g_frame_header;
|
||||
|
||||
#ifdef DEBUG
|
||||
static void dmp_fr(t_mpeg1_header *hdr){
|
||||
printf("rate %d,sfreq %d,pad %d,mod %d,modext %d,emph %d\n",
|
||||
|
@ -16,36 +16,4 @@
|
||||
#define TRUE 1
|
||||
#define FALSE 0
|
||||
|
||||
/* Types used in the frame header */
|
||||
typedef enum { /* Layer number */
|
||||
mpeg1_layer_reserved = 0,
|
||||
mpeg1_layer_3 = 1,
|
||||
mpeg1_layer_2 = 2,
|
||||
mpeg1_layer_1 = 3
|
||||
}
|
||||
t_mpeg1_layer;
|
||||
typedef enum { /* Modes */
|
||||
mpeg1_mode_stereo = 0,
|
||||
mpeg1_mode_joint_stereo,
|
||||
mpeg1_mode_dual_channel,
|
||||
mpeg1_mode_single_channel
|
||||
}
|
||||
t_mpeg1_mode;
|
||||
|
||||
typedef struct { /* MPEG1 Layer 1-3 frame header */
|
||||
unsigned id; /* 1 bit */
|
||||
t_mpeg1_layer layer; /* 2 bits */
|
||||
unsigned protection_bit; /* 1 bit */
|
||||
unsigned bitrate_index; /* 4 bits */
|
||||
unsigned sampling_frequency; /* 2 bits */
|
||||
unsigned padding_bit; /* 1 bit */
|
||||
unsigned private_bit; /* 1 bit */
|
||||
t_mpeg1_mode mode; /* 2 bits */
|
||||
unsigned mode_extension; /* 2 bits */
|
||||
unsigned copyright; /* 1 bit */
|
||||
unsigned original_or_copy; /* 1 bit */
|
||||
unsigned emphasis; /* 2 bits */
|
||||
}
|
||||
t_mpeg1_header;
|
||||
|
||||
#endif
|
||||
|
@ -17,8 +17,6 @@
|
||||
package mp3
|
||||
|
||||
// #include "pdmp3.h"
|
||||
//
|
||||
// extern t_mpeg1_header g_frame_header;
|
||||
import "C"
|
||||
|
||||
import (
|
||||
@ -52,14 +50,14 @@ func readFrame() error {
|
||||
return err
|
||||
}
|
||||
// Get CRC word if present
|
||||
if C.g_frame_header.protection_bit == 0 {
|
||||
if theMPEG1FrameHeader.protection_bit == 0 {
|
||||
if err := readCRC(); err != nil {
|
||||
return err
|
||||
}
|
||||
}
|
||||
|
||||
if C.g_frame_header.layer != 3 {
|
||||
return fmt.Errorf("mp3: Only layer 3(!= %d) is supported!", C.g_frame_header.layer)
|
||||
if theMPEG1FrameHeader.layer != 3 {
|
||||
return fmt.Errorf("mp3: Only layer 3(!= %d) is supported!", theMPEG1FrameHeader.layer)
|
||||
}
|
||||
// Get side info
|
||||
if err := readAudioL3(); err != nil {
|
||||
@ -131,40 +129,40 @@ func readHeader() error {
|
||||
/* If we get here we've found the sync word,and can decode the header
|
||||
* which is in the low 20 bits of the 32-bit sync+header word. */
|
||||
/* Decode the header */
|
||||
C.g_frame_header.id = C.uint((header & 0x00180000) >> 19)
|
||||
C.g_frame_header.layer = C.t_mpeg1_layer((header & 0x00060000) >> 17)
|
||||
C.g_frame_header.protection_bit = C.uint((header & 0x00010000) >> 16)
|
||||
C.g_frame_header.bitrate_index = C.uint((header & 0x0000f000) >> 12)
|
||||
C.g_frame_header.sampling_frequency = C.uint((header & 0x00000c00) >> 10)
|
||||
C.g_frame_header.padding_bit = C.uint((header & 0x00000200) >> 9)
|
||||
C.g_frame_header.private_bit = C.uint((header & 0x00000100) >> 8)
|
||||
C.g_frame_header.mode = C.t_mpeg1_mode((header & 0x000000c0) >> 6)
|
||||
C.g_frame_header.mode_extension = C.uint((header & 0x00000030) >> 4)
|
||||
C.g_frame_header.copyright = C.uint((header & 0x00000008) >> 3)
|
||||
C.g_frame_header.original_or_copy = C.uint((header & 0x00000004) >> 2)
|
||||
C.g_frame_header.emphasis = C.uint((header & 0x00000003) >> 0)
|
||||
theMPEG1FrameHeader.id = int((header & 0x00180000) >> 19)
|
||||
theMPEG1FrameHeader.layer = mpeg1Layer((header & 0x00060000) >> 17)
|
||||
theMPEG1FrameHeader.protection_bit = int((header & 0x00010000) >> 16)
|
||||
theMPEG1FrameHeader.bitrate_index = int((header & 0x0000f000) >> 12)
|
||||
theMPEG1FrameHeader.sampling_frequency = int((header & 0x00000c00) >> 10)
|
||||
theMPEG1FrameHeader.padding_bit = int((header & 0x00000200) >> 9)
|
||||
theMPEG1FrameHeader.private_bit = int((header & 0x00000100) >> 8)
|
||||
theMPEG1FrameHeader.mode = mpeg1Mode((header & 0x000000c0) >> 6)
|
||||
theMPEG1FrameHeader.mode_extension = int((header & 0x00000030) >> 4)
|
||||
theMPEG1FrameHeader.copyright = int((header & 0x00000008) >> 3)
|
||||
theMPEG1FrameHeader.original_or_copy = int((header & 0x00000004) >> 2)
|
||||
theMPEG1FrameHeader.emphasis = int((header & 0x00000003) >> 0)
|
||||
/* Check for invalid values and impossible combinations */
|
||||
if C.g_frame_header.id != 3 {
|
||||
if theMPEG1FrameHeader.id != 3 {
|
||||
return fmt.Errorf("mp3: ID must be 3\nHeader word is 0x%08x at file pos %d",
|
||||
header, getFilepos())
|
||||
}
|
||||
if C.g_frame_header.bitrate_index == 0 {
|
||||
if theMPEG1FrameHeader.bitrate_index == 0 {
|
||||
return fmt.Errorf("mp3: Free bitrate format NIY!\nHeader word is 0x%08x at file pos %d",
|
||||
header, getFilepos())
|
||||
}
|
||||
if C.g_frame_header.bitrate_index == 15 {
|
||||
if theMPEG1FrameHeader.bitrate_index == 15 {
|
||||
return fmt.Errorf("mp3: bitrate_index = 15 is invalid!\nHeader word is 0x%08x at file pos %d",
|
||||
header, getFilepos())
|
||||
}
|
||||
if C.g_frame_header.sampling_frequency == 3 {
|
||||
if theMPEG1FrameHeader.sampling_frequency == 3 {
|
||||
return fmt.Errorf("mp3: sampling_frequency = 3 is invalid! Header word is 0x%08x at file pos %d",
|
||||
header, getFilepos())
|
||||
}
|
||||
if C.g_frame_header.layer == 0 {
|
||||
if theMPEG1FrameHeader.layer == 0 {
|
||||
return fmt.Errorf("mp3: layer = 0 is invalid! Header word is 0x%08x at file pos %d",
|
||||
header, getFilepos())
|
||||
}
|
||||
C.g_frame_header.layer = 4 - C.g_frame_header.layer
|
||||
theMPEG1FrameHeader.layer = 4 - theMPEG1FrameHeader.layer
|
||||
return nil
|
||||
}
|
||||
|
||||
@ -185,7 +183,7 @@ func readHuffman(part_2_start, gr, ch int) error {
|
||||
region_1_start = 36 /* sfb[9/3]*3=36 */
|
||||
region_2_start = 576 /* No Region2 for short block case. */
|
||||
} else {
|
||||
sfreq := C.g_frame_header.sampling_frequency
|
||||
sfreq := theMPEG1FrameHeader.sampling_frequency
|
||||
region_1_start =
|
||||
sfBandIndicesSet[sfreq].l[theMPEG1SideInfo.region0_count[gr][ch]+1]
|
||||
region_2_start =
|
||||
@ -193,7 +191,7 @@ func readHuffman(part_2_start, gr, ch int) error {
|
||||
theMPEG1SideInfo.region1_count[gr][ch]+2]
|
||||
}
|
||||
/* Read big_values using tables according to region_x_start */
|
||||
for is_pos := 0; is_pos < int(theMPEG1SideInfo.big_values[gr][ch])*2; is_pos++ {
|
||||
for is_pos := 0; is_pos < theMPEG1SideInfo.big_values[gr][ch]*2; is_pos++ {
|
||||
table_num := 0
|
||||
if is_pos < region_1_start {
|
||||
table_num = int(theMPEG1SideInfo.table_select[gr][ch][0])
|
||||
|
@ -17,8 +17,6 @@
|
||||
package mp3
|
||||
|
||||
// #include "pdmp3.h"
|
||||
//
|
||||
// extern t_mpeg1_header g_frame_header;
|
||||
import "C"
|
||||
|
||||
import (
|
||||
@ -45,14 +43,14 @@ var g_sampling_frequency = [3]int{44100, 48000, 32000}
|
||||
|
||||
func readAudioL3() error {
|
||||
nch := 2
|
||||
if C.g_frame_header.mode == C.mpeg1_mode_single_channel {
|
||||
if theMPEG1FrameHeader.mode == mpeg1ModeSingleChannel {
|
||||
nch = 1
|
||||
}
|
||||
/* Calculate header audio data size */
|
||||
framesize := (144*
|
||||
g_mpeg1_bitrates[C.g_frame_header.layer-1][C.g_frame_header.bitrate_index])/
|
||||
g_sampling_frequency[C.g_frame_header.sampling_frequency] +
|
||||
int(C.g_frame_header.padding_bit)
|
||||
g_mpeg1_bitrates[theMPEG1FrameHeader.layer-1][theMPEG1FrameHeader.bitrate_index])/
|
||||
g_sampling_frequency[theMPEG1FrameHeader.sampling_frequency] +
|
||||
int(theMPEG1FrameHeader.padding_bit)
|
||||
if framesize > 2000 {
|
||||
return fmt.Errorf("mp3: framesize = %d\n", framesize)
|
||||
}
|
||||
@ -64,7 +62,7 @@ func readAudioL3() error {
|
||||
/* Main data size is the rest of the frame,including ancillary data */
|
||||
main_data_size := framesize - sideinfo_size - 4 /* sync+header */
|
||||
/* CRC is 2 bytes */
|
||||
if C.g_frame_header.protection_bit == 0 {
|
||||
if theMPEG1FrameHeader.protection_bit == 0 {
|
||||
main_data_size -= 2
|
||||
}
|
||||
/* Read sideinfo from bitstream into buffer used by getSideBits() */
|
||||
@ -75,7 +73,7 @@ func readAudioL3() error {
|
||||
/* Pointer to where we should start reading main data */
|
||||
theMPEG1SideInfo.main_data_begin = getSideBits(9)
|
||||
/* Get private bits. Not used for anything. */
|
||||
if C.g_frame_header.mode == C.mpeg1_mode_single_channel {
|
||||
if theMPEG1FrameHeader.mode == mpeg1ModeSingleChannel {
|
||||
theMPEG1SideInfo.private_bits = getSideBits(5)
|
||||
} else {
|
||||
theMPEG1SideInfo.private_bits = getSideBits(3)
|
||||
|
Loading…
Reference in New Issue
Block a user