[vhost:vhost 32/44] drivers/gpu/drm/virtio/virtgpu_ioctl.c:113:7: error: implicit declaration of function 'copy_from_user'; did you mean 'sg_copy_from_buffer'?

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



tree:   https://git.kernel.org/pub/scm/linux/kernel/git/mst/vhost.git vhost
head:   4e6ebec0de18aaea5f5f814b25bfcae3751c6369
commit: 013a472de94693ba05696d59e7df3224c20a22e6 [32/44] virtio: stop using legacy struct vring in kernel
config: m68k-allmodconfig (attached as .config)
compiler: m68k-linux-gcc (GCC) 9.3.0
reproduce:
        wget https://raw.githubusercontent.com/intel/lkp-tests/master/sbin/make.cross -O ~/bin/make.cross
        chmod +x ~/bin/make.cross
        git checkout 013a472de94693ba05696d59e7df3224c20a22e6
        # save the attached .config to linux build tree
        GCC_VERSION=9.3.0 make.cross ARCH=m68k 

If you fix the issue, kindly add following tag as appropriate
Reported-by: kbuild test robot <lkp@xxxxxxxxx>

All errors (new ones prefixed by >>):

   drivers/gpu/drm/virtio/virtgpu_ioctl.c: In function 'virtio_gpu_execbuffer_ioctl':
