Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp1716147pxj; Fri, 21 May 2021 23:38:27 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxDvAPPKew+54QC3EzEUhKj8R/mec+7RTdBZ/gVAmqHDNLGN7KDKBNqAL1ujK3sXwrwoH+P X-Received: by 2002:a50:f388:: with SMTP id g8mr14784263edm.236.1621665507554; Fri, 21 May 2021 23:38:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1621665507; cv=none; d=google.com; s=arc-20160816; b=jKCxg0Bu6ZdNeNRdjrdf5aPx05E1Q/umFen0MxggIr03ZuhphsSFUaVgvP/b8tVZYp 2wYhhJjYTlzGR4bpegia3biebWSMs5IdS3bt7WYnWHSbaJ5R2IZd7OJrNcnSjpLeN4Tp +L6m0Mnp5EFkflx/X/hG3ZHO8ODt3LCdkqETRsBYq4Xv3LJTJ0+6yTixCCk1X6W785Wn QEoZ0CwYBjgND3k4F7g7g9cV7lqZtratjCqPp69c09ygmR3sJAjCQ033fUGa8dK2j7SZ b+xMg8O9DEJYsZ2Go+e2y2TgqtOtlgBhmBXJ+3pm1kN4/uaz0HHrhil5a0iPuNTAUOcQ SOyg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date; bh=QVtzUcWT8sVNK0pY56zfNKAirb2RC6eBzB8djp3s4hE=; b=zLQwpFX+ag+CSamu5sbWvnMZRvEh/mqkJwBpfkJG77zYFjb0jnXZefnOyKSawhrEOY HCciP7/sk9zs4QtO9v98eC+ZeAU8hNcmTkdCFmH3QtF6BxZcne7JabnLPQdOtdt1fAqb PBOQt4s5rPjRih4am4NwBZni8BkdIsLG5F3WNM3TUFMGJuKfDI0Xogjbm70B2tqXqWoa rcF3AS0HPzK7m2bVtYZAswQppbMWhm6G7YiXjwOtO9qh1tNEc3I7jKYyRmLHqWi9ihn2 2Q/D5c3dmoSQjDC7foPjctHe+MldwVSEGCsqozmEgcd8Qa+tAMsk7qee2DMnOXW9ToTO X7tg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id g3si7505834ejf.16.2021.05.21.23.37.50; Fri, 21 May 2021 23:38:27 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229874AbhEVGfd (ORCPT + 99 others); Sat, 22 May 2021 02:35:33 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59102 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229781AbhEVGfc (ORCPT ); Sat, 22 May 2021 02:35:32 -0400 Received: from zeniv-ca.linux.org.uk (zeniv-ca.linux.org.uk [IPv6:2607:5300:60:148a::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 72520C061574 for ; Fri, 21 May 2021 23:34:08 -0700 (PDT) Received: from viro by zeniv-ca.linux.org.uk with local (Exim 4.94.2 #2 (Red Hat Linux)) id 1lkLCh-00HMua-KY; Sat, 22 May 2021 06:33:43 +0000 Date: Sat, 22 May 2021 06:33:43 +0000 From: Al Viro To: Nguyen Dinh Phi Cc: nsaenz@kernel.org, gregkh@linuxfoundation.org, stefan.wahren@i2se.com, arnd@arndb.de, dan.carpenter@oracle.com, phil@raspberrypi.com, amarjargal16@gmail.com, bcm-kernel-feedback-list@broadcom.com, linux-rpi-kernel@lists.infradead.org, linux-arm-kernel@lists.infradead.org, linux-staging@lists.linux.dev, linux-kernel@vger.kernel.org Subject: Re: [PATCH] staging: vchiq_arm: Using copy_from_user() to copy data from userspace address Message-ID: References: <20210522053429.82710-1-phind.uet@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20210522053429.82710-1-phind.uet@gmail.com> Sender: Al Viro Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sat, May 22, 2021 at 01:34:29PM +0800, Nguyen Dinh Phi wrote: > This commit to fix the following sparse warning: > incorrect type in assignment (different address spaces) > expected void *[assigned] userdata > got void [noderef] __user *userdata > > Signed-off-by: Nguyen Dinh Phi > --- > .../staging/vc04_services/interface/vchiq_arm/vchiq_arm.c | 5 ++++- > 1 file changed, 4 insertions(+), 1 deletion(-) > > diff --git a/drivers/staging/vc04_services/interface/vchiq_arm/vchiq_arm.c b/drivers/staging/vc04_services/interface/vchiq_arm/vchiq_arm.c > index afbf01b7364c..2a4fc599f977 100644 > --- a/drivers/staging/vc04_services/interface/vchiq_arm/vchiq_arm.c > +++ b/drivers/staging/vc04_services/interface/vchiq_arm/vchiq_arm.c > @@ -960,7 +960,10 @@ static int vchiq_irq_queue_bulk_tx_rx(struct vchiq_instance *instance, > current->pid); > userdata = &waiter->bulk_waiter; > } else { > - userdata = args->userdata; > + if (copy_from_user(userdata, args->userdata, sizeof(args->userdata))) { The contents of userdata (local variable of type void *) is uninitialized at that point. Just what do you think that call of copy_from_user() would do?