Re: [MMUSIC] Review of draft-ietf-mmusic-sdp-simulcast-08

Bo Burman <bo.burman@ericsson.com> Tue, 04 July 2017 00:06 UTC

Return-Path: <bo.burman@ericsson.com>
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 E911F1317D6; Mon, 3 Jul 2017 17:06:19 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -4.22
X-Spam-Level:
X-Spam-Status: No, score=-4.22 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, RCVD_IN_DNSWL_MED=-2.3, RCVD_IN_MSPIKE_H3=-0.01, RCVD_IN_MSPIKE_WL=-0.01, 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=ericsson.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 aeXMRnH8pMbP; Mon, 3 Jul 2017 17:06:16 -0700 (PDT)
Received: from sessmg22.ericsson.net (sessmg22.ericsson.net [193.180.251.58]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id 43844131806; Mon, 3 Jul 2017 17:06:14 -0700 (PDT)
X-AuditID: c1b4fb3a-803ff70000001b2f-67-595adbf42734
Received: from ESESSHC009.ericsson.se (Unknown_Domain [153.88.183.45]) by sessmg22.ericsson.net (Symantec Mail Security) with SMTP id C9.EA.06959.4FBDA595; Tue, 4 Jul 2017 02:06:12 +0200 (CEST)
Received: from EUR01-VE1-obe.outbound.protection.outlook.com (153.88.183.145) by oa.msg.ericsson.com (153.88.183.45) with Microsoft SMTP Server (TLS) id 14.3.352.0; Tue, 4 Jul 2017 02:06:11 +0200
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ericsson.onmicrosoft.com; s=selector1-ericsson-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version; bh=fCMXiCRUy3+I1hu7/dQ9dr5MKtTZNl9Hzg0H+tHlO2A=; b=aZ5y5BPKb/M6WNrGfIQlYVnlpODzo2tIRgfJtNfF9azLhecmWxuCYLSb6D4GfZ3RwI0kgI3CqBmoiMAER0PyqqzskTVMx4LpqnL2w0MOZltHI+amXn7ohyiBrPt2DOJJ5Z7Dx/wlsBXfP1W6TKi8Mlm/TZgjVyzi9X00FYhGjsA=
Received: from AM5PR0701MB2577.eurprd07.prod.outlook.com (10.173.92.21) by AM5PR0701MB2690.eurprd07.prod.outlook.com (10.173.93.16) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1240.6; Tue, 4 Jul 2017 00:06:10 +0000
Received: from AM5PR0701MB2577.eurprd07.prod.outlook.com ([fe80::ccac:2cc5:7789:e0a7]) by AM5PR0701MB2577.eurprd07.prod.outlook.com ([fe80::ccac:2cc5:7789:e0a7%18]) with mapi id 15.01.1240.010; Tue, 4 Jul 2017 00:06:10 +0000
From: Bo Burman <bo.burman@ericsson.com>
To: Cullen Jennings <fluffy@iii.ca>, Multiparty Multimedia Session Control Discussion List <mmusic@ietf.org>
CC: "draft-ietf-mmusic-sdp-simulcast.authors@ietf.org" <draft-ietf-mmusic-sdp-simulcast.authors@ietf.org>
Thread-Topic: Review of draft-ietf-mmusic-sdp-simulcast-08
Thread-Index: AQHSzZy+deg+ODzFskOkGmiRY5DQ8aJCcNVw
Date: Tue, 04 Jul 2017 00:06:10 +0000
Message-ID: <AM5PR0701MB2577C13615A636E6724D058D8DD70@AM5PR0701MB2577.eurprd07.prod.outlook.com>
References: <0F8243F1-BA73-4814-A35B-6924B609AE29@iii.ca>
In-Reply-To: <0F8243F1-BA73-4814-A35B-6924B609AE29@iii.ca>
Accept-Language: sv-SE, en-US
Content-Language: en-US
X-MS-Has-Attach:
X-MS-TNEF-Correlator:
authentication-results: iii.ca; dkim=none (message not signed) header.d=none;iii.ca; dmarc=none action=none header.from=ericsson.com;
x-originating-ip: [83.209.207.106]
x-ms-publictraffictype: Email
x-microsoft-exchange-diagnostics: 1; AM5PR0701MB2690; 7:MnD+NmoIDWHlRyFLqPJs+vg0U7/buTOtkws4kWPmbLUBGiUN0YBaLWgvvWzpZzsy0mhESorn1OORKiv9p6LjlthJE/iCgwrIK6CCOB8PzlrrCzYo7VMRUZvzVHpoQO4y2+GUKlRMt5FcIv0O0msAUXzklKJI8Oi/8VeiASo5aZjsXjiR8V2lAuSOZynpgiymJdDzGkjdKy77uot1Rnhr8Ds2OOweayiQRRYlvMw+jrN7empCvPmSwsbzHirw1sUVbihgB7NpToRBHteq7adbFbUQeDFveHjn0FSnXMWMJVkV8zyEX88hNB+ZJ+usKhTO9Uc7EBp5BiTC8aHySobLPC5fB1C7b2ZylvZ5wkVEClkY44GpzmSo8HxiYJZjkdheBaj33jX/Tqpi8QI5l0eLTtNLGfuasl6uurJrlvPo5HhahhRJKF1FcAiuOqZKKKB9OsmvloV3aWGZoPAJpt+wM9GUFdgYl61nqQ1+lXLAMS7bDTXsLfXo36G2UuGJvMPoPiVVTGqfGuwRoj2F0VB51SmMxMvfrxpL4fcNdWBBzh6Ahow48R0c8F1FZU6hltB4dW++9xXE0m5DPsZyHj6DZ8rIaq4Bq6AtwqLpSDWNzWL7OzDU1VXUitkTqt6dPpyDk590pQcsT/eSS4fg0Oe5BxcdOk3N/y0vzSQ+yKgBWlkXFNh7YfCDJQCS8hW7kRiGsO5hzeKyUakCJwP9ax8jxW3pduFbz5ZIaujSqjoIQ6IvHSFEcLDE4MgzQAFWnr83ucqfHlRo0rVTyado+DoRc3Vfr7/Deg3c4xdFYh5V9RM=
x-ms-office365-filtering-correlation-id: f6a38989-88b1-4e4e-da70-08d4c2707a42
x-microsoft-antispam: UriScan:; BCL:0; PCL:0; RULEID:(300000500095)(300135000095)(300000501095)(300135300095)(22001)(300000502095)(300135100095)(2017030254075)(300000503095)(300135400095)(2017052603031)(201703131423075)(201703031133081)(201702281549075)(300000504095)(300135200095)(300000505095)(300135600095)(300000506095)(300135500095); SRVR:AM5PR0701MB2690;
x-ms-traffictypediagnostic: AM5PR0701MB2690:
x-microsoft-antispam-prvs: <AM5PR0701MB2690C4012112084F1EA420C68DD70@AM5PR0701MB2690.eurprd07.prod.outlook.com>
x-exchange-antispam-report-test: UriScan:(37575265505322)(236129657087228)(48057245064654)(148574349560750)(209349559609743)(247924648384137);
x-exchange-antispam-report-cfa-test: BCL:0; PCL:0; RULEID:(100000700101)(100105000095)(100000701101)(100105300095)(100000702101)(100105100095)(6040450)(601004)(2401047)(8121501046)(5005006)(2017060910026)(10201501046)(100000703101)(100105400095)(93006095)(93001095)(3002001)(6041248)(20161123562025)(201703131423075)(201702281528075)(201703061421075)(201703061406153)(20161123560025)(20161123558100)(20161123555025)(20161123564025)(6072148)(100000704101)(100105200095)(100000705101)(100105500095); SRVR:AM5PR0701MB2690; BCL:0; PCL:0; RULEID:(100000800101)(100110000095)(100000801101)(100110300095)(100000802101)(100110100095)(100000803101)(100110400095)(100000804101)(100110200095)(100000805101)(100110500095); SRVR:AM5PR0701MB2690;
x-forefront-prvs: 0358535363
x-forefront-antispam-report: SFV:NSPM; SFS:(10009020)(6009001)(39860400002)(39840400002)(39410400002)(39850400002)(39400400002)(39450400003)(13464003)(478600001)(2906002)(3846002)(81166006)(54356999)(14454004)(50986999)(7736002)(3280700002)(86362001)(305945005)(5250100002)(53546010)(76176999)(8936002)(74316002)(3660700001)(5660300001)(345774005)(8676002)(7696004)(6506006)(2900100001)(6436002)(66066001)(4326008)(25786009)(6116002)(102836003)(189998001)(229853002)(33656002)(2950100002)(53936002)(38730400002)(230783001)(99286003)(55016002)(9686003)(6246003); DIR:OUT; SFP:1101; SCL:1; SRVR:AM5PR0701MB2690; H:AM5PR0701MB2577.eurprd07.prod.outlook.com; FPR:; SPF:None; MLV:sfv; LANG:en;
spamdiagnosticoutput: 1:99
spamdiagnosticmetadata: NSPM
Content-Type: text/plain; charset="us-ascii"
Content-Transfer-Encoding: quoted-printable
MIME-Version: 1.0
X-MS-Exchange-CrossTenant-originalarrivaltime: 04 Jul 2017 00:06:10.8472 (UTC)
X-MS-Exchange-CrossTenant-fromentityheader: Hosted
X-MS-Exchange-CrossTenant-id: 92e84ceb-fbfd-47ab-be52-080c6b87953f
X-MS-Exchange-Transport-CrossTenantHeadersStamped: AM5PR0701MB2690
X-OriginatorOrg: ericsson.com
X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFupileLIzCtJLcpLzFFi42KZGbFdV/fL7ahIg3cnVS323DnHYvFh/Q9G i6nLH7M4MHssWfKTyePy+Y+MAUxRXDYpqTmZZalF+nYJXBlTm6cxFbwPrNjz1LuBcYNDFyMn h4SAicSUzzeYQWwhgSOMEut3uHYxcgHZxxklrrx9yA7isAj0Mks0fXvCCpGZziTRcKybEaLl GaNE28pEEJtNQENi/o67QHEODhGBAol7e3VBwswC2RK7Hi5iB7GFBSwlfmxbxgJiiwhYSax5 eAvKNpLY/r4XzGYRUJFYc3852EW8AgkSHzc8YgIZKQTUu+NmNkiYE6i1/dpzsBJGAVmJ+9/v sUCsEpe49WQ+E8RjAhJL9pxnhrBFJV4+/gd2PqNAO6PEjlMTWCASShJrl06BKpKVuDQf5C0u IPsRm8T1nesYIRK+ElO2v2GBSDxhkljStxQqoSNx/etfdgg7X+Ju72aooj5Gie4ZXawQzlVW iSnvO6CqZCTObJ3IDJFYxirx81M74wRG7VlIjoewdSQW7P7EBmFrSyxb+Jp5Fjg8BCVOznzC soCRZRWjaHFqcXFuupGRXmpRZnJxcX6eXl5qySZGYAo5uOW31Q7Gg88dDzEKcDAq8fA+PhEV KcSaWFZcmXuIUYKDWUmEV6YHKMSbklhZlVqUH19UmpNafIhRmoNFSZzXYd+FCCGB9MSS1OzU 1ILUIpgsEwenVAOjc9xy0cshT22/dM7Ilzm/4YBm/rw1O1Rf7pqa8CNIKsB6yUHDzQHestn3 Dkx6bBAhfk0yPS/1uOx0PdVEnwan20oW0WHmnIfSmdWeHbTn0Si5q8/230D/ARfX/ecKyp6v Nj+TYmWL+cq+9KHb5QPNgVXhgsLcF37au3OU3OpqZJP6WR5xQEKJpTgj0VCLuag4EQC3ssrR HQMAAA==
Archived-At: <https://mailarchive.ietf.org/arch/msg/mmusic/i-zz2SDFvqCf6hDJ_rElHWDFdNk>
Subject: Re: [MMUSIC] Review of draft-ietf-mmusic-sdp-simulcast-08
X-BeenThere: mmusic@ietf.org
X-Mailman-Version: 2.1.22
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: Tue, 04 Jul 2017 00:06:20 -0000

Cullen,

Thank you for good and constructive comments! Please see my responses below.
Just posted an -09 that hopefully addresses most if not all of your comments.

Cheers,
/Bo (as individual)



> -----Original Message-----
> From: Cullen Jennings [mailto:fluffy@iii.ca]
> Sent: den 15 maj 2017 19:00
> To: Multiparty Multimedia Session Control Discussion List <mmusic@ietf.org>
> Cc: Bo Burman <bo.burman@ericsson.com>
> Subject: Review of draft-ietf-mmusic-sdp-simulcast-08
> 
> 
> Overall the actually protocol described by the spec seems fine with a few very small technical details. However, it is a bit
> challenging to understand the basic overview of how it works -  I have a few suggestions that I think would be not much
> work that would really help people get up to speed by moving some of the later example text to closer to where the
> overview section is now.
> 
> 
> Technical Issues -----------
> 
> Issue 1: Pause in an SDP re-offer
> 
> The pause in section 6.3.4 seems problematic. If A is sending a re-offer to B, there is no real way to know the pause state
> of a stream B is sending to A at that point without glare issues. Saying A has to send something that matches a state on B
> is not really possible to implement.
[BoB] Agree. This is clearly flawed and must be changed.

> 
> I think this should be changed to say A sets the pause flags in the SDP for RIDs A is sending to match what A currently
> thinks the state of them is, and A sets the the pause flags for the RIDs A is receiving to what A wished they were. The
> way that B processes the offer and creates the answer as well as the handling of the answer by A would be the same as
> the initial offer/answer.
[BoB] OK. SDP information for send direction RIDs becomes a snapshot in time at a session modification and should therefore be taken as informational. A further consequence should reasonably be that, for send direction RID that uses initially paused streams, RFC 7728 signaling is already present in the ongoing session and takes precedence in case of any ambiguity or conflict.
Agree for receive direction RID. The only difference from an initial offer would be if a receive direction RID is actually already paused by A (through RFC 7728 signaling) at the time of sending the updated SDP offer. The (minor) difference to an initial offer is then that pausing a receive direction RID in the initial offer would instead always cause the SDP answerer (RTP sender) to put the stream in _unsolicited_ pause (if the SDP answerer is accepting to pause).

> 
> Given the timing issues of RTCP near at the start of the call, if we don't make this change, it may take significant time to
> un-pause a particular stream at the start of the call. The above change allows that to happen so that if a user joined a call
> that perhaps had a paused presentation stream and wanted to un-pause that right away, they could.
[BoB] OK. Makes sense.

> 
> 
> Issue 2: More than one simulcast line
> 
> Some SDP stacks to not preserve the order of a=lines. I have no idea if this is a bug in them or not. I think it would be
> better to phrase this spec as each m= section MUST have at most one a=simulcast line. 
[BoB] OK

> The current phrasing of receiver
> ignores all but first just begs for people to put proprietary stuff in a second simulcast line.
[BoB] In that case, I assume it is better to say that simulcast is ignored entirely (removed in answer) for a media description with multiple a=simulcast lines?

> 
> 
> Issue 3: Relating simulcast streams using PT
> 
> When the PT are unique, they can be used instead of RID. Obviously, if they are not unique they can't be used, but when
> they are, they often result in being able to display the video sooner. Often RID/MID will not be included in every RTP
> packet because of the bandwidth usage and are instead sent periodically. Being able to join a conference and start
> displaying stuff right away is nice when possible
> 
> I think section 6.5 needs to be updated to be clear that "RTP "Simulcast streams MUST be related on RTP level through
> RID." still means it is fine for the RTP receiver to use the PT of the RTP packet and if that uniquely maps to a RID in the
> SDP, use that for the relation.
[BoB] OK. That was already possible since before, but to be entirely clear I'll add a note saying that.

> 
> 
> Editorial ----------------
> 
> 
> The use cases and requirements go for awhile and the first thing that starts to explain how this works is bullet point point
> 4 in the overview section which says
> 
>  o  The codec configuration for a simulcast stream is expressed
>       through use of separately specified RTP payload format
>       restrictions [I-D.ietf-mmusic-rid] with an associated RTP-level
>       identification mechanism [I-D.ietf-avtext-rid] to identify which
>       RTP payload format restrictions an RTP stream adheres to.  This
>       complements and effectively extends simulcast stream
>       identification and configuration possibilities that could be
>       provided by using only SDP formats as identifier.  Use of multiple
>       RTP streams with the same (non-redundancy) media type in the
>       context of a single media source, where those RTP streams are
>       using different RtpStreamId, is a strong but not totally
>       unambiguous indication of those RTP streams being part of a
>       simulcast.
> 
> Have a skim of the draft up to that point and ask yourself how much sense it would make it you get to this point?  Or how
> much you would understand about how the mechahims of this draft actually worked before you got to the ABNF shortly
> after this. I suspect that you will likely come to the conclusion that it's a bit hard to understand the big picture of how it
> works.
[BoB] OK, the above text is probably way too detailed to provide any benefit to the reader compared to just continue reading.

> 
> I really can't make head or tails of the paragraph I quoted above but the draft would make more sense to me if we
> removed that, along with rest of section 5. 
[BoB] To be clear, do you mean remove the entire section 5, or just the two last bullets? You mention below having an "overview" section.

> From the bullet point above, the draft goes straight into the ABNF for the new
> stuff. I think it would be easier to understand if we: Moved section 4 to appendix,
[BoB] OK, no problem.

> Greatly shortened section 3.
[BoB] Given the amount of discussion we have had to understand what "simulcast" is and why it is useful, I think the reader would benefit from this background. I'm not inclined to remove any of the use cases or motivations, but I'll consider shortening the text.

> Then add
> an overview that starts with showing the offer and answer from 6.6.1. and explaining how the only thing this draft adds is
> the a=simulcast line. 
[BoB] OK. I'd assume that the examples from 6.6.1 are a bit too detailed and could be simplified a bit in such high-level overview? I'll at least start something to discuss more around.

> Explain the one m line means one source concept. Then show how simulcast line allows sending the
> 1;2 RIDs. Then explain how alternatives work. From there jump into the details. I don't think this would be much new text
> and it would not change how anything works, just clear up the explanation.
[BoB] Yes, that would work.

> 
> Section 6.1. and 6.2 are confusing because they are written as if they are not for offer/answer SDP. I think it would be
> better to state up front as that this was offer/answer SDP only and write theses sections to be clear about if they are
> referring to offers or answers when talking about SDP. 
[BoB] The intent is clearly that both 6.1 and 6.2 should describe aspects of a=simulcast that are generally true, independent from offer and answer. Any text there that are applicable only to offer or answer is a mistake and should be moved into those sections.

> As a specific example, the pause discussion on page 13 might be
> correct for answers but looks less correct for offers.
[BoB] I find nothing in that text that does not apply both to offer and answer. The text was written to reflect the view of the sender of the SDP, in terms of stream directions, which should probably be more clearly stated. If that clarification does not help, could you please elaborate?

> 
> The SCID is really confusing in the draft. The draft is never fully clear about if this is a RID or not it calls them "identical too"
> but that hard to see if they are different but same value or work the same way or something else. I think we should
> remove the term SCID from the draft and just use RID. 
[BoB] I have no problem aligning identifiers, but "RID" does not exist. We once thought it would be called "RID", similar to "MID" from BUNDLE, but it didn't happen. "RID" also does not exist in draft-ietf-avtext-rid, where the information element ended up being called "RtpStreamId", both for the SDES Item and the RTP Header Extension carrying that SDES Item. The identifier on an "a=rid" line is called "rid-id" in draft-ietf-mmusic-rid, which is the very same value used on an "a=simulcast" line, so I assume this draft should be changed to be consistent with that naming. 

> Similarly, using RtpStreamID is confusing. I think we should just
> refer to that as the header that carries the RID.
[BoB] Formally, RtpStreamId is the name of the SDES Item in both RTCP and RTP header extension. It can be seen as the "container" that carries RID, but I don't think we can use RID as a name, as said above.

> 
> The example on the top of page 11 makes no sense without enough of the SDP to see the rids and m lines etc and needs
> to be broken apart to be a Offer example followed by the Answer back to that offer.
[BoB] OK, I expect that if any of the information around that example should be kept, it will likely best go into the new overview section you propose above.

> 
> NIT - define SFM on first use
[BoB] OK

> 
> 
>