Re: [dtn] [Last-Call] [EXTERNAL] Re: Genart last call review of draft-ietf-dtn-bpbis-17

Laurence Lundblade <> Fri, 08 November 2019 22:04 UTC

Return-Path: <>
Received: from localhost (localhost []) by (Postfix) with ESMTP id 8D65A120255 for <>; Fri, 8 Nov 2019 14:04:33 -0800 (PST)
X-Virus-Scanned: amavisd-new at
X-Spam-Flag: NO
X-Spam-Score: -1.897
X-Spam-Status: No, score=-1.897 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, HTML_MESSAGE=0.001, RCVD_IN_DNSWL_NONE=-0.0001, SPF_HELO_NONE=0.001, SPF_NONE=0.001] autolearn=unavailable autolearn_force=no
Received: from ([]) by localhost ( []) (amavisd-new, port 10024) with ESMTP id XY9sQGIaaeao for <>; Fri, 8 Nov 2019 14:04:31 -0800 (PST)
Received: from ( []) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by (Postfix) with ESMTPS id AA4D412022D for <>; Fri, 8 Nov 2019 14:04:31 -0800 (PST)
Received: from [] ([]) by :SMTPAUTH: with ESMTPA id TCMmiAs4zrk1WTCMniKFAD; Fri, 08 Nov 2019 15:04:29 -0700
From: Laurence Lundblade <>
Message-Id: <>
Content-Type: multipart/alternative; boundary="Apple-Mail=_4C319A18-5087-452F-87FC-94CB69D499A5"
Mime-Version: 1.0 (Mac OS X Mail 12.4 \(3445.104.11\))
Date: Fri, 8 Nov 2019 14:04:28 -0800
In-Reply-To: <>
Cc: "Burleigh, Scott C (US 312B)" <>, Magnus Westerlund <>, "" <>, "" <>, "" <>, "" <>, Stewart Bryant <>, "" <>
To: Joe Touch <>
References: <> <> <> <> <> <> <>
X-Mailer: Apple Mail (2.3445.104.11)
X-CMAE-Envelope: MS4wfBS3mv7F01KR2BzyZEGOJ5T8BDKYm9rTKH2v8dV2W7o3Lw44ivwKmc+1aBPJwwf47wA4qmJnIlTIV4Lzq7yhXJyj6cFgSqObylTPc6SBx19HhY4zfb78 UIdG+h9R0uGfXy8S3I7LZQL2x+6stIIMdao0x9pp1ClZ+ZqfVqipR+js2IsGGt78efc8VGUXVFJUSPiQBkq3hwKolWx+xLCbfIfIX/AxLA8RwIugE8gZ3gTw K56vcjTZmuXkYaKObYZcaAFOq+fAmt6oUnX+jV5DDysQakE+UgkekmNZC8cf6f1kIz0+mMY96LiobiKGKJMX94tUMrGe/WSlsPF/91SsXBgZ5+ZXWMaEuCxo C0vcS2NTUBMEQN+CE4YbfW/Bg8x1g17ZYSNRyXubN7zdyAN5uOlYBFcsJuP6sq8fAeuFVJ4Wo7Lq/dWOblCrjePSMXTFpB8xISG1ADBNpUg0URR5mspZF5TX aTQgfScmDHx3x47b
Archived-At: <>
Subject: Re: [dtn] [Last-Call] [EXTERNAL] Re: Genart last call review of draft-ietf-dtn-bpbis-17
X-Mailman-Version: 2.1.29
Precedence: list
List-Id: "Delay Tolerant Networking \(DTN\) discussion list at the IETF." <>
List-Unsubscribe: <>, <>
List-Archive: <>
List-Post: <>
List-Help: <>
List-Subscribe: <>, <>
X-List-Received-Date: Fri, 08 Nov 2019 22:04:34 -0000

CBORbis defines an “Epoch-based Date/Time” here <> making normative reference to Posix time with a brief discussion of leap seconds, positive and negative values and number of bits.

