[PATCH v7 3/6] drm/sched: Convert the GPU scheduler to variable number of run-queues
Luben Tuikov
luben.tuikov at amd.com
Thu Oct 26 09:39:56 UTC 2023
Also note that there were no complaints from "kernel test robot <lkp at intel.com>"
when I posted my patch (this patch), but there is now, which further shows
that there's unwarranted changes. Just follow the steps I outlined below,
and we should all be good.
Thanks!
Regards,
Luben
On 2023-10-26 05:36, Luben Tuikov wrote:
> Hi,
>
> On 2023-10-26 02:33, kernel test robot wrote:
>> Hi Matthew,
>>
>> kernel test robot noticed the following build warnings:
>>
>> [auto build test WARNING on 201c8a7bd1f3f415920a2df4b8a8817e973f42fe]
>>
>> url: https://github.com/intel-lab-lkp/linux/commits/Matthew-Brost/drm-sched-Add-drm_sched_wqueue_-helpers/20231026-121313
>> base: 201c8a7bd1f3f415920a2df4b8a8817e973f42fe
>> patch link: https://lore.kernel.org/r/20231026041236.1273694-4-matthew.brost%40intel.com
>> patch subject: [PATCH v7 3/6] drm/sched: Convert the GPU scheduler to variable number of run-queues
>> config: m68k-allyesconfig (https://download.01.org/0day-ci/archive/20231026/202310261439.3rbAtEoB-lkp@intel.com/config)
>> compiler: m68k-linux-gcc (GCC) 13.2.0
>> reproduce (this is a W=1 build): (https://download.01.org/0day-ci/archive/20231026/202310261439.3rbAtEoB-lkp@intel.com/reproduce)
>>
>> If you fix the issue in a separate patch/commit (i.e. not just a new version of
>> the same patch/commit), kindly add following tags
>> | Reported-by: kernel test robot <lkp at intel.com>
>> | Closes: https://lore.kernel.org/oe-kbuild-all/202310261439.3rbAtEoB-lkp@intel.com/
>>
>> All warnings (new ones prefixed by >>):
>>
>> drivers/gpu/drm/etnaviv/etnaviv_sched.c: In function 'etnaviv_sched_init':
>>>> drivers/gpu/drm/etnaviv/etnaviv_sched.c:138:30: warning: passing argument 3 of 'drm_sched_init' makes pointer from integer without a cast [-Wint-conversion]
>> 138 | DRM_SCHED_PRIORITY_COUNT, NULL,
>> | ^~~~~~~~~~~~~~~~~~~~~~~~
>> | |
>> | int
>> In file included from drivers/gpu/drm/etnaviv/etnaviv_drv.h:20,
>> from drivers/gpu/drm/etnaviv/etnaviv_sched.c:8:
>> include/drm/gpu_scheduler.h:530:45: note: expected 'struct workqueue_struct *' but argument is of type 'int'
>> 530 | struct workqueue_struct *submit_wq,
>> | ~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~
>> In file included from include/uapi/linux/posix_types.h:5,
>> from include/uapi/linux/types.h:14,
>> from include/linux/types.h:6,
>> from include/linux/kasan-checks.h:5,
>> from include/asm-generic/rwonce.h:26,
>> from ./arch/m68k/include/generated/asm/rwonce.h:1,
>> from include/linux/compiler.h:246,
>> from include/linux/build_bug.h:5,
>> from include/linux/init.h:5,
>> from include/linux/moduleparam.h:5,
>> from drivers/gpu/drm/etnaviv/etnaviv_sched.c:6:
>
> The reason for this compilation failure is that this patch is completely mangled and nothing like the patch I posted.
>
> My patch is: https://lore.kernel.org/all/20231023032251.164775-1-luben.tuikov@amd.com/
>
> Save it raw to your disk from this link: https://lore.kernel.org/all/20231023032251.164775-1-luben.tuikov@amd.com/raw
>
> And apply it with "git am <file-name>" on top of your clean tree, e.g. drm-misc-next. THEN, after that,
> apply your patches.
>
> It should then compile without any problems.
>
> Just looking at the first hunk in my patch:
>
>> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
>> index 2b8356699f235d..251995a90bbe69 100644
>> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
>> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
>> @@ -2280,6 +2280,7 @@ static int amdgpu_device_init_schedulers(struct amdgpu_device *adev)
>> }
>>
>> r = drm_sched_init(&ring->sched, &amdgpu_sched_ops,
>> + DRM_SCHED_PRIORITY_COUNT,
>> ring->num_hw_submission, 0,
>> timeout, adev->reset_domain->wq,
>> ring->sched_score, ring->name,
>
> While this looks like this in the version you posted of my patch:
>
>> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
>> index b54c4d771104..94d073bfbd13 100644
>> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
>> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
>> @@ -2280,6 +2280,7 @@ static int amdgpu_device_init_schedulers(struct amdgpu_device *adev)
>> }
>>
>> r = drm_sched_init(&ring->sched, &amdgpu_sched_ops, NULL,
>> + DRM_SCHED_PRIORITY_COUNT,
>> ring->num_hw_submission, 0,
>> timeout, adev->reset_domain->wq,
>> ring->sched_score, ring->name,
>
> What's that "NULL" doing as the 3rd argument???
>
> And the rest is similarly mangled as well.
>
> Please apply my patch AS IS, no local changes, and then apply your patches on top. That should ensure compilation is correct for all,
> and a more precise review can be had.
>
> FWIW, we should've had dynamic sched_rq from the outset as opposed to having to have my patch that now. So imagine that you already
> have a branch which has dynamic sched_rq, and then you apply your patches--should be a more straightforward and clean application.
>
> Regards,
> Luben
>
>>>> include/linux/stddef.h:8:14: warning: passing argument 4 of 'drm_sched_init' makes integer from pointer without a cast [-Wint-conversion]
>> 8 | #define NULL ((void *)0)
>> | ^~~~~~~~~~~
>> | |
>> | void *
>> drivers/gpu/drm/etnaviv/etnaviv_sched.c:138:56: note: in expansion of macro 'NULL'
>> 138 | DRM_SCHED_PRIORITY_COUNT, NULL,
>> | ^~~~
>> include/drm/gpu_scheduler.h:531:24: note: expected 'u32' {aka 'unsigned int'} but argument is of type 'void *'
>> 531 | u32 num_rqs, uint32_t hw_submission, unsigned hang_limit,
>> | ~~~~^~~~~~~
>> --
>> drivers/gpu/drm/lima/lima_sched.c: In function 'lima_sched_pipe_init':
>>>> drivers/gpu/drm/lima/lima_sched.c:492:31: warning: passing argument 3 of 'drm_sched_init' makes pointer from integer without a cast [-Wint-conversion]
>> 492 | DRM_SCHED_PRIORITY_COUNT, NULL, 1,
>> | ^~~~~~~~~~~~~~~~~~~~~~~~
>> | |
>> | int
>> In file included from drivers/gpu/drm/lima/lima_sched.h:7,
>> from drivers/gpu/drm/lima/lima_device.h:12,
>> from drivers/gpu/drm/lima/lima_ctx.h:10,
>> from drivers/gpu/drm/lima/lima_drv.h:9,
>> from drivers/gpu/drm/lima/lima_sched.c:11:
>> include/drm/gpu_scheduler.h:530:45: note: expected 'struct workqueue_struct *' but argument is of type 'int'
>> 530 | struct workqueue_struct *submit_wq,
>> | ~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~
>> In file included from include/uapi/linux/posix_types.h:5,
>> from include/uapi/linux/types.h:14,
>> from include/linux/types.h:6,
>> from include/linux/io.h:9,
>> from include/linux/iosys-map.h:10,
>> from drivers/gpu/drm/lima/lima_sched.c:4:
>>>> include/linux/stddef.h:8:14: warning: passing argument 4 of 'drm_sched_init' makes integer from pointer without a cast [-Wint-conversion]
>> 8 | #define NULL ((void *)0)
>> | ^~~~~~~~~~~
>> | |
>> | void *
>> drivers/gpu/drm/lima/lima_sched.c:492:57: note: in expansion of macro 'NULL'
>> 492 | DRM_SCHED_PRIORITY_COUNT, NULL, 1,
>> | ^~~~
>> include/drm/gpu_scheduler.h:531:24: note: expected 'u32' {aka 'unsigned int'} but argument is of type 'void *'
>> 531 | u32 num_rqs, uint32_t hw_submission, unsigned hang_limit,
>> | ~~~~^~~~~~~
>> --
>> drivers/gpu/drm/v3d/v3d_sched.c: In function 'v3d_sched_init':
>>>> drivers/gpu/drm/v3d/v3d_sched.c:391:50: warning: passing argument 3 of 'drm_sched_init' makes pointer from integer without a cast [-Wint-conversion]
>> 391 | &v3d_bin_sched_ops, DRM_SCHED_PRIORITY_COUNT, NULL,
>> | ^~~~~~~~~~~~~~~~~~~~~~~~
>> | |
>> | int
>> In file included from drivers/gpu/drm/v3d/v3d_drv.h:12,
>> from drivers/gpu/drm/v3d/v3d_sched.c:23:
>> include/drm/gpu_scheduler.h:530:45: note: expected 'struct workqueue_struct *' but argument is of type 'int'
>> 530 | struct workqueue_struct *submit_wq,
>> | ~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~
>> In file included from include/uapi/linux/posix_types.h:5,
>> from include/uapi/linux/types.h:14,
>> from include/linux/types.h:6,
>> from include/linux/kasan-checks.h:5,
>> from include/asm-generic/rwonce.h:26,
>> from ./arch/m68k/include/generated/asm/rwonce.h:1,
>> from include/linux/compiler.h:246,
>> from include/linux/err.h:5,
>> from include/linux/kthread.h:5,
>> from drivers/gpu/drm/v3d/v3d_sched.c:21:
>>>> include/linux/stddef.h:8:14: warning: passing argument 4 of 'drm_sched_init' makes integer from pointer without a cast [-Wint-conversion]
>> 8 | #define NULL ((void *)0)
>> | ^~~~~~~~~~~
>> | |
>> | void *
>> drivers/gpu/drm/v3d/v3d_sched.c:391:76: note: in expansion of macro 'NULL'
>> 391 | &v3d_bin_sched_ops, DRM_SCHED_PRIORITY_COUNT, NULL,
>> | ^~~~
>> include/drm/gpu_scheduler.h:531:24: note: expected 'u32' {aka 'unsigned int'} but argument is of type 'void *'
>> 531 | u32 num_rqs, uint32_t hw_submission, unsigned hang_limit,
>> | ~~~~^~~~~~~
>> drivers/gpu/drm/v3d/v3d_sched.c:399:53: warning: passing argument 3 of 'drm_sched_init' makes pointer from integer without a cast [-Wint-conversion]
>> 399 | &v3d_render_sched_ops, DRM_SCHED_PRIORITY_COUNT,
>> | ^~~~~~~~~~~~~~~~~~~~~~~~
>> | |
>> | int
>> include/drm/gpu_scheduler.h:530:45: note: expected 'struct workqueue_struct *' but argument is of type 'int'
>> 530 | struct workqueue_struct *submit_wq,
>> | ~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~
>>>> include/linux/stddef.h:8:14: warning: passing argument 4 of 'drm_sched_init' makes integer from pointer without a cast [-Wint-conversion]
>> 8 | #define NULL ((void *)0)
>> | ^~~~~~~~~~~
>> | |
>> | void *
>> drivers/gpu/drm/v3d/v3d_sched.c:400:30: note: in expansion of macro 'NULL'
>> 400 | NULL, hw_jobs_limit, job_hang_limit,
>> | ^~~~
>> include/drm/gpu_scheduler.h:531:24: note: expected 'u32' {aka 'unsigned int'} but argument is of type 'void *'
>> 531 | u32 num_rqs, uint32_t hw_submission, unsigned hang_limit,
>> | ~~~~^~~~~~~
>> drivers/gpu/drm/v3d/v3d_sched.c:407:50: warning: passing argument 3 of 'drm_sched_init' makes pointer from integer without a cast [-Wint-conversion]
>> 407 | &v3d_tfu_sched_ops, DRM_SCHED_PRIORITY_COUNT, NULL,
>> | ^~~~~~~~~~~~~~~~~~~~~~~~
>> | |
>> | int
>> include/drm/gpu_scheduler.h:530:45: note: expected 'struct workqueue_struct *' but argument is of type 'int'
>> 530 | struct workqueue_struct *submit_wq,
>> | ~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~
>>>> include/linux/stddef.h:8:14: warning: passing argument 4 of 'drm_sched_init' makes integer from pointer without a cast [-Wint-conversion]
>> 8 | #define NULL ((void *)0)
>> | ^~~~~~~~~~~
>> | |
>> | void *
>> drivers/gpu/drm/v3d/v3d_sched.c:407:76: note: in expansion of macro 'NULL'
>> 407 | &v3d_tfu_sched_ops, DRM_SCHED_PRIORITY_COUNT, NULL,
>> | ^~~~
>> include/drm/gpu_scheduler.h:531:24: note: expected 'u32' {aka 'unsigned int'} but argument is of type 'void *'
>> 531 | u32 num_rqs, uint32_t hw_submission, unsigned hang_limit,
>> | ~~~~^~~~~~~
>> drivers/gpu/drm/v3d/v3d_sched.c:417:38: warning: passing argument 3 of 'drm_sched_init' makes pointer from integer without a cast [-Wint-conversion]
>> 417 | DRM_SCHED_PRIORITY_COUNT, NULL,
>> | ^~~~~~~~~~~~~~~~~~~~~~~~
>> | |
>> | int
>> include/drm/gpu_scheduler.h:530:45: note: expected 'struct workqueue_struct *' but argument is of type 'int'
>> 530 | struct workqueue_struct *submit_wq,
>> | ~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~
>>>> include/linux/stddef.h:8:14: warning: passing argument 4 of 'drm_sched_init' makes integer from pointer without a cast [-Wint-conversion]
>> 8 | #define NULL ((void *)0)
>> | ^~~~~~~~~~~
>> | |
>> | void *
>> drivers/gpu/drm/v3d/v3d_sched.c:417:64: note: in expansion of macro 'NULL'
>> 417 | DRM_SCHED_PRIORITY_COUNT, NULL,
>> | ^~~~
>> include/drm/gpu_scheduler.h:531:24: note: expected 'u32' {aka 'unsigned int'} but argument is of type 'void *'
>> 531 | u32 num_rqs, uint32_t hw_submission, unsigned hang_limit,
>> | ~~~~^~~~~~~
>> drivers/gpu/drm/v3d/v3d_sched.c:426:38: warning: passing argument 3 of 'drm_sched_init' makes pointer from integer without a cast [-Wint-conversion]
>> 426 | DRM_SCHED_PRIORITY_COUNT, NULL,
>> | ^~~~~~~~~~~~~~~~~~~~~~~~
>> | |
>> | int
>> include/drm/gpu_scheduler.h:530:45: note: expected 'struct workqueue_struct *' but argument is of type 'int'
>> 530 | struct workqueue_struct *submit_wq,
>> | ~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~
>>>> include/linux/stddef.h:8:14: warning: passing argument 4 of 'drm_sched_init' makes integer from pointer without a cast [-Wint-conversion]
>> 8 | #define NULL ((void *)0)
>> | ^~~~~~~~~~~
>> | |
>> | void *
>> drivers/gpu/drm/v3d/v3d_sched.c:426:64: note: in expansion of macro 'NULL'
>> 426 | DRM_SCHED_PRIORITY_COUNT, NULL,
>> | ^~~~
>> include/drm/gpu_scheduler.h:531:24: note: expected 'u32' {aka 'unsigned int'} but argument is of type 'void *'
>> 531 | u32 num_rqs, uint32_t hw_submission, unsigned hang_limit,
>> | ~~~~^~~~~~~
>>
>>
>> vim +/drm_sched_init +138 drivers/gpu/drm/etnaviv/etnaviv_sched.c
>>
>> 132
>> 133 int etnaviv_sched_init(struct etnaviv_gpu *gpu)
>> 134 {
>> 135 int ret;
>> 136
>> 137 ret = drm_sched_init(&gpu->sched, &etnaviv_sched_ops,
>> > 138 DRM_SCHED_PRIORITY_COUNT, NULL,
>> 139 etnaviv_hw_jobs_limit, etnaviv_job_hang_limit,
>> 140 msecs_to_jiffies(500), NULL, NULL,
>> 141 dev_name(gpu->dev), gpu->dev);
>> 142 if (ret)
>> 143 return ret;
>> 144
>> 145 return 0;
>> 146 }
>> 147
>>
>
--
Regards,
Luben
More information about the dri-devel
mailing list