| | |
| | |
|
| | | RtspClientParam lastParam;
|
| | |
|
| | | volatile bool killed;
|
| | |
|
| | | RTSPClient_Internal() :
|
| | | rtspConfig(), live_daemon_thid(0),
|
| | | eventLoopWatchVariable(0), live_daemon_running(false),
|
| | | frame_mutex(new pthread_mutex_t), continue_mutex(new pthread_mutex_t),
|
| | | lastFrame(), lastParam()
|
| | | lastFrame(), lastParam(), killed(false)
|
| | | {
|
| | | pthread_mutex_init(frame_mutex, NULL);
|
| | | pthread_mutex_init(continue_mutex, NULL);
|
| | |
| | | RTSPClient_Internal* in = (RTSPClient_Internal*)internal;
|
| | |
|
| | | in->eventLoopWatchVariable = 1;
|
| | |
|
| | | pthread_mutex_unlock(in->continue_mutex);
|
| | | pthread_mutex_unlock(in->frame_mutex);
|
| | |
|
| | | pthread_join(in->live_daemon_thid, NULL);
|
| | |
|
| | | in->reset();
|
| | | }
|
| | |
|
| | | bool PL_RTSPClient::pay(const PipeMaterial& pm)
|
| | |
| | | return false;
|
| | | }
|
| | |
|
| | | if (in->killed)
|
| | | {
|
| | | LOGP(WARN, "killed 1");
|
| | | return false;
|
| | | }
|
| | |
|
| | | ret = pthread_mutex_lock(in->frame_mutex);
|
| | | if(ret != 0)
|
| | | {
|
| | | LOGP(ERROR, "pthread_mutex_lock: %s/n", strerror(ret));
|
| | | return false;
|
| | | }
|
| | |
|
| | | if (in->killed)
|
| | | {
|
| | | LOGP(WARN, "killed 2");
|
| | | return false;
|
| | | }
|
| | |
|
| | |
| | | pm.former = this;
|
| | |
|
| | | return true;
|
| | | }
|
| | |
|
| | | void PL_RTSPClient::kill()
|
| | | {
|
| | | RTSPClient_Internal* in = (RTSPClient_Internal*)internal;
|
| | | in->killed = true;
|
| | | pthread_mutex_unlock(in->frame_mutex);
|
| | | }
|
| | |
|
| | | void rtsp_client_set_param_callback(void* arg, RtspClientParam& param)
|
| | |
| | | int ret = pthread_mutex_lock(in->continue_mutex);
|
| | | if(ret != 0)
|
| | | {
|
| | | LOG_ERROR << "pthread_mutex_unlock continue_mutex: " << strerror(ret) << std::endl;
|
| | | LOG_ERROR << "pthread_mutex_lock continue_mutex: " << strerror(ret) << std::endl;
|
| | | }
|
| | | }
|