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 for Android: free password hash cracker in your pocket
[<prev] [next>] [day] [month] [year] [list]
Date:   Sun, 5 Dec 2021 01:40:29 +0800
From:   kernel test robot <lkp@...el.com>
To:     Guenter Roeck <linux@...ck-us.net>
Cc:     kbuild-all@...ts.01.org, linux-kernel@...r.kernel.org,
        Palmer Dabbelt <palmerdabbelt@...gle.com>
Subject: drivers/scsi/myrs.c:2434:13: sparse: sparse: incorrect type in
 assignment (different base types)

Hi Guenter,

First bad commit (maybe != root cause):

tree:   https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git master
head:   12119cfa1052d512a92524e90ebee85029a918f8
commit: a18b14d8886614b3c7d290c4cfc33389822b0535 riscv: Disable STACKPROTECTOR_PER_TASK if GCC_PLUGIN_RANDSTRUCT is enabled
date:   4 months ago
config: riscv-allmodconfig (https://download.01.org/0day-ci/archive/20211205/202112050107.2l2GufNo-lkp@intel.com/config)
compiler: riscv64-linux-gcc (GCC) 11.2.0
reproduce:
        wget https://raw.githubusercontent.com/intel/lkp-tests/master/sbin/make.cross -O ~/bin/make.cross
        chmod +x ~/bin/make.cross
        # apt-get install sparse
        # sparse version: v0.6.4-dirty
        # https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=a18b14d8886614b3c7d290c4cfc33389822b0535
        git remote add linus https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
        git fetch --no-tags linus master
        git checkout a18b14d8886614b3c7d290c4cfc33389822b0535
        # save the config file to linux build tree
        mkdir build_dir
        COMPILER_INSTALL_PATH=$HOME/0day COMPILER=gcc-11.2.0 make.cross C=1 CF='-fdiagnostic-prefix -D__CHECK_ENDIAN__' O=build_dir ARCH=riscv SHELL=/bin/bash arch/riscv/ drivers/scsi/

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/scsi/myrs.c:2267:34: sparse: sparse: incorrect type in argument 1 (different address spaces) @@     expected void [noderef] __iomem *base @@     got struct myrs_hba *cs @@
   drivers/scsi/myrs.c:2267:34: sparse:     expected void [noderef] __iomem *base
   drivers/scsi/myrs.c:2267:34: sparse:     got struct myrs_hba *cs
   drivers/scsi/myrs.c:2419:9: sparse: sparse: cast from restricted __le32
   drivers/scsi/myrs.c:2472:9: sparse: sparse: cast from restricted __le32
   drivers/scsi/myrs.c:2412:9: sparse: sparse: cast from restricted __le32
   drivers/scsi/myrs.c:2472:9: sparse: sparse: cast from restricted __le32
   drivers/scsi/myrs.c:2405:9: sparse: sparse: cast from restricted __le32
>> drivers/scsi/myrs.c:2434:13: sparse: sparse: incorrect type in assignment (different base types) @@     expected restricted __le32 [usertype] val @@     got unsigned int [assigned] [usertype] __v @@
   drivers/scsi/myrs.c:2434:13: sparse:     expected restricted __le32 [usertype] val
   drivers/scsi/myrs.c:2434:13: sparse:     got unsigned int [assigned] [usertype] __v
   drivers/scsi/myrs.c:2504:13: sparse: sparse: incorrect type in assignment (different base types) @@     expected restricted __le32 [usertype] val @@     got unsigned int [assigned] [usertype] __v @@
   drivers/scsi/myrs.c:2504:13: sparse:     expected restricted __le32 [usertype] val
   drivers/scsi/myrs.c:2504:13: sparse:     got unsigned int [assigned] [usertype] __v
   drivers/scsi/myrs.c:2507:18: sparse: sparse: restricted __le32 degrades to integer
   drivers/scsi/myrs.c:2412:9: sparse: sparse: cast from restricted __le32
   drivers/scsi/myrs.c:2465:9: sparse: sparse: cast from restricted __le32
   drivers/scsi/myrs.c:2450:9: sparse: sparse: cast from restricted __le32
   drivers/scsi/myrs.c:2426:13: sparse: sparse: incorrect type in assignment (different base types) @@     expected restricted __le32 [usertype] val @@     got unsigned int [assigned] [usertype] __v @@
   drivers/scsi/myrs.c:2426:13: sparse:     expected restricted __le32 [usertype] val
   drivers/scsi/myrs.c:2426:13: sparse:     got unsigned int [assigned] [usertype] __v
   drivers/scsi/myrs.c:2398:9: sparse: sparse: cast from restricted __le32
   drivers/scsi/myrs.c:2457:13: sparse: sparse: incorrect type in assignment (different base types) @@     expected restricted __le32 [usertype] val @@     got unsigned int [assigned] [usertype] __v @@
   drivers/scsi/myrs.c:2457:13: sparse:     expected restricted __le32 [usertype] val
   drivers/scsi/myrs.c:2457:13: sparse:     got unsigned int [assigned] [usertype] __v
   drivers/scsi/myrs.c:2442:9: sparse: sparse: cast from restricted __le32
   drivers/scsi/myrs.c:2405:9: sparse: sparse: cast from restricted __le32

vim +2434 drivers/scsi/myrs.c

77266186397c6c Hannes Reinecke   2018-10-17  2258  
77266186397c6c Hannes Reinecke   2018-10-17  2259  static void myrs_cleanup(struct myrs_hba *cs)
77266186397c6c Hannes Reinecke   2018-10-17  2260  {
77266186397c6c Hannes Reinecke   2018-10-17  2261  	struct pci_dev *pdev = cs->pdev;
77266186397c6c Hannes Reinecke   2018-10-17  2262  
77266186397c6c Hannes Reinecke   2018-10-17  2263  	/* Free the memory mailbox, status, and related structures */
77266186397c6c Hannes Reinecke   2018-10-17  2264  	myrs_unmap(cs);
77266186397c6c Hannes Reinecke   2018-10-17  2265  
77266186397c6c Hannes Reinecke   2018-10-17  2266  	if (cs->mmio_base) {
77266186397c6c Hannes Reinecke   2018-10-17 @2267  		cs->disable_intr(cs);
77266186397c6c Hannes Reinecke   2018-10-17  2268  		iounmap(cs->mmio_base);
2bb817712e2f77 Lv Yunlong        2021-03-10  2269  		cs->mmio_base = NULL;
77266186397c6c Hannes Reinecke   2018-10-17  2270  	}
77266186397c6c Hannes Reinecke   2018-10-17  2271  	if (cs->irq)
77266186397c6c Hannes Reinecke   2018-10-17  2272  		free_irq(cs->irq, cs);
77266186397c6c Hannes Reinecke   2018-10-17  2273  	if (cs->io_addr)
77266186397c6c Hannes Reinecke   2018-10-17  2274  		release_region(cs->io_addr, 0x80);
77266186397c6c Hannes Reinecke   2018-10-17  2275  	pci_set_drvdata(pdev, NULL);
77266186397c6c Hannes Reinecke   2018-10-17  2276  	pci_disable_device(pdev);
77266186397c6c Hannes Reinecke   2018-10-17  2277  	scsi_host_put(cs->host);
77266186397c6c Hannes Reinecke   2018-10-17  2278  }
77266186397c6c Hannes Reinecke   2018-10-17  2279  
77266186397c6c Hannes Reinecke   2018-10-17  2280  static struct myrs_hba *myrs_detect(struct pci_dev *pdev,
77266186397c6c Hannes Reinecke   2018-10-17  2281  		const struct pci_device_id *entry)
77266186397c6c Hannes Reinecke   2018-10-17  2282  {
77266186397c6c Hannes Reinecke   2018-10-17  2283  	struct myrs_privdata *privdata =
77266186397c6c Hannes Reinecke   2018-10-17  2284  		(struct myrs_privdata *)entry->driver_data;
77266186397c6c Hannes Reinecke   2018-10-17  2285  	irq_handler_t irq_handler = privdata->irq_handler;
77266186397c6c Hannes Reinecke   2018-10-17  2286  	unsigned int mmio_size = privdata->mmio_size;
77266186397c6c Hannes Reinecke   2018-10-17  2287  	struct myrs_hba *cs = NULL;
77266186397c6c Hannes Reinecke   2018-10-17  2288  
77266186397c6c Hannes Reinecke   2018-10-17  2289  	cs = myrs_alloc_host(pdev, entry);
77266186397c6c Hannes Reinecke   2018-10-17  2290  	if (!cs) {
77266186397c6c Hannes Reinecke   2018-10-17  2291  		dev_err(&pdev->dev, "Unable to allocate Controller\n");
77266186397c6c Hannes Reinecke   2018-10-17  2292  		return NULL;
77266186397c6c Hannes Reinecke   2018-10-17  2293  	}
77266186397c6c Hannes Reinecke   2018-10-17  2294  	cs->pdev = pdev;
77266186397c6c Hannes Reinecke   2018-10-17  2295  
77266186397c6c Hannes Reinecke   2018-10-17  2296  	if (pci_enable_device(pdev))
77266186397c6c Hannes Reinecke   2018-10-17  2297  		goto Failure;
77266186397c6c Hannes Reinecke   2018-10-17  2298  
77266186397c6c Hannes Reinecke   2018-10-17  2299  	cs->pci_addr = pci_resource_start(pdev, 0);
77266186397c6c Hannes Reinecke   2018-10-17  2300  
77266186397c6c Hannes Reinecke   2018-10-17  2301  	pci_set_drvdata(pdev, cs);
77266186397c6c Hannes Reinecke   2018-10-17  2302  	spin_lock_init(&cs->queue_lock);
77266186397c6c Hannes Reinecke   2018-10-17  2303  	/* Map the Controller Register Window. */
77266186397c6c Hannes Reinecke   2018-10-17  2304  	if (mmio_size < PAGE_SIZE)
77266186397c6c Hannes Reinecke   2018-10-17  2305  		mmio_size = PAGE_SIZE;
4bdc0d676a6431 Christoph Hellwig 2020-01-06  2306  	cs->mmio_base = ioremap(cs->pci_addr & PAGE_MASK, mmio_size);
77266186397c6c Hannes Reinecke   2018-10-17  2307  	if (cs->mmio_base == NULL) {
77266186397c6c Hannes Reinecke   2018-10-17  2308  		dev_err(&pdev->dev,
77266186397c6c Hannes Reinecke   2018-10-17  2309  			"Unable to map Controller Register Window\n");
77266186397c6c Hannes Reinecke   2018-10-17  2310  		goto Failure;
77266186397c6c Hannes Reinecke   2018-10-17  2311  	}
77266186397c6c Hannes Reinecke   2018-10-17  2312  
77266186397c6c Hannes Reinecke   2018-10-17  2313  	cs->io_base = cs->mmio_base + (cs->pci_addr & ~PAGE_MASK);
77266186397c6c Hannes Reinecke   2018-10-17  2314  	if (privdata->hw_init(pdev, cs, cs->io_base))
77266186397c6c Hannes Reinecke   2018-10-17  2315  		goto Failure;
77266186397c6c Hannes Reinecke   2018-10-17  2316  
77266186397c6c Hannes Reinecke   2018-10-17  2317  	/* Acquire shared access to the IRQ Channel. */
77266186397c6c Hannes Reinecke   2018-10-17  2318  	if (request_irq(pdev->irq, irq_handler, IRQF_SHARED, "myrs", cs) < 0) {
77266186397c6c Hannes Reinecke   2018-10-17  2319  		dev_err(&pdev->dev,
77266186397c6c Hannes Reinecke   2018-10-17  2320  			"Unable to acquire IRQ Channel %d\n", pdev->irq);
77266186397c6c Hannes Reinecke   2018-10-17  2321  		goto Failure;
77266186397c6c Hannes Reinecke   2018-10-17  2322  	}
77266186397c6c Hannes Reinecke   2018-10-17  2323  	cs->irq = pdev->irq;
77266186397c6c Hannes Reinecke   2018-10-17  2324  	return cs;
77266186397c6c Hannes Reinecke   2018-10-17  2325  
77266186397c6c Hannes Reinecke   2018-10-17  2326  Failure:
77266186397c6c Hannes Reinecke   2018-10-17  2327  	dev_err(&pdev->dev,
77266186397c6c Hannes Reinecke   2018-10-17  2328  		"Failed to initialize Controller\n");
77266186397c6c Hannes Reinecke   2018-10-17  2329  	myrs_cleanup(cs);
77266186397c6c Hannes Reinecke   2018-10-17  2330  	return NULL;
77266186397c6c Hannes Reinecke   2018-10-17  2331  }
77266186397c6c Hannes Reinecke   2018-10-17  2332  
8a692fdb1d04f5 Lee Jones         2020-07-13  2333  /*
77266186397c6c Hannes Reinecke   2018-10-17  2334   * myrs_err_status reports Controller BIOS Messages passed through
8a692fdb1d04f5 Lee Jones         2020-07-13  2335   * the Error Status Register when the driver performs the BIOS handshaking.
8a692fdb1d04f5 Lee Jones         2020-07-13  2336   * It returns true for fatal errors and false otherwise.
77266186397c6c Hannes Reinecke   2018-10-17  2337   */
77266186397c6c Hannes Reinecke   2018-10-17  2338  
77266186397c6c Hannes Reinecke   2018-10-17  2339  static bool myrs_err_status(struct myrs_hba *cs, unsigned char status,
77266186397c6c Hannes Reinecke   2018-10-17  2340  		unsigned char parm0, unsigned char parm1)
77266186397c6c Hannes Reinecke   2018-10-17  2341  {
77266186397c6c Hannes Reinecke   2018-10-17  2342  	struct pci_dev *pdev = cs->pdev;
77266186397c6c Hannes Reinecke   2018-10-17  2343  
77266186397c6c Hannes Reinecke   2018-10-17  2344  	switch (status) {
77266186397c6c Hannes Reinecke   2018-10-17  2345  	case 0x00:
77266186397c6c Hannes Reinecke   2018-10-17  2346  		dev_info(&pdev->dev,
77266186397c6c Hannes Reinecke   2018-10-17  2347  			 "Physical Device %d:%d Not Responding\n",
77266186397c6c Hannes Reinecke   2018-10-17  2348  			 parm1, parm0);
77266186397c6c Hannes Reinecke   2018-10-17  2349  		break;
77266186397c6c Hannes Reinecke   2018-10-17  2350  	case 0x08:
77266186397c6c Hannes Reinecke   2018-10-17  2351  		dev_notice(&pdev->dev, "Spinning Up Drives\n");
77266186397c6c Hannes Reinecke   2018-10-17  2352  		break;
77266186397c6c Hannes Reinecke   2018-10-17  2353  	case 0x30:
77266186397c6c Hannes Reinecke   2018-10-17  2354  		dev_notice(&pdev->dev, "Configuration Checksum Error\n");
77266186397c6c Hannes Reinecke   2018-10-17  2355  		break;
77266186397c6c Hannes Reinecke   2018-10-17  2356  	case 0x60:
77266186397c6c Hannes Reinecke   2018-10-17  2357  		dev_notice(&pdev->dev, "Mirror Race Recovery Failed\n");
77266186397c6c Hannes Reinecke   2018-10-17  2358  		break;
77266186397c6c Hannes Reinecke   2018-10-17  2359  	case 0x70:
77266186397c6c Hannes Reinecke   2018-10-17  2360  		dev_notice(&pdev->dev, "Mirror Race Recovery In Progress\n");
77266186397c6c Hannes Reinecke   2018-10-17  2361  		break;
77266186397c6c Hannes Reinecke   2018-10-17  2362  	case 0x90:
77266186397c6c Hannes Reinecke   2018-10-17  2363  		dev_notice(&pdev->dev, "Physical Device %d:%d COD Mismatch\n",
77266186397c6c Hannes Reinecke   2018-10-17  2364  			   parm1, parm0);
77266186397c6c Hannes Reinecke   2018-10-17  2365  		break;
77266186397c6c Hannes Reinecke   2018-10-17  2366  	case 0xA0:
77266186397c6c Hannes Reinecke   2018-10-17  2367  		dev_notice(&pdev->dev, "Logical Drive Installation Aborted\n");
77266186397c6c Hannes Reinecke   2018-10-17  2368  		break;
77266186397c6c Hannes Reinecke   2018-10-17  2369  	case 0xB0:
77266186397c6c Hannes Reinecke   2018-10-17  2370  		dev_notice(&pdev->dev, "Mirror Race On A Critical Logical Drive\n");
77266186397c6c Hannes Reinecke   2018-10-17  2371  		break;
77266186397c6c Hannes Reinecke   2018-10-17  2372  	case 0xD0:
77266186397c6c Hannes Reinecke   2018-10-17  2373  		dev_notice(&pdev->dev, "New Controller Configuration Found\n");
77266186397c6c Hannes Reinecke   2018-10-17  2374  		break;
77266186397c6c Hannes Reinecke   2018-10-17  2375  	case 0xF0:
77266186397c6c Hannes Reinecke   2018-10-17  2376  		dev_err(&pdev->dev, "Fatal Memory Parity Error\n");
77266186397c6c Hannes Reinecke   2018-10-17  2377  		return true;
77266186397c6c Hannes Reinecke   2018-10-17  2378  	default:
77266186397c6c Hannes Reinecke   2018-10-17  2379  		dev_err(&pdev->dev, "Unknown Initialization Error %02X\n",
77266186397c6c Hannes Reinecke   2018-10-17  2380  			status);
77266186397c6c Hannes Reinecke   2018-10-17  2381  		return true;
77266186397c6c Hannes Reinecke   2018-10-17  2382  	}
77266186397c6c Hannes Reinecke   2018-10-17  2383  	return false;
77266186397c6c Hannes Reinecke   2018-10-17  2384  }
77266186397c6c Hannes Reinecke   2018-10-17  2385  
77266186397c6c Hannes Reinecke   2018-10-17  2386  /*
77266186397c6c Hannes Reinecke   2018-10-17  2387   * Hardware-specific functions
77266186397c6c Hannes Reinecke   2018-10-17  2388   */
77266186397c6c Hannes Reinecke   2018-10-17  2389  
77266186397c6c Hannes Reinecke   2018-10-17  2390  /*
77266186397c6c Hannes Reinecke   2018-10-17  2391   * DAC960 GEM Series Controllers.
77266186397c6c Hannes Reinecke   2018-10-17  2392   */
77266186397c6c Hannes Reinecke   2018-10-17  2393  
77266186397c6c Hannes Reinecke   2018-10-17  2394  static inline void DAC960_GEM_hw_mbox_new_cmd(void __iomem *base)
77266186397c6c Hannes Reinecke   2018-10-17  2395  {
77266186397c6c Hannes Reinecke   2018-10-17  2396  	__le32 val = cpu_to_le32(DAC960_GEM_IDB_HWMBOX_NEW_CMD << 24);
77266186397c6c Hannes Reinecke   2018-10-17  2397  
77266186397c6c Hannes Reinecke   2018-10-17  2398  	writel(val, base + DAC960_GEM_IDB_READ_OFFSET);
77266186397c6c Hannes Reinecke   2018-10-17  2399  }
77266186397c6c Hannes Reinecke   2018-10-17  2400  
77266186397c6c Hannes Reinecke   2018-10-17  2401  static inline void DAC960_GEM_ack_hw_mbox_status(void __iomem *base)
77266186397c6c Hannes Reinecke   2018-10-17  2402  {
77266186397c6c Hannes Reinecke   2018-10-17  2403  	__le32 val = cpu_to_le32(DAC960_GEM_IDB_HWMBOX_ACK_STS << 24);
77266186397c6c Hannes Reinecke   2018-10-17  2404  
77266186397c6c Hannes Reinecke   2018-10-17  2405  	writel(val, base + DAC960_GEM_IDB_CLEAR_OFFSET);
77266186397c6c Hannes Reinecke   2018-10-17  2406  }
77266186397c6c Hannes Reinecke   2018-10-17  2407  
77266186397c6c Hannes Reinecke   2018-10-17  2408  static inline void DAC960_GEM_reset_ctrl(void __iomem *base)
77266186397c6c Hannes Reinecke   2018-10-17  2409  {
77266186397c6c Hannes Reinecke   2018-10-17  2410  	__le32 val = cpu_to_le32(DAC960_GEM_IDB_CTRL_RESET << 24);
77266186397c6c Hannes Reinecke   2018-10-17  2411  
77266186397c6c Hannes Reinecke   2018-10-17  2412  	writel(val, base + DAC960_GEM_IDB_READ_OFFSET);
77266186397c6c Hannes Reinecke   2018-10-17  2413  }
77266186397c6c Hannes Reinecke   2018-10-17  2414  
77266186397c6c Hannes Reinecke   2018-10-17  2415  static inline void DAC960_GEM_mem_mbox_new_cmd(void __iomem *base)
77266186397c6c Hannes Reinecke   2018-10-17  2416  {
77266186397c6c Hannes Reinecke   2018-10-17  2417  	__le32 val = cpu_to_le32(DAC960_GEM_IDB_HWMBOX_NEW_CMD << 24);
77266186397c6c Hannes Reinecke   2018-10-17  2418  
77266186397c6c Hannes Reinecke   2018-10-17  2419  	writel(val, base + DAC960_GEM_IDB_READ_OFFSET);
77266186397c6c Hannes Reinecke   2018-10-17  2420  }
77266186397c6c Hannes Reinecke   2018-10-17  2421  
77266186397c6c Hannes Reinecke   2018-10-17  2422  static inline bool DAC960_GEM_hw_mbox_is_full(void __iomem *base)
77266186397c6c Hannes Reinecke   2018-10-17  2423  {
77266186397c6c Hannes Reinecke   2018-10-17  2424  	__le32 val;
77266186397c6c Hannes Reinecke   2018-10-17  2425  
77266186397c6c Hannes Reinecke   2018-10-17  2426  	val = readl(base + DAC960_GEM_IDB_READ_OFFSET);
77266186397c6c Hannes Reinecke   2018-10-17  2427  	return (le32_to_cpu(val) >> 24) & DAC960_GEM_IDB_HWMBOX_FULL;
77266186397c6c Hannes Reinecke   2018-10-17  2428  }
77266186397c6c Hannes Reinecke   2018-10-17  2429  
77266186397c6c Hannes Reinecke   2018-10-17  2430  static inline bool DAC960_GEM_init_in_progress(void __iomem *base)
77266186397c6c Hannes Reinecke   2018-10-17  2431  {
77266186397c6c Hannes Reinecke   2018-10-17  2432  	__le32 val;
77266186397c6c Hannes Reinecke   2018-10-17  2433  
77266186397c6c Hannes Reinecke   2018-10-17 @2434  	val = readl(base + DAC960_GEM_IDB_READ_OFFSET);
77266186397c6c Hannes Reinecke   2018-10-17  2435  	return (le32_to_cpu(val) >> 24) & DAC960_GEM_IDB_INIT_IN_PROGRESS;
77266186397c6c Hannes Reinecke   2018-10-17  2436  }
77266186397c6c Hannes Reinecke   2018-10-17  2437  

:::::: The code at line 2434 was first introduced by commit
:::::: 77266186397c6c782a3f670d32808a9671806ec5 scsi: myrs: Add Mylex RAID controller (SCSI interface)

:::::: TO: Hannes Reinecke <hare@...e.com>
:::::: CC: Martin K. Petersen <martin.petersen@...cle.com>

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

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