Unverified Commit 70a1311d authored by Wolle's avatar Wolle Committed by GitHub

Add files via upload

parent 5f445854
...@@ -2898,7 +2898,7 @@ void Audio::processWebStream() { ...@@ -2898,7 +2898,7 @@ void Audio::processWebStream() {
AUDIO_INFO("stream ready"); AUDIO_INFO("stream ready");
} }
if(!f_stream) return; if(!f_stream) return;
if(m_codec == CODEC_OGG){ log_i("determine correct codec here"); if(m_codec == CODEC_OGG){ // log_i("determine correct codec here");
uint8_t codec = determineOggCodec(InBuff.getReadPtr(), maxFrameSize); uint8_t codec = determineOggCodec(InBuff.getReadPtr(), maxFrameSize);
if(codec == CODEC_FLAC) {m_codec = CODEC_FLAC; initializeDecoder(); return;} if(codec == CODEC_FLAC) {m_codec = CODEC_FLAC; initializeDecoder(); return;}
if(codec == CODEC_OPUS) {m_codec = CODEC_OPUS; initializeDecoder(); return;} if(codec == CODEC_OPUS) {m_codec = CODEC_OPUS; initializeDecoder(); return;}
......
...@@ -19,24 +19,25 @@ FLACFrameHeader_t *FLACFrameHeader; ...@@ -19,24 +19,25 @@ FLACFrameHeader_t *FLACFrameHeader;
FLACMetadataBlock_t *FLACMetadataBlock; FLACMetadataBlock_t *FLACMetadataBlock;
FLACsubFramesBuff_t *FLACsubFramesBuff; FLACsubFramesBuff_t *FLACsubFramesBuff;
vector<int32_t>coefs; vector<int32_t> coefs;
const uint16_t outBuffSize = 2048; const uint16_t outBuffSize = 2048;
uint16_t m_blockSize=0; uint16_t m_blockSize = 0;
uint16_t m_blockSizeLeft = 0; uint16_t m_blockSizeLeft = 0;
uint16_t m_validSamples = 0; uint16_t m_validSamples = 0;
uint8_t m_status = 0; uint8_t m_status = 0;
uint8_t* m_inptr; uint8_t *m_inptr;
int16_t m_bytesAvail; int16_t m_bytesAvail;
int16_t m_bytesDecoded = 0; int16_t m_bytesDecoded = 0;
uint16_t *s_flacSegmentTable = NULL;
float m_compressionRatio = 0; float m_compressionRatio = 0;
uint16_t m_rIndex=0; uint16_t m_rIndex = 0;
uint64_t m_bitBuffer = 0; uint64_t m_bitBuffer = 0;
uint8_t m_bitBufferLen = 0; uint8_t m_bitBufferLen = 0;
bool s_f_flacParseOgg = false; bool s_f_flacParseOgg = false;
uint8_t m_flacPageSegments = 0; uint8_t m_flacPageSegments = 0;
uint8_t m_page0_len = 0; uint8_t m_page0_len = 0;
char *m_streamTitle= NULL; char *m_streamTitle = NULL;
boolean m_newSt = false; boolean s_f_newSt = false;
//---------------------------------------------------------------------------------------------------------------------- //----------------------------------------------------------------------------------------------------------------------
// FLAC INI SECTION // FLAC INI SECTION
...@@ -48,14 +49,17 @@ bool FLACDecoder_AllocateBuffers(void){ ...@@ -48,14 +49,17 @@ bool FLACDecoder_AllocateBuffers(void){
if(!FLACMetadataBlock) {FLACMetadataBlock = (FLACMetadataBlock_t*) ps_malloc(sizeof(FLACMetadataBlock_t));} if(!FLACMetadataBlock) {FLACMetadataBlock = (FLACMetadataBlock_t*) ps_malloc(sizeof(FLACMetadataBlock_t));}
if(!FLACsubFramesBuff) {FLACsubFramesBuff = (FLACsubFramesBuff_t*) ps_malloc(sizeof(FLACsubFramesBuff_t));} if(!FLACsubFramesBuff) {FLACsubFramesBuff = (FLACsubFramesBuff_t*) ps_malloc(sizeof(FLACsubFramesBuff_t));}
if(!m_streamTitle) {m_streamTitle = (char*) ps_malloc(256);} if(!m_streamTitle) {m_streamTitle = (char*) ps_malloc(256);}
if(!s_flacSegmentTable) {s_flacSegmentTable = (uint16_t*) ps_malloc(256 * sizeof(uint16_t));}
} }
else { else {
if(!FLACFrameHeader) {FLACFrameHeader = (FLACFrameHeader_t*) malloc(sizeof(FLACFrameHeader_t));} if(!FLACFrameHeader) {FLACFrameHeader = (FLACFrameHeader_t*) malloc(sizeof(FLACFrameHeader_t));}
if(!FLACMetadataBlock) {FLACMetadataBlock = (FLACMetadataBlock_t*) malloc(sizeof(FLACMetadataBlock_t));} if(!FLACMetadataBlock) {FLACMetadataBlock = (FLACMetadataBlock_t*) malloc(sizeof(FLACMetadataBlock_t));}
if(!FLACsubFramesBuff) {FLACsubFramesBuff = (FLACsubFramesBuff_t*) malloc(sizeof(FLACsubFramesBuff_t));} if(!FLACsubFramesBuff) {FLACsubFramesBuff = (FLACsubFramesBuff_t*) malloc(sizeof(FLACsubFramesBuff_t));}
if(!m_streamTitle) {m_streamTitle = (char*) malloc(256);} if(!m_streamTitle) {m_streamTitle = (char*) malloc(256);}
if(!s_flacSegmentTable) {s_flacSegmentTable = (uint16_t*) malloc(256 * sizeof(uint16_t));}
} }
if(!FLACFrameHeader || !FLACMetadataBlock || !FLACsubFramesBuff || !m_streamTitle){ if(!FLACFrameHeader || !FLACMetadataBlock || !FLACsubFramesBuff || !m_streamTitle || !s_flacSegmentTable){
log_e("not enough memory to allocate flacdecoder buffers"); log_e("not enough memory to allocate flacdecoder buffers");
return false; return false;
} }
...@@ -76,6 +80,7 @@ void FLACDecoder_FreeBuffers(){ ...@@ -76,6 +80,7 @@ void FLACDecoder_FreeBuffers(){
if(FLACMetadataBlock) {free(FLACMetadataBlock); FLACMetadataBlock = NULL;} if(FLACMetadataBlock) {free(FLACMetadataBlock); FLACMetadataBlock = NULL;}
if(FLACsubFramesBuff) {free(FLACsubFramesBuff); FLACsubFramesBuff = NULL;} if(FLACsubFramesBuff) {free(FLACsubFramesBuff); FLACsubFramesBuff = NULL;}
if(m_streamTitle) {free(m_streamTitle); m_streamTitle = NULL;} if(m_streamTitle) {free(m_streamTitle); m_streamTitle = NULL;}
if(s_flacSegmentTable) {free(s_flacSegmentTable); s_flacSegmentTable = NULL;}
} }
//---------------------------------------------------------------------------------------------------------------------- //----------------------------------------------------------------------------------------------------------------------
// B I T R E A D E R // B I T R E A D E R
...@@ -165,24 +170,9 @@ boolean FLACFindMagicWord(unsigned char* buf, int nBytes){ ...@@ -165,24 +170,9 @@ boolean FLACFindMagicWord(unsigned char* buf, int nBytes){
return false; return false;
} }
//---------------------------------------------------------------------------------------------------------------------- //----------------------------------------------------------------------------------------------------------------------
boolean FLACFindStreamTitle(unsigned char* buf, int nBytes){
int idx = FLAC_specialIndexOf(buf, "title=", nBytes);
if(idx >0){
idx += 6;
int len = nBytes - idx;
if(len > 255) return false;
m_newSt = true;
memcpy(m_streamTitle, buf + idx, len + 1);
m_streamTitle[len] = '\0';
// log_i("%s", m_streamTitle);
return true;
}
return false;
}
//----------------------------------------------------------------------------------------------------------------------
char* FLACgetStreamTitle(){ char* FLACgetStreamTitle(){
if(m_newSt){ if(s_f_newSt){
m_newSt = false; s_f_newSt = false;
return m_streamTitle; return m_streamTitle;
} }
return NULL; return NULL;
...@@ -191,10 +181,8 @@ char* FLACgetStreamTitle(){ ...@@ -191,10 +181,8 @@ char* FLACgetStreamTitle(){
int FLACparseOGG(uint8_t *inbuf, int *bytesLeft){ // reference https://www.xiph.org/ogg/doc/rfc3533.txt int FLACparseOGG(uint8_t *inbuf, int *bytesLeft){ // reference https://www.xiph.org/ogg/doc/rfc3533.txt
s_f_flacParseOgg = false; s_f_flacParseOgg = false;
int ret = 0;
int idx = FLAC_specialIndexOf(inbuf, "OggS", 6); int idx = FLAC_specialIndexOf(inbuf, "OggS", 6);
if(idx != 0) return ERR_FLAC_DECODER_ASYNC;
// if(idx != 0) return -1; //ERR_OPUS_DECODER_ASYNC;
uint8_t version = *(inbuf + 4); (void) version; uint8_t version = *(inbuf + 4); (void) version;
uint8_t headerType = *(inbuf + 5); (void) headerType; uint8_t headerType = *(inbuf + 5); (void) headerType;
...@@ -222,7 +210,6 @@ int FLACparseOGG(uint8_t *inbuf, int *bytesLeft){ // reference https://www.xiph ...@@ -222,7 +210,6 @@ int FLACparseOGG(uint8_t *inbuf, int *bytesLeft){ // reference https://www.xiph
// read the segment table (contains pageSegments bytes), 1...251: Length of the frame in bytes, // read the segment table (contains pageSegments bytes), 1...251: Length of the frame in bytes,
// 255: A second byte is needed. The total length is first_byte + second byte // 255: A second byte is needed. The total length is first_byte + second byte
uint8_t psegmBuff[256];
int16_t segmentTableWrPtr = 0; int16_t segmentTableWrPtr = 0;
...@@ -232,16 +219,46 @@ int FLACparseOGG(uint8_t *inbuf, int *bytesLeft){ // reference https://www.xiph ...@@ -232,16 +219,46 @@ int FLACparseOGG(uint8_t *inbuf, int *bytesLeft){ // reference https://www.xiph
i++; i++;
n+= *(inbuf + 27 + i); n+= *(inbuf + 27 + i);
} }
psegmBuff[segmentTableWrPtr] = n; s_flacSegmentTable[segmentTableWrPtr] = n;
segmentTableWrPtr++; segmentTableWrPtr++;
// s_flacSegmentLength += n; // s_flacSegmentLength += n;
} }
m_page0_len = psegmBuff[0]; m_page0_len = s_flacSegmentTable[0];
uint16_t headerSize = pageSegments + 27; bool continuedPage = headerType & 0x01; // set: page contains data of a packet continued from the previous page
if(pageSegments == 1) headerSize = pageSegments + psegmBuff[0] +27; bool firstPage = headerType & 0x02; // set: this is the first page of a logical bitstream (bos)
bool lastPage = headerType & 0x04; // set: this is the last page of a logical bitstream (eos)
static uint8_t secondPage = 0; (void)continuedPage; (void)lastPage;
if(firstPage) secondPage = 3;
if(secondPage) secondPage--;
uint16_t headerSize = 0;
uint8_t aLen = 0, tLen = 0;
uint8_t *aPos = NULL, *tPos = NULL;
if(firstPage || secondPage == 1){
// log_i("s_flacSegmentTable[0] %i", s_flacSegmentTable[0]);
headerSize = pageSegments + s_flacSegmentTable[0] +27;
idx = FLAC_specialIndexOf(inbuf + 28, "ARTIST", s_flacSegmentTable[0]);
if(idx > 0){
aPos = inbuf + 28 + idx + 7;
aLen = *(inbuf + 28 +idx -4) - 7;
}
idx = FLAC_specialIndexOf(inbuf + 28, "TITLE", s_flacSegmentTable[0]);
if(idx > 0){
tPos = inbuf + 28 + idx + 6;
tLen = *(inbuf + 28 + idx -4) - 6;
}
int pos = 0;
if(aLen) {memcpy(m_streamTitle, aPos, aLen); m_streamTitle[aLen] = '\0'; pos = aLen;}
if(aLen && tLen) {strcat(m_streamTitle, " - "); pos += 3;}
if(tLen) {memcpy(m_streamTitle + pos, tPos, tLen); m_streamTitle[pos + tLen] = '\0';}
if(tLen || aLen) s_f_newSt = true;
}
else{
headerSize = pageSegments + 27;
}
*bytesLeft -= headerSize; *bytesLeft -= headerSize;
return ERR_FLAC_NONE; // no error return ERR_FLAC_NONE; // no error
} }
//---------------------------------------------------------------------------------------------------------------------- //----------------------------------------------------------------------------------------------------------------------
......
...@@ -40,7 +40,8 @@ enum : int8_t {FLAC_PARSE_OGG_DONE = 100, ...@@ -40,7 +40,8 @@ enum : int8_t {FLAC_PARSE_OGG_DONE = 100,
ERR_FLAC_RESERVED_RESIDUAL_CODING = -8, ERR_FLAC_RESERVED_RESIDUAL_CODING = -8,
ERR_FLAC_WRONG_RICE_PARTITION_NR = -9, ERR_FLAC_WRONG_RICE_PARTITION_NR = -9,
ERR_FLAC_BITS_PER_SAMPLE_TOO_BIG = -10, ERR_FLAC_BITS_PER_SAMPLE_TOO_BIG = -10,
ERR_FLAG_BITS_PER_SAMPLE_UNKNOWN = 11}; ERR_FLAG_BITS_PER_SAMPLE_UNKNOWN = -11,
ERR_FLAC_DECODER_ASYNC = -12};
typedef struct FLACMetadataBlock_t{ typedef struct FLACMetadataBlock_t{
// METADATA_BLOCK_STREAMINFO // METADATA_BLOCK_STREAMINFO
...@@ -145,7 +146,6 @@ typedef struct FLACFrameHeader_t { ...@@ -145,7 +146,6 @@ typedef struct FLACFrameHeader_t {
int FLACFindSyncWord(unsigned char *buf, int nBytes); int FLACFindSyncWord(unsigned char *buf, int nBytes);
boolean FLACFindMagicWord(unsigned char* buf, int nBytes); boolean FLACFindMagicWord(unsigned char* buf, int nBytes);
boolean FLACFindStreamTitle(unsigned char* buf, int nBytes);
char* FLACgetStreamTitle(); char* FLACgetStreamTitle();
int FLACparseOGG(uint8_t *inbuf, int *bytesLeft); int FLACparseOGG(uint8_t *inbuf, int *bytesLeft);
bool FLACDecoder_AllocateBuffers(void); bool FLACDecoder_AllocateBuffers(void);
......
...@@ -165,7 +165,7 @@ int parseOpusTOC(uint8_t TOC_Byte){ // https://www.rfc-editor.org/rfc/rfc6716 ...@@ -165,7 +165,7 @@ int parseOpusTOC(uint8_t TOC_Byte){ // https://www.rfc-editor.org/rfc/rfc6716
if(s_opusOldMode != mode) { if(s_opusOldMode != mode) {
s_opusOldMode = mode; s_opusOldMode = mode;
if(mode == 2) log_i("opus mode is MODE_CELT_ONLY"); // if(mode == 2) log_i("opus mode is MODE_CELT_ONLY");
} }
/* Configuration Mode Bandwidth FrameSizes Audio Bandwidth Sample Rate (Effective) /* Configuration Mode Bandwidth FrameSizes Audio Bandwidth Sample Rate (Effective)
...@@ -353,7 +353,7 @@ int OPUSFindSyncWord(unsigned char *buf, int nBytes){ ...@@ -353,7 +353,7 @@ int OPUSFindSyncWord(unsigned char *buf, int nBytes){
// assume we have a ogg wrapper // assume we have a ogg wrapper
int idx = OPUS_specialIndexOf(buf, "OggS", nBytes); int idx = OPUS_specialIndexOf(buf, "OggS", nBytes);
if(idx >= 0){ // Magic Word found if(idx >= 0){ // Magic Word found
log_i("OggS found at %i", idx); // log_i("OggS found at %i", idx);
s_f_opusParseOgg = true; s_f_opusParseOgg = true;
return idx; return idx;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment