mirror of
https://github.com/ossrs/srs.git
synced 2025-03-09 15:49:59 +00:00
Merge branch v5.0.116 into develop
1. MP3: Fix bug for TS or HLS with mp3 codec. v4.0.269 (#296) (#3333) 2. MP3: Add config examples for MP3. #296 3. Script: Refine GitHub actions.
This commit is contained in:
commit
b5aaf67c93
16 changed files with 212 additions and 55 deletions
|
@ -595,6 +595,9 @@ srs_error_t SrsFrame::initialize(SrsCodecConfig* c)
|
|||
srs_error_t SrsFrame::add_sample(char* bytes, int size)
|
||||
{
|
||||
srs_error_t err = srs_success;
|
||||
|
||||
// Ignore empty sample.
|
||||
if (!bytes || size <= 0) return err;
|
||||
|
||||
if (nb_samples >= SrsMaxNbSamples) {
|
||||
return srs_error_new(ERROR_HLS_DECODE_ERROR, "Frame samples overflow");
|
||||
|
@ -2063,20 +2066,13 @@ srs_error_t SrsFormat::audio_mp3_demux(SrsBuffer* stream, int64_t timestamp)
|
|||
// we always decode aac then mp3.
|
||||
srs_assert(acodec->id == SrsAudioCodecIdMP3);
|
||||
|
||||
// Update the RAW MP3 data.
|
||||
// Update the RAW MP3 data. Note the start is 12 bits syncword 0xFFF, so we should not skip any bytes, for detail
|
||||
// please see ISO_IEC_11172-3-MP3-1993.pdf page 20 and 26.
|
||||
raw = stream->data() + stream->pos();
|
||||
nb_raw = stream->size() - stream->pos();
|
||||
|
||||
stream->skip(1);
|
||||
if (stream->empty()) {
|
||||
return err;
|
||||
}
|
||||
|
||||
char* data = stream->data() + stream->pos();
|
||||
int size = stream->size() - stream->pos();
|
||||
|
||||
// mp3 payload.
|
||||
if ((err = audio->add_sample(data, size)) != srs_success) {
|
||||
if ((err = audio->add_sample(raw, nb_raw)) != srs_success) {
|
||||
return srs_error_wrap(err, "add audio frame");
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue