void ms_init(){ int i; MSSndCardManager *cm; #if !defined(_WIN32_WCE) if (getenv("MEDIASTREAMER_DEBUG")!=NULL){ ortp_set_log_level_mask(ORTP_DEBUG|ORTP_MESSAGE|ORTP_WARNING|ORTP_ERROR|ORTP_FATAL); } #endif #ifdef ANDROID ortp_set_log_level_mask(ORTP_MESSAGE|ORTP_WARNING|ORTP_ERROR|ORTP_FATAL); ortp_set_log_handler(ms_android_log_handler); #endif ms_message("Registering all filters..."); /* register builtin MSFilter's */ for (i=0;ms_filter_descs[i]!=NULL;i++){ ms_filter_register(ms_filter_descs[i]); } ms_message("Registering all soundcard handlers"); cm=ms_snd_card_manager_get(); for (i=0;ms_snd_card_descs[i]!=NULL;i++){ ms_snd_card_manager_register_desc(cm,ms_snd_card_descs[i]); } #ifdef VIDEO_ENABLED ms_message("Registering all webcam handlers"); { MSWebCamManager *wm; wm=ms_web_cam_manager_get(); for (i=0;ms_web_cam_descs[i]!=NULL;i++){ ms_web_cam_manager_register_desc(wm,ms_web_cam_descs[i]); } } #if !defined(NO_FFMPEG) ms_ffmpeg_check_init(); __register_ffmpeg_encoders_if_possible(); #endif #endif #ifdef PACKAGE_PLUGINS_DIR ms_message("Loading plugins"); ms_load_plugins(PACKAGE_PLUGINS_DIR); #endif #if defined(ANDROID) && defined (VIDEO_ENABLED) libmsandroiddisplay_init(); #endif ms_message("ms_init() done"); }
void ms_base_init(){ int i; long num_cpu=1; #if defined(ENABLE_NLS) bindtextdomain (GETTEXT_PACKAGE, LOCALEDIR); #endif #if !defined(_WIN32_WCE) if (getenv("MEDIASTREAMER_DEBUG")!=NULL){ ortp_set_log_level_mask(ORTP_DEBUG|ORTP_MESSAGE|ORTP_WARNING|ORTP_ERROR|ORTP_FATAL); } #endif //#ifdef ANDROID // ortp_set_log_level_mask(ORTP_MESSAGE|ORTP_WARNING|ORTP_ERROR|ORTP_FATAL); // ortp_set_log_handler(ms_android_log_handler); //#endif ms_message("Mediastreamer2 " MEDIASTREAMER_VERSION " (git: " GIT_VERSION ") starting."); /* register builtin MSFilter's */ for (i=0;ms_base_filter_descs[i]!=NULL;i++){ ms_filter_register(ms_base_filter_descs[i]); } #ifdef WIN32 /*fixme to be tested*/ SYSTEM_INFO sysinfo; GetSystemInfo( &sysinfo ); num_cpu = sysinfo.dwNumberOfProcessors; #elif __APPLE_ || __linux num_cpu = sysconf( _SC_NPROCESSORS_ONLN ); #endif ms_set_cpu_count(num_cpu); ms_message("ms_base_init() done"); }
myAudioStream::myAudioStream(QString payload) { if (!initialized) { ortp_set_log_level_mask(ORTP_DEBUG|ORTP_ERROR); ms_init(); ortp_init(); initialized = true; } if (!init_card()) { return; } if (!init_stream()) { return; } if (!init_filters(payload)) { return; } if (!link_filters()) { return; } if (!start_ticker()) { return; } }
void rtp_send_init() { ortp_init(); ortp_scheduler_init(); ortp_set_log_level_mask(ORTP_DEBUG | ORTP_MESSAGE | ORTP_WARNING | ORTP_ERROR); // ortp_set_log_level_mask(ORTP_ERROR); }
int main(int argc, char *argv[]){ int pos; int count; ortp_init(); ortp_set_log_level_mask(ORTP_MESSAGE|ORTP_WARNING|ORTP_ERROR|ORTP_FATAL); ms_init(); rtp_profile_set_payload(&av_profile,115,&payload_type_lpc1015); rtp_profile_set_payload(&av_profile,110,&payload_type_speex_nb); rtp_profile_set_payload(&av_profile,111,&payload_type_speex_wb); rtp_profile_set_payload(&av_profile,112,&payload_type_ilbc); signal(SIGINT,stop); count=0; for (pos=0;cfg[pos].num_session!=0;pos++) { count = count + init_bench(&cfg[pos]); ms_sleep(10); } ms_message("Number of session started: %i.", count); while(run) ms_sleep(1); for (pos=0;cfg[pos].num_session!=0;pos++) { uninit_bench(&cfg[pos]); } return 0; }
int main(int argc, char *argv[]) { RingStream *r; const char *file; MSSndCard *sc; const char * card_id=NULL; MSFactory *factory; ortp_init(); ortp_set_log_level_mask(ORTP_LOG_DOMAIN, ORTP_MESSAGE|ORTP_WARNING|ORTP_ERROR|ORTP_FATAL); factory = ms_factory_new_with_voip(); if (argc>1) { file=argv[1]; } else file="/usr/share/sounds/linphone/rings/oldphone.wav"; if (argc>2) { card_id=argv[2]; } sc=ms_snd_card_manager_get_card(ms_factory_get_snd_card_manager(factory),card_id); #ifdef __linux if (sc==NULL) sc = ms_alsa_card_new_custom(card_id, card_id); #endif r=ring_start(factory, file,2000,sc); ms_sleep(10); ring_stop(r); ms_factory_destroy(factory); return 0; }
int main(int argc, char * argv[]) { int i; int localport=0,remoteport=0,payload=0; char ip[50]; const char *fmtp=NULL; int jitter=50; int bitrate=0; bool_t ec=FALSE; /*create the rtp session */ ortp_init(); ortp_set_log_level_mask(ORTP_MESSAGE|ORTP_WARNING|ORTP_ERROR|ORTP_FATAL); rtp_profile_set_payload(&av_profile,115,&payload_type_lpc1015); rtp_profile_set_payload(&av_profile,110,&payload_type_speex_nb); rtp_profile_set_payload(&av_profile,111,&payload_type_speex_wb); rtp_profile_set_payload(&av_profile,112,&payload_type_ilbc); #ifdef VIDEO_ENABLED rtp_profile_set_payload(&av_profile,98,&payload_type_h263_1998); rtp_profile_set_payload(&av_profile,97,&payload_type_theora); rtp_profile_set_payload(&av_profile,99,&payload_type_mp4v); rtp_profile_set_payload(&av_profile,100,&payload_type_x_snow); #endif if (argc<4) { printf(usage); return -1; } for (i=1; i<argc; i++) { if (strcmp(argv[i],"--local")==0) { i++; localport=atoi(argv[i]); } else if (strcmp(argv[i],"--remote")==0) { i++; if (!parse_addr(argv[i],ip,sizeof(ip),&remoteport)) { printf(usage); return -1; } printf("Remote addr: ip=%s port=%i\n",ip,remoteport); } else if (strcmp(argv[i],"--payload")==0) { i++; payload=atoi(argv[i]); } else if (strcmp(argv[i],"--fmtp")==0) { i++; fmtp=argv[i]; } else if (strcmp(argv[i],"--jitter")==0) { i++; jitter=atoi(argv[i]); } else if (strcmp(argv[i],"--bitrate")==0) { i++; bitrate=atoi(argv[i]); } else if (strcmp(argv[i],"--ec")==0) { ec=TRUE; } } run_media_streams(localport,ip,remoteport,payload,fmtp,jitter,ec,bitrate); return 0; }
void rtp_init(void) { ortp_init(); ortp_scheduler_init(); ortp_set_log_level_mask(ORTP_ERROR); register_config_context( "input", "rtp", start_block, end_block, config_statements ); }
int apple_main (int argc, char *argv[]) { #else int main (int argc, char *argv[]) { #endif int i; int ret; mediastreamer2_tester_init(NULL); // this allows to launch tester from outside of tester directory if (strstr(argv[0], ".libs")) { long prefix_length = strstr(argv[0], ".libs") - argv[0] + 1; char *prefix = ms_strdup_printf("%s%.*s", argv[0][0] == '/' ? "" : "./", prefix_length, argv[0]); ms_warning("Resource prefix set to %s", prefix); bc_tester_set_resource_dir_prefix(prefix); bc_tester_set_writable_dir_prefix(prefix); ms_free(prefix); } for(i = 1; i < argc; ++i) { if (strcmp(argv[i], "--verbose") == 0) { ortp_set_log_level_mask(ORTP_LOG_DOMAIN, ORTP_MESSAGE|ORTP_WARNING|ORTP_ERROR|ORTP_FATAL); } else if (strcmp(argv[i], "--silent") == 0) { ortp_set_log_level_mask(ORTP_LOG_DOMAIN, ORTP_FATAL); } else if (strcmp(argv[i],"--log-file")==0){ CHECK_ARG("--log-file", ++i, argc); if (mediastreamer2_tester_set_log_file(argv[i]) < 0) return -2; } else { int ret = bc_tester_parse_args(argc, argv, i); if (ret>0) { i += ret - 1; continue; } else if (ret<0) { bc_tester_helper(argv[0], mediastreamer2_helper); } return ret; } } ret = bc_tester_start(argv[0]); mediastreamer2_tester_uninit(); return ret; }
int main(int argc, char *argv[]){ ms_init(); if (argc<2){ ms_error("Usage: mtudiscover [host]"); return -1; } ortp_set_log_level_mask(ORTP_MESSAGE|ORTP_WARNING|ORTP_ERROR|ORTP_FATAL); printf("result: %i \n",ms_discover_mtu(argv[1])); return 0; }
int apple_main (int argc, char *argv[]) { #else int main (int argc, char *argv[]) { #endif int i; int ret; mediastreamer2_tester_init(); for(i = 1; i < argc; ++i) { if (strcmp(argv[i], "--verbose") == 0) { ortp_set_log_level_mask(ORTP_MESSAGE|ORTP_WARNING|ORTP_ERROR|ORTP_FATAL); } else if (strcmp(argv[i], "--silent") == 0) { ortp_set_log_level_mask(ORTP_FATAL); } else if (strcmp(argv[i],"--log-file")==0){ CHECK_ARG("--log-file", ++i, argc); log_file=fopen(argv[i],"w"); if (!log_file) { ms_error("Cannot open file [%s] for writing logs because [%s]",argv[i],strerror(errno)); return -2; } else { ms_message("Redirecting traces to file [%s]",argv[i]); ortp_set_log_file(log_file); } } else { int ret = bc_tester_parse_args(argc, argv, i); if (ret>0) { i += ret - 1; continue; } else if (ret<0) { bc_tester_helper(argv[0], mediastreamer2_helper); } return ret; } } ret = bc_tester_start(); mediastreamer2_tester_uninit(); return ret; }
// Constructors MastTool::MastTool( const char* tool_name, RtpSessionMode mode ) { int log_level = ORTP_WARNING|ORTP_ERROR|ORTP_FATAL; // Initialise defaults this->session = NULL; this->profile = &av_profile; this->mimetype = new MastMimeType(); this->payloadtype = NULL; this->payloadtype_index = -1; this->tool_name = tool_name; this->payload_size_limit = DEFAULT_PAYLOAD_LIMIT; // Initialise the oRTP library ortp_init(); // Set the logging message level #ifdef DEBUGGING MAST_DEBUG( "Compiled with debugging enabled" ); log_level |= ORTP_DEBUG; log_level |= ORTP_MESSAGE; #endif ortp_set_log_level_mask(log_level); // Create RTP session session = rtp_session_new( mode ); if (session==NULL) { MAST_FATAL( "Failed to create oRTP session.\n" ); } // Enabled multicast loopback rtp_session_set_multicast_loopback(session, TRUE); // Callbacks rtp_session_signal_connect(session,"ssrc_changed",(RtpCallback)ssrc_changed_cb, 0); rtp_session_signal_connect(session,"payload_type_changed",(RtpCallback)pt_changed_cb, 0); rtp_session_signal_connect(session,"network_error",(RtpCallback)network_error_cb, 0); // Set the MPEG Audio payload type to 14 in the AV profile rtp_profile_set_payload(profile, RTP_MPEG_AUDIO_PT, &payload_type_mpeg_audio); // Set RTCP parameters this->set_source_sdes(); }
int main(int argc, char *argv[]){ double ret=0; if (argc<3){ fprintf(stderr,"%s: file1 file2\nCompare two wav audio files and display a similarity factor between 0 and 1.\n",argv[0]); return -1; } ortp_set_log_level_mask(ORTP_MESSAGE|ORTP_WARNING|ORTP_ERROR|ORTP_FATAL); if (ms_audio_diff(argv[1],argv[2],&ret,completion_cb,NULL)==0){ fprintf(stdout,"%s and %s are similar with a degree of %g.\n",argv[1],argv[2],ret); return 0; }else{ fprintf(stderr,"Error encountered during processing, exiting.\n"); } return -1; }
void rtp_init() { sem_init(&rtp_semaphore,0,1); ortp_init(); ortp_scheduler_init(); ortp_set_log_file (stdout); ortp_set_log_level_mask(ORTP_DEBUG|ORTP_MESSAGE|ORTP_WARNING|ORTP_ERROR); jittcomp=100; timestamp_jump_limit = 500; adapt=1; rtp_connected = 0; rtp_listening = 0; rtp_initialized = 1; }
void ms_base_init(){ int i; long num_cpu=1; #ifdef WIN32 SYSTEM_INFO sysinfo; #endif if (ms_base_ref++ >0 ) { ms_message ("Skiping ms_base_init, because [%i] ref",ms_base_ref); return; } #if defined(ENABLE_NLS) bindtextdomain (GETTEXT_PACKAGE, LOCALEDIR); #endif #if !defined(_WIN32_WCE) if (getenv("MEDIASTREAMER_DEBUG")!=NULL){ ortp_set_log_level_mask(ORTP_DEBUG|ORTP_MESSAGE|ORTP_WARNING|ORTP_ERROR|ORTP_FATAL); } #endif //#ifdef ANDROID // ortp_set_log_level_mask(ORTP_MESSAGE|ORTP_WARNING|ORTP_ERROR|ORTP_FATAL); // ortp_set_log_handler(ms_android_log_handler); //#endif ms_message("Mediastreamer2 " MEDIASTREAMER_VERSION " (git: " GIT_VERSION ") starting."); /* register builtin MSFilter's */ for (i=0;ms_base_filter_descs[i]!=NULL;i++){ ms_filter_register(ms_base_filter_descs[i]); } #ifdef WIN32 /*fixme to be tested*/ GetSystemInfo( &sysinfo ); num_cpu = sysinfo.dwNumberOfProcessors; #elif __APPLE__ || __linux num_cpu = sysconf( _SC_NPROCESSORS_ONLN ); #elif __QNX__ num_cpu = _syspage_ptr->num_cpu; #else #warning "There is no code that detects the number of CPU for this platform." #endif ms_set_cpu_count(num_cpu); ms_message("ms_base_init() done"); }
static void WINAPI mainp(int argc, char **argv) { #ifdef WIN32 if (!_verbase) { if (regWinService() < 0) return; } #endif // log_init(); ms_init(); ortp_init(); #ifdef _DEBUG putenv("xmpp_domain=qddevsrv.zonekey"); #endif // debug fprintf(stderr, "VER: %s\n", VERSION_STR); ortp_set_log_level_mask(ORTP_FATAL); zonekey_publisher_register(); zonekey_void_register(); zonekey_publisher_set_log_handler(log); libmsilbc_init(); zonekey_audio_mixer_register(); zonekey_audio_mixer_set_log_handler(log); zonekey_video_mixer_register(); zonekey_video_mixer_set_log_handler(log); rtp_profile_set_payload(&av_profile, 100, &payload_type_h264); rtp_profile_set_payload(&av_profile, 110, &payload_type_speex_wb); rtp_profile_set_payload(&av_profile, 102, &payload_type_ilbc); Server server; server.run(&_quit); #ifdef WIN32 if (!_verbase) ReportSvcStatus(SERVICE_STOPPED, NO_ERROR, 0); CloseHandle(_global_obj); #endif }
int yy_init( int port) { RtpSession *session; ortp_init(); ortp_scheduler_init(); ortp_set_log_level_mask( ORTP_DEBUG | ORTP_MESSAGE | ORTP_WARNING | ORTP_ERROR); session = rtp_session_new(RTP_SESSION_RECVONLY); rtp_session_set_scheduling_mode(session, 1); rtp_session_set_blocking_mode(session, 1); rtp_session_set_local_addr(session, "0.0.0.0", port); rtp_session_set_connected_mode(session, TRUE); rtp_session_set_symmetric_rtp(session, TRUE); // rtp_session_enable_adaptive_jitter_compensation(session,adapt); // rtp_session_set_jitter_compensation(session,jittcomp); rtp_session_set_payload_type(session, 0); return (int) session; }
int main(int argc, char *argv[]){ double ret=0; MSAudioDiffParams params={0}; if (argc<3){ fprintf(stderr,"%s: file1 file2 [overlap-percentage] [chunk size in milliseconds]\nCompare two wav audio files and display a similarity factor between 0 and 1.\n",argv[0]); return -1; } if (argc>3){ params.max_shift_percent=atoi(argv[3]); } if (argc>4){ params.chunk_size_ms = atoi(argv[4]); } ortp_set_log_level_mask(ORTP_MESSAGE|ORTP_WARNING|ORTP_ERROR|ORTP_FATAL); if (ms_audio_diff(argv[1],argv[2],&ret,¶ms,completion_cb,NULL)==0){ fprintf(stdout,"%s and %s are similar with a degree of %g.\n",argv[1],argv[2],ret); return 0; }else{ fprintf(stderr,"Error encountered during processing, exiting.\n"); } return -1; }
void zkmcu_hlp_init() { static bool _inited = false; static ost::Mutex _cs; ost::MutexLock al(_cs); if (!_inited) { ms_init(); ortp_init(); ortp_set_log_level_mask(ORTP_FATAL); zonekey_h264_source_register(); zonekey_yuv_sink_register(); zonekey_void_register(); rtp_profile_set_payload(&av_profile, 100, &payload_type_h264); rtp_profile_set_payload(&av_profile, 110, &payload_type_speex_wb); rtp_profile_set_payload(&av_profile, 102, &payload_type_ilbc); } }
void ms_base_init(){ int i; #if defined(ENABLE_NLS) bindtextdomain (GETTEXT_PACKAGE, LOCALEDIR); #endif #if !defined(_WIN32_WCE) if (getenv("MEDIASTREAMER_DEBUG")!=NULL){ ortp_set_log_level_mask(ORTP_DEBUG|ORTP_MESSAGE|ORTP_WARNING|ORTP_ERROR|ORTP_FATAL); } #endif //#ifdef ANDROID // ortp_set_log_level_mask(ORTP_MESSAGE|ORTP_WARNING|ORTP_ERROR|ORTP_FATAL); // ortp_set_log_handler(ms_android_log_handler); //#endif ms_message("Mediastreamer2 " MEDIASTREAMER_VERSION " (git: " GIT_VERSION ") starting."); /* register builtin MSFilter's */ for (i=0;ms_base_filter_descs[i]!=NULL;i++){ ms_filter_register(ms_base_filter_descs[i]); } ms_message("ms_base_init() done"); }
int main(int argc, char*argv[]) { RtpSession *session; unsigned char buffer[32]; int err; uint32_t ts=0; int stream_received=0; FILE *outfile; int local_port; int have_more; int i; int format=0; int soundcard=0; int sound_fd=0; int jittcomp=40; bool_t adapt=TRUE; /* init the lib */ if (argc<3){ printf("%s",help); return -1; } local_port=atoi(argv[2]); if (local_port<=0) { printf("%s",help); return -1; } for (i=3;i<argc;i++) { if (strcmp(argv[i],"--noadapt")==0) adapt=FALSE; if (strcmp(argv[i],"--format")==0){ i++; if (i<argc){ if (strcmp(argv[i],"mulaw")==0){ format=MULAW; }else if (strcmp(argv[i],"alaw")==0){ format=ALAW; }else{ printf("Unsupported format %s\n",argv[i]); return -1; } } } else if (strcmp(argv[i],"--soundcard")==0){ soundcard=1; } else if (strcmp(argv[i],"--with-jitter")==0){ i++; if (i<argc){ jittcomp=atoi(argv[i]); printf("Using a jitter buffer of %i milliseconds.\n",jittcomp); } } } outfile=fopen(argv[1],"wb"); if (outfile==NULL) { perror("Cannot open file for writing"); return -1; } if (soundcard){ sound_fd=sound_init(format); } ortp_init(); ortp_scheduler_init(); ortp_set_log_level_mask(ORTP_DEBUG|ORTP_MESSAGE|ORTP_WARNING|ORTP_ERROR); signal(SIGINT,stop_handler); session=rtp_session_new(RTP_SESSION_RECVONLY); rtp_session_set_scheduling_mode(session,1); rtp_session_set_blocking_mode(session,1); rtp_session_set_local_addr(session,"0.0.0.0",atoi(argv[2])); rtp_session_set_connected_mode(session,TRUE); rtp_session_set_symmetric_rtp(session,TRUE); rtp_session_enable_adaptive_jitter_compensation(session,adapt); rtp_session_set_jitter_compensation(session,jittcomp); rtp_session_set_payload_type(session,0); rtp_session_signal_connect(session,"ssrc_changed",(RtpCallback)ssrc_cb,0); rtp_session_signal_connect(session,"ssrc_changed",(RtpCallback)rtp_session_reset,0); fwrite("#!AMR\n",1,6,outfile); // write(sound_fd,"#!AMR\n",err); while(cond) { have_more=1; while (have_more){ err=rtp_session_recv_with_ts(session,buffer,32,ts,&have_more); if (err>0) stream_received=1; /* this is to avoid to write to disk some silence before the first RTP packet is returned*/ if ((stream_received) && (err>0)) { size_t ret = fwrite(buffer,1,err,outfile); int ii; for(ii =0 ; ii < 32 ; ii ++) printf("%x " ,buffer[ii]); printf("\n"); // while(1); if (sound_fd>0){ ret = write(sound_fd,buffer,err); if (ret==-1){ fprintf(stderr,"write to sound card failed (%s)",strerror(errno)); } } } } ts+=160; //ortp_message("Receiving packet."); } rtp_session_destroy(session); ortp_exit(); ortp_global_stats_display(); return 0; }
int main(int argc, char *argv[]){ MSFilter *src, *gen, *det, *rec; MSTicker *ticker; ms_base_init(); ortp_set_log_level_mask (ORTP_MESSAGE|ORTP_WARNING|ORTP_ERROR|ORTP_FATAL); src=ms_filter_new(MS_FILE_PLAYER_ID); rec=ms_filter_new(MS_FILE_REC_ID); gen=ms_filter_new(MS_DTMF_GEN_ID); det=ms_filter_new(MS_TONE_DETECTOR_ID); ms_filter_link(src,0,gen,0); ms_filter_link(gen,0,det,0); //ms_filter_link(gen,0,rec,0); ms_filter_link(det,0,rec,0); ticker=ms_ticker_new(); ms_ticker_attach(ticker,src); ms_filter_call_method(rec,MS_FILE_REC_OPEN,"/tmp/output.wav"); ms_filter_call_method_noarg(rec,MS_FILE_REC_START); { /*generate and detect the tones*/ MSDtmfGenCustomTone tone; MSToneDetectorDef expected_tone; char dtmf='*'; tone.frequency=2000; tone.duration=400; tone.amplitude=0.6; expected_tone.frequency=2000; expected_tone.min_duration=200; expected_tone.min_amplitude=0.5; ms_filter_set_notify_callback(det,(MSFilterNotifyFunc)tone_detected_cb,NULL); ms_filter_set_notify_callback(gen,(MSFilterNotifyFunc)tone_sent_cb,NULL); ms_filter_call_method(det,MS_TONE_DETECTOR_ADD_SCAN,&expected_tone); ms_filter_call_method(gen,MS_DTMF_GEN_PLAY,&dtmf); ms_sleep(1); ms_filter_call_method(gen,MS_DTMF_GEN_PLAY_CUSTOM,&tone); ms_sleep(1); ms_filter_call_method(gen,MS_DTMF_GEN_PLAY_CUSTOM,&tone); ms_sleep(1); ms_filter_call_method(gen,MS_DTMF_GEN_PLAY_CUSTOM,&tone); ms_sleep(1); tone.frequency=1500; tone.amplitude=1.0; ms_filter_call_method(gen,MS_DTMF_GEN_PLAY_CUSTOM,&tone); ms_sleep(1); } ms_filter_call_method_noarg(rec,MS_FILE_REC_CLOSE); ms_ticker_detach(ticker,src); ms_filter_unlink(src,0,gen,0); ms_filter_unlink(gen,0,det,0); //ms_filter_unlink(gen,0,rec,0); ms_filter_unlink(det,0,rec,0); ms_ticker_destroy(ticker); ms_filter_destroy(src); ms_filter_destroy(gen); ms_filter_destroy(det); ms_filter_destroy(rec); ms_base_exit(); return 0; }
int main(int argc, char *argv[]){ MSFilter *f1,*f2; MSSndCard *card_capture; MSSndCard *card_playback; MSTicker *ticker; MSFactory *factory; char *capt_card=NULL,*play_card=NULL; int rate = 8000; int i; #ifdef __linux const char *alsadev=NULL; #endif ortp_init(); ortp_set_log_level_mask(ORTP_LOG_DOMAIN, ORTP_MESSAGE|ORTP_WARNING|ORTP_ERROR|ORTP_FATAL); factory = ms_factory_new_with_voip(); #ifndef _WIN32_WCE signal(SIGINT,stop); #endif #ifdef __linux alsadev=getenv("MS2_ALSADEV"); if (alsadev!=NULL){ ms_snd_card_manager_add_card( ms_factory_get_snd_card_manager(factory), ms_alsa_card_new_custom (alsadev,alsadev)); } #endif for(i=1;i<argc;++i){ if (strcmp(argv[i],"--help")==0){ print_usage(); }else if (strcmp(argv[i],"--card")==0){ i++; capt_card=play_card=argv[i]; }else if (strcmp(argv[i],"--capt-card")==0){ i++; capt_card=argv[i]; }else if (strcmp(argv[i],"--play-card")==0){ i++; play_card=argv[i]; } } if (capt_card) card_capture = ms_snd_card_manager_get_card(ms_factory_get_snd_card_manager(factory),capt_card); else card_capture = ms_snd_card_manager_get_default_capture_card(ms_factory_get_snd_card_manager(factory)); if (play_card) card_playback = ms_snd_card_manager_get_card(ms_factory_get_snd_card_manager(factory),play_card); else card_playback = ms_snd_card_manager_get_default_playback_card(ms_factory_get_snd_card_manager(factory)); if (card_playback==NULL || card_capture==NULL){ ms_error("No card."); return -1; } f1=ms_snd_card_create_reader(card_capture); f2=ms_snd_card_create_writer(card_playback); ms_filter_call_method (f1, MS_FILTER_SET_SAMPLE_RATE, &rate); ms_filter_call_method (f2, MS_FILTER_SET_SAMPLE_RATE, &rate); ticker=ms_ticker_new(); ms_filter_link(f1,0,f2,0); ms_ticker_attach(ticker,f1); #ifndef _WIN32_WCE while(run) ms_sleep(1); #else ms_sleep(5); #endif ms_ticker_detach(ticker,f1); ms_ticker_destroy(ticker); ms_filter_unlink(f1,0,f2,0); ms_filter_destroy(f1); ms_filter_destroy(f2); ms_factory_destroy(factory); return 0; }
int main(int argc, char*argv[]) { RtpSession *session; #ifndef SBUS unsigned char buffer[160]; #else unsigned char buffer[SBUS_FRAME_SIZE]; #endif int err; uint32_t ts=0; int stream_received=0; FILE *outfile; int local_port; int have_more; int i; int format=0; int soundcard=0; int sound_fd=0; int jittcomp=40; bool_t adapt=TRUE; #ifdef SBUS RtpProfile prof; #endif /* init the lib */ if (argc<3){ printf("%s",help); return -1; } local_port=atoi(argv[2]); if (local_port<=0) { printf("%s",help); return -1; } for (i=3;i<argc;i++) { if (strcmp(argv[i],"--noadapt")==0) adapt=FALSE; if (strcmp(argv[i],"--format")==0){ i++; if (i<argc){ if (strcmp(argv[i],"mulaw")==0){ format=MULAW; }else if (strcmp(argv[i],"alaw")==0){ format=ALAW; }else{ printf("Unsupported format %s\n",argv[i]); return -1; } } } else if (strcmp(argv[i],"--soundcard")==0){ soundcard=1; } else if (strcmp(argv[i],"--with-jitter")==0){ i++; if (i<argc){ jittcomp=atoi(argv[i]); printf("Using a jitter buffer of %i milliseconds.\n",jittcomp); } } } outfile=fopen(argv[1],"wb"); if (outfile==NULL) { perror("Cannot open file for writing"); return -1; } #ifdef SBUS setvbuf(outfile, NULL, _IONBF, 0); #endif if (soundcard){ sound_fd=sound_init(format); } ortp_init(); ortp_scheduler_init(); ortp_set_log_level_mask(ORTP_DEBUG|ORTP_MESSAGE|ORTP_WARNING|ORTP_ERROR); signal(SIGINT,stop_handler); session=rtp_session_new(RTP_SESSION_RECVONLY); rtp_session_set_scheduling_mode(session,1); rtp_session_set_blocking_mode(session,1); rtp_session_set_local_addr(session,"0.0.0.0",atoi(argv[2]),-1); rtp_session_set_connected_mode(session,TRUE); rtp_session_set_symmetric_rtp(session,TRUE); rtp_session_enable_adaptive_jitter_compensation(session,adapt); rtp_session_set_jitter_compensation(session,jittcomp); #ifndef SBUS rtp_session_set_payload_type(session,0); #else rtp_profile_clear_all(&prof); //rtp_profile_set_name(&prof, "SBUS"); rtp_profile_set_payload(&prof, 71, &payload_type_sbus); rtp_session_set_profile(session, &prof); rtp_session_set_payload_type(session, 71); #endif rtp_session_signal_connect(session,"ssrc_changed",(RtpCallback)ssrc_cb,0); rtp_session_signal_connect(session,"ssrc_changed",(RtpCallback)rtp_session_reset,0); while(cond) { have_more=1; while (have_more){ #ifndef SBUS err=rtp_session_recv_with_ts(session,buffer,160,ts,&have_more); #else err=rtp_session_recv_with_ts(session,buffer,SBUS_FRAME_SIZE,ts,&have_more); #endif if (err>0) stream_received=1; /* this is to avoid to write to disk some silence before the first RTP packet is returned*/ if ((stream_received) && (err>0)) { #ifdef SBUS clock_gettime(CLOCK_REALTIME, &tsnew); printf("%09ld\n", tsnew.tv_nsec); #endif size_t ret = fwrite(buffer,1,err,outfile); if (sound_fd>0){ ret = write(sound_fd,buffer,err); if (ret==-1){ fprintf(stderr,"write to sound card failed (%s)",strerror(errno)); } } } } #ifndef SBUS ts+=160; #else ts+=70; #endif //ortp_message("Receiving packet."); } rtp_session_destroy(session); ortp_exit(); ortp_global_stats_display(); return 0; }
void ms_factory_init(MSFactory *obj){ int i; long num_cpu=1; char *debug_log_enabled = NULL; char *tags; #ifdef _WIN32 SYSTEM_INFO sysinfo; #endif #if defined(ENABLE_NLS) bindtextdomain (GETTEXT_PACKAGE, LOCALEDIR); #endif #ifndef MS2_WINDOWS_UNIVERSAL debug_log_enabled=getenv("MEDIASTREAMER_DEBUG"); #endif if (debug_log_enabled!=NULL && (strcmp("1",debug_log_enabled)==0) ){ ortp_set_log_level_mask(ORTP_MESSAGE|ORTP_WARNING|ORTP_ERROR|ORTP_FATAL); } ms_message("Mediastreamer2 factory " MEDIASTREAMER_VERSION " (git: " GIT_VERSION ") initialized."); /* register builtin MSFilter's */ for (i=0;ms_base_filter_descs[i]!=NULL;i++){ ms_factory_register_filter(obj,ms_base_filter_descs[i]); } #ifdef _WIN32 /*fixme to be tested*/ GetNativeSystemInfo( &sysinfo ); num_cpu = sysinfo.dwNumberOfProcessors; #elif __APPLE__ || __linux num_cpu = sysconf( _SC_NPROCESSORS_CONF); /*check the number of processors configured, not just the one that are currently active.*/ #elif __QNX__ num_cpu = _syspage_ptr->num_cpu; #else #warning "There is no code that detects the number of CPU for this platform." #endif ms_factory_set_cpu_count(obj,num_cpu); ms_factory_set_mtu(obj,MS_MTU_DEFAULT); #ifdef _WIN32 ms_factory_add_platform_tag(obj, "win32"); #ifdef MS2_WINDOWS_PHONE ms_factory_add_platform_tag(obj, "windowsphone"); #endif #ifdef MS2_WINDOWS_UNIVERSAL ms_factory_add_platform_tag(obj, "windowsuniversal"); #endif #endif #ifdef __APPLE__ ms_factory_add_platform_tag(obj, "apple"); #endif #ifdef __linux ms_factory_add_platform_tag(obj, "linux"); #endif #ifdef __QNX__ ms_factory_add_platform_tag(obj, "qnx"); #endif #ifdef ANDROID ms_factory_add_platform_tag(obj, "android"); #endif #ifdef TARGET_OS_IPHONE ms_factory_add_platform_tag(obj, "ios"); #endif #if defined(__arm__) || defined(_M_ARM) ms_factory_add_platform_tag(obj, "arm"); #else ms_factory_add_platform_tag(obj, "x86"); #endif #if defined(ANDROID) || (TARGET_OS_IPHONE == 1) || defined(__arm__) || defined(_M_ARM) ms_factory_add_platform_tag(obj, "embedded"); #else ms_factory_add_platform_tag(obj, "desktop"); #endif tags = ms_factory_get_platform_tags_as_string(obj); ms_message("ms_factory_init() done: platform_tags=%s", tags); ms_free(tags); }
int main(int argc, char *argv[]) { RtpSession *session; unsigned char buffer[160]; int i; FILE *infile; char *ssrc; uint32_t packet_ts=0,send_ts=0; uint32_t send_ts_inc=160; int clockslide=0; int jitter=0; if (argc<4){ printf("%s",help); return -1; } for(i=4;i<argc;i++){ if (strcmp(argv[i],"--with-clockslide")==0){ i++; if (i>=argc) { printf("%s",help); return -1; } clockslide=atoi(argv[i]); ortp_message("Using clockslide of %i milisecond every 50 packets.",clockslide); }else if (strcmp(argv[i],"--with-ptime")==0){ ortp_message("Ptime related jitter will be added to outgoing stream."); i++; if (i>=argc) { printf("%s",help); return -1; } jitter=atoi(argv[i]); send_ts_inc=jitter*8; } } ortp_init(); ortp_scheduler_init(); ortp_set_log_level_mask(NULL, ORTP_MESSAGE|ORTP_WARNING|ORTP_ERROR); session=rtp_session_new(RTP_SESSION_SENDONLY); rtp_session_set_scheduling_mode(session,1); rtp_session_set_blocking_mode(session,1); rtp_session_set_connected_mode(session,TRUE); rtp_session_set_remote_addr(session,argv[2],atoi(argv[3])); rtp_session_set_payload_type(session,0); ssrc=getenv("SSRC"); if (ssrc!=NULL) { printf("using SSRC=%i.\n",atoi(ssrc)); rtp_session_set_ssrc(session,atoi(ssrc)); } #ifndef _WIN32 infile=fopen(argv[1],"r"); #else infile=fopen(argv[1],"rb"); #endif if (infile==NULL) { perror("Cannot open file"); return -1; } signal(SIGINT,stophandler); while( ((i=fread(buffer,1,160,infile))>0) && (runcond) ) { mblk_t *m=rtp_session_create_packet(session,RTP_FIXED_HEADER_SIZE,buffer,i); __rtp_session_sendm_with_ts(session,m,packet_ts,send_ts); packet_ts+=160; if ((send_ts+send_ts_inc)<=packet_ts){ send_ts+=send_ts_inc; } if (clockslide!=0 && send_ts%(160*50)==0){ ortp_message("Clock sliding of %i miliseconds now",clockslide); rtp_session_make_time_distorsion(session,clockslide); } } fclose(infile); rtp_session_destroy(session); ortp_exit(); ortp_global_stats_display(); return 0; }
int main(int argc, char **argv) { ortp_init(); ms_init(); zk_xmpp_uac_init(); ortp_set_log_level_mask(ORTP_MESSAGE); if (argc < 2) { fprintf(stderr, "usage: %s <zqpkt src url> [s]\n", argv[0]); return -1; } bool stream_mode = false; if (argc == 3 && argv[2][0] == 's') stream_mode = true; _stream_mode = stream_mode; if (stream_mode) fprintf(stdout, "=== STREAMING MODE ===\n\n"); else fprintf(stdout, "=== SOURCING MODE ===\n\n"); _url = argv[1]; _env = CreateEvent(0, 0, 0, 0); fprintf(stdout, "%s: using zqpkt src '%s', just wait mcu .....\n", argv[0], argv[1]); // 使用 normaluser 登录 cb_xmpp_uac cbs = { 0, 0, 0, 0, cb_connect_notify }; _uac = zk_xmpp_uac_log_in(get_user_jid(), "ddkk1212", &cbs, 0); WaitForSingleObject(_env, 10000); if (_sid == -1) { fprintf(stderr, ":( somthing err, exit!\n"); } else { SetConsoleCtrlHandler(signal_ctrl_c, 1); const char *src_url = argv[1]; const char *target_ip = _ip.c_str(); int target_port = _rtp_port; int target_port2 = _rtcp_port; //fprintf(stdout, "target ip=%s\ntarget port=%d\n\n", target_ip, target_port); // only support h264 rtp_profile_set_payload(&av_profile,100, &payload_type_h264); /// 使用 zonekey.h264.source filter zonekey_h264_source_register(); MSFilterDesc *desc = ms_filter_lookup_by_name("ZonekeyH264Source"); MSFilter *source = ms_filter_new_from_desc(desc); if (_stream_mode) zonekey_yuv_sink_register(); // 获取 writer_params ZonekeyH264SourceWriterParam writer_param; ms_filter_call_method(source, ZONEKEY_METHOD_H264_SOURCE_GET_WRITER_PARAM, &writer_param); // RTP Session RtpSession *rtpsess = rtp_session_new(RTP_SESSION_SENDRECV); // rtp_session_set_local_addr(rtpsess, "0.0.0.0", -1, -1); // 随机端口 rtp_session_set_remote_addr_and_port(rtpsess, target_ip, target_port, target_port2); rtp_session_set_payload_type(rtpsess, 100); // h264 JBParameters jb; jb.adaptive = 1; jb.max_packets = 3000; jb.max_size = -1; jb.min_size = jb.nom_size = 300; rtp_session_set_jitter_buffer_params(rtpsess, &jb); // disable video jitter control rtp_session_enable_jitter_buffer(rtpsess, 0); /// rtp sender MSFilter *rtp_sender = ms_filter_new(MS_RTP_SEND_ID); ms_filter_call_method(rtp_sender, MS_RTP_SEND_SET_SESSION, rtpsess); // connect source --> rtp sender ms_filter_link(source, 0, rtp_sender, 0); // MSTicker MSTicker *ticker = ms_ticker_new(); // attach ticker ms_ticker_attach(ticker, source); if (_stream_mode) { // FIXME: recv, but .... MSFilter *rtp_recver = ms_filter_new(MS_RTP_RECV_ID); ms_filter_call_method(rtp_recver, MS_RTP_RECV_SET_SESSION, rtpsess); MSFilter *decoder = ms_filter_new(MS_H264_DEC_ID); MSFilter *sink = ms_filter_new_from_name("ZonekeyYUVSink"); ms_filter_link(rtp_recver, 0, decoder, 0); ms_filter_link(decoder, 0, sink, 0); MSTicker *tk = ms_ticker_new(); //ms_ticker_attach(tk, rtp_recver); } // 利用 libzqpkt 接收 h264 数据,并且调用 zonekey h264 source 的 writer() void *zqp = 0; if (zqpsrc_open(&zqp, src_url) < 0) { fprintf(stderr, "to open src err\n"); return -1; } while (!_quit) { zq_pkt *pkt = zqpsrc_getpkt(zqp); if (pkt) { if (pkt->type == 1) { // h264 writer_param.write(writer_param.ctx, pkt->ptr, pkt->len, pkt->pts / 45000.0); } zqpsrc_freepkt(zqp, pkt); } else break; } // 发送删除 sid 的命令 char options[128], *cmd="test.fc.del_source"; if (_stream_mode) { snprintf(options, sizeof(options), "streamid=%d", _sid); cmd = "test.dc.del_stream"; } else snprintf(options, sizeof(options), "sid=%d", _sid); zk_xmpp_uac_send_cmd(_uac, get_mcu_jid(), cmd, options, 0, cb_response); fprintf(stderr, "\n\nen. to del sid=%d\n\n", _sid); zqpsrc_close(zqp); fprintf(stderr, "END!\n"); WaitForSingleObject(_env, 3000); // 等待 test.fc.de_source 发送成功 } return 0; }
int main(int argc, char *argv[]) { int sendport=5070; char *file=NULL; char *url=NULL; bool_t ipv6=FALSE; int i; for(i=1;i<argc;i++){ if ( (strcmp(argv[i],"-h")==0) || (strcmp(argv[i],"--help")==0) ){ display_help(); continue; } if ( (strcmp(argv[i],"-v")==0) || (strcmp(argv[i],"--version")==0) ){ printf("version: " LINPHONE_VERSION "\n"); exit(0); } if (strcmp(argv[i],"-u")==0){ i++; url=getarg(argc,argv,i); continue; } if (strcmp(argv[i],"-s")==0){ char *port; i++; port=getarg(argc,argv,i); sendport=atoi(port); continue; } if (strcmp(argv[i],"-f")==0){ i++; file=getarg(argc,argv,i); continue; } if (strcmp(argv[i],"-6")==0){ ipv6=TRUE; continue; } } signal(SIGINT,stop_handler); ortp_init(); ms_init(); ortp_set_log_level_mask(ORTP_MESSAGE|ORTP_WARNING|ORTP_ERROR|ORTP_FATAL); rtp_profile_set_payload(&av_profile,115,&payload_type_lpc1015); rtp_profile_set_payload(&av_profile,110,&payload_type_speex_nb); rtp_profile_set_payload(&av_profile,111,&payload_type_speex_wb); rtp_profile_set_payload(&av_profile,112,&payload_type_ilbc); rtp_profile_set_payload(&av_profile,101,&payload_type_telephone_event); rtp_profile_set_payload(&av_profile,116,&payload_type_truespeech); rtp_profile_set_payload(&av_profile,98,&payload_type_h263_1998); sipomatic_init(&sipomatic,url,ipv6); if (file!=NULL) sipomatic_set_annouce_file(&sipomatic,file); while (run_cond){ sipomatic_iterate(&sipomatic); usleep(20000); } return(0); }
static int tester_init() { ortp_set_log_level_mask(ORTP_MESSAGE | ORTP_WARNING | ORTP_ERROR | ORTP_FATAL); ms_init(); return 0; }
int main(int argc, char * argv[]) { int i; int localport=0,remoteport=0,payload=0; char ip[50]; const char *fmtp=NULL; int jitter=50; int bitrate=0; MSVideoSize vs; bool_t ec=FALSE; bool_t agc=FALSE; bool_t eq=FALSE; /*create the rtp session */ ortp_init(); ortp_set_log_level_mask(ORTP_MESSAGE|ORTP_WARNING|ORTP_ERROR|ORTP_FATAL); rtp_profile_set_payload(&av_profile,115,&payload_type_lpc1015); rtp_profile_set_payload(&av_profile,110,&payload_type_speex_nb); rtp_profile_set_payload(&av_profile,111,&payload_type_speex_wb); rtp_profile_set_payload(&av_profile,112,&payload_type_ilbc); rtp_profile_set_payload(&av_profile,113,&payload_type_amr); #ifdef VIDEO_ENABLED rtp_profile_set_payload(&av_profile,26,&payload_type_jpeg); rtp_profile_set_payload(&av_profile,98,&payload_type_h263_1998); rtp_profile_set_payload(&av_profile,97,&payload_type_theora); rtp_profile_set_payload(&av_profile,99,&payload_type_mp4v); rtp_profile_set_payload(&av_profile,100,&payload_type_x_snow); rtp_profile_set_payload(&av_profile,102,&payload_type_h264); #endif vs.width=MS_VIDEO_SIZE_CIF_W; vs.height=MS_VIDEO_SIZE_CIF_H; if (argc<4) { printf("%s",usage); return -1; } for (i=1;i<argc;i++){ if (strcmp(argv[i],"--local")==0){ i++; localport=atoi(argv[i]); }else if (strcmp(argv[i],"--remote")==0){ i++; if (!parse_addr(argv[i],ip,sizeof(ip),&remoteport)) { printf("%s",usage); return -1; } printf("Remote addr: ip=%s port=%i\n",ip,remoteport); }else if (strcmp(argv[i],"--payload")==0){ i++; payload=atoi(argv[i]); }else if (strcmp(argv[i],"--fmtp")==0){ i++; fmtp=argv[i]; }else if (strcmp(argv[i],"--jitter")==0){ i++; jitter=atoi(argv[i]); }else if (strcmp(argv[i],"--bitrate")==0){ i++; bitrate=atoi(argv[i]); }else if (strcmp(argv[i],"--width")==0){ i++; vs.width=atoi(argv[i]); }else if (strcmp(argv[i],"--height")==0){ i++; vs.height=atoi(argv[i]); }else if (strcmp(argv[i],"--capture-card")==0){ i++; capture_card=argv[i]; }else if (strcmp(argv[i],"--playback-card")==0){ i++; playback_card=argv[i]; }else if (strcmp(argv[i],"--ec")==0){ ec=TRUE; }else if (strcmp(argv[i],"--agc")==0){ agc=TRUE; }else if (strcmp(argv[i],"--eq")==0){ eq=TRUE; }else if (strcmp(argv[i],"--ng")==0){ use_ng=1; }else if (strcmp(argv[i],"--ng-threshold")==0){ i++; ng_threshold=atof(argv[i]); }else if (strcmp(argv[i],"--two-windows")==0){ two_windows=TRUE; }else if (strcmp(argv[i],"--infile")==0){ i++; infile=argv[i]; }else if (strcmp(argv[i],"--outfile")==0){ i++; outfile=argv[i]; } } run_media_streams(localport,ip,remoteport,payload,fmtp,jitter,bitrate,vs,ec,agc,eq); return 0; }