Hi,
Thank you for the patch! Yet something to improve:
[auto build test ERROR on scsi/for-next]
[also build test ERROR on mkp-scsi/for-next v5.14 next-20210910]
[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]
url:
https://github.com/0day-ci/linux/commits/wenxiong-linux-vnet-ibm-com/scsi...
base:
https://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi.git for-next
config: microblaze-buildonly-randconfig-r001-20210910 (attached as .config)
compiler: microblaze-linux-gcc (GCC) 11.2.0
reproduce (this is a W=1 build):
wget
https://raw.githubusercontent.com/intel/lkp-tests/master/sbin/make.cross -O
~/bin/make.cross
chmod +x ~/bin/make.cross
#
https://github.com/0day-ci/linux/commit/a117eeeef2a13989a97ac0e10d86ffa63...
git remote add linux-review
https://github.com/0day-ci/linux
git fetch --no-tags linux-review
wenxiong-linux-vnet-ibm-com/scsi-ses-Saw-Failed-to-get-diagnostic-page-0x1/20210911-043434
git checkout a117eeeef2a13989a97ac0e10d86ffa6314f481e
# save the attached .config to linux build tree
mkdir build_dir
COMPILER_INSTALL_PATH=$HOME/0day COMPILER=gcc-11.2.0 make.cross O=build_dir
ARCH=microblaze SHELL=/bin/bash drivers/scsi/
If you fix the issue, kindly add following tag as appropriate
Reported-by: kernel test robot <lkp(a)intel.com>
All error/warnings (new ones prefixed by >>):
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/microblaze/include/generated/asm/rwonce.h:1,
from include/linux/compiler.h:264,
from include/asm-generic/bug.h:5,
from ./arch/microblaze/include/generated/asm/bug.h:1,
from include/linux/bug.h:5,
from include/linux/mmdebug.h:5,
from include/linux/gfp.h:5,
from include/linux/slab.h:15,
from drivers/scsi/ses.c:8:
drivers/scsi/ses.c: In function 'ses_recv_diag':
> include/linux/stddef.h:8:14: warning: passing argument 7 of
'scsi_execute_req' makes integer from pointer without a cast [-Wint-conversion]
8 | #define NULL ((void *)0)
| ^~~~~~~~~~~
| |
| void *
drivers/scsi/ses.c:95:42: note: in expansion of macro 'NULL'
95 | bufflen, &sshdr, NULL, SES_TIMEOUT, SES_RETRIES,
NULL);
| ^~~~
In file included from include/scsi/scsi_cmnd.h:12,
from drivers/scsi/ses.c:15:
include/scsi/scsi_device.h:467:61: note: expected 'int' but argument is of type
'void *'
467 | unsigned bufflen, struct scsi_sense_hdr *sshdr, int timeout,
| ~~~~^~~~~~~
> drivers/scsi/ses.c:61:21: warning: passing argument 9 of
'scsi_execute_req' makes pointer from integer without a cast [-Wint-conversion]
61 | #define SES_RETRIES 3
| ^
| |
| int
drivers/scsi/ses.c:95:61: note: in expansion of macro 'SES_RETRIES'
95 | bufflen, &sshdr, NULL, SES_TIMEOUT, SES_RETRIES,
NULL);
| ^~~~~~~~~~~
In file included from include/scsi/scsi_cmnd.h:12,
from drivers/scsi/ses.c:15:
include/scsi/scsi_device.h:468:27: note: expected 'int *' but argument is of
type 'int'
468 | int retries, int *resid)
| ~~~~~^~~~~
> drivers/scsi/ses.c:94:24: error: too many arguments to function
'scsi_execute_req'
94 | ret = scsi_execute_req(sdev,
cmd, DMA_FROM_DEVICE, buf,
| ^~~~~~~~~~~~~~~~
In file included from include/scsi/scsi_cmnd.h:12,
from drivers/scsi/ses.c:15:
include/scsi/scsi_device.h:465:19: note: declared here
465 | static inline int scsi_execute_req(struct scsi_device *sdev,
| ^~~~~~~~~~~~~~~~
vim +/scsi_execute_req +94 drivers/scsi/ses.c
59
60 #define SES_TIMEOUT (30 * HZ)
61 #define SES_RETRIES 3
62
63 static void init_device_slot_control(unsigned char *dest_desc,
64 struct enclosure_component *ecomp,
65 unsigned char *status)
66 {
67 memcpy(dest_desc, status, 4);
68 dest_desc[0] = 0;
69 /* only clear byte 1 for ENCLOSURE_COMPONENT_DEVICE */
70 if (ecomp->type == ENCLOSURE_COMPONENT_DEVICE)
71 dest_desc[1] = 0;
72 dest_desc[2] &= 0xde;
73 dest_desc[3] &= 0x3c;
74 }
75
76
77 static int ses_recv_diag(struct scsi_device *sdev, int page_code,
78 void *buf, int bufflen)
79 {
80 int ret;
81 unsigned char cmd[] = {
82 RECEIVE_DIAGNOSTIC,
83 1, /* Set PCV bit */
84 page_code,
85 bufflen >> 8,
86 bufflen & 0xff,
87 0
88 };
89 unsigned char recv_page_code;
90 struct scsi_sense_hdr sshdr;
91 int retries = SES_RETRIES;
92
93 do {
94 ret = scsi_execute_req(sdev, cmd, DMA_FROM_DEVICE, buf,
95 bufflen, &sshdr, NULL, SES_TIMEOUT, SES_RETRIES, NULL);
96
97 } while (scsi_sense_valid(&sshdr) &&
98 sshdr.sense_key == UNIT_ATTENTION && --retries);
99
100 if (unlikely(ret))
101 return ret;
102
103 recv_page_code = ((unsigned char *)buf)[0];
104
105 if (likely(recv_page_code == page_code))
106 return ret;
107
108 /* successful diagnostic but wrong page code. This happens to some
109 * USB devices, just print a message and pretend there was an error */
110
111 sdev_printk(KERN_ERR, sdev,
112 "Wrong diagnostic page; asked for %d got %u\n",
113 page_code, recv_page_code);
114
115 return -EINVAL;
116 }
117
---
0-DAY CI Kernel Test Service, Intel Corporation
https://lists.01.org/hyperkitty/list/kbuild-all@lists.01.org