Changeset 1823 for pjproject/trunk


Ignore:
Timestamp:
Feb 26, 2008 3:32:16 PM (17 years ago)
Author:
bennylp
Message:

Ticket #495: ability to specify different clock rate when opening sound device

Location:
pjproject/trunk
Files:
4 edited

Legend:

Unmodified
Added
Removed
  • pjproject/trunk/pjsip-apps/src/pjsua/pjsua_app.c

    r1802 r1823  
    172172    puts  ("  --add-codec=name    Manually add codec (default is to enable all)"); 
    173173    puts  ("  --dis-codec=name    Disable codec (can be specified multiple times)"); 
    174     puts  ("  --clock-rate=N      Override sound device clock rate"); 
     174    puts  ("  --clock-rate=N      Override conference bridge clock rate"); 
     175    puts  ("  --snd-clock-rate=N  Override sound device clock rate"); 
    175176    puts  ("  --null-audio        Use NULL audio device"); 
    176177    puts  ("  --play-file=file    Register WAV file in conference bridge."); 
     
    387388           OPT_ADD_BUDDY, OPT_OFFER_X_MS_MSG, OPT_NO_PRESENCE, 
    388389           OPT_AUTO_ANSWER, OPT_AUTO_HANGUP, OPT_AUTO_PLAY, OPT_AUTO_LOOP, 
    389            OPT_AUTO_CONF, OPT_CLOCK_RATE, OPT_USE_ICE, OPT_USE_SRTP,  
    390            OPT_SRTP_SECURE, 
     390           OPT_AUTO_CONF, OPT_CLOCK_RATE, OPT_SND_CLOCK_RATE, OPT_USE_ICE, 
     391           OPT_USE_SRTP, OPT_SRTP_SECURE, 
    391392           OPT_PLAY_FILE, OPT_PLAY_TONE, OPT_RTP_PORT, OPT_ADD_CODEC,  
    392393           OPT_ILBC_MODE, OPT_REC_FILE, OPT_AUTO_REC, 
     
    410411        { "version",    0, 0, OPT_VERSION}, 
    411412        { "clock-rate", 1, 0, OPT_CLOCK_RATE}, 
     413        { "snd-clock-rate",     1, 0, OPT_SND_CLOCK_RATE}, 
    412414        { "null-audio", 0, 0, OPT_NULL_AUDIO}, 
    413415        { "local-port", 1, 0, OPT_LOCAL_PORT}, 
     
    563565            if (lval < 8000 || lval > 48000) { 
    564566                PJ_LOG(1,(THIS_FILE, "Error: expecting value between " 
    565                                      "8000-48000 for clock rate")); 
     567                                     "8000-48000 for conference clock rate")); 
    566568                return PJ_EINVAL; 
    567569            } 
    568570            cfg->media_cfg.clock_rate = lval;  
     571            break; 
     572 
     573        case OPT_SND_CLOCK_RATE: 
     574            lval = pj_strtoul(pj_cstr(&tmp, pj_optarg)); 
     575            if (lval < 8000 || lval > 48000) { 
     576                PJ_LOG(1,(THIS_FILE, "Error: expecting value between " 
     577                                     "8000-48000 for sound device clock rate")); 
     578                return PJ_EINVAL; 
     579            } 
     580            cfg->media_cfg.snd_clock_rate = lval;  
    569581            break; 
    570582 
     
    13861398        pj_ansi_sprintf(line, "#using default --clock-rate %d\n", 
    13871399                        config->media_cfg.clock_rate); 
     1400        pj_strcat2(&cfg, line); 
     1401    } 
     1402 
     1403    if (config->media_cfg.snd_clock_rate != config->media_cfg.clock_rate) { 
     1404        pj_ansi_sprintf(line, "--snd-clock-rate %d\n", 
     1405                        config->media_cfg.snd_clock_rate); 
     1406        pj_strcat2(&cfg, line); 
     1407    } else { 
     1408        pj_ansi_sprintf(line, "#using default --snd-clock-rate %d\n", 
     1409                        config->media_cfg.snd_clock_rate); 
    13881410        pj_strcat2(&cfg, line); 
    13891411    } 
  • pjproject/trunk/pjsip/include/pjsua-lib/pjsua.h

    r1806 r1823  
    37433743 
    37443744    /** 
     3745     * Clock rate to be applied when opening the sound device. 
     3746     * If value is zero, conference bridge clock rate will be used. 
     3747     */ 
     3748    unsigned            snd_clock_rate; 
     3749 
     3750    /** 
    37453751     * Specify audio frame ptime. The value here will affect the  
    37463752     * samples per frame of both the sound device and the conference 
  • pjproject/trunk/pjsip/src/pjsua-lib/pjsua_core.c

    r1815 r1823  
    163163 
    164164    cfg->clock_rate = PJSUA_DEFAULT_CLOCK_RATE; 
     165    cfg->snd_clock_rate = PJSUA_DEFAULT_CLOCK_RATE; 
    165166    cfg->audio_frame_ptime = PJSUA_DEFAULT_AUDIO_FRAME_PTIME; 
    166167    cfg->max_media_ports = PJSUA_MAX_CONF_PORTS; 
  • pjproject/trunk/pjsip/src/pjsua-lib/pjsua_media.c

    r1810 r1823  
    17721772    pjmedia_port *conf_port; 
    17731773    const pjmedia_snd_dev_info *play_info; 
    1774     unsigned clock_rates[] = { 0, 22050, 44100, 48000, 11025, 32000, 8000}; 
     1774    unsigned clock_rates[] = {0, 22050, 44100, 48000, 32000, 16000,  
     1775                              8000}; 
    17751776    unsigned selected_clock_rate = 0; 
    17761777    unsigned i; 
     
    17851786 
    17861787    /* Set default clock rate */ 
    1787     clock_rates[0] = pjsua_var.media_cfg.clock_rate; 
     1788    clock_rates[0] = pjsua_var.media_cfg.snd_clock_rate; 
     1789    if (clock_rates[0] == 0) 
     1790        clock_rates[0] = pjsua_var.media_cfg.clock_rate; 
    17881791 
    17891792    /* Attempts to open the sound device with different clock rates */ 
     
    18321835    if (selected_clock_rate != pjsua_var.media_cfg.clock_rate) { 
    18331836        pjmedia_port *resample_port; 
    1834  
     1837        unsigned resample_opt = 0; 
     1838 
     1839        if (pjsua_var.media_cfg.quality >= 3 && 
     1840            pjsua_var.media_cfg.quality <= 4) 
     1841        { 
     1842            resample_opt |= PJMEDIA_CONF_SMALL_FILTER; 
     1843        } 
     1844        else if (pjsua_var.media_cfg.quality < 3) { 
     1845            resample_opt |= PJMEDIA_CONF_USE_LINEAR; 
     1846        } 
     1847         
    18351848        status = pjmedia_resample_port_create(pjsua_var.pool, conf_port,  
    1836                                               selected_clock_rate, 0,  
    1837                                               &resample_port); 
     1849                                              selected_clock_rate,  
     1850                                              resample_opt, &resample_port); 
    18381851        if (status != PJ_SUCCESS) { 
    18391852            pjsua_perror("Error creating resample port", THIS_FILE, status); 
     
    18641877    play_info = pjmedia_snd_get_dev_info(si.rec_id); 
    18651878 
    1866     pjmedia_conf_set_port0_name(pjsua_var.mconf,  
    1867                                 pj_cstr(&tmp, play_info->name)); 
     1879    if (si.clock_rate != pjsua_var.media_cfg.clock_rate) { 
     1880        char tmp_buf[128]; 
     1881        int tmp_buf_len = sizeof(tmp_buf); 
     1882 
     1883        tmp_buf_len = pj_ansi_snprintf(tmp_buf, sizeof(tmp_buf)-1, "%s (%dKHz)", 
     1884                                       play_info->name, si.clock_rate/1000); 
     1885        pj_strset(&tmp, tmp_buf, tmp_buf_len); 
     1886        pjmedia_conf_set_port0_name(pjsua_var.mconf, &tmp);  
     1887    } else { 
     1888        pjmedia_conf_set_port0_name(pjsua_var.mconf,  
     1889                                    pj_cstr(&tmp, play_info->name)); 
     1890    } 
    18681891 
    18691892    return PJ_SUCCESS; 
Note: See TracChangeset for help on using the changeset viewer.