On 01/23/2018 04:50 PM, Eric Dumazet wrote:
> On Mon, 2018-01-22 at 22:53 -0800, Yonghong Song wrote:
>> In commit b471f2f1de8b ("bpf: implement MAP_GET_NEXT_KEY command for 
>> LPM_TRIE map"),
>> the implemented MAP_GET_NEXT_KEY callback function is guarded with rcu read 
>> lock.
>> In the function body, "kmalloc(size, GFP_USER | __GFP_NOWARN)" is used which 
>> may
>> sleep and violate rcu read lock region requirements. This patch fixed the 
>> issue
>> by using GFP_ATOMIC instead to avoid blocking kmalloc. Tested with
>> CONFIG_DEBUG_ATOMIC_SLEEP=y as suggested by Eric Dumazet.
>>
>> Fixes: b471f2f1de8b ("bpf: implement MAP_GET_NEXT_KEY command for LPM_TRIE 
>> map")
>> Signed-off-by: Yonghong Song <y...@fb.com>
> 
> Reported-by: syzbot <syzkal...@googlegroups.com>
> Reviewed-by: Eric Dumazet <eduma...@google.com>

Applied to bpf-next, thanks everyone!

Reply via email to