mirror of
https://github.com/ossrs/srs.git
synced 2025-03-09 15:49:59 +00:00
For #913, Kernel MP4 FLV HTTP support complex error.
This commit is contained in:
parent
9802dc326e
commit
204ef041da
23 changed files with 1413 additions and 1660 deletions
|
@ -39,37 +39,36 @@ using namespace std;
|
|||
#include <srs_kernel_buffer.hpp>
|
||||
#include <srs_kernel_file.hpp>
|
||||
#include <srs_kernel_codec.hpp>
|
||||
#include <srs_core_autofree.hpp>
|
||||
|
||||
SrsMp3Transmuxer::SrsMp3Transmuxer()
|
||||
{
|
||||
writer = NULL;
|
||||
tag_stream = new SrsBuffer();
|
||||
}
|
||||
|
||||
SrsMp3Transmuxer::~SrsMp3Transmuxer()
|
||||
{
|
||||
srs_freep(tag_stream);
|
||||
}
|
||||
|
||||
int SrsMp3Transmuxer::initialize(SrsFileWriter* fw)
|
||||
srs_error_t SrsMp3Transmuxer::initialize(SrsFileWriter* fw)
|
||||
{
|
||||
int ret = ERROR_SUCCESS;
|
||||
srs_error_t err = srs_success;
|
||||
|
||||
srs_assert(fw);
|
||||
|
||||
if (!fw->is_open()) {
|
||||
ret = ERROR_KERNEL_MP3_STREAM_CLOSED;
|
||||
srs_warn("stream is not open for encoder. ret=%d", ret);
|
||||
return ret;
|
||||
return srs_error_new(ERROR_KERNEL_MP3_STREAM_CLOSED, "stream is not open");
|
||||
}
|
||||
|
||||
writer = fw;
|
||||
|
||||
return ret;
|
||||
return err;
|
||||
}
|
||||
|
||||
int SrsMp3Transmuxer::write_header()
|
||||
srs_error_t SrsMp3Transmuxer::write_header()
|
||||
{
|
||||
srs_error_t err = srs_success;
|
||||
|
||||
char id3[] = {
|
||||
(char)0x49, (char)0x44, (char)0x33, // ID3
|
||||
(char)0x03, (char)0x00, // version
|
||||
|
@ -80,27 +79,28 @@ int SrsMp3Transmuxer::write_header()
|
|||
(char)0x00, (char)0x00, (char)0x00, (char)0x00, // FrameSize
|
||||
(char)0x00, (char)0x00 // Flags
|
||||
};
|
||||
return writer->write(id3, sizeof(id3), NULL);
|
||||
|
||||
if ((err = writer->write(id3, sizeof(id3), NULL)) != srs_success) {
|
||||
return srs_error_wrap(err, "write id3");
|
||||
}
|
||||
|
||||
return err;
|
||||
}
|
||||
|
||||
int SrsMp3Transmuxer::write_audio(int64_t timestamp, char* data, int size)
|
||||
srs_error_t SrsMp3Transmuxer::write_audio(int64_t timestamp, char* data, int size)
|
||||
{
|
||||
int ret = ERROR_SUCCESS;
|
||||
srs_error_t err = srs_success;
|
||||
|
||||
srs_assert(data);
|
||||
|
||||
timestamp &= 0x7fffffff;
|
||||
|
||||
SrsBuffer* stream = tag_stream;
|
||||
if ((ret = stream->initialize(data, size)) != ERROR_SUCCESS) {
|
||||
return ret;
|
||||
}
|
||||
SrsBuffer* stream = new SrsBuffer(data, size);
|
||||
SrsAutoFree(SrsBuffer, stream);
|
||||
|
||||
// audio decode
|
||||
if (!stream->require(1)) {
|
||||
ret = ERROR_MP3_DECODE_ERROR;
|
||||
srs_error("mp3 decode audio sound_format failed. ret=%d", ret);
|
||||
return ret;
|
||||
return srs_error_new(ERROR_MP3_DECODE_ERROR, "decode sound_format");
|
||||
}
|
||||
|
||||
// @see: E.4.2 Audio Tags, video_file_format_spec_v10_1.pdf, page 76
|
||||
|
@ -112,18 +112,18 @@ int SrsMp3Transmuxer::write_audio(int64_t timestamp, char* data, int size)
|
|||
sound_format = (sound_format >> 4) & 0x0f;
|
||||
|
||||
if ((SrsAudioCodecId)sound_format != SrsAudioCodecIdMP3) {
|
||||
ret = ERROR_MP3_DECODE_ERROR;
|
||||
srs_error("mp3 required, format=%d. ret=%d", sound_format, ret);
|
||||
return ret;
|
||||
return srs_error_new(ERROR_MP3_DECODE_ERROR, "mp3 required, format=%d", sound_format);
|
||||
}
|
||||
|
||||
if (!stream->require(1)) {
|
||||
ret = ERROR_MP3_DECODE_ERROR;
|
||||
srs_error("mp3 decode aac_packet_type failed. ret=%d", ret);
|
||||
return ret;
|
||||
return srs_error_new(ERROR_MP3_DECODE_ERROR, "mp3 decode aac_packet_type failed");
|
||||
}
|
||||
|
||||
return writer->write(data + stream->pos(), size - stream->pos(), NULL);
|
||||
if ((err = writer->write(data + stream->pos(), size - stream->pos(), NULL)) != srs_success) {
|
||||
return srs_error_wrap(err, "write audio");
|
||||
}
|
||||
|
||||
return err;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue