From: kernel test robot <lkp@intel.com>
To: David Zhang <yidong.zhang@amd.com>,
linux-kernel@vger.kernel.org, linux-fpga@vger.kernel.org,
mdf@kernel.org, hao.wu@intel.com, yilun.xu@intel.com
Cc: oe-kbuild-all@lists.linux.dev,
Yidong Zhang <yidong.zhang@amd.com>,
lizhi.hou@amd.com, Nishad Saraf <nishads@amd.com>,
Prapul Krishnamurthy <prapulk@amd.com>
Subject: Re: [PATCH V1 2/3] drivers/fpga/amd: Add communication with firmware
Date: Wed, 9 Oct 2024 18:44:51 +0800 [thread overview]
Message-ID: <202410091855.yLTZGOfr-lkp@intel.com> (raw)
In-Reply-To: <20241007220128.3023169-2-yidong.zhang@amd.com>
Hi David,
kernel test robot noticed the following build warnings:
[auto build test WARNING on linus/master]
[also build test WARNING on v6.12-rc2 next-20241008]
[If your patch is applied to the wrong git tree, kindly drop us a note.
And when submitting patch, we suggest to use '--base' as documented in
https://git-scm.com/docs/git-format-patch#_base_tree_information]
url: https://github.com/intel-lab-lkp/linux/commits/David-Zhang/drivers-fpga-amd-Add-communication-with-firmware/20241008-060253
base: linus/master
patch link: https://lore.kernel.org/r/20241007220128.3023169-2-yidong.zhang%40amd.com
patch subject: [PATCH V1 2/3] drivers/fpga/amd: Add communication with firmware
config: x86_64-randconfig-121-20241009 (https://download.01.org/0day-ci/archive/20241009/202410091855.yLTZGOfr-lkp@intel.com/config)
compiler: gcc-12 (Debian 12.2.0-14) 12.2.0
reproduce (this is a W=1 build): (https://download.01.org/0day-ci/archive/20241009/202410091855.yLTZGOfr-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@intel.com>
| Closes: https://lore.kernel.org/oe-kbuild-all/202410091855.yLTZGOfr-lkp@intel.com/
sparse warnings: (new ones prefixed by >>)
drivers/fpga/amd/vmgmt.c:35:14: sparse: sparse: symbol 'vmgmt_class' was not declared. Should it be static?
>> drivers/fpga/amd/vmgmt.c:272:45: sparse: sparse: incorrect type in argument 2 (different address spaces) @@ expected void const [noderef] __user *from @@ got void * @@
drivers/fpga/amd/vmgmt.c:272:45: sparse: expected void const [noderef] __user *from
drivers/fpga/amd/vmgmt.c:272:45: sparse: got void *
drivers/fpga/amd/vmgmt.c:301:45: sparse: sparse: incorrect type in argument 2 (different address spaces) @@ expected void const [noderef] __user *from @@ got void * @@
drivers/fpga/amd/vmgmt.c:301:45: sparse: expected void const [noderef] __user *from
drivers/fpga/amd/vmgmt.c:301:45: sparse: got void *
vim +272 drivers/fpga/amd/vmgmt.c
257
258 static long vmgmt_ioctl(struct file *filep, unsigned int cmd, unsigned long arg)
259 {
260 struct vmgmt_device *vdev = (struct vmgmt_device *)filep->private_data;
261 struct vmgmt_fpga_region reg = { 0 };
262 struct fpga_region *region = NULL;
263 struct axlf *axlf = NULL;
264 void *data = NULL;
265 size_t size = 0;
266 int ret = 0;
267
268 axlf = vmalloc(sizeof(*axlf));
269 if (!axlf)
270 return -ENOMEM;
271
> 272 ret = copy_from_user((void *)axlf, (void *)arg, sizeof(*axlf));
273 if (ret) {
274 vmgmt_err(vdev, "Failed to copy axlf: %d", ret);
275 ret = -EFAULT;
276 goto exit;
277 }
278
279 ret = memcmp(axlf->magic, VERSAL_XCLBIN_MAGIC_ID,
280 sizeof(VERSAL_XCLBIN_MAGIC_ID));
281 if (ret) {
282 vmgmt_err(vdev, "unknown axlf magic %s", axlf->magic);
283 ret = -EINVAL;
284 goto exit;
285 }
286
287 /* axlf should never be over 1G and less than size of struct axlf */
288 size = axlf->header.length;
289 if (size < sizeof(struct axlf) || size > 1024 * 1024 * 1024) {
290 vmgmt_err(vdev, "axlf length %zu is invalid", size);
291 ret = -EINVAL;
292 goto exit;
293 }
294
295 data = vmalloc(size);
296 if (!data) {
297 ret = -ENOMEM;
298 goto exit;
299 }
300
301 ret = copy_from_user((void *)data, (void *)arg, size);
302 if (ret) {
303 vmgmt_err(vdev, "Failed to copy data: %d", ret);
304 ret = -EFAULT;
305 goto exit;
306 }
307
308 switch (cmd) {
309 case VERSAL_MGMT_LOAD_XCLBIN_IOCTL:
310 vdev->fdev->fw.opcode = RM_QUEUE_OP_LOAD_XCLBIN;
311 break;
312 default:
313 vmgmt_err(vdev, "Invalid IOCTL command: %d", cmd);
314 ret = -EINVAL;
315 goto exit;
316 }
317
318 reg.uuid = &axlf->header.rom_uuid;
319 reg.fdev = vdev->fdev;
320
321 region = fpga_region_class_find(NULL, ®, vmgmt_fpga_region_match);
322 if (!region) {
323 vmgmt_err(vdev, "Failed to find compatible region");
324 ret = -ENOENT;
325 goto exit;
326 }
327
328 ret = vmgmt_region_program(region, data);
329 if (ret) {
330 vmgmt_err(vdev, "Failed to program region");
331 goto exit;
332 }
333
334 vmgmt_info(vdev, "Downloaded axlf %pUb of size %zu Bytes",
335 &axlf->header.uuid, size);
336 uuid_copy(&vdev->xclbin_uuid, &axlf->header.uuid);
337
338 exit:
339 vfree(data);
340 vfree(axlf);
341
342 return ret;
343 }
344
--
0-DAY CI Kernel Test Service
https://github.com/intel/lkp-tests/wiki
next prev parent reply other threads:[~2024-10-09 10:45 UTC|newest]
Thread overview: 19+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-10-07 22:01 [PATCH V1 1/3] drivers/fpga/amd: Add new driver for AMD Versal PCIe card David Zhang
2024-10-07 22:01 ` [PATCH V1 2/3] drivers/fpga/amd: Add communication with firmware David Zhang
2024-10-09 5:29 ` kernel test robot
2024-10-09 10:44 ` kernel test robot [this message]
2024-10-18 8:11 ` Xu Yilun
2024-10-18 17:40 ` Zhang, Yidong (David)
2024-11-12 1:29 ` Yidong Zhang
2024-10-07 22:01 ` [PATCH V1 3/3] drivers/fpga/amd: Add remote queue service APIs David Zhang
2024-10-09 7:13 ` kernel test robot
2024-10-09 9:01 ` [PATCH V1 1/3] drivers/fpga/amd: Add new driver for AMD Versal PCIe card kernel test robot
2024-10-18 6:17 ` Xu Yilun
2024-11-12 1:22 ` Yidong Zhang
2024-11-19 7:07 ` Xu Yilun
2024-11-20 6:15 ` Yidong Zhang
2024-12-23 1:53 ` Yidong Zhang
2023-03-12 18:03 ` Xu Yilun
2024-12-26 6:10 ` Yidong Zhang
2023-03-12 21:30 ` Xu Yilun
2025-01-02 5:30 ` Yidong Zhang
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=202410091855.yLTZGOfr-lkp@intel.com \
--to=lkp@intel.com \
--cc=hao.wu@intel.com \
--cc=linux-fpga@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=lizhi.hou@amd.com \
--cc=mdf@kernel.org \
--cc=nishads@amd.com \
--cc=oe-kbuild-all@lists.linux.dev \
--cc=prapulk@amd.com \
--cc=yidong.zhang@amd.com \
--cc=yilun.xu@intel.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).