Re: [rtcweb] [tram] Payload Types assignments

"Karl Stahl" <karl.stahl@intertex.se> Thu, 03 April 2014 15:40 UTC

Return-Path: <karl.stahl@intertex.se>
X-Original-To: rtcweb@ietfa.amsl.com
Delivered-To: rtcweb@ietfa.amsl.com
Received: from localhost (ietfa.amsl.com [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 666C61A020A for <rtcweb@ietfa.amsl.com>; Thu, 3 Apr 2014 08:40:32 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: 1.801
X-Spam-Level: *
X-Spam-Status: No, score=1.801 tagged_above=-999 required=5 tests=[BAYES_50=0.8, HTML_MESSAGE=0.001, MSGID_MULTIPLE_AT=1] autolearn=no
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 I7X6E3czH6PO for <rtcweb@ietfa.amsl.com>; Thu, 3 Apr 2014 08:40:28 -0700 (PDT)
Received: from smtp.it-norr.com (smtp.it-norr.com [80.244.64.163]) by ietfa.amsl.com (Postfix) with ESMTP id A106B1A01FA for <rtcweb@ietf.org>; Thu, 3 Apr 2014 08:40:23 -0700 (PDT)
Received: from ([90.229.134.75]) by smtp.it-norr.com (Telecom3 SMTP service) with ASMTP id 201404031740154007; Thu, 03 Apr 2014 17:40:15 +0200
From: Karl Stahl <karl.stahl@intertex.se>
To: 'Harald Alvestrand' <harald@alvestrand.no>, rtcweb@ietf.org, 'Magnus Westerlund' <magnus.westerlund@ericsson.com>
References: <C5E08FE080ACFD4DAE31E4BDBF944EB11667BBA0@xmb-aln-x02.cisco.com> <5238446D.8050700@ericsson.com> <9F33F40F6F2CD847824537F3C4E37DDF17BCF581@MCHP04MSX.global-ad.net> <07a601ceb64e$5caaba00$16002e00$@stahl@intertex.se> <07b001ceb65f$ce3f0cf0$6abd26d0$@stahl@intertex.se> <07e401ceb713$bef87a60$3ce96f20$@stahl@intertex.se> <524AB730.7040809@ericsson.com> <00b001cebfc1$ba8e89e0$2fab9da0$@stahl@intertex.se> <525272E8.5050300@ericsson.com> <050801cec3f6$6172aec0$24580c40$@stahl@intertex.se> <5253E5EB.8030608@alvestrand.no> <02bf01cecf34$35e174a0$a1a45de0$@stahl@intertex.se> <04dd01cf31ad$0fe62d00$2fb28700$@stahl@intertex.se> <580B467D-4679-4DE1-96DE-CA37DE755563@csperkins.org> <052e01cf31cb$5311a0a0$f934e1e0$@stahl@intertex.se> <530C56CD.3010003@ericsson.com> <025d01cf3e9a$f4267340$dc7359c0$@stahl@intertex.se> <532716F1.4030109@alvestrand.no>
In-Reply-To: <532716F1.4030109@alvestrand.no>
Date: Thu, 03 Apr 2014 17:40:16 +0200
Message-ID: <009801cf4f53$02c1d110$08457330$@stahl>
MIME-Version: 1.0
Content-Type: multipart/alternative; boundary="----=_NextPart_000_0099_01CF4F63.C64AA110"
X-Mailer: Microsoft Office Outlook 12.0
Thread-Index: Ac9B9vxwJd+obSIiS4eQo5UFm/Y58ANRNjvw
Content-Language: sv
Archived-At: http://mailarchive.ietf.org/arch/msg/rtcweb/-EnI0NbQ_PIiFd1_yYHrUR4iT-I
Subject: Re: [rtcweb] [tram] Payload Types assignments
X-BeenThere: rtcweb@ietf.org
X-Mailman-Version: 2.1.15
Precedence: list
List-Id: Real-Time Communication in WEB-browsers working group list <rtcweb.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/rtcweb>, <mailto:rtcweb-request@ietf.org?subject=unsubscribe>
List-Archive: <http://www.ietf.org/mail-archive/web/rtcweb/>
List-Post: <mailto:rtcweb@ietf.org>
List-Help: <mailto:rtcweb-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/rtcweb>, <mailto:rtcweb-request@ietf.org?subject=subscribe>
X-List-Received-Date: Thu, 03 Apr 2014 15:40:33 -0000

Harald, 

 

I think my intention was misunderstood. It was not to change the DTLS/SCTP
structure or format of the data channel (It was to insert the traffic
bandwidth and type information between the UDP and DTLS headers.).

 

However, having dug deeper into the data channel (and also found the
quality/priority obstacles introduced by SCTP with the p2p file transfer
(see next email), a better way to introduce the traffic info would be to use
a new DTLS ContentType (e.g. 24 instead of current 23) where the content
would be the unencrypted traffic info (preferable the same as in the RTP
header extension[1]) followed by the SCTP as it is today (where it today
comes directly in the DTLS as the only content).:

 

TODAY:

Content Type: 23 (1 byte) content type 23 means “application data”

DTLS version:  0xfeff (2 byte)

Epoch: 0001 (2 byte)

Sequence number (e.g. 00 00 00 00 00 01) 6 byte

Length (e.g. 01 c0) 2 byte

Encrypted application data: ...... = the SCTP

 

SUGGESTION WITH ADDED TRAFFIC INFO FOR LOWER LEVELS: 

Content Type: 24 (1 byte) content type 24 meaning “application data preceded
by traffic info”

DTLS version:  0xfeff (2 byte)

Epoch: 0001 (2 byte)

Sequence number (e.g. 00 00 00 00 00 01) 6 byte

Length (e.g. 01 c0) 2 byte: length of the encrypted application data after
the new header extension

TRAFFIC INFO, Same as suggested for the RTP Header extension: 

Encrypted application data: ...... ...... = the SCTP unchanged

 

Shouldn’t this be doable?

(As you see from next email, this kind of information is also required to
make the data channel work, separating prioritized data chunks from a file
transfer data channel that must NOT be prioritized.)

 

/Karl

 

 

 

 

Från: rtcweb [mailto:rtcweb-bounces@ietf.org] För Harald Alvestrand
Skickat: den 17 mars 2014 16:38
Till: rtcweb@ietf.org
Ämne: Re: [rtcweb] [tram] Payload Types assignments

 

On 03/13/2014 10:02 AM, Karl Stahl wrote:

For the “mission to bring quality to real-time traffic over our best effort
Internet” I have started
<http://www.ietf.org/mail-archive/web/tram/current/msg00331.html>
http://www.ietf.org/mail-archive/web/tram/current/msg00331.html

[tram] [rtcweb] The way to "Interfacing to QoS", A level 3-5
IP/IETF/WebRTC-thing how to interface to lower level's QoS-stuff [1] [2]

 

Hi Magnus,

 

With the response just sent to Pål
http://www.ietf.org/mail-archive/web/rtcweb/current/msg11846.html, skipping
all the QoS methods and functions that really does not belong here when
creating an “Interface to QoS”, I only see the suggestion of “data channel
information”, i.e. also marking each data channel packet with traffic
bandwidth and type information  to be relevant and interesting. I checked
with one of our developers and I think the same traffic information as for
RTP can be transferred in data channel packets as follows:

 

The RTP header has the following format (RFC 3550):

    0                   1                   2                   3

    0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1

   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+

   |V=2|P|X|  CC   |M|     PT      |       sequence number         |

   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+

   |                           timestamp                           |

   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+

   |           synchronization source (SSRC) identifier            |

   +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+

   |            contributing source (CSRC) identifiers             |

   |                             ....                              |

   +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+

   |            RFC5285 header extension ...                      |

   |     2 bytes Max Bandwidth     |   2 bytes Traffic Type        |

   |                             ....                              |

RTP Payload (often encrypted)

 

A Data Channel header could have the following format:

    0                   1                   2                   3

    0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1

   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+

   |   Data Channel Magic Cookie   |      (sequence number)        |

   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+

   |                           timestamp                           |

   +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+

   |           synchronization source (SSRC) identifier            |

   +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+

   |            contributing source (CSRC) identifiers             |

   |                             ....                              |

   +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+

   |            RFC5285 header extension ...                      |

   |     2 bytes Max Bandwidth     |   2 bytes Traffic Type        |

   |                             ....                              |

  DTLS Header 13 bytes

  SCTP

 

The RFC5285 header extension is not in a fixed position in any of these
cases, but still trivial to find (especially when in  a TURN flow). This
could be introduced in
http://tools.ietf.org/html/draft-ietf-rtcweb-data-channel-07#section-5 

by making room for these bytes after the UDP header, but before the DTLS
header.

 

What do you think?



No.

We've chosen to make Data Channel a protocol within DTLS, and not use any
unencrypted headers for it. Neither does the data channel have any concept
resembling SSRC, CSRC or timestamp. Changing to an RTP-based format such as
the one you propose would be a drastic revision of the spec.

There's no reason to believe such a revision at this time has any traction
in the WG.