重写rtp去冲突逻辑

This commit is contained in:
xia-chu
2021-02-04 18:20:59 +08:00
parent d6fc56d950
commit b0e1d5d6aa
6 changed files with 40 additions and 57 deletions

View File

@@ -28,43 +28,55 @@ using namespace mediakit;
#if defined(ENABLE_RTPPROXY)
static bool loadFile(const char *path){
FILE *fp = fopen(path, "rb");
std::shared_ptr<FILE> fp(fopen(path, "rb"), [](FILE *fp) {
if (fp) {
fclose(fp);
}
});
if (!fp) {
WarnL << "open file failed:" << path;
return false;
}
semaphore sem;
uint16_t len = 0;
uint32_t timeStamp_last = 0;
uint16_t len;
char rtp[2 * 1024];
struct sockaddr addr = {0};
while (true) {
if (2 != fread(&len, 1, 2, fp)) {
auto sock = Socket::createSocket();
sock->getPoller()->doDelayTask(0, [&]() mutable -> uint64_t {
if (2 != fread(&len, 1, 2, fp.get())) {
WarnL;
break;
sem.post();
return 0;
}
len = ntohs(len);
if (len < 12 || len > sizeof(rtp)) {
WarnL << len;
break;
sem.post();
return 0;
}
if (len != fread(rtp, 1, len, fp)) {
if (len != fread(rtp, 1, len, fp.get())) {
WarnL;
break;
sem.post();
return 0;
}
uint32_t timeStamp;
RtpSelector::Instance().inputRtp(nullptr, rtp, len, &addr, &timeStamp);
if(timeStamp_last){
RtpSelector::Instance().inputRtp(sock, rtp, len, &addr, &timeStamp);
if (timeStamp_last) {
auto diff = timeStamp - timeStamp_last;
if(diff > 0 && diff < 500){
usleep(diff * 1000);
if (diff > 0 && diff < 500) {
timeStamp_last = timeStamp;
return diff;
}
}
timeStamp_last = timeStamp;
}
fclose(fp);
return 1;
});
sem.wait();
return true;
}
#endif//#if defined(ENABLE_RTPPROXY)
@@ -85,10 +97,11 @@ int main(int argc,char *argv[]) {
//此处选择是否导出调试文件
// mINI::Instance()[RtpProxy::kDumpDir] = "/Users/xzl/Desktop/";
if (argc == 2)
loadFile(argv[1]);
else
ErrorL << "parameter error.";
if (argc == 2) {
loadFile(argv[1]);
} else {
ErrorL << "parameter error.";
}
#else
ErrorL << "please ENABLE_RTPPROXY and then test";
#endif//#if defined(ENABLE_RTPPROXY)