]> git.baikalelectronics.ru Git - kernel.git/commit
ptr_ring: wrap back ->producer in __ptr_ring_swap_queue()
authorCong Wang <xiyou.wangcong@gmail.com>
Sun, 30 Dec 2018 20:43:42 +0000 (12:43 -0800)
committerDavid S. Miller <davem@davemloft.net>
Tue, 1 Jan 2019 19:58:33 +0000 (11:58 -0800)
commit3ee356ae16e9565e12665b8dfffc752432e911e1
tree1c26fd35a8fc7540bb81ca60fe96251c74e71b36
parenta476285b33de37e70d0c04275fd7996f66c23576
ptr_ring: wrap back ->producer in __ptr_ring_swap_queue()

__ptr_ring_swap_queue() tries to move pointers from the old
ring to the new one, but it forgets to check if ->producer
is beyond the new size at the end of the operation. This leads
to an out-of-bound access in __ptr_ring_produce() as reported
by syzbot.

Reported-by: syzbot+8993c0fa96d57c399735@syzkaller.appspotmail.com
Fixes: 500513cc606b ("ptr_ring: resize support")
Cc: "Michael S. Tsirkin" <mst@redhat.com>
Cc: John Fastabend <john.fastabend@gmail.com>
Cc: Jason Wang <jasowang@redhat.com>
Signed-off-by: Cong Wang <xiyou.wangcong@gmail.com>
Acked-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
include/linux/ptr_ring.h