Skip to content

Commit

Permalink
Clarify the safety of NetClock::time_point arithmetic:
Browse files Browse the repository at this point in the history
* NetClock::rep is uint32_t and can be error-prone when
  used with subtraction.
* Fixes #3656
  • Loading branch information
HowardHinnant authored and manojsdoshi committed Mar 17, 2021
1 parent 9d89d4c commit 64e4a89
Show file tree
Hide file tree
Showing 3 changed files with 4 additions and 3 deletions.
2 changes: 1 addition & 1 deletion src/ripple/app/tx/impl/CreateOffer.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -638,7 +638,7 @@ CreateOffer::takerCross(
Sandbox& sbCancel,
Amounts const& takerAmount)
{
NetClock::time_point const when{ctx_.view().parentCloseTime()};
NetClock::time_point const when = ctx_.view().parentCloseTime();

beast::WrappedSink takerSink(j_, "Taker ");

Expand Down
4 changes: 3 additions & 1 deletion src/ripple/consensus/Validations.h
Original file line number Diff line number Diff line change
Expand Up @@ -152,7 +152,9 @@ isCurrent(
// Because this can be called on untrusted, possibly
// malicious validations, we do our math in a way
// that avoids any chance of overflowing or underflowing
// the signing time.
// the signing time. All of the expressions below are
// promoted from unsigned 32 bit to signed 64 bit prior
// to computation.

return (signTime > (now - p.validationCURRENT_EARLY)) &&
(signTime < (now + p.validationCURRENT_WALL)) &&
Expand Down
1 change: 0 additions & 1 deletion src/ripple/overlay/impl/Handshake.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -268,7 +268,6 @@ verifyHandshake(
// We can't blindly "return a-b;" because TimeKeeper::time_point
// uses an unsigned integer for representing durations, which is
// a problem when trying to subtract time points.
// FIXME: @HowardHinnant, should we migrate to using std::int64_t?
auto calculateOffset = [](TimeKeeper::time_point a,
TimeKeeper::time_point b) {
if (a > b)
Expand Down

0 comments on commit 64e4a89

Please sign in to comment.