lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [day] [month] [year] [list]
Message-ID: <202006182330.gdBW6ihA%lkp@intel.com>
Date:   Thu, 18 Jun 2020 23:53:33 +0800
From:   kernel test robot <lkp@...el.com>
To:     Jack Xiao <Jack.Xiao@....com>
Cc:     kbuild-all@...ts.01.org, linux-kernel@...r.kernel.org,
        Alex Deucher <alexander.deucher@....com>
Subject: drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:999:32: sparse: sparse:
 cast to restricted __le32

tree:   https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git master
head:   1b5044021070efa3259f3e9548dc35d1eb6aa844
commit: 6698a3d05fda57f37add68c55a0696bfa7100413 drm/amdgpu: add mcbp unit test in debugfs (v3)
date:   12 months ago
config: riscv-randconfig-s032-20200618 (attached as .config)
compiler: riscv64-linux-gcc (GCC) 9.3.0
reproduce:
        # apt-get install sparse
        # sparse version: v0.6.2-rc1-10-gc17b1b06-dirty
        git checkout 6698a3d05fda57f37add68c55a0696bfa7100413
        # save the attached .config to linux build tree
        make W=1 C=1 ARCH=riscv CF='-fdiagnostic-prefix -D__CHECK_ENDIAN__'

If you fix the issue, kindly add following tag as appropriate
Reported-by: kernel test robot <lkp@...el.com>


sparse warnings: (new ones prefixed by >>)

   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:163:29: sparse: sparse: cast removes address space '<asn:1>' of expression
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:163:29: sparse: sparse: cast removes address space '<asn:1>' of expression
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:163:29: sparse: sparse: incorrect type in initializer (different address spaces) @@     expected unsigned int [noderef] <asn:1> *__p @@     got unsigned int [usertype] * @@
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:163:29: sparse:     expected unsigned int [noderef] <asn:1> *__p
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:163:29: sparse:     got unsigned int [usertype] *
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:165:29: sparse: sparse: cast removes address space '<asn:1>' of expression
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:165:29: sparse: sparse: cast removes address space '<asn:1>' of expression
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:165:29: sparse: sparse: incorrect type in initializer (different address spaces) @@     expected unsigned int const [noderef] <asn:1> *__p @@     got unsigned int [usertype] * @@
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:165:29: sparse:     expected unsigned int const [noderef] <asn:1> *__p
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:165:29: sparse:     got unsigned int [usertype] *
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:240:21: sparse: sparse: cast removes address space '<asn:1>' of expression
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:240:21: sparse: sparse: cast removes address space '<asn:1>' of expression
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:240:21: sparse: sparse: incorrect type in initializer (different address spaces) @@     expected unsigned int [noderef] <asn:1> *__p @@     got unsigned int [usertype] * @@
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:240:21: sparse:     expected unsigned int [noderef] <asn:1> *__p
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:240:21: sparse:     got unsigned int [usertype] *
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:278:21: sparse: sparse: cast removes address space '<asn:1>' of expression
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:278:21: sparse: sparse: cast removes address space '<asn:1>' of expression
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:278:21: sparse: sparse: incorrect type in initializer (different address spaces) @@     expected unsigned int const [noderef] <asn:1> *__p @@     got unsigned int [usertype] * @@
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:278:21: sparse:     expected unsigned int const [noderef] <asn:1> *__p
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:278:21: sparse:     got unsigned int [usertype] *
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:319:21: sparse: sparse: cast removes address space '<asn:1>' of expression
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:319:21: sparse: sparse: cast removes address space '<asn:1>' of expression
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:319:21: sparse: sparse: incorrect type in initializer (different address spaces) @@     expected unsigned int [noderef] <asn:1> *__p @@     got unsigned int [usertype] * @@
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:319:21: sparse:     expected unsigned int [noderef] <asn:1> *__p
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:319:21: sparse:     got unsigned int [usertype] *
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:357:21: sparse: sparse: cast removes address space '<asn:1>' of expression
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:357:21: sparse: sparse: cast removes address space '<asn:1>' of expression
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:357:21: sparse: sparse: incorrect type in initializer (different address spaces) @@     expected unsigned int const [noderef] <asn:1> *__p @@     got unsigned int [usertype] * @@
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:357:21: sparse:     expected unsigned int const [noderef] <asn:1> *__p
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:357:21: sparse:     got unsigned int [usertype] *
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:398:21: sparse: sparse: cast removes address space '<asn:1>' of expression
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:398:21: sparse: sparse: cast removes address space '<asn:1>' of expression
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:398:21: sparse: sparse: incorrect type in initializer (different address spaces) @@     expected unsigned int [noderef] <asn:1> *__p @@     got unsigned int [usertype] * @@
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:398:21: sparse:     expected unsigned int [noderef] <asn:1> *__p
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:398:21: sparse:     got unsigned int [usertype] *
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:436:21: sparse: sparse: cast removes address space '<asn:1>' of expression
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:436:21: sparse: sparse: cast removes address space '<asn:1>' of expression
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:436:21: sparse: sparse: incorrect type in initializer (different address spaces) @@     expected unsigned int const [noderef] <asn:1> *__p @@     got unsigned int [usertype] * @@
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:436:21: sparse:     expected unsigned int const [noderef] <asn:1> *__p
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:436:21: sparse:     got unsigned int [usertype] *
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:525:21: sparse: sparse: cast removes address space '<asn:1>' of expression
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:525:21: sparse: sparse: cast removes address space '<asn:1>' of expression
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:525:21: sparse: sparse: incorrect type in initializer (different address spaces) @@     expected unsigned int [noderef] <asn:1> *__p @@     got unsigned int [usertype] * @@
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:525:21: sparse:     expected unsigned int [noderef] <asn:1> *__p
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:525:21: sparse:     got unsigned int [usertype] *
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:582:29: sparse: sparse: cast removes address space '<asn:1>' of expression
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:582:29: sparse: sparse: cast removes address space '<asn:1>' of expression
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:582:29: sparse: sparse: incorrect type in initializer (different address spaces) @@     expected signed int [noderef] <asn:1> *__p @@     got signed int [usertype] * @@
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:582:29: sparse:     expected signed int [noderef] <asn:1> *__p
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:582:29: sparse:     got signed int [usertype] *
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:650:21: sparse: sparse: cast removes address space '<asn:1>' of expression
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:650:21: sparse: sparse: cast removes address space '<asn:1>' of expression
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:650:21: sparse: sparse: incorrect type in initializer (different address spaces) @@     expected unsigned int [noderef] <asn:1> *__p @@     got unsigned int [usertype] * @@
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:650:21: sparse:     expected unsigned int [noderef] <asn:1> *__p
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:650:21: sparse:     got unsigned int [usertype] *
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:729:21: sparse: sparse: cast removes address space '<asn:1>' of expression
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:729:21: sparse: sparse: cast removes address space '<asn:1>' of expression
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:729:21: sparse: sparse: incorrect type in initializer (different address spaces) @@     expected unsigned int [noderef] <asn:1> *__p @@     got unsigned int [usertype] * @@
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:729:21: sparse:     expected unsigned int [noderef] <asn:1> *__p
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:729:21: sparse:     got unsigned int [usertype] *
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:942:25: sparse: sparse: incompatible types in comparison expression (different address spaces):
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:942:25: sparse:    struct dma_fence [noderef] <asn:4> *
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:942:25: sparse:    struct dma_fence *
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:943:17: sparse: sparse: incompatible types in comparison expression (different address spaces):
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:943:17: sparse:    struct dma_fence [noderef] <asn:4> *
   drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:943:17: sparse:    struct dma_fence *
>> drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c:999:32: sparse: sparse: cast to restricted __le32

vim +999 drivers/gpu/drm/amd/amdgpu/amdgpu_debugfs.c

   980	
   981	static int amdgpu_debugfs_ib_preempt(void *data, u64 val)
   982	{
   983		int r, resched, length;
   984		struct amdgpu_ring *ring;
   985		struct drm_sched_job *s_job;
   986		struct amdgpu_job *job;
   987		struct dma_fence **fences = NULL;
   988		struct amdgpu_device *adev = (struct amdgpu_device *)data;
   989	
   990		if (val >= AMDGPU_MAX_RINGS)
   991			return -EINVAL;
   992	
   993		ring = adev->rings[val];
   994	
   995		if (!ring || !ring->funcs->preempt_ib || !ring->sched.thread)
   996			return -EINVAL;
   997	
   998		/* the last preemption failed */
 > 999		if (ring->trail_seq != le32_to_cpu(*ring->trail_fence_cpu_addr))
  1000			return -EBUSY;
  1001	
  1002		length = ring->fence_drv.num_fences_mask + 1;
  1003		fences = kcalloc(length, sizeof(void *), GFP_KERNEL);
  1004		if (!fences)
  1005			return -ENOMEM;
  1006	
  1007		/* stop the scheduler */
  1008		kthread_park(ring->sched.thread);
  1009	
  1010		resched = ttm_bo_lock_delayed_workqueue(&adev->mman.bdev);
  1011	
  1012		/* preempt the IB */
  1013		r = amdgpu_ring_preempt_ib(ring);
  1014		if (r) {
  1015			DRM_WARN("failed to preempt ring %d\n", ring->idx);
  1016			goto failure;
  1017		}
  1018	
  1019		amdgpu_fence_process(ring);
  1020	
  1021		if (atomic_read(&ring->fence_drv.last_seq) !=
  1022		    ring->fence_drv.sync_seq) {
  1023			DRM_INFO("ring %d was preempted\n", ring->idx);
  1024	
  1025			/* swap out the old fences */
  1026			amdgpu_ib_preempt_fences_swap(ring, fences);
  1027	
  1028			amdgpu_fence_driver_force_completion(ring);
  1029	
  1030			s_job = list_first_entry_or_null(
  1031				&ring->sched.ring_mirror_list,
  1032				struct drm_sched_job, node);
  1033			if (s_job) {
  1034				job = to_amdgpu_job(s_job);
  1035				/* mark the job as preempted */
  1036				/* job->preemption_status |=
  1037				   AMDGPU_IB_PREEMPTED; */
  1038			}
  1039	
  1040			/* resubmit unfinished jobs */
  1041			amdgpu_ib_preempt_job_recovery(&ring->sched);
  1042	
  1043			/* wait for jobs finished */
  1044			amdgpu_fence_wait_empty(ring);
  1045	
  1046			/* signal the old fences */
  1047			amdgpu_ib_preempt_signal_fences(fences, length);
  1048		}
  1049	
  1050	failure:
  1051		/* restart the scheduler */
  1052		kthread_unpark(ring->sched.thread);
  1053	
  1054		ttm_bo_unlock_delayed_workqueue(&adev->mman.bdev, resched);
  1055	
  1056		if (fences)
  1057			kfree(fences);
  1058	
  1059		return 0;
  1060	}
  1061	

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

Download attachment ".config.gz" of type "application/gzip" (31254 bytes)

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