Files
ANSCORE/MediaClient/rtp/mpeg4_rtp_rx.cpp

125 lines
3.0 KiB
C++

/***************************************************************************************
*
* IMPORTANT: READ BEFORE DOWNLOADING, COPYING, INSTALLING OR USING.
*
* By downloading, copying, installing or using the software you agree to this license.
* If you do not agree to this license, do not download, install,
* copy or use the software.
*
* Copyright (C) 2014-2024, Happytimesoft Corporation, all rights reserved.
*
* Redistribution and use in binary forms, with or without modification, are permitted.
*
* Unless required by applicable law or agreed to in writing, software distributed
* under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
* CONDITIONS OF ANY KIND, either express or implied. See the License for the specific
* language governing permissions and limitations under the License.
*
****************************************************************************************/
#include "sys_inc.h"
#include "mpeg4_rtp_rx.h"
BOOL mpeg4_data_rx(MPEG4RXI * p_rxi, uint8 * p_data, int len)
{
BOOL begin_packet = FALSE;
// The packet begins a frame iff its data begins with a system code
// (i.e., 0x000001??)
begin_packet = (len >= 4 && p_data[0] == 0 && p_data[1] == 0 && p_data[2] == 1);
if (begin_packet)
{
p_rxi->d_offset = 0;
}
if (p_rxi->rtprxi.rxf_loss)
{
// Packet loss, discard the previously cached packets
p_rxi->d_offset = 0;
// Packet loss, until the next start packet
if (!begin_packet)
{
return FALSE;
}
else
{
p_rxi->rtprxi.rxf_loss = 0;
}
}
if ((p_rxi->d_offset + len + p_rxi->hdr_len) >= p_rxi->buf_len)
{
log_print(HT_LOG_ERR, "%s, fragment packet too big %d!!!",
__FUNCTION__, p_rxi->d_offset + len + p_rxi->hdr_len);
return FALSE;
}
memcpy(p_rxi->p_buf + p_rxi->d_offset + p_rxi->hdr_len, p_data, len);
p_rxi->d_offset += len;
if (p_rxi->rtprxi.rxf_marker)
{
if (p_rxi->pkt_func)
{
p_rxi->pkt_func(p_rxi->p_buf, p_rxi->d_offset + p_rxi->hdr_len, p_rxi->rtprxi.ts, p_rxi->rtprxi.seq, p_rxi->user_data);
}
p_rxi->d_offset = 0;
}
return TRUE;
}
BOOL mpeg4_rtp_rx(MPEG4RXI * p_rxi, uint8 * p_data, int len)
{
if (p_rxi == NULL)
{
return FALSE;
}
if (!rtp_data_rx(&p_rxi->rtprxi, p_data, len))
{
return FALSE;
}
return mpeg4_data_rx(p_rxi, p_rxi->rtprxi.p_data, p_rxi->rtprxi.len);
}
BOOL mpeg4_rxi_init(MPEG4RXI * p_rxi, VRTPRXCBF cbf, void * p_userdata)
{
memset(p_rxi, 0, sizeof(MPEG4RXI));
p_rxi->buf_len = RTP_MAX_VIDEO_BUFF;
p_rxi->p_buf_org = (uint8 *)malloc(p_rxi->buf_len);
if (p_rxi->p_buf_org == NULL)
{
return FALSE;
}
p_rxi->p_buf = p_rxi->p_buf_org + 32;
p_rxi->buf_len -= 32;
p_rxi->pkt_func = cbf;
p_rxi->user_data = p_userdata;
return TRUE;
}
void mpeg4_rxi_deinit(MPEG4RXI * p_rxi)
{
if (p_rxi->p_buf_org)
{
free(p_rxi->p_buf_org);
}
memset(p_rxi, 0, sizeof(MPEG4RXI));
}