diff options
author | Cong Wang <xiyou.wangcong@gmail.com> | 2018-12-30 23:43:42 +0300 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2019-01-09 19:14:44 +0300 |
commit | e553166251bfd189758f3da6ba540ebdc32ac917 (patch) | |
tree | d98627dd3f93e739569f9a60b2ed330b31336d47 /include | |
parent | 41783853bd1a62045c2474a3ab9f1682d5e470d8 (diff) | |
download | linux-e553166251bfd189758f3da6ba540ebdc32ac917.tar.xz |
ptr_ring: wrap back ->producer in __ptr_ring_swap_queue()
[ Upstream commit aff6db454599d62191aabc208930e891748e4322 ]
__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: 5d49de532002 ("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>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'include')
-rw-r--r-- | include/linux/ptr_ring.h | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/include/linux/ptr_ring.h b/include/linux/ptr_ring.h index e8b12b79a0de..dc396196585a 100644 --- a/include/linux/ptr_ring.h +++ b/include/linux/ptr_ring.h @@ -551,6 +551,8 @@ static inline void **__ptr_ring_swap_queue(struct ptr_ring *r, void **queue, else if (destroy) destroy(ptr); + if (producer >= size) + producer = 0; __ptr_ring_set_size(r, size); r->producer = producer; r->consumer_head = 0; |