From: Mathias Krause Date: Wed, 20 Mar 2013 21:59:11 +0000 (+0100) Subject: xfrm: Fix esn sequence number diff calculation in xfrm_replay_notify_esn() X-Git-Tag: upstream/snapshot3+hdmi~5426^2~22^2 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=799ef90c55e692e096d8bd9e5871b95264b1e9ba;p=platform%2Fadaptation%2Frenesas_rcar%2Frenesas_kernel.git xfrm: Fix esn sequence number diff calculation in xfrm_replay_notify_esn() Commit 0017c0b "xfrm: Fix replay notification for esn." is off by one for the sequence number wrapped case as UINT_MAX is 0xffffffff, not 0x100000000. ;) Just calculate the diff like done everywhere else in the file. Signed-off-by: Mathias Krause Signed-off-by: Steffen Klassert --- diff --git a/net/xfrm/xfrm_replay.c b/net/xfrm/xfrm_replay.c index a390673..8dafe6d3 100644 --- a/net/xfrm/xfrm_replay.c +++ b/net/xfrm/xfrm_replay.c @@ -359,14 +359,12 @@ static void xfrm_replay_notify_esn(struct xfrm_state *x, int event) if (replay_esn->seq_hi == preplay_esn->seq_hi) seq_diff = replay_esn->seq - preplay_esn->seq; else - seq_diff = UINT_MAX - preplay_esn->seq - + replay_esn->seq; + seq_diff = ~preplay_esn->seq + replay_esn->seq + 1; if (replay_esn->oseq_hi == preplay_esn->oseq_hi) oseq_diff = replay_esn->oseq - preplay_esn->oseq; else - oseq_diff = UINT_MAX - preplay_esn->oseq - + replay_esn->oseq; + oseq_diff = ~preplay_esn->oseq + replay_esn->oseq + 1; if (seq_diff < x->replay_maxdiff && oseq_diff < x->replay_maxdiff) {