From mboxrd@z Thu Jan 1 00:00:00 1970 From: Christian Borntraeger Subject: Re: [PATCH] macvtap: fix TUNSETSNDBUF values > 64k Date: Fri, 18 Sep 2015 12:49:07 +0200 Message-ID: <55FBEC23.8080409@de.ibm.com> References: <1442572808-6438-1-git-send-email-mst@redhat.com> Mime-Version: 1.0 Content-Type: text/plain; charset=windows-1252 Content-Transfer-Encoding: 7bit Cc: "David S. Miller" , Matthew Rosato , Al Viro , Jason Wang , David Gibson , Greg Kurz , Vlad Yasevich , Justin Cormack , Herbert Xu , netdev@vger.kernel.org, Matthew Rosato To: "Michael S. Tsirkin" , linux-kernel@vger.kernel.org Return-path: In-Reply-To: <1442572808-6438-1-git-send-email-mst@redhat.com> Sender: linux-kernel-owner@vger.kernel.org List-Id: netdev.vger.kernel.org Am 18.09.2015 um 12:41 schrieb Michael S. Tsirkin: > Upon TUNSETSNDBUF, macvtap reads the requested sndbuf size into > a local variable u. > commit 39ec7de7092b ("macvtap: fix uninitialized access on > TUNSETIFF") changed its type to u16 (which is the right thing to > do for all other macvtap ioctls), breaking all values > 64k. > > The value of TUNSETSNDBUF is actually a signed 32 bit integer, so > the right thing to do is to read it into an int. > > Cc: David S. Miller > Fixes: 39ec7de7092b ("macvtap: fix uninitialized access on TUNSETIFF") > Reported-by: Mark A. Peloquin > Bisected-by: Matthew Rosato > Reported-by: Christian Borntraeger > Signed-off-by: Michael S. Tsirkin You can add Tested-by: Matthew Rosato as this looks identical to an early version of my patch which was tested, by Matt. (I send you the other version that changes back u as I felt that u and up are named to identify unsigned) and please add Acked-by: Christian Borntraeger what about CC: stable@vger.kernel.org Christian > --- > > This patch probably makes sense on stable. > > drivers/net/macvtap.c | 4 ++-- > 1 file changed, 2 insertions(+), 2 deletions(-) > > diff --git a/drivers/net/macvtap.c b/drivers/net/macvtap.c > index edd7734..248478c 100644 > --- a/drivers/net/macvtap.c > +++ b/drivers/net/macvtap.c > @@ -1111,10 +1111,10 @@ static long macvtap_ioctl(struct file *file, unsigned int cmd, > return 0; > > case TUNSETSNDBUF: > - if (get_user(u, up)) > + if (get_user(s, sp)) > return -EFAULT; > > - q->sk.sk_sndbuf = u; > + q->sk.sk_sndbuf = s; > return 0; > > case TUNGETVNETHDRSZ: >