Re: [MMUSIC] T.140 in Data Channel scenarios - SDP support

Gunnar Hellström <gunnar.hellstrom@omnitor.se> Thu, 26 September 2019 14:58 UTC

Return-Path: <gunnar.hellstrom@omnitor.se>
X-Original-To: mmusic@ietfa.amsl.com
Delivered-To: mmusic@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 9CE42120937 for <mmusic@ietfa.amsl.com>; Thu, 26 Sep 2019 07:58:05 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -1.898
X-Spam-Level:
X-Spam-Status: No, score=-1.898 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, FROM_EXCESS_BASE64=0.001, HTML_MESSAGE=0.001, RCVD_IN_DNSWL_NONE=-0.0001, SPF_PASS=-0.001, URIBL_BLOCKED=0.001] autolearn=ham autolearn_force=no
Authentication-Results: ietfa.amsl.com (amavisd-new); dkim=pass (1024-bit key) header.d=omnitorab.onmicrosoft.com
Received: from mail.ietf.org ([4.31.198.44]) by localhost (ietfa.amsl.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id Y_xv8dt2zwkH for <mmusic@ietfa.amsl.com>; Thu, 26 Sep 2019 07:58:00 -0700 (PDT)
Received: from EUR01-DB5-obe.outbound.protection.outlook.com (mail-db5eur01on071d.outbound.protection.outlook.com [IPv6:2a01:111:f400:fe02::71d]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-SHA384 (256/256 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id 866DA120929 for <mmusic@ietf.org>; Thu, 26 Sep 2019 07:57:58 -0700 (PDT)
ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=Dki3/wMceZUVHQh1rScsX1UU9U6qEj6wUb0jre+9kU9VYUp1KPzDXkHzkn2ZRiufwP0OiS4eRv3ZBR4Em6BSQdMLWTlekCvi9wQblTq3Mv4l5jUePp4ElLR5lwvUbhLxgzEYweq93LDQU08DQIlN/9l3njZyZNK5JHjM2hgGYoj6hxBVLU8LIlE1o4JC+f2Zho8yFBA4dmB6YCN63ZmJFKgWs7xsJoMlfq89oSNGDXTEWcsu90cAOm+a06iQwE0HU58X7zTyKpj+mW8Yi9sGmW/VAfIZswT4MURbJoiJAQpuGMjYrZZEIgnM9FmgiRnjIH6/vajCBSY+iTCiOarIHg==
ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=j1roGkvqHe1jSYlXZoScEPXFWD5dCUxoCyg6ctoCiss=; b=nGEEh5kEMcYAkdX0cCELWztn74tBQI2NcDeJvZq4V5dUBTIQd7R37pikpJucJynJHkVMEV0TGFE0mDXPyXOpdLF1xOiXhEwLzcSwTI5S4thVPShqJL5zkbI1cOvXXml11Pls9/aGyYb/bZbe9Bd+kecnGea1gNefq00IJWerEJpoO5vXN6IKEPzKrreCuFcXYPcMZbxWPIiOb5TB0xxcNsStU9eeiAUGFxGMEL5n77aTSoU9QhJi2vondhraW6L35CKcOrhiBh47sMtjzwBDvzC3aoENTO4LAJPcuJ9Kbys9UgHEpdC0EZK0S24AUxVBldtLtRwM/KVbspc2LzGBxA==
ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=omnitor.se; dmarc=pass action=none header.from=omnitor.se; dkim=pass header.d=omnitor.se; arc=none
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=omnitorab.onmicrosoft.com; s=selector1-omnitorab-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=j1roGkvqHe1jSYlXZoScEPXFWD5dCUxoCyg6ctoCiss=; b=nQNoJyWY2pT4bvlUO2r4qLwHhf990yfuRDpxCTfxt+TCtPf0Qqe/p1t/jA4YfH3Ijqt7joncNyuQabchAQ0VDGZaF/d05Jh4zJ+N6vtl7kobiOK+7GLOTIbvJW4W/C5aZstFNJC1sQM0Rz95AjJ1LGMMNKok/FsKyd6/sNWSMjA=
Received: from VI1P193MB0669.EURP193.PROD.OUTLOOK.COM (10.186.178.76) by VI1P193MB0334.EURP193.PROD.OUTLOOK.COM (52.134.122.26) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.2284.26; Thu, 26 Sep 2019 14:57:54 +0000
Received: from VI1P193MB0669.EURP193.PROD.OUTLOOK.COM ([fe80::1835:6533:1158:2507]) by VI1P193MB0669.EURP193.PROD.OUTLOOK.COM ([fe80::1835:6533:1158:2507%3]) with mapi id 15.20.2284.023; Thu, 26 Sep 2019 14:57:54 +0000
From: Gunnar Hellström <gunnar.hellstrom@omnitor.se>
To: Christer Holmberg <christer.holmberg@ericsson.com>, Bernard Aboba <bernard.aboba@gmail.com>
CC: mmusic WG <mmusic@ietf.org>
Thread-Topic: [MMUSIC] T.140 in Data Channel scenarios - SDP support
Thread-Index: AQHVc941FhVr12DOkEigKs4uOWK5/ac84rUAgAAqZoCAAO/WgIAAENmA
Date: Thu, 26 Sep 2019 14:57:54 +0000
Message-ID: <b456e53f-7673-4a6a-b8db-92ba01a4f759@omnitor.se>
References: <CAOW+2duiD8ZTDQpzupfC9S7tp7k6Xm5K2vA+643RMTpkDCnsMQ@mail.gmail.com> <HE1PR07MB3161640EC7A7269FE3A0D11993840@HE1PR07MB3161.eurprd07.prod.outlook.com> <VI1P193MB06698BA67FA8D8C5050BF10CFB840@VI1P193MB0669.EURP193.PROD.OUTLOOK.COM> <CAOW+2dv1YQ-UtXBWj5RZ=FDGvGKmjV+mwjQH4TAyFsbe75ivEQ@mail.gmail.com> <VI1P193MB0669B64299BDD4D0A39573ACFB870@VI1P193MB0669.EURP193.PROD.OUTLOOK.COM> <a5b5c943-3079-d2dd-988c-e2b3c853c37c@omnitor.se> <CAOW+2dvVGVzpN_VpJAnz_gtGwnxzh6xEUj4f0Z45ityjqkTOEQ@mail.gmail.com> <a026e3bd-6621-181c-34f3-ff5d296535a1@omnitor.se> <FE61365B-46ED-450C-9FB2-26286F8CA53F@ericsson.com>
In-Reply-To: <FE61365B-46ED-450C-9FB2-26286F8CA53F@ericsson.com>
Accept-Language: sv-SE, en-US
Content-Language: en-US
X-MS-Has-Attach:
X-MS-TNEF-Correlator:
x-clientproxiedby: GV0P278CA0009.CHEP278.PROD.OUTLOOK.COM (2603:10a6:710:26::19) To VI1P193MB0669.EURP193.PROD.OUTLOOK.COM (2603:10a6:800:159::12)
authentication-results: spf=none (sender IP is ) smtp.mailfrom=gunnar.hellstrom@omnitor.se;
x-ms-exchange-messagesentrepresentingtype: 1
x-originating-ip: [77.53.231.170]
x-ms-publictraffictype: Email
x-ms-office365-filtering-correlation-id: 028fd95e-d8b9-4052-4252-08d74291e8f8
x-microsoft-antispam: BCL:0; PCL:0; RULEID:(2390118)(7020095)(4652040)(7021145)(8989299)(5600167)(711020)(4605104)(1401327)(4534185)(7022145)(4603075)(4627221)(201702281549075)(8990200)(7048125)(7024125)(7027125)(7023125)(2017052603328)(7193020); SRVR:VI1P193MB0334;
x-ms-traffictypediagnostic: VI1P193MB0334:
x-ms-exchange-purlcount: 12
x-microsoft-antispam-prvs: <VI1P193MB0334B39D128C90569A713090FB860@VI1P193MB0334.EURP193.PROD.OUTLOOK.COM>
x-ms-oob-tlc-oobclassifiers: OLM:10000;
x-forefront-prvs: 0172F0EF77
x-forefront-antispam-report: SFV:NSPM; SFS:(10019020)(396003)(366004)(136003)(39830400003)(376002)(346002)(189003)(199004)(606006)(486006)(7736002)(6436002)(36756003)(4326008)(86362001)(76176011)(476003)(85182001)(53546011)(386003)(5660300002)(26005)(6486002)(6306002)(236005)(256004)(186003)(6512007)(14444005)(54896002)(52116002)(8936002)(81166006)(2906002)(66574012)(102836004)(71190400001)(71200400001)(6506007)(3846002)(6116002)(31686004)(81156014)(8676002)(110136005)(31696002)(508600001)(64756008)(66946007)(66476007)(66556008)(66446008)(25786009)(30864003)(85202003)(66066001)(6246003)(966005)(14454004)(446003)(11346002)(229853002)(2616005)(316002)(5070765005)(99286004)(559001)(579004); DIR:OUT; SFP:1102; SCL:1; SRVR:VI1P193MB0334; H:VI1P193MB0669.EURP193.PROD.OUTLOOK.COM; FPR:; SPF:None; LANG:en; PTR:InfoNoRecords; MX:1; A:1;
received-spf: None (protection.outlook.com: omnitor.se does not designate permitted sender hosts)
x-ms-exchange-senderadcheck: 1
x-microsoft-antispam-message-info: +g75RpipR28RfE7ajIIaRaEim9rM+WHrw5+TAmSFcEz70TZ+F0+W/npXxeIHHddIKwHU0wCOxfu5+WN2MJLQtnN3vpyBh1TdKRSNVhn7sM3qgmhNxYvMp7wZN0Xa5pUY4z/Z65d3EL5HcL1kfFRFTCFOAcYp+kgU3f+4FLkpXuRgMiejE1EpZRFjpcyQrwl1KWfZOwJyepbf9yOSUscyd7G3kUlcGN+5FLKb+YU3RqqaX/+u3goEQBrilxkRNbKVO6VQPIh457THlyjfWh6Q7CmhImHb6ZFYdvhbntfbwz6fb7otw/hsWX4vaLgqM1RabJvBu7CiRx0DOtukevKtjrva6jYiwDo/VJLingYvTW4Miju4S5TnWGLnnzyMhFbPsMJETN5NUVPctyZIvuhkC9TzS6B8YQ3HoQgziePr2AfhPh56y7NgpKaW6yhw6M5zctvZ+3kUipzelMFeKQ1mZQ==
x-ms-exchange-transport-forked: True
Content-Type: multipart/alternative; boundary="_000_b456e53f76734a6ab8db92ba01a4f759omnitorse_"
MIME-Version: 1.0
X-OriginatorOrg: omnitor.se
X-MS-Exchange-CrossTenant-Network-Message-Id: 028fd95e-d8b9-4052-4252-08d74291e8f8
X-MS-Exchange-CrossTenant-originalarrivaltime: 26 Sep 2019 14:57:54.5081 (UTC)
X-MS-Exchange-CrossTenant-fromentityheader: Hosted
X-MS-Exchange-CrossTenant-id: 2df8b35f-363f-46b8-a0d1-ee9b1723225b
X-MS-Exchange-CrossTenant-mailboxtype: HOSTED
X-MS-Exchange-CrossTenant-userprincipalname: HXUMryURueOI5Q3cgvxTxWZs9x93GGpDWbmNe3WYhDvMbrrHvwlleff0jKNJzECw9/4mYq0ohZud183pTQXxr+wHmIBAyRtmgarbm5f5X90=
X-MS-Exchange-Transport-CrossTenantHeadersStamped: VI1P193MB0334
Archived-At: <https://mailarchive.ietf.org/arch/msg/mmusic/yLoyf1_NUraC1xSMfLjZ6yhETso>
Subject: Re: [MMUSIC] T.140 in Data Channel scenarios - SDP support
X-BeenThere: mmusic@ietf.org
X-Mailman-Version: 2.1.29
Precedence: list
List-Id: Multiparty Multimedia Session Control Working Group <mmusic.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/mmusic>, <mailto:mmusic-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/mmusic/>
List-Post: <mailto:mmusic@ietf.org>
List-Help: <mailto:mmusic-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/mmusic>, <mailto:mmusic-request@ietf.org?subject=subscribe>
X-List-Received-Date: Thu, 26 Sep 2019 14:58:06 -0000

Hi,

Den 2019-09-26 kl. 15:57, skrev Christer Holmberg:
Hi,

As far as the hlang and direction attributes are concerned, is there a need for them to be supported by the API?

The attributes are only for the applications to exchange information (they do not impact the media plane, so the browser does not need them), so the application can insert them in the SDP offer/answer before sending the SDP to the remote peer.

The note we have says that the API does not support handling of our dsca attributes. That note was because on earlier reading of the API specification I did not see the SDP-related primitives.

Now I discovered that there are SDP-related primitives which seem to enable free modification of the SDP before transmission, and analysis of incoming SDP. If that is true and works on the data channel part of the SDP, then our note is wrong and should be deleted or changed.

This is the note in question:

"NOTE: At the time of writing this specification, the latest verion of

   the API defined in [W3C.webrtc<https://tools.ietf.org/html/draft-ietf-mmusic-t140-usage-data-channel-05#ref-W3C.webrtc>] does not support the use of the SDP

   attributes defined in this section."



You are right that the directions, the languages and also the cps attributes are for action by the application. But the browser seems to be heavily involved in setting up and reporting about SDP, so I assumed that we needed to go through the API to handle our attributes.

It is of course of interest to know if our attributes can be handled other ways than through the API. Still the main question was if our note was wrong. I hope someone with deeper understanding of the WebRTC API can comment.

Regards

Gunnar

Regards,

Christer






From: Gunnar Hellstrom <gunnar.hellstrom@omnitor.se><mailto:gunnar.hellstrom@omnitor.se>
Date: Thursday, 26 September 2019 at 0.39
To: Bernard Aboba <bernard.aboba@gmail.com><mailto:bernard.aboba@gmail.com>
Cc: Christer Holmberg <christer.holmberg@ericsson.com><mailto:christer.holmberg@ericsson.com>, "mmusic@ietf.org"<mailto:mmusic@ietf.org> <mmusic@ietf.org><mailto:mmusic@ietf.org>
Subject: Re: [MMUSIC] T.140 in Data Channel scenarios - SDP support

Den 2019-09-25 kl. 23:07, skrev Bernard Aboba:
The latest WebRTC API specification is here:
https://w3c.github.io/webrtc-pc/<https://protect2.fireeye.com/url?k=9311c92f-cf9bebf9-931189b4-0cc47ad93dcc-e456b7610222e27b&q=1&u=https%3A%2F%2Fw3c.github.io%2Fwebrtc-pc%2F>

While WebRTC applications are free to use whatever signaling they like, the SDP utilized in the WebRTC API is described in the JSEP document:
https://tools.ietf.org/html/draft-ietf-rtcweb-jsep

While some statements in that draft seem to indicate that customised SDP for data channels can be made through that API,

section 5.2 limits the scope to RTP media.

"

<https://tools.ietf.org/html/draft-ietf-rtcweb-jsep-26#section-5.2>
5.2<https://tools.ietf.org/html/draft-ietf-rtcweb-jsep-26#section-5.2>.  Constructing an Offer





   When createOffer is called, a new SDP description must be created

   that includes the functionality specified in

   [I-D.ietf-rtcweb-rtp-usage<https://tools.ietf.org/html/draft-ietf-rtcweb-jsep-26#ref-I-D.ietf-rtcweb-rtp-usage>].  The exact details of this process are

   explained below."



Can you please check if the intention is to be able to negotiate data channels and their individual dcsa attributes?



Attributes such as hlang would not make sense for use in the WebRTC API because browser themselves do not have language preferences (though it might make sense for a WebRTC application to use hlang in its own signaling).

hlang makes sense. The main targets for hlang are the users who need to know in which language they will be able to start the spoken or typed or signed session. The browser just need to convey the values between the user and the attributes.



The question is for all dcsa attributes: cps , format, directions, hlang

Regards

Gunnar







On Wed, Sep 25, 2019 at 1:17 PM Gunnar Hellström <gunnar.hellstrom@omnitor.se<mailto:gunnar.hellstrom@omnitor.se>> wrote:

Hi,

We have a note in section 4.2. saying:

"NOTE: At the time of writing this specification, the latest verion of

   the API defined in [W3C.webrtc<https://tools.ietf.org/html/draft-ietf-mmusic-t140-usage-data-channel-05#ref-W3C.webrtc>] does not support the use of the SDP

   attributes defined in this section."



However, now I found that sections 4.4.1.6, 4.6 and 4.7 of the W3C API for WebRTC contains specification

 of SDP negotiation and customized SDP contents.



I would like to get comments if that SDP interface is flexible enough for including our dcsa attributes

and performing an SDP negotiation of a T.140 data channel.



If so, we should delete or reword that note in 4.2.



This is the W3C spec I read: https://www.w3.org/TR/webrtc/





Regards

Gunnar








Den 2019-09-25 kl. 21:26, skrev Gunnar Hellström:
Hi,

Gunnar said:

"A concern though: If the reliable channel breaks because of bad conditions, can we then really know on both sides what has been transmitted so that if we get a successful reconnection we can avoid resending already received text?"

[BA] Without some additional application-layer mechanism, I think the answer is "no".

[GH] Yes, I expected that. Even if the data channel protocol has ambitions to report what data was sent and received before a failure, I am sure that there are error situations when this ambition cannot be satisfied, and the applications is left not exactly knowing what was transmitted successfully before a channel or association breakage.

This finding calls for reviewing wording in two places in the draft,

------------------in 5.4---------------------<https://tools.ietf.org/html/draft-ietf-mmusic-t140-usage-data-channel-05#section-5.4>
5.4<https://tools.ietf.org/html/draft-ietf-mmusic-t140-usage-data-channel-05#section-5.4>.  Loss of T140blocks





   In case of network failure or congestion, T.140 data channels might

   fail and get torn down.  If this happens but the session sustains, it

   is RECOMMENDED that a low number of retries are made to reestablish

   the T.140 data channels.  If reestablishment of the T.140 data

   channel is successful, an implementation MUST evaluate if any

   T140blocks were lost.  Retransmission of already successfully

   transmitted T140blocks MUST be avoided, and missing text markers

   [T140ad1<https://tools.ietf.org/html/draft-ietf-mmusic-t140-usage-data-channel-05#ref-T140ad1>] SHOULD be inserted in the received data stream where loss

   is detected or suspected.



----------and in a bullet point in 6.. Gateway considerations--------

o  If the gateway detects that the T.140 data channel has failed and

      got torn down, once the data channel has been reestablished the

      gateway SHOULD insert the T.140 missing text marker [T140ad1<https://tools.ietf.org/html/draft-ietf-mmusic-t140-usage-data-channel-05#ref-T140ad1>] in

      the data sent on the outgoing RTP stream if it detects or suspects

      that data on the T.140 data channel was lost.

-------------------------------------------------------------------
Situations when the channel is torn down because of error are expected to be very rare exceptional cases. How the text session behaves in such situation should not be required to meet the requirements in T.140.  Looking at how current multimedia conversational applications handle similar situations, it seems common that for human operated apps, the user gets alerted by a message box with text in this style .. "Problems are detected with your Internet connection. We make efforts to get back to normal operation." And eventually, communication is recovered and you do not know what was lost.

Such actions could be recommendable also for sessions containing T.140 data channels, but it is a general app behavior towards users that may be less relevant for us to specify.

Looking at this phrase in 5.4: "

Retransmission of already successfully

   transmitted T140blocks MUST be avoided, and missing text markers

   [T140ad1<https://tools.ietf.org/html/draft-ietf-mmusic-t140-usage-data-channel-05#ref-T140ad1>] SHOULD be inserted in the received data stream where loss

   is detected or suspected.
"
There may be T140blocks in the data channel transmission buffer that have been transmitted, and received by the other party, but not yet noted as successfully transmitted.
So, in order to obey the MUST for not resending already successfully transmitted text, nothing that is in the transmission buffer may be resent after reconnection. So, the normal action should be to ignore any text in the transmission buffer, insert a missing text marker in the transmitted text if any unacknowledged text was in the transmission buffer at the time of the failure.
It is harder for the receiving side to analyze if anything was lost in reception over the break and reconnect. But it could be a general advice to insert a missing text marker because some text may have been lost.

So, the analysis calls for just a small modification to add "sent and" in the last sentence to make it read:
"

Retransmission of already successfully

   transmitted T140blocks MUST be avoided, and missing text markers

   [T140ad1<https://tools.ietf.org/html/draft-ietf-mmusic-t140-usage-data-channel-05#ref-T140ad1>] SHOULD be inserted in the sent and received data streams where loss

   is detected or suspected.

"

For the wording in section 6, gateway considerations, I find that the existing text is good, but marking may be needed also in the transmission direction towards the T.140 data channel. So, I suggest to add that in the bullet point to make it read:
----------------------------------------------------------------------------

o  If the gateway detects that the T.140 data channel has failed and

      got torn down, once the data channel has been reestablished the

      gateway SHOULD insert the T.140 missing text marker [T140ad1<https://tools.ietf.org/html/draft-ietf-mmusic-t140-usage-data-channel-05#ref-T140ad1>] in

      the data sent on the outgoing RTP stream and on the outgoing

      T.140 data channel if it detects or suspects

      that data on the T.140 data channel was lost in the corresponding

      transmission directions.

-------------------------------------------------------------------


Regards

Gunnar





On Tue, Sep 24, 2019 at 3:08 PM Gunnar Hellström <gunnar.hellstrom@omnitor.se<mailto:gunnar.hellstrom@omnitor.se>> wrote:
Hi,

Hi Bernard,



Gunnar will probably be able to give a better answer, but below are some comments from me.



>At the W3C TPAC 2019 meeting last week, draft-ietf-mmusic-t140-usage-data-channel came up as part of a discussion of Accessible RTC Use Cases:

>https://www.w3..org/WAI/APA/wiki/Accessible_RTC_Use_Cases<https://www.w3.org/WAI/APA/wiki/Accessible_RTC_Use_Cases>

>

>Here are a few of the questions that came up.

>

>Section 3

>

>       +--------------------------+-------------------------------+

>       | Subprotocol Identifier   | t140                          |

>       | Transmission reliability | reliable                      |

>       | Transmission order       | in-order                      |

>       | Label                    | See Section 4.1<https://tools.ietf.org/html/draft-ietf-mmusic-t140-usage-data-channel-05#section-4.1> and Section 6<https://tools.ietf.org/html/draft-ietf-mmusic-t140-usage-data-channel-05#section-6> |

>       +--------------------------+-------------------------------+

>

> Are there any situations in which unreliable or partially reliable transport might be appropriate?

> For example, some participants envisaged scenarios in which low latency communications might be

>  desirable, such as in emergencies, and questioned whether it might make sense to use the maxPacketLifetime

> or maxRetransmissions parameters.

>

> So there was a question about whether it might ever make sense to support an unreliable data channel (possibly with redundancy).



T.140 requires the transport mechanism to keep packets in order, and without duplication. When using RTP, the sequence number is used to detect out-of-order packets and loss of packets. You don’t have that mechanism in a data channel, and T.140 itself does not contain a sequence number.



When using RTP, reliability can provided by sending of redundant data, or by using FEC. FEC is RTP-specific, so you can’t use that on a data channel.



I don’t think the redundancy mechanism can be used on the data channel either, because it uses the RTP header timestamp.



And, you can not re-transmit T.140 text on a data channel (T.140 RTP packets are not re-transmitted either), because the receiver will not be able to detect it (again, because T.140 does not contain a sequence number).



Of course we could have defined an “envelope” for the data channel T.140 text, with sequence numbers. But, the idea was to simply send the T.140 text as the data channel itself provides delivery and reliability.



[GH] I agree with Christer. There is a risk that during very severe conditions, the reliable SCTP association makes a number of retries for up to 30 seconds and then breaks,

But the chance to get understandable text through in such conditions by sending in an unreliable channel with redundancy is probably not much higher. And it would require to for example use RTP and RFC 4103 on top of an unreliable data channel, a complication I would not like to introduce.

I made a bit more comments on this on August 21.









---



>Lost information (compared with RTP)

>

>We had some questions relating to information "lost in translation" between realtime text

>and data channel.  This includes aspects of the RTP header, including SSRCs, timestamps and sequence numbers.



Yes, that information is lost.



There were some discussions about including SSRC somehow, in order to support conferences where a mixer uses a single data channel for text received from multiple remote users, but we decided that it is outside the scope of this draft.



[GH] The Stream-ID can be seen as "an SSRC", and the Label can be seen as a CNAME in one direction. Sequence number and timestamp are usually only used on transport level, and something similar is likely used in the reliable data channel transport, but not reported to the application.

A concern though: If the reliable channel breaks because of bad conditions, can we then really know on both sides what has been transmitted so that if we get a successful reconnection we can avoid resending already received text?

Regards

Gunnar





Regards,



Christer







_______________________________________________

mmusic mailing list

mmusic@ietf.org<mailto:mmusic@ietf.org>

https://www.ietf.org/mailman/listinfo/mmusic

--

+ + + + + + + + + + + + + +

Gunnar Hellström
Omnitor
gunnar.hellstrom@omnitor.se<mailto:gunnar.hellstrom@omnitor.se>
+46 708 204 288