From: Sabrina Dubroca Date: Sun, 31 Dec 2017 15:18:56 +0000 (+0100) Subject: xfrm: fix rcu usage in xfrm_get_type_offload X-Git-Tag: v4.15-rc9~33^2~26^2~6 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=2f10a61cee8fdb9f8da90f5db687e1862b22cf06;p=thirdparty%2Fkernel%2Flinux.git xfrm: fix rcu usage in xfrm_get_type_offload request_module can sleep, thus we cannot hold rcu_read_lock() while calling it. The function also jumps back and takes rcu_read_lock() again (in xfrm_state_get_afinfo()), resulting in an imbalance. This codepath is triggered whenever a new offloaded state is created. Fixes: ffdb5211da1c ("xfrm: Auto-load xfrm offload modules") Reported-by: syzbot+ca425f44816d749e8eb49755567a75ee48cf4a30@syzkaller.appspotmail.com Signed-off-by: Sabrina Dubroca Signed-off-by: Steffen Klassert --- diff --git a/net/xfrm/xfrm_state.c b/net/xfrm/xfrm_state.c index 1e80f68e22666..4299574126338 100644 --- a/net/xfrm/xfrm_state.c +++ b/net/xfrm/xfrm_state.c @@ -313,13 +313,14 @@ retry: if ((type && !try_module_get(type->owner))) type = NULL; + rcu_read_unlock(); + if (!type && try_load) { request_module("xfrm-offload-%d-%d", family, proto); try_load = 0; goto retry; } - rcu_read_unlock(); return type; }