<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40"><head><meta http-equiv=Content-Type content="text/html; charset=utf-8"><meta name=Generator content="Microsoft Word 15 (filtered medium)"><!--[if !mso]><style>v\:* {behavior:url(#default#VML);}
o\:* {behavior:url(#default#VML);}
w\:* {behavior:url(#default#VML);}
.shape {behavior:url(#default#VML);}
</style><![endif]--><style><!--
/* Font Definitions */
@font-face
        {font-family:Wingdings;
        panose-1:5 0 0 0 0 0 0 0 0 0;}
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0in;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:blue;
        text-decoration:underline;}
tt
        {mso-style-priority:99;
        font-family:"Courier New";}
span.EmailStyle21
        {mso-style-type:personal-reply;
        font-family:"Calibri",sans-serif;
        color:windowtext;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-size:10.0pt;}
@page WordSection1
        {size:8.5in 11.0in;
        margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
        {page:WordSection1;}
/* List Definitions */
@list l0
        {mso-list-id:21513304;
        mso-list-template-ids:1541318426;}
@list l0:level1
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:.5in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Symbol;}
@list l0:level2
        {mso-level-number-format:bullet;
        mso-level-text:o;
        mso-level-tab-stop:1.0in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:"Courier New";
        mso-bidi-font-family:"Times New Roman";}
@list l0:level3
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:1.5in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l0:level4
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:2.0in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l0:level5
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:2.5in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l0:level6
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:3.0in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l0:level7
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:3.5in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l0:level8
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:4.0in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l0:level9
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:4.5in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l1
        {mso-list-id:430971041;
        mso-list-template-ids:687884640;}
@list l1:level1
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:.5in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Symbol;}
@list l1:level2
        {mso-level-number-format:bullet;
        mso-level-text:o;
        mso-level-tab-stop:1.0in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:"Courier New";
        mso-bidi-font-family:"Times New Roman";}
@list l1:level3
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:1.5in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l1:level4
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:2.0in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l1:level5
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:2.5in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l1:level6
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:3.0in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l1:level7
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:3.5in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l1:level8
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:4.0in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l1:level9
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:4.5in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l2
        {mso-list-id:974407750;
        mso-list-template-ids:-650497186;}
@list l2:level1
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:.5in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Symbol;}
@list l2:level2
        {mso-level-number-format:bullet;
        mso-level-text:o;
        mso-level-tab-stop:1.0in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:"Courier New";
        mso-bidi-font-family:"Times New Roman";}
@list l2:level3
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:1.5in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l2:level4
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:2.0in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l2:level5
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:2.5in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l2:level6
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:3.0in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l2:level7
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:3.5in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l2:level8
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:4.0in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l2:level9
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:4.5in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l3
        {mso-list-id:1371298433;
        mso-list-template-ids:-2118192744;}
@list l3:level1
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:.5in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Symbol;}
@list l3:level2
        {mso-level-number-format:bullet;
        mso-level-text:o;
        mso-level-tab-stop:1.0in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:"Courier New";
        mso-bidi-font-family:"Times New Roman";}
@list l3:level3
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:1.5in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l3:level4
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:2.0in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l3:level5
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:2.5in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l3:level6
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:3.0in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l3:level7
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:3.5in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l3:level8
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:4.0in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l3:level9
        {mso-level-number-format:bullet;
        mso-level-text:;
        mso-level-tab-stop:4.5in;
        mso-level-number-position:left;
        text-indent:-.25in;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
ol
        {margin-bottom:0in;}
ul
        {margin-bottom:0in;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]--></head><body lang=EN-US link=blue vlink=purple style='word-wrap:break-word'><div class=WordSection1><p class=MsoNormal>Making sure this shows up on sis-dtn as well as the IETF…<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><div style='border:none;border-top:solid #B5C4DF 1.0pt;padding:3.0pt 0in 0in 0in'><p class=MsoNormal><b><span style='font-size:12.0pt;color:black'>From: </span></b><span style='font-size:12.0pt;color:black'>Keith Scott <kscott@mitre.org><br><b>Date: </b>Thursday, March 31, 2022 at 8:23 AM<br><b>To: </b>Felix Flentge <Felix.Flentge@esa.int>, <sburleig.sb@gmail.com><br><b>Cc: </b>"'Sipos, Brian J.'" <Brian.Sipos@jhuapl.edu>, <dtn@ietf.org>, dtn <dtn-bounces@ietf.org>, "'Sanchez Net, Marc(JPL-332H)[JPL Employee]'" <marc.sanchez.net@jpl.nasa.gov>, "'Chaoua, Rachid(GSFC-4500)'" <rachid.chaoua@nasa.gov><br><b>Subject: </b>Re: [dtn] [EXTERNAL] Re: [Sis-dtn] [EXT] Re: Bundle custody transfer and reliable CLs<o:p></o:p></span></p></div><div><p class=MsoNormal><o:p> </o:p></p></div><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>I do think the kernel of the issue under discussion is whether the rover is willing to release resources based on a reliable CLA confirming receipt, or if it (the rover) should wait for some signaling from the BP layer.  The former implies an assumption that successful receipt by the (reliable) CLA <span style='font-family:Wingdings'></span> “custody transfer” to the receiving node and that the receiving node will hold onto the bundle until it can be reliably transferred (via a reliable CLA) to the next hop.  Without the assumption that every node takes custody, BP is a best-effort service and I think that’s too loose a service for what we want in space.<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>The way I read RFC9171, a bundle node that attempts to send a bundle that results in one or more of the CLAs reporting failure to forward MAY attempt to retransmit the bundle (or, presumably, it MAY not).  [The text after step 5 in section 5.4].  Depending on settings, some sort of signal SHOULD / could be generated noting the deletion of the bundle, but it would be lost regardless.<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>So, even if forwarding is attempted over a reliable CLA (e.g. TCPCLv4), if that fails for some reason, bundles can be lost.  Even if the space community modifies the processing rules to mandate that bundles that fail CLA forwarding ARE retransmitted, such a change can only apply to the portion of the path that we control.  If we end up buying commercial DTN routers for use in the ground, they could very well stick to the MAY clause and drop bundles for which the initial CLA transmission failed (I think).<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>To signaling (or at least being able to signal) all sorts of interesting events per Felix’s email: yeah, we should be able to do that.<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>                                --keith<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><div style='border:none;border-top:solid #B5C4DF 1.0pt;padding:3.0pt 0in 0in 0in'><p class=MsoNormal><b><span style='font-size:12.0pt;color:black'>From: </span></b><span style='font-size:12.0pt;color:black'>Felix Flentge <Felix.Flentge@esa.int><br><b>Date: </b>Thursday, March 31, 2022 at 4:37 AM<br><b>To: </b><sburleig.sb@gmail.com><br><b>Cc: </b>"'Sipos, Brian J.'" <Brian.Sipos@jhuapl.edu>, <dtn@ietf.org>, dtn <dtn-bounces@ietf.org>, Keith Scott <kscott@mitre.org>, "'Sanchez Net, Marc(JPL-332H)[JPL Employee]'" <marc.sanchez.net@jpl.nasa.gov>, "'Chaoua, Rachid(GSFC-4500)'" <rachid.chaoua@nasa.gov><br><b>Subject: </b>Re: [dtn] [EXTERNAL] Re: [Sis-dtn] [EXT] Re: Bundle custody transfer and reliable CLs<o:p></o:p></span></p></div><div><p class=MsoNormal><o:p> </o:p></p></div><p class=MsoNormal><span style='font-size:10.0pt;font-family:"Arial",sans-serif'>Well,</span> <br><br><span style='font-size:10.0pt;font-family:"Arial",sans-serif'>I would say all a reliable CLA would do is to confirm to the forwarding CLA that it has received all data that has been forwarded. I wouldn't expect the CLA to check whether this data is a bundle or something else.</span> <br><span style='font-size:10.0pt;font-family:"Arial",sans-serif'>This data will be provided to the BPA. Now:</span> <br><span style='font-size:10.0pt;font-family:"Arial",sans-serif'>a) if it is corrupted, the bundle node may not be able to do anything with it and just delete it.</span> <br><span style='font-size:10.0pt;font-family:"Arial",sans-serif'>b) the bundle node might be able to read correct bundles --> in this case we might want to report reception</span> <br><br><span style='font-size:10.0pt;font-family:"Arial",sans-serif'>After this:</span> <br><span style='font-size:10.0pt;font-family:"Arial",sans-serif'>c) the bundle node may forward the bundle --> we might want to report forwarding</span> <br><span style='font-size:10.0pt;font-family:"Arial",sans-serif'>d) the bundle node delivers the bundle --> we might want to report delivery</span> <br><span style='font-size:10.0pt;font-family:"Arial",sans-serif'>e) the bundle node deletes the bundle (expired, security checks fail, no storage, ...) --> we might want to report deletion</span> <br><br><span style='font-size:10.0pt;font-family:"Arial",sans-serif'>(The Compressed Bundle Reporting mechanism is about making these reporting more efficient.)</span> <br><br><span style='font-size:10.0pt;font-family:"Arial",sans-serif'>The report receiving node may do something wrt to the reports received (delete data, re-transmit data, ...). This might be application specific or we might want to specify some behaviour (which could be a re-transmission mechanism). </span><br><br><span style='font-size:10.0pt;font-family:"Arial",sans-serif'>Having said this, I agree that re-transmission at the convergence layer is the preferred mechanism if possible (eg, for bi-directional links) and that bundle re-transmission should only happen in exceptional (whatever this means) cases, e..g. if we have reliable convergence layers but maybe loose a bundle at the end of a contact.</span> <br><br><span style='font-size:10.0pt;font-family:"Arial",sans-serif'>Regards,</span> <br><span style='font-size:10.0pt;font-family:"Arial",sans-serif'>Felix</span> <br><br><br><br><br><span style='font-size:9.0pt;font-family:"Arial",sans-serif;color:#5F5F5F'>From:        </span><span style='font-size:9.0pt;font-family:"Arial",sans-serif'><sburleig.sb@gmail.com></span> <br><span style='font-size:9.0pt;font-family:"Arial",sans-serif;color:#5F5F5F'>To:        </span><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>"'Chaoua, Rachid\(GSFC-4500\)'" <rachid.chaoua@nasa.gov>, "'Sanchez Net,  Marc\(JPL-332H\)[JPL Employee]'" <marc.sanchez.net@jpl.nasa.gov>, <Felix.Flentge@esa.int>, "'Dr. Keith L Scott'" <kscott@mitre.org></span> <br><span style='font-size:9.0pt;font-family:"Arial",sans-serif;color:#5F5F5F'>Cc:        </span><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>"'Sipos, Brian J.'" <Brian.Sipos@jhuapl.edu>, dtn@ietf.org</span> <br><span style='font-size:9.0pt;font-family:"Arial",sans-serif;color:#5F5F5F'>Date:        </span><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>30/03/2022 19:52</span> <br><span style='font-size:9.0pt;font-family:"Arial",sans-serif;color:#5F5F5F'>Subject:        </span><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>Re: [dtn] [EXTERNAL] Re: [Sis-dtn] [EXT] Re: Bundle custody transfer and reliable CLs</span> <br><span style='font-size:9.0pt;font-family:"Arial",sans-serif;color:#5F5F5F'>Sent by:        </span><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>"dtn" <dtn-bounces@ietf.org></span> <o:p></o:p></p><div class=MsoNormal align=center style='text-align:center'><hr size=0 width="100%" noshade style='color:#A0A0A0' align=center></div><p class=MsoNormal style='margin-bottom:12.0pt'><o:p> </o:p></p><p style='margin:0in'>Hi, Rachid.  Confirming that the next BP node in the end-to-end path – the next bundle hop (bop) – has received a bundle is precisely what a reliable convergence-layer protocol does.  Now, it may be the case that the received bundle will not be forwarded any further:<o:p></o:p></p><ul type=disc><li class=MsoNormal style='mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;mso-list:l3 level1 lfo1'>The bundle may be malformed or otherwise corrupted, therefore deleted. <o:p></o:p></li><li class=MsoNormal style='mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;mso-list:l3 level1 lfo1'>The bundle may be too large to fit into available storage, therefore dropped.<o:p></o:p></li></ul><p class=MsoNormal>In a well-managed network these errors will be rare, but I agree that for critical transmissions they need to be reported.  That is why I fully endorse Felix’s concept of adding to BP a mechanism for sending aggregated bundle acknowledgments.  But that mechanism is not a substitute for a technically sound retransmission protocol at the convergence layer, for reasons we’ve already discussed at length; it’s an augmentation. <o:p></o:p></p><p style='margin:0in'> <o:p></o:p></p><p style='margin:0in'>I also agree that reliance on BIBE ARQ will work only on nodes that support BIBE ARQ.  Similarly, reliance on custody transfer – aggregated bundle acknowledgments at the bundle layer – will work only on nodes that support custody transfer.  This is a deficiency that is common to all protocols that I know of.<o:p></o:p></p><p style='margin:0in'> <o:p></o:p></p><p style='margin:0in'>Scott<o:p></o:p></p><p style='margin:0in'> <o:p></o:p></p><p style='margin:0in'><b>From:</b> Chaoua, Rachid (GSFC-4500) <rachid.chaoua@nasa.gov> <b><br>Sent:</b> Wednesday, March 30, 2022 9:39 AM<b><br>To:</b> sburleig.sb@gmail.com; Sanchez Net, Marc (JPL-332H)[JPL Employee] <marc.sanchez.net@jpl.nasa.gov>; Felix.Flentge@esa.int; 'Dr. Keith L Scott' <kscott@mitre.org><b><br>Cc:</b> 'Sipos, Brian J.' <Brian.Sipos@jhuapl.edu>; dtn@ietf.org<b><br>Subject:</b> RE: [dtn] [EXTERNAL] Re: [Sis-dtn] [EXT] Re: Bundle custody transfer and reliable CLs<o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'>Marc’s statement “the rover unequivocally knows that a complete data product has made it to the orbiter” reflects the sentiments I’ve heard within the Near Space Network when discussing DTN and Bundle Protocol. It is a core requirement for GSFC to confirm the next hop (bop) has custody of a data payload prior to that data being released from the source (or previous bop). This is requirement for certain data flow types not all. <o:p></o:p></p><p style='margin:0in'> <o:p></o:p></p><p style='margin:0in'>Regarding the statement (the LTP part), “Why are people in MRN opposed to using LTP”. Our (NSN/GSFC) stance (captured in the Draft LunaNet Interoperability Specification, <a href="https://esc.gsfc.nasa.gov/static-files/Draft%20LunaNet%20Interoperability%20Specification%20Final.pdf">https://esc.gsfc.nasa.gov/static-files/Draft%20LunaNet%20Interoperability%20Specification%20Final.pdf</a>, p.10) is that we will initially support various CLAs: TCPCL, UDPCL, LTPCL, or Encapsulation (future CLAs will be assessed and supportability determined by the NSN). Since we are planning on using various service providers, we are leaving the CLs used up to them. Regardless of the CL implemented, there is a need for a custody transfer option at the bundle layer. Relying on BIBE CL only works on nodes that support BIBE CL.  That gives me some concern. <o:p></o:p></p><p style='margin:0in'> <o:p></o:p></p><p style='margin:0in'> <o:p></o:p></p><p style='margin:0in'>Cheers!<o:p></o:p></p><p style='margin:0in'> <o:p></o:p></p><p style='margin:0in'> <o:p></o:p></p><p style='margin:0in'><b>From:</b> dtn <<a href="mailto:dtn-bounces@ietf.org">dtn-bounces@ietf.org</a>> <b>On Behalf Of </b><a href="mailto:sburleig.sb@gmail.com">sburleig.sb@gmail.com</a><b><br>Sent:</b> Tuesday, March 29, 2022 7:22 PM<b><br>To:</b> Sanchez Net, Marc (JPL-332H)[JPL Employee] <<a href="mailto:marc.sanchez.net@jpl.nasa.gov">marc.sanchez.net@jpl.nasa.gov</a>>; <a href="mailto:Felix.Flentge@esa.int">Felix.Flentge@esa.int</a>; 'Dr. Keith L Scott' <<a href="mailto:kscott@mitre.org">kscott@mitre.org</a>><b><br>Cc:</b> 'Sipos, Brian J.' <<a href="mailto:Brian.Sipos@jhuapl.edu">Brian.Sipos@jhuapl.edu</a>>; <a href="mailto:dtn@ietf.org">dtn@ietf.org</a><b><br>Subject:</b> Re: [dtn] [EXTERNAL] Re: [Sis-dtn] [EXT] Re: Bundle custody transfer and reliable CLs<o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'>Marc, I certainly agree that this is a serious problem, but I don’t agree that it motivates development of a reliability mechanism above the CLA.  (I believe a number of other requirements do that.)  Prox-1 may be technically a reliable CLA, but since it routinely misses data it’s apparently not the right one to use for this environment.  Why are people in MRN opposed to using LTP, which is a CCSDS standard that has been in continuous operational use in low Earth orbit (on ISS) since 2016?<o:p></o:p></p><p style='margin:0in'> <o:p></o:p></p><p style='margin:0in'>Sorry, this discussion is likely not of general interest to DTN WG; we should take it to another thread.<o:p></o:p></p><p style='margin:0in'> <o:p></o:p></p><p style='margin:0in'>Scott<o:p></o:p></p><p style='margin:0in'> <o:p></o:p></p><p style='margin:0in'><b>From:</b> Sanchez Net, Marc (US 332H) <<a href="mailto:marc.sanchez.net@jpl.nasa.gov">marc.sanchez.net@jpl.nasa.gov</a>> <b><br>Sent:</b> Tuesday, March 29, 2022 1:09 PM<b><br>To:</b> <a href="mailto:sburleig.sb@gmail.com">sburleig.sb@gmail.com</a>; <a href="mailto:Felix.Flentge@esa.int">Felix.Flentge@esa.int</a>; 'Dr. Keith L Scott' <<a href="mailto:kscott@mitre.org">kscott@mitre.org</a>><b><br>Cc:</b> 'Sipos, Brian J.' <<a href="mailto:Brian.Sipos@jhuapl.edu">Brian.Sipos@jhuapl.edu</a>>; <a href="mailto:dtn@ietf.org">dtn@ietf.org</a><b><br>Subject:</b> RE: [EXTERNAL] Re: [Sis-dtn] [dtn] [EXT] Re: Bundle custody transfer and reliable CLs<o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'>I also agree that having reliability mechanisms above the CLA is necessary. For example, the Mars Relay Network (MRN) uses the Prox-1 protocol on the proximity links, which has a built-in Go-Back-N ARQ mechanism, so it is technically a reliable CLA. Yet, they routinely miss data on the return direction and both the relay orbiter and rover missions have accountability mechanisms that look for missing data.<o:p></o:p></p><p style='margin:0in'> <o:p></o:p></p><p style='margin:0in'>When I talk to people in the MRN, their biggest desire from DTN is to avoid the problem above. In their words, they want a mechanism so that the rover unequivocally knows that a complete data product has made it to the orbiter. <o:p></o:p></p><p style='margin:0in'> <o:p></o:p></p><p style='margin:0in'>-----------------------------------------------------------------------------------------------------------------------<o:p></o:p></p><p style='margin:0in'>Marc Sanchez Net<o:p></o:p></p><p style='margin:0in'><span style='font-size:10.0pt;color:gray'>Telecommunications Engineer</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:10.0pt;color:gray'>Jet Propulsion Laboratory</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:10.0pt;color:gray'>Office:</span><span style='font-size:10.0pt;font-family:"Arial",sans-serif;color:#2F2F2F'> </span><a href="tel:(818)%20393-5840" target="_blank"><span style='font-size:10.0pt;font-family:"Arial",sans-serif;color:#0082BF'>(818) 354-1650</span></a><span style='font-size:10.0pt;font-family:"Arial",sans-serif;color:#0082BF'> </span><span style='font-size:10.0pt;color:gray'>|</span><span style='font-size:10.0pt;font-family:"Arial",sans-serif;color:#0082BF'> </span><span style='font-size:10.0pt;color:gray'>Email:</span><span style='font-size:10.0pt;font-family:"Arial",sans-serif;color:#2F2F2F'> </span><a href="mailto:marc.sanchez.net@jpl.nasa.gov"><span style='font-size:10.0pt;font-family:"Arial",sans-serif'>marc.sanchez.net@jpl.nasa.gov</span></a><o:p></o:p></p><p style='margin:0in'>-----------------------------------------------------------------------------------------------------------------------<o:p></o:p></p><p style='margin:0in'> <o:p></o:p></p><p style='margin:0in'><b>From:</b> SIS-DTN <<a href="mailto:sis-dtn-bounces@mailman.ccsds.org">sis-dtn-bounces@mailman.ccsds.org</a>> <b>On Behalf Of </b>sburleig.sb--- via SIS-DTN<b><br>Sent:</b> Monday, March 28, 2022 11:44 AM<b><br>To:</b> <a href="mailto:Felix.Flentge@esa.int">Felix.Flentge@esa.int</a>; 'Dr. Keith L Scott' <<a href="mailto:kscott@mitre.org">kscott@mitre.org</a>><b><br>Cc:</b> 'Sipos, Brian J.' <<a href="mailto:Brian.Sipos@jhuapl.edu">Brian.Sipos@jhuapl.edu</a>>; <a href="mailto:sis-dtn@mailman.ccsds.org">sis-dtn@mailman.ccsds.org</a>; <a href="mailto:dtn@ietf.org">dtn@ietf.org</a><b><br>Subject:</b> [EXTERNAL] Re: [Sis-dtn] [dtn] [EXT] Re: Bundle custody transfer and reliable CLs<o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'>I agree with everything Felix says here (except perhaps abandonment of the term “custodial”, which seems to have a lot of resonance in the DTN community).<o:p></o:p></p><p style='margin:0in'> <o:p></o:p></p><p style='margin:0in'>It is true that computed retransmission timeout intervals will not necessarily be absolutely accurate even in BIBE/CT, but at least there are ways to limit the error.  Methods for bundle delivery time estimation based on contact plan analysis were studied in detail and published almost 10 years ago: given known source and destination node ID and a bundle origination time and bundle size, we can estimate the time of arrival of the original bundle and consequently the time of arrival of its acknowledgment bundle, even over asymmetric paths.<o:p></o:p></p><p style='margin:0in'> <o:p></o:p></p><p style='margin:0in'>Certainly we don’t have the final answer to BP node congestion.  QoS may well play a role, and we are starting to think about that in DTN WG.  BPv7 does support the concept of “paring” excessive traffic by imposing lifetime overrides that result in immediate bundle expiration, a somewhat manageable mechanism for dropping bundles as necessary.<o:p></o:p></p><p style='margin:0in'> <o:p></o:p></p><p style='margin:0in'>But I don’t think we need to give up on flow control altogether.  When TCP is used at the convergence layer, a receiving node that is facing congestion can simply stop reading on the socket and let TCP flow control back-propagate.  When LTP is used at the convergence layer, a receiving node that is facing congestion can begin canceling sessions; this will result in CL protocol failure at the sender, bouncing the affected bundles back up to the BPA where reforwarding procedures can be initiated (admittedly an implementation matter, at least for now).  Neither entails bundle reception that requires the receiving BPA to make a decision.  Personally, I think building on these kinds of capabilities to address congestion at the convergence layer would be more powerful than demanding more functionality from custody transfer.<o:p></o:p></p><p style='margin:0in'> <o:p></o:p></p><p style='margin:0in'>Scott<o:p></o:p></p><p style='margin:0in'> <o:p></o:p></p><p style='margin:0in'><b>From:</b> <a href="mailto:Felix.Flentge@esa.int">Felix.Flentge@esa.int</a> <<a href="mailto:Felix.Flentge@esa.int">Felix.Flentge@esa.int</a>> <b><br>Sent:</b> Monday, March 28, 2022 7:54 AM<b><br>To:</b> Dr. Keith L Scott <<a href="mailto:kscott@mitre.org">kscott@mitre.org</a>><b><br>Cc:</b> 'Sipos, Brian J.' <<a href="mailto:Brian.Sipos@jhuapl.edu">Brian.Sipos@jhuapl.edu</a>>; <a href="mailto:dtn@ietf.org">dtn@ietf.org</a>; Mehmet Adalier <<a href="mailto:madalier@antarateknik.com">madalier@antarateknik.com</a>>; <a href="mailto:sburleig.sb@gmail.com">sburleig.sb@gmail.com</a>; <a href="mailto:sis-dtn@mailman.ccsds.org">sis-dtn@mailman.ccsds.org</a><b><br>Subject:</b> Re: [Sis-dtn] [dtn] [EXT] Re: Bundle custody transfer and reliable CLs<o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:10.0pt;font-family:"Arial",sans-serif'>Yes, I do think there is a need for reliability mechanisms above the CLA Layer. BIBE as a generic reliable CLA allows to address the case of reliability for uni-directional links (although in this case the setting of the timers may already get difficult) but it is currently not addressing:</span><span style='font-size:12.0pt'> </span><span style='font-size:10.0pt;font-family:"Arial",sans-serif'><br>- non-timer based re-transmission (which might be very specific to a certain node and deployment and therefore might be better addressed as part of the BPA / AA)</span><span style='font-size:12.0pt'> </span><span style='font-size:10.0pt;font-family:"Arial",sans-serif'><br>- forwarding a bundle without explicitly addressing a (singleton) next hop (eg, an opportunistic downlink where some signal about reception or delivery is uplinked at some later time).</span><span style='font-size:12.0pt'> <br></span><span style='font-size:10.0pt;font-family:"Arial",sans-serif'><br>I agree that we somehow can consider all received bundles as 'custodial' as a node should attempt to store and forward them. I also think that the typical use of custody transfer for BPv6 has been probably more to be informed about the reception (or deletion) of a bundle then whatever (additional ???) responsibility would be taken by the receiving node. So, maybe we should abandon the term 'custody' altogether. However, there are certainly situations where a sending node would like to get information about reception/delivery/deletion/forwarding of a bundle at another node in an operationally viable and efficient way (so, not using the current Bundle Status Reports).</span><span style='font-size:12.0pt'> <br></span><span style='font-size:10.0pt;font-family:"Arial",sans-serif'><br>Regards,</span><span style='font-size:12.0pt'> </span><span style='font-size:10.0pt;font-family:"Arial",sans-serif'><br>Felix</span><span style='font-size:12.0pt'> <br><br><br></span><span style='font-size:9.0pt;font-family:"Arial",sans-serif;color:#5F5F5F'><br>From:        </span><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>"Dr. Keith L Scott" <</span><a href="mailto:kscott@mitre.org"><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>kscott@mitre.org</span></a><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>></span><span style='font-size:12.0pt'> </span><span style='font-size:9.0pt;font-family:"Arial",sans-serif;color:#5F5F5F'><br>To:        </span><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>"Mehmet Adalier" <</span><a href="mailto:madalier@antarateknik.com"><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>madalier@antarateknik.com</span></a><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>>, "</span><a href="mailto:sburleig.sb@gmail.com"><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>sburleig.sb@gmail.com</span></a><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>" <</span><a href="mailto:sburleig.sb@gmail.com"><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>sburleig.sb@gmail.com</span></a><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>>, "'Sipos, Brian J.'" <</span><a href="mailto:Brian.Sipos@jhuapl.edu"><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>Brian.Sipos@jhuapl.edu</span></a><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>>, "</span><a href="mailto:Felix.Flentge@esa.int"><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>Felix.Flentge@esa.int</span></a><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>" <</span><a href="mailto:Felix.Flentge@esa.int"><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>Felix.Flentge@esa.int</span></a><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>>, "</span><a href="mailto:dtn@ietf.org"><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>dtn@ietf.org</span></a><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>" <</span><a href="mailto:dtn@ietf.org"><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>dtn@ietf.org</span></a><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>>, "</span><a href="mailto:sis-dtn@mailman.ccsds.org"><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>sis-dtn@mailman.ccsds.org</span></a><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>" <</span><a href="mailto:sis-dtn@mailman.ccsds.org"><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>sis-dtn@mailman.ccsds.org</span></a><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>></span><span style='font-size:12.0pt'> </span><span style='font-size:9.0pt;font-family:"Arial",sans-serif;color:#5F5F5F'><br>Date:        </span><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>28/03/2022 15:11</span><span style='font-size:12.0pt'> </span><span style='font-size:9.0pt;font-family:"Arial",sans-serif;color:#5F5F5F'><br>Subject:        </span><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>Re: [Sis-dtn] [dtn] [EXT] Re: Bundle custody transfer and reliable CLs</span><span style='font-size:12.0pt'> </span><o:p></o:p></p><div class=MsoNormal align=center style='text-align:center'><hr size=0 width="100%" noshade style='color:#A0A0A0' align=center></div><p style='mso-margin-top-alt:0in;margin-right:0in;margin-bottom:2.5in;margin-left:0in'><span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>The question remains: do we need some form of reliability above the CLA layer?  As Scott points out, BIBE is ‘just’ a reliable CLA that uses bundles as its transport mechanism.  That allows BIBE to function as a reliable CLA in environments where other CLAs that require bidirectional connectivity cannot, but viewed from the standpoint of the sending and receiving BIBE endpoints, it’s just another reliable CLA.</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>The not-often-stated assumption here is that bundle nodes that receive bundles via reliable CLAs do in fact take on the responsibilities of what was traditionally referred to as ‘custody transfer’ – i.e. following whatever procedures are necessary to ensure that the received bundle reaches its destination (e.g. store it until a forward path becomes available, attempt retransmission to the next hop until there’s an indication that the next hop has (via a reliable CLA in this context) received the bundle, etc.).  I.e. this approach assumes that receipt of a bundle </span><span style='font-size:12.0pt;font-family:Wingdings'>è</span><span style='font-size:12.0pt'> accepting ‘custody’ of it.  Without this assumption, the service provided by BP is essentially the same best-effort service that IP provides, which I think is less than what we want, particularly for space missions. So I think that in the BPv7 context, all bundles are considered ‘custodial’.</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>If we consider cases where there may be congestion (contention for storage space at nodes), this means that when congestion happens at a node, the only course of action available to the node will be to refuse new incoming bundles (presumably because the receiving CLAs stop accepting them).  </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>There are at least two things to consider here:</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:10.0pt;font-family:"Arial",sans-serif'><br>1.        </span>What if I have a bundle node that is capable of forwarding but that has quite minimal storage?  By receiving a bundle, this node is committing to storing that bundle until it can be reliably forwarded.  It seems like there could be cases where this is really inefficient, especially if the reliable forwarding is over something like BIBE where the RTT to get an acknowledgement could be high.  In BPv6, such a node could simply forward a custody-requesting bundle without actually taking custody, sort of like a ‘transit node’ in a BIBE tunnel.  In this case, it might be able to achieve a higher throughput at the expense of NOT accepting the storage requirements from the current custodians.<span style='font-size:12.0pt'> </span><span style='font-size:10.0pt;font-family:"Arial",sans-serif'><br>2.        </span>Even if a congested node has a lot of storage (but still becomes congested), in BPv6 there was the notion that the node could drop (probably lower-priority) non-custodial bundles in favor of (probably higher-priority) custodial bundles.  We don’t currently have any notion of priority in BPv7, but if we ever want to admit the possibility that a bundle node might drop a bundle due to congestion, it seems like the assumption that receipt <span style='font-family:Wingdings'>à</span> ‘custodial’ acceptance constrains us.  In the BPv7 ‘receipt is (custody) acceptance’ model, the node would have to refuse new bundles.<span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>This might be right thing for some CONOPS.  It would impose backpressure (at DTN timescales) on the network, eventually to the bundle sources.  The same thing would happen with BPv6 and custodial bundles, the difference being that a BPv6 node would have the option of dropping non-custodial bundles to accommodate newer (again, presumably higher-priority) bundles.</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>I’ll readily admit that calculating a (good) retransmission timer value in the case where a node does NOT know if the proximate (or even which) downstream node will take custody is difficult or impossible for some networks.  BIBE still has a bit of this problem, especially if the path to the BIBE destination is long, as the sender won’t necessarily know the path the BIBE bundles will take, but it is at least more constrained than the completely open case.</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>If we want to have the option of dropping lower-priority bundles that have already been received and are being stored at a node, we’ll need an extension block to mark priority, fine.  We could then create rules that operate at the BP layer to drop bundles when congestion occurs according to their priority markings and address #2 above. I suppose in this case the ‘reliability’ is still at the CLA layer and the decision-making process on whether or not to drop an incoming bundle is at the BP layer.  </span><o:p></o:p></p><ul type=disc><li class=MsoNormal style='mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;mso-list:l0 level1 lfo2'>That might not address #1 above but maybe #1 is sufficiently rare (or non-existent) that we decide to ignore it.<span style='font-size:12.0pt'> </span><o:p></o:p></li><li class=MsoNormal style='mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;mso-list:l0 level1 lfo2'>Regardless, this has the disadvantage that the transmitting node would believe that the bundle was accepted (because it would have been, by the receiving CLA) event though it then got dropped by the BP layer at the receiving node.<o:p></o:p></li></ul><p class=MsoNormal> <span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>                                --keith</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'><b><span style='font-size:12.0pt'>From: </span></b><span style='font-size:12.0pt'>"</span><a href="mailto:sis-dtn-bounces@mailman.ccsds.org"><span style='font-size:12.0pt'>sis-dtn-bounces@mailman.ccsds.org</span></a><span style='font-size:12.0pt'>" <</span><a href="mailto:sis-dtn-bounces@mailman.ccsds.org"><span style='font-size:12.0pt'>sis-dtn-bounces@mailman.ccsds.org</span></a><span style='font-size:12.0pt'>> on behalf of "</span><a href="mailto:sis-dtn@mailman.ccsds.org"><span style='font-size:12.0pt'>sis-dtn@mailman.ccsds.org</span></a><span style='font-size:12.0pt'>" <</span><a href="mailto:sis-dtn@mailman.ccsds.org"><span style='font-size:12.0pt'>sis-dtn@mailman.ccsds.org</span></a><span style='font-size:12.0pt'>><b><br>Reply-To: </b>Mehmet Adalier <</span><a href="mailto:madalier@antarateknik.com"><span style='font-size:12.0pt'>madalier@antarateknik.com</span></a><span style='font-size:12.0pt'>><b><br>Date: </b>Friday, March 25, 2022 at 1:21 PM<b><br>To: </b>"</span><a href="mailto:sburleig.sb@gmail.com"><span style='font-size:12.0pt'>sburleig.sb@gmail.com</span></a><span style='font-size:12.0pt'>" <</span><a href="mailto:sburleig.sb@gmail.com"><span style='font-size:12.0pt'>sburleig.sb@gmail.com</span></a><span style='font-size:12.0pt'>>, "'Sipos, Brian J.'" <</span><a href="mailto:Brian.Sipos@jhuapl.edu"><span style='font-size:12.0pt'>Brian.Sipos@jhuapl.edu</span></a><span style='font-size:12.0pt'>>, Felix Flentge <</span><a href="mailto:Felix.Flentge@esa.int"><span style='font-size:12.0pt'>Felix.Flentge@esa.int</span></a><span style='font-size:12.0pt'>>, "</span><a href="mailto:dtn@ietf.org"><span style='font-size:12.0pt'>dtn@ietf.org</span></a><span style='font-size:12.0pt'>" <</span><a href="mailto:dtn@ietf.org"><span style='font-size:12.0pt'>dtn@ietf.org</span></a><span style='font-size:12.0pt'>>, "</span><a href="mailto:sis-dtn@mailman.ccsds.org"><span style='font-size:12.0pt'>sis-dtn@mailman.ccsds.org</span></a><span style='font-size:12.0pt'>" <</span><a href="mailto:sis-dtn@mailman.ccsds.org"><span style='font-size:12.0pt'>sis-dtn@mailman.ccsds.org</span></a><span style='font-size:12.0pt'>><b><br>Subject: </b>Re: [Sis-dtn] [dtn] [EXT] Re: Bundle custody transfer and reliable CLs</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>I believe Scott’s analysis below succinctly articulates the difference between the two approaches and I agree that they should be kept separate. For my intended use cases, approach 1 (BIBE/BPARQ?) is what I would need to use. I’ll be happy to contribute to this approach and prototype.</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>Best</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>mehmet</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'><b><span style='font-size:12.0pt'>From: </span></b><span style='font-size:12.0pt'>SIS-DTN <</span><a href="mailto:sis-dtn-bounces@mailman.ccsds.org"><span style='font-size:12.0pt'>sis-dtn-bounces@mailman.ccsds.org</span></a><span style='font-size:12.0pt'>> on behalf of "sburleig.sb--- via SIS-DTN" <</span><a href="mailto:sis-dtn@mailman.ccsds.org"><span style='font-size:12.0pt'>sis-dtn@mailman.ccsds.org</span></a><span style='font-size:12.0pt'>><b><br>Reply-To: </b><</span><a href="mailto:sburleig.sb@gmail.com"><span style='font-size:12.0pt'>sburleig.sb@gmail.com</span></a><span style='font-size:12.0pt'>><b><br>Date: </b>Friday, March 25, 2022 at 10:07 AM<b><br>To: </b>"'Sipos, Brian J.'" <</span><a href="mailto:Brian.Sipos@jhuapl.edu"><span style='font-size:12.0pt'>Brian.Sipos@jhuapl.edu</span></a><span style='font-size:12.0pt'>>, <</span><a href="mailto:Felix.Flentge@esa.int"><span style='font-size:12.0pt'>Felix.Flentge@esa.int</span></a><span style='font-size:12.0pt'>>, <</span><a href="mailto:dtn@ietf.org"><span style='font-size:12.0pt'>dtn@ietf.org</span></a><span style='font-size:12.0pt'>>, <</span><a href="mailto:sis-dtn@mailman.ccsds.org"><span style='font-size:12.0pt'>sis-dtn@mailman.ccsds.org</span></a><span style='font-size:12.0pt'>><b><br>Subject: </b>Re: [Sis-dtn] [dtn] [EXT] Re: Bundle custody transfer and reliable CLs</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>Hi, Brian.  Actually I think Felix’s analysis is pretty much spot-on.  We really are talking about two different behaviors, which respond to two different sets of requirements.</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>The “custody transfer” procedures that I proposed in the BIBE draft are very specifically aimed at defining a reliable convergence-layer adapter that happens to use BP as its underlying convergence-layer protocol.  There is a requirement for this capability: Keith Scott has often pointed out that there are scenarios in which reliable transmission between nodes is required but no reliable transmission protocol is available, e.g., when the sender’s communication capability is temporarily unidirectional.  These are not hypothetical; MITRE’s customers must at times operate in such environments, and some space flight missions and other IoT systems could be similarly constrained.  Under these conditions, the mechanism by which NAKs and ACKs are returned to the sender may function at a later time and/or be unrelated to the mechanism by which the sender transmitted the data.  There might be better standardized protocols than BP for supporting these kinds of scenarios, but none leap to mind.</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>The ”custody transfer” procedures for which Felix proposes requirements are different.  Since there is no need for timeout-triggered retransmission (retransmission is instead triggered by command or by negative acknowledgment), there is no need for accurate estimation of the round-trip time; therefore there is no need for the sender to know which node will issue the responding (positive) custody acknowledgment, exactly as required.  I think of it as a resource management system rather than an ARQ system.  A mechanism very much like BPv6 custody transfer will work fine.</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>I would propose that we term the latter procedures “custody transfer” and proceed to standardize them, while renaming the former something like “BPARQ”.</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>I don’t think there’s any need to impose any additional requirements on CL protocols, TCPCL or other, to satisfy the requirements.  These are separate things.  Let’s keep them separate and support them separately and clearly.</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>Scott</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'><b><span style='font-size:12.0pt'>From:</span></b><span style='font-size:12.0pt'> dtn <</span><a href="mailto:dtn-bounces@ietf.org"><span style='font-size:12.0pt'>dtn-bounces@ietf.org</span></a><span style='font-size:12.0pt'>> <b>On Behalf Of </b>Sipos, Brian J.<b><br>Sent:</b> Friday, March 25, 2022 4:46 AM<b><br>To:</b> </span><a href="mailto:Felix.Flentge@esa.int"><span style='font-size:12.0pt'>Felix.Flentge@esa.int</span></a><span style='font-size:12.0pt'>; </span><a href="mailto:dtn@ietf.org"><span style='font-size:12.0pt'>dtn@ietf.org</span></a><span style='font-size:12.0pt'>; </span><a href="mailto:sis-dtn@mailman.ccsds.org"><span style='font-size:12.0pt'>sis-dtn@mailman.ccsds.org</span></a><b><span style='font-size:12.0pt'><br>Subject:</span></b><span style='font-size:12.0pt'> Re: [dtn] [EXT] Re: Bundle custody transfer and reliable CLs</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;color:#004080'>Felix,</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;color:#004080'>Thank you for this feedback. There is a misinterpretation of what I (and maybe also Scott via BIBE) am suggesting about what happens during reliable reception. The idea isn’t that two different things happen, it’s that it’s the same BP agent custody acceptance criteria just that some CLs can provide intrinsic signaling of that acceptance while other CLs have no means to signal that specific feedback.</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;color:#004080'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;color:#004080'>While IETF doesn’t (normally) specify internal APIs, the CCSDS documents do and this can help here. Currently 734.2-B-1 does not actually define a BPA—CLA interface API, but it seems like the rough interface looks like:</span><o:p></o:p></p><ul type=disc><li class=MsoNormal style='mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;mso-list:l1 level1 lfo3'><span style='color:#004080'>Send.request to the CLA</span><span style='font-size:12.0pt'> </span><o:p></o:p></li><li class=MsoNormal style='mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;mso-list:l1 level1 lfo3'><span style='color:#004080'>Send.response from the CLA</span><span style='font-size:12.0pt'> </span><o:p></o:p></li><li class=MsoNormal style='mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;mso-list:l1 level1 lfo3'><span style='color:#004080'>Receive.indication from the CLA</span><o:p></o:p></li></ul><p class=MsoNormal><span style='color:#004080'> </span><span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;color:#004080'>What I am suggesting is that the Receive side could be changed from the asynchronous “I just got this transfer. Here it is, thanks.” to a synchronous “I just got this transfer. Will you accept it?” similar to:</span><o:p></o:p></p><ul type=disc><li class=MsoNormal style='mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;mso-list:l2 level1 lfo4'><span style='color:#004080'>Receive.indication from the CLA</span><span style='font-size:12.0pt'> </span><o:p></o:p></li><li class=MsoNormal style='mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;mso-list:l2 level1 lfo4'><span style='color:#004080'>Receive.response to the CLA</span><o:p></o:p></li></ul><p class=MsoNormal><span style='color:#004080'> </span><span style='font-size:12.0pt'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;color:#004080'>The TCPCL and LTPCL already provide the negative response over-the-wire (TCPCL reception can send XFER_REFUSE at any time before the END ACK, and LTPCL can send “Cancel from the block receiver” similarly) there is currently just no specific formal definition of what, from the BPA side, the positive acknowledgement is required to mean. For example “If the transfer is not canceled by the receiver and the final ACK is sent, the transferred bundle SHALL be completely and positively received within the BP agent’s forwarding or delivery queue.” </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;color:#004080'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;color:#004080'>As Scott mentioned earlier, custody isn’t an anthropomorphization of the BPA, it’s a specific behavior, and it seems like by acknowledging that the bundle was received into the queue for delivery/forwarding the agent has “accepted” it. If the intent of custody is that it’s a more restricted/reserved resource pool (e.g. my forwarding queue is size X but of that only Y (with Y<X) is reserved for bundles over which I have custody) then that’s a local agent management issue, not an over-the-wire signaling issue. The BPA has still positively accepted the bundle and some CLAs can communicate this back to the sending agent synchronously.</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;color:#004080'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;color:#004080'>Thanks for any further clarification,</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;color:#004080'>Brian S.</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;color:#004080'> </span><o:p></o:p></p><p style='margin:0in'><b><span style='font-size:12.0pt'>From:</span></b><span style='font-size:12.0pt'> dtn <</span><a href="mailto:dtn-bounces@ietf.org"><span style='font-size:12.0pt'>dtn-bounces@ietf.org</span></a><span style='font-size:12.0pt'>> <b>On Behalf Of </b></span><a href="mailto:Felix.Flentge@esa.int"><span style='font-size:12.0pt'>Felix.Flentge@esa.int</span></a><b><span style='font-size:12.0pt'><br>Sent:</span></b><span style='font-size:12.0pt'> Friday, March 25, 2022 6:11 AM<b><br>To:</b> </span><a href="mailto:dtn@ietf.org"><span style='font-size:12.0pt'>dtn@ietf.org</span></a><span style='font-size:12.0pt'>; </span><a href="mailto:sis-dtn@mailman.ccsds.org"><span style='font-size:12.0pt'>sis-dtn@mailman.ccsds.org</span></a><b><span style='font-size:12.0pt'><br>Subject:</span></b><span style='font-size:12.0pt'> [EXT] Re: [dtn] Bundle custody transfer and reliable CLs</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:10.0pt;font-family:"Arial",sans-serif'>(cross-posting to CCSDS DTN mailinglist as it seems to be of high relevance to the on-going discussions in the DTN WG).</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:10.0pt;font-family:"Arial",sans-serif'><br><br>I think we clearly need to distinguish between (at least) two different types of 'custody transfer' according to where it is implemented:</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:10.0pt;font-family:"Arial",sans-serif'><br><br>(a) BPv6 - like custody transfer which has been a function of the BPA / AA Administrative element</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:10.0pt;font-family:"Arial",sans-serif'><br>(b) BIBE-like custody transfer which is implemented in the CLA</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:10.0pt;font-family:"Arial",sans-serif'><br><br>The main differences I see are:</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:10.0pt;font-family:"Arial",sans-serif'><br>- In (a) the decision whether to take custody or not can be taken on more available information, eg timely availability of a route toward a next hop, available storage, policies (eg, checking Bundle Integrity Blocks), ... In (b), the CLA may accept custody and the BPA would just decide to discard the bundle for whatever reason (of course, there could be interfaces to make such information available to the CLA but this would somehow 'blur' the architecture.</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:10.0pt;font-family:"Arial",sans-serif'><br>- In (b), the node to take custody needs to be explicitly addressed (it's the BIBE destination) while in (a) any node could take custody.</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:10.0pt;font-family:"Arial",sans-serif'><br><br>Requirements regarding custody transfer I would see for space missions are:</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:10.0pt;font-family:"Arial",sans-serif'><br><br>1) Assertion of a high probability that a bundle will reach its destination once a hop has accepted custody (which would allow the forwarding node to release storage).</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:10.0pt;font-family:"Arial",sans-serif'><br>The meaning of 'high probability' does really depend on the mission data return requirements. While for some missions it may be close to 100%, other mission may be ready to accept higher data loss in favour of timeliness (eg, certain types of Earth Observation missions).</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:10.0pt;font-family:"Arial",sans-serif'><br><br>2) Forwarding bundles without knowing which node will take custody.</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:10.0pt;font-family:"Arial",sans-serif'><br>In particular with high data rates and optical direct-to-Earth downlinks we may have situations where the spacecraft may not know the actual next hop is sending to but may want to get a confirmation that the bundle has been received on ground. With high-data rates, bundles might already be prepared and encoded in frames and be sitting in some buffers within optical terminal because the data rates on the on-board buses would not allow to generate and send in real time. Use of optical direct-to-Earth links may be opportunistic and we may not know in advance how much data will go down. So, addressing a specific DTN node in a ground station becomes unpractical (if DTN nodes in ground station would share the same anycast eID it may be possible but BIBE is currently limited to singleton endpoints).</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:10.0pt;font-family:"Arial",sans-serif'><br><br>It is clear that these requirements cannot be solved by protocol specification as Scott pointed out below but will also require that implementing nodes conform to certain behaviours. This will not be possible for an open, Internet-like DTN network (where we can only try to take defensive actions). For space missions I would still expect limited, tightly-controlled network for some time to come (maybe becoming 'trusted zones' in a larger network). For these, we should have protocol mechanism which can support above requirements (while being aware that some of these mechanisms will not work in a fully open DTN).</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:10.0pt;font-family:"Arial",sans-serif'><br><br>Finally, 'custody transfer' seems to be always related to timer-base re-transmission. However, I think there are other options as well, like:</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:10.0pt;font-family:"Arial",sans-serif'><br>- command-based re-transmission: an explicit command is sent to a DTN node to re-transmit all bundles for which custody has been requested but no signal has been received</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:10.0pt;font-family:"Arial",sans-serif'><br>- sequence-based re-transmission: in some situations it might be possible (using additional extension blocks) to detect which bundles have not been received by inspecting the received custody signals and re-send the ones for which no custody signal have been received</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:10.0pt;font-family:"Arial",sans-serif'><br>Again, this would likely not work in an open DTN but only in (very) limited, controlled networks. But this doesn't make such mechanisms less useful (although I would prefer to have something more generic if possible) and we should address it in the IETF (if there is general interest) and/or the CCSDS (if it is for near-to-medium term space mission use cases only). <br><br>Regarding reliable CLs: I currently don't see the point of a reliable CL taking custody because it would be (only) type (b) custody which is basically just a confirmation that the bundle has been received and this can already be assumed by the fact that it is a reliable CL.</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:10.0pt;font-family:"Arial",sans-serif'><br><br>Regards,</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:10.0pt;font-family:"Arial",sans-serif'><br>Felix</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> <br><br><br></span><span style='font-size:9.0pt;font-family:"Arial",sans-serif;color:#5F5F5F'><br><br>From:        </span><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>"William Ivancic" <</span><a href="mailto:ivancic@syzygyengineering.com"><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>ivancic@syzygyengineering.com</span></a><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>></span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:9.0pt;font-family:"Arial",sans-serif;color:#5F5F5F'><br>To:        </span><span style='font-size:9.0pt;font-family:"Arial",sans-serif'><</span><a href="mailto:sburleig.sb@gmail.com"><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>sburleig.sb@gmail.com</span></a><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>>, "'Sipos, Brian J.'" <</span><a href="mailto:Brian.Sipos@jhuapl.edu"><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>Brian.Sipos@jhuapl.edu</span></a><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>>, <</span><a href="mailto:dtn@ietf.org"><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>dtn@ietf.org</span></a><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>></span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:9.0pt;font-family:"Arial",sans-serif;color:#5F5F5F'><br>Date:        </span><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>25/03/2022 01:16</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:9.0pt;font-family:"Arial",sans-serif;color:#5F5F5F'><br>Subject:        </span><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>Re: [dtn] Bundle custody transfer and reliable CLs</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:9.0pt;font-family:"Arial",sans-serif;color:#5F5F5F'><br>Sent by:        </span><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>"dtn" <</span><a href="mailto:dtn-bounces@ietf.org"><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>dtn-bounces@ietf.org</span></a><span style='font-size:9.0pt;font-family:"Arial",sans-serif'>></span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><o:p></o:p></p><div class=MsoNormal align=center style='text-align:center'><hr size=0 width="100%" noshade style='color:#A0A0A0' align=center></div><p style='margin-bottom:0in;\ýÍ■ýÍ■-O'><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>“</span><span style='font-size:12.0pt'>Custody</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>”</span><span style='font-size:12.0pt'> is </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt'>a bundle level concept, not transport. </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt'>Way back when, </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>“</span><span style='font-size:12.0pt'>Custody</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>”</span><span style='font-size:12.0pt'> meant that the node taking </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>“</span><span style='font-size:12.0pt'>Custody</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>”</span><span style='font-size:12.0pt'> would try it</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>’</span><span style='font-size:12.0pt'>s best to ensure the bundle was forwarded either to another </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>“</span><span style='font-size:12.0pt'>Custody</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>”</span><span style='font-size:12.0pt'> node or to eventually the destination node. </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt'>The idea, as I recall, was this would allow the original bundle source to clear its memory of that bundle. </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>For space operations, I don</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>’</span><span style='font-size:12.0pt'>t think the operations people were ever comfortable with this concept.</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>//Will</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><o:p></o:p></p><p style='margin:0in'><b><span style='font-size:12.0pt'>From: </span></b><span style='font-size:12.0pt'>dtn <</span><a href="mailto:dtn-bounces@ietf.org"><span style='font-size:12.0pt'>dtn-bounces@ietf.org</span></a><span style='font-size:12.0pt'>> on behalf of <</span><a href="mailto:sburleig.sb@gmail.com"><span style='font-size:12.0pt'>sburleig.sb@gmail.com</span></a><span style='font-size:12.0pt'>><b><br>Date: </b>Thursday, March 24, 2022 at 6:04 PM<b><br>To: </b>"'Sipos, Brian J.'" <</span><a href="mailto:Brian.Sipos@jhuapl.edu"><span style='font-size:12.0pt'>Brian.Sipos@jhuapl.edu</span></a><span style='font-size:12.0pt'>>, <</span><a href="mailto:dtn@ietf.org"><span style='font-size:12.0pt'>dtn@ietf.org</span></a><span style='font-size:12.0pt'>><b><br>Subject: </b>Re: [dtn] Bundle custody transfer and reliable CLs</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>Brian, there was some further discussion of custody transfer in this morning</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>’</span><span style='font-size:12.0pt'>s meeting of the CCSDS Space Internetworking Systems DTN Working Group as well. </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt'>A couple of notes:</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>It</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>’</span><span style='font-size:12.0pt'>s important to remember that we are talking about state machines here, not people. </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt'>Anthropomorphizing the DTN architecture is tempting but treacherous. </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt'>BP nodes have no will; they cannot take responsibility; they cannot promise to do anything. </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt'>All they do is behave, ideally in a fashion that conforms to the protocol specifications to which they were allegedly developed.</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>Also, any given node may have been designed with malign intent or implemented with errors. </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt'>Stating a requirement in a protocol specification does not ensure its satisfaction; what it does is give a node</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>’</span><span style='font-size:12.0pt'>s human (maybe eventually AI) network operators a means of assessing the behavior of another node and possibly taking some sort of out-of-band administrative action in defense against that behavior as needed.</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>You</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>’</span><span style='font-size:12.0pt'>re right, the term </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>“</span><span style='font-size:12.0pt'>custody</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>”</span><span style='font-size:12.0pt'> is not defined for BPv7. </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt'>It is still widely used to refer to some behavior that future users of DTN for space flight operations state will be very important, but for which the requirements are not yet clearly established. </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt'>It is starting to look like the BP-based ARQ in the most recent BIBE draft, while needed (I think), is not exactly what people mean by </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>“</span><span style='font-size:12.0pt'>custody transfer.</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>”</span><span style='font-size:12.0pt'> </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt'>So it may become useful to define an additional BP extension (TBD) that we label with this term.</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>TCPCL enhancements along the lines you propose here may very well be valuable; I don</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>’</span><span style='font-size:12.0pt'>t know, need to think about them some more. </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt'>But I would say the BPv7 specification already contains language (in 5.4, Step 5 and the following two paragraphs, and in 7.2, second bullet point) constraining the sort of convergence-layer reliability that I think is indispensable, regardless of what we call it.</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>Scott</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><o:p></o:p></p><p style='margin:0in'><b><span style='font-size:12.0pt'>From:</span></b><span style='font-size:12.0pt'> dtn <</span><a href="mailto:dtn-bounces@ietf.org"><span style='font-size:12.0pt'>dtn-bounces@ietf.org</span></a><span style='font-size:12.0pt'>> <b>On Behalf Of </b>Sipos, Brian J.<b><br>Sent:</b> Thursday, March 24, 2022 1:39 PM<b><br>To:</b> </span><a href="mailto:dtn@ietf.org"><span style='font-size:12.0pt'>dtn@ietf.org</span></a><b><span style='font-size:12.0pt'><br>Subject:</span></b><span style='font-size:12.0pt'> [dtn] Bundle custody transfer and reliable CLs</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>All,</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>There was some brief discussion during the BIBE presentation about custody transfer concept and CL mechanisms. This is also an open topic in the CCSDS drafting of BPv7 standardization. I would like to add some additional points for thought in how a reliable convergence layer can relate to the concept of custody transfer for agents on either side of the transfer.</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>Overall, there still seems to be some vagueness about what </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>“</span><span style='font-size:12.0pt'>custody</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>”</span><span style='font-size:12.0pt'> means (in the sense of a service level agreement) between peers exchanging bundles. My understanding is that </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>“</span><span style='font-size:12.0pt'>custody</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>”</span><span style='font-size:12.0pt'> means the custodial node is willing to make some kind of effort to keep the bundle moving toward its destination until the bundle lifetime expires.</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>The current RFC 9174 document is silent about what exactly an XFER_ACK segment with END flag set (an END ACK) means from the perspective of the BP agent and what is guaranteed about the transferred bundle. This provides an opportunity for a follow-on clarification of END ACK semantics for the TCPCL entity and for the BP agent. Two potential ways of making the behavior more well-defined:</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>1. </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt'> </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt'> </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt'> A network-specific profile of TCPCL could simply mandate that any node accepts custody by sending an END ACK. This would simply be a condition of conformance to the profile in a controlled network. This could be done immediately without any change elsewhere, but needs out-of-band coordination.</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>2. </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt'> </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt'> </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt'> One or more (quite simple) extension types can be defined for TCPCL to allow an entity to expose its END ACK behavior (RX) and desire (TX):</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>a. </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt'> </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt'> </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt'> A session extension can allow an entity to assert what its sent END ACK means for received transfers. The value in this is to allow the peer entity to adjust behavior depending on the capability (e.g. use BIBE if the next-hop doesn</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>’</span><span style='font-size:12.0pt'>t take END ACK custody), including possibly refusing to establish a session with (or refusing to send bundles to) a peer that does not take custody via END ACK.</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>b. </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt'> </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt'> </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt'>Additionally, a transfer extension can allow a sender to assert its custody desire on a per-bundle basis (signaling that some bundles need custody transfer while others do not). The value in this is to allow the receiving entity to optimize its behavior based on whether or not custody is needed for a bundle; though I don</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>’</span><span style='font-size:12.0pt'>t know how much benefit this would be.</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>The possible values enumerated by the session extension would be something like:</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;font-family:Symbol'>· </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt;font-family:Symbol'> </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt;font-family:Symbol'> </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt;font-family:Symbol'> </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt;font-family:Symbol'> </span><span style='font-size:12.0pt'>Custody is not taken at END ACK</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;font-family:Symbol'>· </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt;font-family:Symbol'> </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt;font-family:Symbol'> </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt;font-family:Symbol'> </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt;font-family:Symbol'> </span><span style='font-size:12.0pt'>Custody is taken at END ACK</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>And if there is a transfer extension defined, a the session extension could indicate:</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;font-family:Symbol'>· </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt;font-family:Symbol'> </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt;font-family:Symbol'> </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt;font-family:Symbol'> </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt;font-family:Symbol'> </span><span style='font-size:12.0pt'>Reception behavior is unconditional</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;font-family:Symbol'>· </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt;font-family:Symbol'> </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt;font-family:Symbol'> </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt;font-family:Symbol'> </span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><span style='font-size:12.0pt;font-family:Symbol'> </span><span style='font-size:12.0pt'>Reception behavior can be overridden per-transfer based on the sender</span><span style='font-size:12.0pt;font-family:"Times New Roman",serif'>’</span><span style='font-size:12.0pt'>s desire</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>These changes would all be backward compatible in the sense that a default policy would be in place in the absence of this extension item. And all of this is an independent mechanism from BIBE for a custody transfer to take place; both this mechanism and BIBE have their own costs, benefits, and side effects of such a transfer.</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt;font-family:"Times New Roman",serif'> </span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>Trying to make almost-there-already capabilities more obvious,</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>Brian S.</span><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>_______________________________________________ dtn mailing list </span><a href="mailto:dtn@ietf.org"><span style='font-size:12.0pt'>dtn@ietf.org</span></a><span style='font-size:12.0pt'> </span><a href="https://gcc02.safelinks.protection.outlook.com/?url=https%3A%2F%2Furldefense.us%2Fv3%2F__https%3A%2Fwww.ietf.org%2Fmailman%2Flistinfo%2Fdtn__%3B!!PvBDto6Hs4WbVuu7!epFXV3_S7aEW7PDxgWNBW8LKuki9s1NTL4sa8CVsC2thPyLbcOdehXgutIckCym6WUzbi2bq%24&data=04%7C01%7Crachid.chaoua%40nasa.gov%7C5d5bb21035074c676e4608da11db3786%7C7005d45845be48ae8140d43da96dd17b%7C0%7C0%7C637841930483903637%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000&sdata=k%2F3uv%2B8kTA25lenkOtDhpbQxi43lX30qVx%2BdyjkZHVk%3D&reserved=0"><span style='font-size:12.0pt'>https://www.ietf.org/mailman/listinfo/dtn</span></a><span style='font-size:12.0pt'> </span><span style='font-size:10.0pt;font-family:"Courier New"'>_______________________________________________<br>dtn mailing list</span><u><span style='font-size:12.0pt;color:blue'><br></span></u><a href="mailto:dtn@ietf.org"><span style='font-size:10.0pt;font-family:"Courier New"'>dtn@ietf.org</span></a><u><span style='font-size:12.0pt;color:blue'><br></span></u><a href="https://gcc02.safelinks.protection.outlook.com/?url=https%3A%2F%2Furldefense.us%2Fv3%2F__https%3A%2Fwww.ietf.org%2Fmailman%2Flistinfo%2Fdtn__%3B!!PvBDto6Hs4WbVuu7!epFXV3_S7aEW7PDxgWNBW8LKuki9s1NTL4sa8CVsC2thPyLbcOdehXgutIckCym6WUzbi2bq%24&data=04%7C01%7Crachid.chaoua%40nasa.gov%7C5d5bb21035074c676e4608da11db3786%7C7005d45845be48ae8140d43da96dd17b%7C0%7C0%7C637841930483903637%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000&sdata=k%2F3uv%2B8kTA25lenkOtDhpbQxi43lX30qVx%2BdyjkZHVk%3D&reserved=0"><span style='font-size:10.0pt;font-family:"Courier New"'>https://www.ietf.org/mailman/listinfo/dtn</span></a><o:p></o:p></p><p style='margin:0in'><span style='font-size:12.0pt'>_______________________________________________ SIS-DTN mailing list </span><a href="mailto:SIS-DTN@mailman.ccsds.org"><span style='font-size:12.0pt'>SIS-DTN@mailman.ccsds.org</span></a><span style='font-size:12.0pt'> </span><a href="https://gcc02.safelinks.protection.outlook.com/?url=https%3A%2F%2Furldefense.us%2Fv3%2F__https%3A%2Fmailman.ccsds.org%2Fcgi-bin%2Fmailman%2Flistinfo%2Fsis-dtn__%3B!!PvBDto6Hs4WbVuu7!epFXV3_S7aEW7PDxgWNBW8LKuki9s1NTL4sa8CVsC2thPyLbcOdehXgutIckCym6Wcylx8mv%24&data=04%7C01%7Crachid.chaoua%40nasa.gov%7C5d5bb21035074c676e4608da11db3786%7C7005d45845be48ae8140d43da96dd17b%7C0%7C0%7C637841930483903637%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000&sdata=gkjxxJBrXxMT2YODEHEErMPPkwa0WmljSO7Y4Z%2Bcius%3D&reserved=0"><span style='font-size:12.0pt'>https://mailman.ccsds.org/cgi-bin/mailman/listinfo/sis-dtn</span></a><span style='font-size:12.0pt'> </span><tt><span style='font-size:10.0pt'>_______________________________________________</span></tt><span style='font-size:10.0pt;font-family:"Courier New"'><br><tt>dtn mailing list</tt><br><tt>dtn@ietf.org</tt><br></span><a href="https://www.ietf.org/mailman/listinfo/dtn"><tt><span style='font-size:10.0pt'>https://www.ietf.org/mailman/listinfo/dtn</span></tt></a><o:p></o:p></p></div></body></html>