diff --git a/src/input/r_real.cpp b/src/input/r_real.cpp index f5fd25384..c6f78490b 100644 --- a/src/input/r_real.cpp +++ b/src/input/r_real.cpp @@ -142,16 +142,6 @@ real_reader_c::read_headers() { } real_reader_c::~real_reader_c() { - size_t i; - - for (i = 0; i < demuxers.size(); i++) { - real_demuxer_cptr &demuxer = demuxers[i]; - - safefree(demuxer->private_data); - safefree(demuxer->extra_data); - } - demuxers.clear(); - m_ti.m_private_data = NULL; rmff_close_file(file); } @@ -191,8 +181,7 @@ real_reader_c::parse_headers() { dmx->height = get_uint16_be(&dmx->rvp->height); uint32_t i = get_uint32_be(&dmx->rvp->fps); dmx->fps = (float)((i & 0xffff0000) >> 16) + ((float)(i & 0x0000ffff)) / 65536.0; - dmx->private_data = (unsigned char *)safememdup(ts_data, ts_size); - dmx->private_size = ts_size; + dmx->private_data = memory_c::clone(ts_data, ts_size); demuxers.push_back(dmx); @@ -208,7 +197,6 @@ real_reader_c::parse_headers() { dmx->samples_per_second = 8000; dmx->channels = 1; dmx->bits_per_sample = 16; - dmx->extra_data_size = 0; strcpy(dmx->fourcc, "14_4"); } else if (4 == version) { @@ -231,10 +219,8 @@ real_reader_c::parse_headers() { dmx->fourcc[4] = 0; p += 4; - if (ts_size > static_cast(p - ts_data)) { - dmx->extra_data_size = ts_size - (p - ts_data); - dmx->extra_data = (unsigned char *)safememdup(p, dmx->extra_data_size); - } + if (ts_size > static_cast(p - ts_data)) + dmx->extra_data = memory_c::clone(p, ts_size - (p - ts_data)); } } else if (5 == version) { @@ -245,10 +231,8 @@ real_reader_c::parse_headers() { memcpy(dmx->fourcc, &dmx->ra5p->fourcc3, 4); dmx->fourcc[4] = 0; - if ((sizeof(real_audio_v5_props_t) + 4) < ts_size) { - dmx->extra_data_size = ts_size - 4 - sizeof(real_audio_v5_props_t); - dmx->extra_data = (unsigned char *)safememdup((unsigned char *)dmx->ra5p + 4 + sizeof(real_audio_v5_props_t), dmx->extra_data_size); - } + if ((sizeof(real_audio_v5_props_t) + 4) < ts_size) + dmx->extra_data = memory_c::clone(reinterpret_cast(dmx->ra5p) + 4 + sizeof(real_audio_v5_props_t), ts_size - 4 - sizeof(real_audio_v5_props_t)); } else { mxwarn(boost::format(Y("real_reader: Only audio header versions 3, 4 and 5 are supported. Track ID %1% uses version %2% and will be skipped.\n")) @@ -256,12 +240,10 @@ real_reader_c::parse_headers() { ok = false; } - mxverb(2, boost::format("real_reader: extra_data_size: %1%\n") % dmx->extra_data_size); + mxverb(2, boost::format("real_reader: extra_data_size: %1%\n") % dmx->extra_data->get_size()); if (ok) { - dmx->private_data = (unsigned char *)safememdup(ts_data, ts_size); - dmx->private_size = ts_size; - + dmx->private_data = memory_c::clone(ts_data, ts_size); demuxers.push_back(dmx); } } @@ -270,8 +252,14 @@ real_reader_c::parse_headers() { void real_reader_c::create_video_packetizer(real_demuxer_cptr dmx) { + if (dmx->private_data.is_set()) { + m_ti.m_private_data = dmx->private_data->get_buffer(); + m_ti.m_private_size = dmx->private_data->get_size(); + } + std::string codec_id = (boost::format("V_REAL/%1%") % dmx->fourcc).str(); - dmx->ptzr = add_packetizer(new video_packetizer_c(this, m_ti, codec_id.c_str(), 0.0, dmx->width, dmx->height)); + dmx->ptzr = add_packetizer(new video_packetizer_c(this, m_ti, codec_id.c_str(), 0.0, dmx->width, dmx->height)); + m_ti.m_private_data = NULL; if (strcmp(dmx->fourcc, "RV40")) dmx->rv_dimensions = true; @@ -296,13 +284,14 @@ real_reader_c::create_aac_audio_packetizer(real_demuxer_cptr dmx) { bool sbr = false; bool extra_data_parsed = false; - if (4 < dmx->extra_data_size) { - uint32_t extra_len = get_uint32_be(dmx->extra_data); + if ((dmx->extra_data.is_set()) && (4 < dmx->extra_data->get_size())) { + const unsigned char *extra_data = dmx->extra_data->get_buffer(); + uint32_t extra_len = get_uint32_be(extra_data); mxverb(2, boost::format("real_reader: extra_len: %1%\n") % extra_len); - if ((4 + extra_len) <= dmx->extra_data_size) { + if ((4 + extra_len) <= dmx->extra_data->get_size()) { extra_data_parsed = true; - if (!parse_aac_data(&dmx->extra_data[4 + 1], extra_len - 1, profile, channels, sample_rate, output_sample_rate, sbr)) + if (!parse_aac_data(&extra_data[4 + 1], extra_len - 1, profile, channels, sample_rate, output_sample_rate, sbr)) mxerror_tid(m_ti.m_fname, tid, Y("This AAC track does not contain valid headers. Could not parse the AAC information.\n")); mxverb(2, boost::format("real_reader: 1. profile: %1%, channels: %2%, sample_rate: %3%, output_sample_rate: %4%, sbr: %5%\n") @@ -343,10 +332,8 @@ real_reader_c::create_aac_audio_packetizer(real_demuxer_cptr dmx) { boost::format("real_reader: 2. profile: %1%, channels: %2%, sample_rate: %3%, output_sample_rate: %4%, sbr: %5%\n") % profile % channels % sample_rate % output_sample_rate % sbr); - m_ti.m_private_data = NULL; - m_ti.m_private_size = 0; - dmx->is_aac = true; - dmx->ptzr = add_packetizer(new aac_packetizer_c(this, m_ti, AAC_ID_MPEG4, profile, sample_rate, channels, false, true)); + dmx->is_aac = true; + dmx->ptzr = add_packetizer(new aac_packetizer_c(this, m_ti, AAC_ID_MPEG4, profile, sample_rate, channels, false, true)); show_packetizer_info(tid, PTZR(dmx->ptzr)); @@ -375,8 +362,7 @@ real_reader_c::create_audio_packetizer(real_demuxer_cptr dmx) { if (!strcasecmp(dmx->fourcc, "COOK")) dmx->cook_audio_fix = true; - dmx->ptzr = add_packetizer(new ra_packetizer_c(this, m_ti, dmx->samples_per_second, dmx->channels, dmx->bits_per_sample, get_uint32_be(dmx->fourcc), - dmx->private_data, dmx->private_size)); + dmx->ptzr = add_packetizer(new ra_packetizer_c(this, m_ti, dmx->samples_per_second, dmx->channels, dmx->bits_per_sample, get_uint32_be(dmx->fourcc), dmx->private_data)); show_packetizer_info(dmx->track->id, PTZR(dmx->ptzr)); } @@ -394,8 +380,6 @@ real_reader_c::create_packetizer(int64_t tid) { rmff_track_t *track = dmx->track; m_ti.m_id = track->id; - m_ti.m_private_data = dmx->private_data; - m_ti.m_private_size = dmx->private_size; if (RMFF_TRACK_TYPE_VIDEO == track->type) create_video_packetizer(dmx); @@ -450,9 +434,8 @@ real_reader_c::read(generic_packetizer_c *, return finish(); } - unsigned char *chunk = (unsigned char *)safemalloc(size); - memory_c mem(chunk, size, true); - rmff_frame_t *frame = rmff_read_next_frame(file, chunk); + memory_c mem(size); + rmff_frame_t *frame = rmff_read_next_frame(file, mem.get_buffer()); if (NULL == frame) { if (file->num_packets_read < file->num_packets_in_chunk) diff --git a/src/input/r_real.h b/src/input/r_real.h index 0f2768f6f..9f19c7a32 100644 --- a/src/input/r_real.h +++ b/src/input/r_real.h @@ -48,8 +48,7 @@ struct real_demuxer_t { real_audio_v4_props_t *ra4p; real_audio_v5_props_t *ra5p; - unsigned char *private_data, *extra_data; - unsigned int private_size, extra_data_size; + memory_cptr private_data, extra_data; bool first_frame; int num_packets; @@ -75,10 +74,6 @@ struct real_demuxer_t { rvp(NULL), ra4p(NULL), ra5p(NULL), - private_data(NULL), - extra_data(NULL), - private_size(0), - extra_data_size(0), first_frame(true), num_packets(0), last_timecode(0), diff --git a/src/output/p_realaudio.cpp b/src/output/p_realaudio.cpp index fd6e2a13c..852a9e22c 100644 --- a/src/output/p_realaudio.cpp +++ b/src/output/p_realaudio.cpp @@ -25,14 +25,13 @@ ra_packetizer_c::ra_packetizer_c(generic_reader_c *p_reader, int channels, int bits_per_sample, uint32_t fourcc, - unsigned char *private_data, - int private_size) + const memory_cptr &private_data) : generic_packetizer_c(p_reader, p_ti) , m_samples_per_sec(samples_per_sec) , m_channels(channels) , m_bits_per_sample(bits_per_sample) , m_fourcc(fourcc) - , m_private_data(new memory_c((unsigned char *)safememdup(private_data, private_size), private_size, true)) + , m_private_data(private_data.is_set() ? private_data->clone() : private_data) { set_track_type(track_audio, TFA_SHORT_QUEUEING); } @@ -48,7 +47,8 @@ ra_packetizer_c::set_headers() { set_audio_sampling_freq((float)m_samples_per_sec); set_audio_channels(m_channels); set_audio_bit_depth(m_bits_per_sample); - set_codec_private(m_private_data->get_buffer(), m_private_data->get_size()); + if (m_private_data.is_set()) + set_codec_private(m_private_data->get_buffer(), m_private_data->get_size()); generic_packetizer_c::set_headers(); m_track_entry->EnableLacing(false); diff --git a/src/output/p_realaudio.h b/src/output/p_realaudio.h index 7a19ca304..16f5fa318 100644 --- a/src/output/p_realaudio.h +++ b/src/output/p_realaudio.h @@ -25,7 +25,7 @@ private: memory_cptr m_private_data; public: - ra_packetizer_c(generic_reader_c *p_reader, track_info_c &p_ti, int samples_per_sec, int channels, int bits_per_sample, uint32_t fourcc, unsigned char *private_data, int private_size); + ra_packetizer_c(generic_reader_c *p_reader, track_info_c &p_ti, int samples_per_sec, int channels, int bits_per_sample, uint32_t fourcc, const memory_cptr &private_data); virtual ~ra_packetizer_c(); virtual int process(packet_cptr packet);