diff options
author | Antony Antony <antony.antony@secunet.com> | 2020-09-04 08:50:29 +0200 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2020-10-14 09:51:13 +0200 |
commit | 2bb379108c4ad36a761fcf1efaf51bb176b326b3 (patch) | |
tree | dc5c476c43f281725962ef94d706fa27e8d3c3c6 /net/xfrm | |
parent | f0da697e44c5b1410ec6a2aa8aac52eaa4132c19 (diff) | |
download | linux-stable-2bb379108c4ad36a761fcf1efaf51bb176b326b3.tar.gz linux-stable-2bb379108c4ad36a761fcf1efaf51bb176b326b3.tar.bz2 linux-stable-2bb379108c4ad36a761fcf1efaf51bb176b326b3.zip |
xfrm: clone whole liftime_cur structure in xfrm_do_migrate
[ Upstream commit 8366685b2883e523f91e9816d7be371eb1144749 ]
When we clone state only add_time was cloned. It missed values like
bytes, packets. Now clone the all members of the structure.
v1->v3:
- use memcpy to copy the entire structure
Fixes: 80c9abaabf42 ("[XFRM]: Extension for dynamic update of endpoint address(es)")
Signed-off-by: Antony Antony <antony.antony@secunet.com>
Signed-off-by: Steffen Klassert <steffen.klassert@secunet.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
Diffstat (limited to 'net/xfrm')
-rw-r--r-- | net/xfrm/xfrm_state.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/net/xfrm/xfrm_state.c b/net/xfrm/xfrm_state.c index 37104258808a..3f21d34833cf 100644 --- a/net/xfrm/xfrm_state.c +++ b/net/xfrm/xfrm_state.c @@ -1427,7 +1427,7 @@ static struct xfrm_state *xfrm_state_clone(struct xfrm_state *orig, x->tfcpad = orig->tfcpad; x->replay_maxdiff = orig->replay_maxdiff; x->replay_maxage = orig->replay_maxage; - x->curlft.add_time = orig->curlft.add_time; + memcpy(&x->curlft, &orig->curlft, sizeof(x->curlft)); x->km.state = orig->km.state; x->km.seq = orig->km.seq; x->replay = orig->replay; |