- Timestamp:
- May 10, 2011 5:42:28 AM (13 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
pjproject/branches/projects/2.0-dev/pjsip/src/pjsua-lib/pjsua_media.c
r3521 r3560 1371 1371 return status; 1372 1372 } 1373 1374 call_med->tp_st = PJSUA_MED_TP_IDLE; 1375 } else if (call_med->tp_st == PJSUA_MED_TP_DISABLED) { 1376 /* Media is being reenabled. */ 1377 call_med->tp_st = PJSUA_MED_TP_INIT; 1373 1378 } 1374 1379 … … 1393 1398 /* Always create SRTP adapter */ 1394 1399 pjmedia_srtp_setting_default(&srtp_opt); 1395 srtp_opt.close_member_tp = PJ_ FALSE;1400 srtp_opt.close_member_tp = PJ_TRUE; 1396 1401 /* If media session has been ever established, let's use remote's 1397 1402 * preference in SRTP usage policy, especially when it is stricter. … … 1451 1456 PJ_UNUSED_ARG(role); 1452 1457 1458 /* 1459 * Note: this function may be called when the media already exists 1460 * (e.g. in reinvites, updates, etc). 1461 */ 1462 1453 1463 if (pjsua_get_state() != PJSUA_STATE_RUNNING) 1454 1464 return PJ_EBUSY; … … 1468 1478 sort_media(rem_sdp, &STR_AUDIO, acc->cfg.use_srtp, 1469 1479 maudidx, &maudcnt); 1480 if (maudcnt > acc->cfg.max_audio_cnt) 1481 maudcnt = acc->cfg.max_audio_cnt; 1470 1482 1471 1483 if (maudcnt==0) { … … 1478 1490 sort_media(rem_sdp, &STR_VIDEO, acc->cfg.use_srtp, 1479 1491 mvididx, &mvidcnt); 1480 mvidcnt = (mvidcnt < acc->cfg.max_video_cnt) ? 1481 mvidcnt : acc->cfg.max_video_cnt; 1492 if (mvidcnt > acc->cfg.max_video_cnt) 1493 mvidcnt = acc->cfg.max_video_cnt; 1494 1495 /* Update media count only when remote add any media, this media count 1496 * must never decrease. 1497 */ 1498 if (call->med_cnt < rem_sdp->media_count) 1499 call->med_cnt = PJ_MIN(rem_sdp->media_count, PJSUA_MAX_CALL_MEDIA); 1482 1500 1483 1501 } else { … … 1491 1509 media_types[maudcnt + mi] = PJMEDIA_TYPE_VIDEO; 1492 1510 } 1493 } 1494 1495 call->med_cnt = maudcnt + mvidcnt;1511 1512 call->med_cnt = maudcnt + mvidcnt; 1513 } 1496 1514 1497 1515 if (call->med_cnt == 0) { … … 1509 1527 1510 1528 if (rem_sdp) { 1511 if (!pj_stricmp(&rem_sdp->media[mi]->desc.media, &STR_AUDIO)) { 1529 if (mi >= rem_sdp->media_count) { 1530 /* Media has been removed in remote re-offer */ 1531 media_type = call_med->type; 1532 } else if (!pj_stricmp(&rem_sdp->media[mi]->desc.media, &STR_AUDIO)) { 1512 1533 media_type = PJMEDIA_TYPE_AUDIO; 1513 1534 if (pj_memchr(maudidx, mi, maudcnt * sizeof(maudidx[0]))) { … … 1536 1557 } 1537 1558 } else { 1538 /* By convention, the media is inactive if transport is NULL */ 1559 /* By convention, the media is disabled if transport is NULL 1560 * or transport state is PJSUA_MED_TP_DISABLED. 1561 */ 1539 1562 if (call_med->tp) { 1540 pjmedia_transport_close(call_med->tp); 1541 call_med->tp = NULL; 1563 // Don't close transport here, as SDP negotiation has not been 1564 // done and stream may be still active. 1565 //pjmedia_transport_close(call_med->tp); 1566 //call_med->tp = NULL; 1567 pj_assert(call_med->tp_st == PJSUA_MED_TP_INIT || 1568 call_med->tp_st == PJSUA_MED_TP_RUNNING); 1569 call_med->tp_st = PJSUA_MED_TP_DISABLED; 1542 1570 } 1571 1572 /* Put media type just for info */ 1573 call_med->type = media_type; 1543 1574 } 1544 1575 } … … 1553 1584 pjsua_call_media *call_med = &call->media[mi]; 1554 1585 1555 /* Note: tp may be NULL if this media line is inactive*/1556 if (call_med->tp ) {1586 /* Note: tp may be NULL if this media line is disabled */ 1587 if (call_med->tp && call_med->tp_st == PJSUA_MED_TP_IDLE) { 1557 1588 status = pjmedia_transport_media_create(call_med->tp, 1558 1589 tmp_pool, 0, … … 1577 1608 int *sip_err_code) 1578 1609 { 1579 const pj_str_t STR_AUDIO = { "audio", 5 };1580 1610 enum { MAX_MEDIA = PJSUA_MAX_CALL_MEDIA }; 1581 1611 pjmedia_sdp_session *sdp; 1582 1612 pj_sockaddr origin; 1583 1613 pjsua_call *call = &pjsua_var.calls[call_id]; 1584 pjsua_acc *acc = &pjsua_var.acc[call->acc_id];1585 1614 pjmedia_sdp_neg_state sdp_neg_state = PJMEDIA_SDP_NEG_STATE_NULL; 1586 1615 unsigned mi; … … 1591 1620 1592 1621 if (rem_sdp) { 1622 /* If this is a re-offer, let's re-initialize media as remote may 1623 * add or remove media 1624 */ 1625 if (call->inv && call->inv->state == PJSIP_INV_STATE_CONFIRMED) { 1626 status = pjsua_media_channel_init(call_id, PJSIP_ROLE_UAS, 1627 call->secure_level, pool, 1628 rem_sdp, sip_err_code); 1629 if (status != PJ_SUCCESS) 1630 return status; 1631 } 1632 1633 #if 0 1634 pjsua_acc *acc = &pjsua_var.acc[call->acc_id]; 1593 1635 pj_uint8_t maudidx[PJSUA_MAX_CALL_MEDIA]; 1594 1636 unsigned maudcnt = PJ_ARRAY_SIZE(maudidx); … … 1605 1647 1606 1648 call->audio_idx = maudidx[0]; 1649 #endif 1607 1650 } else { 1608 1651 /* Audio is first in our offer, by convention */ 1609 call->audio_idx = 0; 1610 } 1611 1652 // The audio_idx should not be changed here, as this function may be 1653 // called in generating re-offer and the current active audio index 1654 // can be anywhere. 1655 //call->audio_idx = 0; 1656 } 1657 1658 #if 0 1659 // Since r3512, old-style hold should have got transport, created by 1660 // pjsua_media_channel_init() in initial offer/answer or remote reoffer. 1612 1661 /* Create media if it's not created. This could happen when call is 1613 1662 * currently on-hold (with the old style hold) … … 1621 1670 return status; 1622 1671 } 1672 #endif 1623 1673 1624 1674 /* Get SDP negotiator state */ … … 1652 1702 pjmedia_transport_info tpinfo; 1653 1703 1654 if (call_med->tp == NULL) { 1704 if (rem_sdp && mi >= rem_sdp->media_count) { 1705 /* Remote might have removed some media lines. */ 1706 break; 1707 } 1708 1709 if (call_med->tp == NULL || call_med->tp_st == PJSUA_MED_TP_DISABLED) 1710 { 1655 1711 /* 1656 * This media is d eactivated. Just create a valid SDP with zero1712 * This media is disabled. Just create a valid SDP with zero 1657 1713 * port. 1658 1714 */ … … 1916 1972 } 1917 1973 1918 if (call_med->tp_orig && call_med->tp && 1919 call_med->tp != call_med->tp_orig) 1920 { 1974 //if (call_med->tp_orig && call_med->tp && 1975 // call_med->tp != call_med->tp_orig) 1976 //{ 1977 // pjmedia_transport_close(call_med->tp); 1978 // call_med->tp = call_med->tp_orig; 1979 //} 1980 if (call_med->tp) { 1921 1981 pjmedia_transport_close(call_med->tp); 1922 call_med->tp = call_med->tp_orig ;1982 call_med->tp = call_med->tp_orig = NULL; 1923 1983 } 1924 1984 } … … 2414 2474 pj_pool_t *tmp_pool = call->inv->pool_prov; 2415 2475 unsigned mi; 2476 pj_bool_t got_media = PJ_FALSE; 2416 2477 pj_status_t status = PJ_SUCCESS; 2417 2478 … … 2429 2490 pjsua_call_media *call_med = &call->media[mi]; 2430 2491 2431 if (mi > local_sdp->media_count ||2432 mi > remote_sdp->media_count)2492 if (mi >= local_sdp->media_count || 2493 mi >= remote_sdp->media_count) 2433 2494 { 2495 /* This may happen when remote removed any SDP media lines in 2496 * its re-offer. 2497 */ 2498 continue; 2499 #if 0 2434 2500 /* Something is wrong */ 2435 2501 PJ_LOG(1,(THIS_FILE, "Error updating media for call %d: " 2436 2502 "invalid media index %d in SDP", call_id, mi)); 2437 2503 return PJMEDIA_SDP_EINSDP; 2504 #endif 2438 2505 } 2439 2506 … … 2455 2522 #endif 2456 2523 default: 2524 status = PJMEDIA_EINVALIMEDIATYPE; 2457 2525 break; 2458 2526 } 2459 2527 2460 2528 if (status != PJ_SUCCESS) { 2461 PJ_PERROR(1,(THIS_FILE, status, "Error updating media call%02 :%d",2529 PJ_PERROR(1,(THIS_FILE, status, "Error updating media call%02d:%d", 2462 2530 call_id, mi)); 2463 } 2464 } 2465 2466 return PJ_SUCCESS; 2531 } else { 2532 got_media = PJ_TRUE; 2533 } 2534 } 2535 2536 return (got_media? PJ_SUCCESS : PJMEDIA_SDPNEG_ENOMEDIA); 2467 2537 } 2468 2538
Note: See TracChangeset
for help on using the changeset viewer.