(I’m not familiar with draft-ietf-dtn-bpbis-xxm, just saw the time discussion and thought it might be of use)


> On Nov 8, 2019, at 7:40 AM, Joe Touch <> wrote:
> Unix time != the Posix time API. One is a time scale; the other is the interface to obtain potentially many different time scales.
> I dove into these issues here: draft-touch-time
> Joe
>> On Nov 8, 2019, at 7:34 AM, Burleigh, Scott C (US 312B) < <>> wrote:
>> I disagree.  From Wikipedia:
>> Unix time (also known as Epoch time, POSIX time,[1] <> seconds since the Epoch,[2] <> or UNIX Epoch time[3] <>) is a system for describing a point in time <>. It is the number of seconds <> that have elapsed since the Unix epoch, that is the time 00:00:00 UTC <> on 1 January 1970, minus leap seconds <>. Leap seconds are ignored,[4] <> with a leap second having the same Unix time as the second before it, and every day is treated as if it contains exactly 86400 seconds.[2] <> Due to this treatment Unix time is not a true representation of UTC.
>> Now, of course, this is Wikipedia, which everyone knows to be useless and unreliable.  But the summary is at least concise and clear, and in this particular case it is supported by several source documents, noted at the bottom of the article.
>> For example, “The Open Group Base Specifications Issue 7, Rationale: Base Definitions”, section A.4 (General Concepts) says “Coordinated Universal Time (UTC) includes leap seconds. However, in POSIX time (seconds since the Epoch), leap seconds are ignored(not applied) to provide an easy and compatible method of computing time differences.”
>> Going back a bit, page 166 of <> Dennis and Ritchie (who ought to know) say “Time returns the time since 00:00:00 GMT, Jan. 1, 1970, measured in seconds.”
>> I am happy to agree that an operating system’s implementation of the time() function may typically obtain accurate UTC time (from GPS or NTP) and subtract the leap seconds out of that value to obtain Epoch time, and in this sense the implementation of the time() function is typically dependent on information about leap seconds.
>> But that is an implementation expedient, which BP does not care about.  What BP cares about is expressing time as a number of seconds that have elapsed since the Epoch (minus an offset, the number of seconds elapsed from the Epoch to midnight 1 January 2000 UTC).  The manner in which that value is generated doesn’t matter to the protocol.
>> Scott
>> From: Stewart Bryant < <>> 
>> Sent: Friday, November 8, 2019 6:33 AM
>> To: <>
>> Cc: Magnus Westerlund < <>>; <>; <>; <>; <>
>> Subject: [EXTERNAL] Re: [Last-Call] Genart last call review of draft-ietf-dtn-bpbis-17
>> On 8 Nov 2019, at 13:03, <> wrote:
>> <>
>> The critical text in that paper is:
>> "The Bundle Protocol uses Coordinated Universal Time (UTC), where leap seconds are added at irregular, unpredictable, intervals to reflect slowing of the Earth’s rotation. For nodes ‘in the field’ for a long time (decades), some way of communicating newly-decided UTC leap seconds will be required to prevent clock drift over long time scales that would eventually lead to bundles expiring before delivery. This is most likely to be a significant issue for real-time traffic with very short bundle lifetimes."
>> That says that leap-seconds need to be transmitted to the remote site, but the ID does not say anything about that, indeed it silently implies that this is handled.
>> The draft text says
>> Like TAI, Unix epoch time
>>    is simply a count of seconds elapsed since a standard epoch.  Unlike
>>    TAI, the current value of Unix epoch time is provided by virtually
>>    all operating systems on which BP is likely to run.
>> Which is not quite right. The TAI is a continuous count of the number of seconds since the epoch. The UNIX tine is the continuous count + leap seconds since the epoch. Unix knows how many leap seconds have happened by a background process and adds them in, but for that to work it has to have a method of knowing the current leap second state. BTW leap seconds can be removed as well as added.
>> - Stewart
>> -- 
>> last-call mailing list
>> <>
>> <>
> -- 
> last-call mailing list