>> drivers/gpu/drm/virtio/virtgpu_ioctl.c:113:7: error: implicit declaration of function 'copy_from_user'; did you mean 'sg_copy_from_buffer'? [-Werror=implicit-function-declaration]
     113 |   if (copy_from_user(bo_handles, user_bo_handles,
         |       ^~~~~~~~~~~~~~
         |       sg_copy_from_buffer
   drivers/gpu/drm/virtio/virtgpu_ioctl.c: In function 'virtio_gpu_getparam_ioctl':
>> drivers/gpu/drm/virtio/virtgpu_ioctl.c:196:6: error: implicit declaration of function 'copy_to_user' [-Werror=implicit-function-declaration]
     196 |  if (copy_to_user(u64_to_user_ptr(param->value), &value, sizeof(int)))
         |      ^~~~~~~~~~~~
   cc1: some warnings being treated as errors

vim +113 drivers/gpu/drm/virtio/virtgpu_ioctl.c

62fb7a5e10962a Gerd Hoffmann   2014-10-28   46  
5c32c3dd8501b0 Gustavo Padovan 2016-08-31   47  /*
5c32c3dd8501b0 Gustavo Padovan 2016-08-31   48   * Usage of execbuffer:
5c32c3dd8501b0 Gustavo Padovan 2016-08-31   49   * Relocations need to take into account the full VIRTIO_GPUDrawable size.
5c32c3dd8501b0 Gustavo Padovan 2016-08-31   50   * However, the command as passed from user space must *not* contain the initial
5c32c3dd8501b0 Gustavo Padovan 2016-08-31   51   * VIRTIO_GPUReleaseInfo struct (first XXX bytes)
5c32c3dd8501b0 Gustavo Padovan 2016-08-31   52   */
5c32c3dd8501b0 Gustavo Padovan 2016-08-31   53  static int virtio_gpu_execbuffer_ioctl(struct drm_device *dev, void *data,
62fb7a5e10962a Gerd Hoffmann   2014-10-28   54  				 struct drm_file *drm_file)
62fb7a5e10962a Gerd Hoffmann   2014-10-28   55  {
5c32c3dd8501b0 Gustavo Padovan 2016-08-31   56  	struct drm_virtgpu_execbuffer *exbuf = data;
62fb7a5e10962a Gerd Hoffmann   2014-10-28   57  	struct virtio_gpu_device *vgdev = dev->dev_private;
62fb7a5e10962a Gerd Hoffmann   2014-10-28   58  	struct virtio_gpu_fpriv *vfpriv = drm_file->driver_priv;
2cd7b6f08bc4cf Robert Foss     2018-11-12   59  	struct virtio_gpu_fence *out_fence;
62fb7a5e10962a Gerd Hoffmann   2014-10-28   60  	int ret;
62fb7a5e10962a Gerd Hoffmann   2014-10-28   61  	uint32_t *bo_handles = NULL;
62fb7a5e10962a Gerd Hoffmann   2014-10-28   62  	void __user *user_bo_handles = NULL;
da758d51968a88 Gerd Hoffmann   2019-08-29   63  	struct virtio_gpu_object_array *buflist = NULL;
2cd7b6f08bc4cf Robert Foss     2018-11-12   64  	struct sync_file *sync_file;
2cd7b6f08bc4cf Robert Foss     2018-11-12   65  	int in_fence_fd = exbuf->fence_fd;
2cd7b6f08bc4cf Robert Foss     2018-11-12   66  	int out_fence_fd = -1;
62fb7a5e10962a Gerd Hoffmann   2014-10-28   67  	void *buf;
62fb7a5e10962a Gerd Hoffmann   2014-10-28   68  
62fb7a5e10962a Gerd Hoffmann   2014-10-28   69  	if (vgdev->has_virgl_3d == false)
62fb7a5e10962a Gerd Hoffmann   2014-10-28   70  		return -ENOSYS;
62fb7a5e10962a Gerd Hoffmann   2014-10-28   71  
a56f9c868ccf56 Robert Foss     2018-11-12   72  	if ((exbuf->flags & ~VIRTGPU_EXECBUF_FLAGS))
a56f9c868ccf56 Robert Foss     2018-11-12   73  		return -EINVAL;
a56f9c868ccf56 Robert Foss     2018-11-12   74  
a56f9c868ccf56 Robert Foss     2018-11-12   75  	exbuf->fence_fd = -1;
a56f9c868ccf56 Robert Foss     2018-11-12   76  
2cd7b6f08bc4cf Robert Foss     2018-11-12   77  	if (exbuf->flags & VIRTGPU_EXECBUF_FENCE_FD_IN) {
2cd7b6f08bc4cf Robert Foss     2018-11-12   78  		struct dma_fence *in_fence;
2cd7b6f08bc4cf Robert Foss     2018-11-12   79  
2cd7b6f08bc4cf Robert Foss     2018-11-12   80  		in_fence = sync_file_get_fence(in_fence_fd);
2cd7b6f08bc4cf Robert Foss     2018-11-12   81  
2cd7b6f08bc4cf Robert Foss     2018-11-12   82  		if (!in_fence)
2cd7b6f08bc4cf Robert Foss     2018-11-12   83  			return -EINVAL;
2cd7b6f08bc4cf Robert Foss     2018-11-12   84  
2cd7b6f08bc4cf Robert Foss     2018-11-12   85  		/*
2cd7b6f08bc4cf Robert Foss     2018-11-12   86  		 * Wait if the fence is from a foreign context, or if the fence
2cd7b6f08bc4cf Robert Foss     2018-11-12   87  		 * array contains any fence from a foreign context.
2cd7b6f08bc4cf Robert Foss     2018-11-12   88  		 */
2cd7b6f08bc4cf Robert Foss     2018-11-12   89  		ret = 0;
2cd7b6f08bc4cf Robert Foss     2018-11-12   90  		if (!dma_fence_match_context(in_fence, vgdev->fence_drv.context))
2cd7b6f08bc4cf Robert Foss     2018-11-12   91  			ret = dma_fence_wait(in_fence, true);
2cd7b6f08bc4cf Robert Foss     2018-11-12   92  
2cd7b6f08bc4cf Robert Foss     2018-11-12   93  		dma_fence_put(in_fence);
2cd7b6f08bc4cf Robert Foss     2018-11-12   94  		if (ret)
2cd7b6f08bc4cf Robert Foss     2018-11-12   95  			return ret;
2cd7b6f08bc4cf Robert Foss     2018-11-12   96  	}
2cd7b6f08bc4cf Robert Foss     2018-11-12   97  
2cd7b6f08bc4cf Robert Foss     2018-11-12   98  	if (exbuf->flags & VIRTGPU_EXECBUF_FENCE_FD_OUT) {
2cd7b6f08bc4cf Robert Foss     2018-11-12   99  		out_fence_fd = get_unused_fd_flags(O_CLOEXEC);
2cd7b6f08bc4cf Robert Foss     2018-11-12  100  		if (out_fence_fd < 0)
2cd7b6f08bc4cf Robert Foss     2018-11-12  101  			return out_fence_fd;
2cd7b6f08bc4cf Robert Foss     2018-11-12  102  	}
2cd7b6f08bc4cf Robert Foss     2018-11-12  103  
62fb7a5e10962a Gerd Hoffmann   2014-10-28  104  	if (exbuf->num_bo_handles) {
2098105ec65cb3 Michal Hocko    2017-05-17  105  		bo_handles = kvmalloc_array(exbuf->num_bo_handles,
2098105ec65cb3 Michal Hocko    2017-05-17  106  					    sizeof(uint32_t), GFP_KERNEL);
da758d51968a88 Gerd Hoffmann   2019-08-29  107  		if (!bo_handles) {
2cd7b6f08bc4cf Robert Foss     2018-11-12  108  			ret = -ENOMEM;
2cd7b6f08bc4cf Robert Foss     2018-11-12  109  			goto out_unused_fd;
62fb7a5e10962a Gerd Hoffmann   2014-10-28  110  		}
62fb7a5e10962a Gerd Hoffmann   2014-10-28  111  
4b013bb2d3a4a3 Gurchetan Singh 2019-06-04  112  		user_bo_handles = u64_to_user_ptr(exbuf->bo_handles);
62fb7a5e10962a Gerd Hoffmann   2014-10-28 @113  		if (copy_from_user(bo_handles, user_bo_handles,
62fb7a5e10962a Gerd Hoffmann   2014-10-28  114  				   exbuf->num_bo_handles * sizeof(uint32_t))) {
62fb7a5e10962a Gerd Hoffmann   2014-10-28  115  			ret = -EFAULT;
2cd7b6f08bc4cf Robert Foss     2018-11-12  116  			goto out_unused_fd;
62fb7a5e10962a Gerd Hoffmann   2014-10-28  117  		}
62fb7a5e10962a Gerd Hoffmann   2014-10-28  118  
da758d51968a88 Gerd Hoffmann   2019-08-29  119  		buflist = virtio_gpu_array_from_handles(drm_file, bo_handles,
da758d51968a88 Gerd Hoffmann   2019-08-29  120  							exbuf->num_bo_handles);
da758d51968a88 Gerd Hoffmann   2019-08-29  121  		if (!buflist) {
2cd7b6f08bc4cf Robert Foss     2018-11-12  122  			ret = -ENOENT;
2cd7b6f08bc4cf Robert Foss     2018-11-12  123  			goto out_unused_fd;
62fb7a5e10962a Gerd Hoffmann   2014-10-28  124  		}
2098105ec65cb3 Michal Hocko    2017-05-17  125  		kvfree(bo_handles);
2cd7b6f08bc4cf Robert Foss     2018-11-12  126  		bo_handles = NULL;
62fb7a5e10962a Gerd Hoffmann   2014-10-28  127  	}
62fb7a5e10962a Gerd Hoffmann   2014-10-28  128  
da758d51968a88 Gerd Hoffmann   2019-08-29  129  	if (buflist) {
da758d51968a88 Gerd Hoffmann   2019-08-29  130  		ret = virtio_gpu_array_lock_resv(buflist);
62fb7a5e10962a Gerd Hoffmann   2014-10-28  131  		if (ret)
da758d51968a88 Gerd Hoffmann   2019-08-29  132  			goto out_unused_fd;
da758d51968a88 Gerd Hoffmann   2019-08-29  133  	}
62fb7a5e10962a Gerd Hoffmann   2014-10-28  134  
e1218b8c0cc1f8 David Riley     2019-09-11  135  	buf = vmemdup_user(u64_to_user_ptr(exbuf->command), exbuf->size);
7ad61e6b4a79c5 Markus Elfring  2016-08-18  136  	if (IS_ERR(buf)) {
7ad61e6b4a79c5 Markus Elfring  2016-08-18  137  		ret = PTR_ERR(buf);
62fb7a5e10962a Gerd Hoffmann   2014-10-28  138  		goto out_unresv;
62fb7a5e10962a Gerd Hoffmann   2014-10-28  139  	}
9fdd90c0f42440 Robert Foss     2018-11-12  140  
2cd7b6f08bc4cf Robert Foss     2018-11-12  141  	out_fence = virtio_gpu_fence_alloc(vgdev);
2cd7b6f08bc4cf Robert Foss     2018-11-12  142  	if(!out_fence) {
9fdd90c0f42440 Robert Foss     2018-11-12  143  		ret = -ENOMEM;
2cd7b6f08bc4cf Robert Foss     2018-11-12  144  		goto out_memdup;
2cd7b6f08bc4cf Robert Foss     2018-11-12  145  	}
2cd7b6f08bc4cf Robert Foss     2018-11-12  146  
2cd7b6f08bc4cf Robert Foss     2018-11-12  147  	if (out_fence_fd >= 0) {
2cd7b6f08bc4cf Robert Foss     2018-11-12  148  		sync_file = sync_file_create(&out_fence->f);
2cd7b6f08bc4cf Robert Foss     2018-11-12  149  		if (!sync_file) {
2cd7b6f08bc4cf Robert Foss     2018-11-12  150  			dma_fence_put(&out_fence->f);
2cd7b6f08bc4cf Robert Foss     2018-11-12  151  			ret = -ENOMEM;
2cd7b6f08bc4cf Robert Foss     2018-11-12  152  			goto out_memdup;
2cd7b6f08bc4cf Robert Foss     2018-11-12  153  		}
2cd7b6f08bc4cf Robert Foss     2018-11-12  154  
2cd7b6f08bc4cf Robert Foss     2018-11-12  155  		exbuf->fence_fd = out_fence_fd;
2cd7b6f08bc4cf Robert Foss     2018-11-12  156  		fd_install(out_fence_fd, sync_file->file);
9fdd90c0f42440 Robert Foss     2018-11-12  157  	}
2cd7b6f08bc4cf Robert Foss     2018-11-12  158  
62fb7a5e10962a Gerd Hoffmann   2014-10-28  159  	virtio_gpu_cmd_submit(vgdev, buf, exbuf->size,
da758d51968a88 Gerd Hoffmann   2019-08-29  160  			      vfpriv->ctx_id, buflist, out_fence);
62fb7a5e10962a Gerd Hoffmann   2014-10-28  161  	return 0;
62fb7a5e10962a Gerd Hoffmann   2014-10-28  162  
2cd7b6f08bc4cf Robert Foss     2018-11-12  163  out_memdup:
e1218b8c0cc1f8 David Riley     2019-09-11  164  	kvfree(buf);
62fb7a5e10962a Gerd Hoffmann   2014-10-28  165  out_unresv:
da758d51968a88 Gerd Hoffmann   2019-08-29  166  	if (buflist)
da758d51968a88 Gerd Hoffmann   2019-08-29  167  		virtio_gpu_array_unlock_resv(buflist);
2cd7b6f08bc4cf Robert Foss     2018-11-12  168  out_unused_fd:
2cd7b6f08bc4cf Robert Foss     2018-11-12  169  	kvfree(bo_handles);
da758d51968a88 Gerd Hoffmann   2019-08-29  170  	if (buflist)
da758d51968a88 Gerd Hoffmann   2019-08-29  171  		virtio_gpu_array_put_free(buflist);
2cd7b6f08bc4cf Robert Foss     2018-11-12  172  
2cd7b6f08bc4cf Robert Foss     2018-11-12  173  	if (out_fence_fd >= 0)
2cd7b6f08bc4cf Robert Foss     2018-11-12  174  		put_unused_fd(out_fence_fd);
2cd7b6f08bc4cf Robert Foss     2018-11-12  175  
62fb7a5e10962a Gerd Hoffmann   2014-10-28  176  	return ret;
62fb7a5e10962a Gerd Hoffmann   2014-10-28  177  }
62fb7a5e10962a Gerd Hoffmann   2014-10-28  178  
62fb7a5e10962a Gerd Hoffmann   2014-10-28  179  static int virtio_gpu_getparam_ioctl(struct drm_device *dev, void *data,
62fb7a5e10962a Gerd Hoffmann   2014-10-28  180  				     struct drm_file *file_priv)
62fb7a5e10962a Gerd Hoffmann   2014-10-28  181  {
62fb7a5e10962a Gerd Hoffmann   2014-10-28  182  	struct virtio_gpu_device *vgdev = dev->dev_private;
62fb7a5e10962a Gerd Hoffmann   2014-10-28  183  	struct drm_virtgpu_getparam *param = data;
62fb7a5e10962a Gerd Hoffmann   2014-10-28  184  	int value;
62fb7a5e10962a Gerd Hoffmann   2014-10-28  185  
62fb7a5e10962a Gerd Hoffmann   2014-10-28  186  	switch (param->param) {
62fb7a5e10962a Gerd Hoffmann   2014-10-28  187  	case VIRTGPU_PARAM_3D_FEATURES:
62fb7a5e10962a Gerd Hoffmann   2014-10-28  188  		value = vgdev->has_virgl_3d == true ? 1 : 0;
62fb7a5e10962a Gerd Hoffmann   2014-10-28  189  		break;
9a191b11490645 Dave Airlie     2018-02-21  190  	case VIRTGPU_PARAM_CAPSET_QUERY_FIX:
9a191b11490645 Dave Airlie     2018-02-21  191  		value = 1;
9a191b11490645 Dave Airlie     2018-02-21  192  		break;
62fb7a5e10962a Gerd Hoffmann   2014-10-28  193  	default:
62fb7a5e10962a Gerd Hoffmann   2014-10-28  194  		return -EINVAL;
62fb7a5e10962a Gerd Hoffmann   2014-10-28  195  	}
4b013bb2d3a4a3 Gurchetan Singh 2019-06-04 @196  	if (copy_to_user(u64_to_user_ptr(param->value), &value, sizeof(int)))
62fb7a5e10962a Gerd Hoffmann   2014-10-28  197  		return -EFAULT;
4b013bb2d3a4a3 Gurchetan Singh 2019-06-04  198  
62fb7a5e10962a Gerd Hoffmann   2014-10-28  199  	return 0;
62fb7a5e10962a Gerd Hoffmann   2014-10-28  200  }
62fb7a5e10962a Gerd Hoffmann   2014-10-28  201  

:::::: The code at line 113 was first introduced by commit
:::::: 62fb7a5e10962ac6ae2a2d2dbd3aedcb2a3e3257 virtio-gpu: add 3d/virgl support

:::::: TO: Gerd Hoffmann <kraxel@xxxxxxxxxx>
:::::: CC: Gerd Hoffmann <kraxel@xxxxxxxxxx>

---
0-DAY CI Kernel Test Service, Intel Corporation
https://lists.01.org/hyperkitty/list/kbuild-all@xxxxxxxxxxxx

Attachment: .config.gz
Description: application/gzip


[Index of Archives]     [KVM ARM]     [KVM ia64]     [KVM ppc]     [Virtualization Tools]     [Spice Development]     [Libvirt]     [Libvirt Users]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite Questions]     [Linux Kernel]     [Linux SCSI]     [XFree86]

  Powered by Linux