[<prev] [next>] [day] [month] [year] [list]
Message-ID: <202411071733.0WhA131G-lkp@intel.com>
Date: Thu, 7 Nov 2024 17:25:03 +0800
From: kernel test robot <lkp@...el.com>
To: Artur Rojek <contact@...ur-rojek.eu>
Cc: oe-kbuild-all@...ts.linux.dev, linux-kernel@...r.kernel.org,
John Paul Adrian Glaubitz <glaubitz@...sik.fu-berlin.de>
Subject: arch/sh/cchips/hd6446x/hd64461.c:27:16: sparse: sparse: incorrect
type in argument 1 (different base types)
Hi Artur,
First bad commit (maybe != root cause):
tree: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git master
head: ff7afaeca1a15fbeaa2c4795ee806c0667bd77b2
commit: 1e21acb7fbfb15fcb4afe21fb5a50a1bc00743ec sh: hd64461: Make setup_hd64461() static
date: 8 months ago
config: sh-randconfig-r111-20241107 (https://download.01.org/0day-ci/archive/20241107/202411071733.0WhA131G-lkp@intel.com/config)
compiler: sh4-linux-gcc (GCC) 14.2.0
reproduce: (https://download.01.org/0day-ci/archive/20241107/202411071733.0WhA131G-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@...el.com>
| Closes: https://lore.kernel.org/oe-kbuild-all/202411071733.0WhA131G-lkp@intel.com/
sparse warnings: (new ones prefixed by >>)
>> arch/sh/cchips/hd6446x/hd64461.c:27:16: sparse: sparse: incorrect type in argument 1 (different base types) @@ expected void const volatile [noderef] __iomem *ptr @@ got unsigned int @@
arch/sh/cchips/hd6446x/hd64461.c:27:16: sparse: expected void const volatile [noderef] __iomem *ptr
arch/sh/cchips/hd6446x/hd64461.c:27:16: sparse: got unsigned int
arch/sh/cchips/hd6446x/hd64461.c:29:9: sparse: sparse: incorrect type in argument 1 (different base types) @@ expected void const volatile [noderef] __iomem *ptr @@ got unsigned int @@
arch/sh/cchips/hd6446x/hd64461.c:29:9: sparse: expected void const volatile [noderef] __iomem *ptr
arch/sh/cchips/hd6446x/hd64461.c:29:9: sparse: got unsigned int
arch/sh/cchips/hd6446x/hd64461.c:38:16: sparse: sparse: incorrect type in argument 1 (different base types) @@ expected void const volatile [noderef] __iomem *ptr @@ got unsigned int @@
arch/sh/cchips/hd6446x/hd64461.c:38:16: sparse: expected void const volatile [noderef] __iomem *ptr
arch/sh/cchips/hd6446x/hd64461.c:38:16: sparse: got unsigned int
arch/sh/cchips/hd6446x/hd64461.c:40:9: sparse: sparse: incorrect type in argument 1 (different base types) @@ expected void const volatile [noderef] __iomem *ptr @@ got unsigned int @@
arch/sh/cchips/hd6446x/hd64461.c:40:9: sparse: expected void const volatile [noderef] __iomem *ptr
arch/sh/cchips/hd6446x/hd64461.c:40:9: sparse: got unsigned int
arch/sh/cchips/hd6446x/hd64461.c:49:17: sparse: sparse: incorrect type in argument 1 (different base types) @@ expected void const volatile [noderef] __iomem *ptr @@ got unsigned int @@
arch/sh/cchips/hd6446x/hd64461.c:49:17: sparse: expected void const volatile [noderef] __iomem *ptr
arch/sh/cchips/hd6446x/hd64461.c:49:17: sparse: got unsigned int
arch/sh/cchips/hd6446x/hd64461.c:62:31: sparse: sparse: incorrect type in argument 1 (different base types) @@ expected void const volatile [noderef] __iomem *ptr @@ got unsigned int @@
arch/sh/cchips/hd6446x/hd64461.c:62:31: sparse: expected void const volatile [noderef] __iomem *ptr
arch/sh/cchips/hd6446x/hd64461.c:62:31: sparse: got unsigned int
>> arch/sh/cchips/hd6446x/hd64461.c:86:9: sparse: sparse: incorrect type in argument 1 (different base types) @@ expected void const volatile [noderef] __iomem *ptr @@ got unsigned long @@
arch/sh/cchips/hd6446x/hd64461.c:86:9: sparse: expected void const volatile [noderef] __iomem *ptr
arch/sh/cchips/hd6446x/hd64461.c:86:9: sparse: got unsigned long
arch/sh/cchips/hd6446x/hd64461.c:88:9: sparse: sparse: incorrect type in argument 1 (different base types) @@ expected void const volatile [noderef] __iomem *ptr @@ got unsigned int @@
arch/sh/cchips/hd6446x/hd64461.c:88:9: sparse: expected void const volatile [noderef] __iomem *ptr
arch/sh/cchips/hd6446x/hd64461.c:88:9: sparse: got unsigned int
arch/sh/cchips/hd6446x/hd64461.c:105:9: sparse: sparse: incorrect type in argument 1 (different base types) @@ expected void const volatile [noderef] __iomem *ptr @@ got unsigned int @@
arch/sh/cchips/hd6446x/hd64461.c:105:9: sparse: expected void const volatile [noderef] __iomem *ptr
arch/sh/cchips/hd6446x/hd64461.c:105:9: sparse: got unsigned int
arch/sh/cchips/hd6446x/hd64461.c:106:9: sparse: sparse: incorrect type in argument 1 (different base types) @@ expected void const volatile [noderef] __iomem *ptr @@ got unsigned int @@
arch/sh/cchips/hd6446x/hd64461.c:106:9: sparse: expected void const volatile [noderef] __iomem *ptr
arch/sh/cchips/hd6446x/hd64461.c:106:9: sparse: got unsigned int
vim +27 arch/sh/cchips/hd6446x/hd64461.c
f1382305b9357c arch/sh/cchips/hd6446x/hd64461.c Kristoffer Ericson 2007-09-11 20
19add7e11656dc arch/sh/cchips/hd6446x/hd64461.c Paul Mundt 2010-10-27 21 static void hd64461_mask_irq(struct irq_data *data)
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 22 {
19add7e11656dc arch/sh/cchips/hd6446x/hd64461.c Paul Mundt 2010-10-27 23 unsigned int irq = data->irq;
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 24 unsigned short nimr;
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 25 unsigned short mask = 1 << (irq - HD64461_IRQBASE);
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 26
135210b378d26f arch/sh/cchips/hd6446x/hd64461.c Matt Fleming 2008-11-28 @27 nimr = __raw_readw(HD64461_NIMR);
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 28 nimr |= mask;
135210b378d26f arch/sh/cchips/hd6446x/hd64461.c Matt Fleming 2008-11-28 29 __raw_writew(nimr, HD64461_NIMR);
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 30 }
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 31
19add7e11656dc arch/sh/cchips/hd6446x/hd64461.c Paul Mundt 2010-10-27 32 static void hd64461_unmask_irq(struct irq_data *data)
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 33 {
19add7e11656dc arch/sh/cchips/hd6446x/hd64461.c Paul Mundt 2010-10-27 34 unsigned int irq = data->irq;
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 35 unsigned short nimr;
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 36 unsigned short mask = 1 << (irq - HD64461_IRQBASE);
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 37
135210b378d26f arch/sh/cchips/hd6446x/hd64461.c Matt Fleming 2008-11-28 38 nimr = __raw_readw(HD64461_NIMR);
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 39 nimr &= ~mask;
135210b378d26f arch/sh/cchips/hd6446x/hd64461.c Matt Fleming 2008-11-28 40 __raw_writew(nimr, HD64461_NIMR);
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 41 }
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 42
19add7e11656dc arch/sh/cchips/hd6446x/hd64461.c Paul Mundt 2010-10-27 43 static void hd64461_mask_and_ack_irq(struct irq_data *data)
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 44 {
19add7e11656dc arch/sh/cchips/hd6446x/hd64461.c Paul Mundt 2010-10-27 45 hd64461_mask_irq(data);
19add7e11656dc arch/sh/cchips/hd6446x/hd64461.c Paul Mundt 2010-10-27 46
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 47 #ifdef CONFIG_HD64461_ENABLER
19add7e11656dc arch/sh/cchips/hd6446x/hd64461.c Paul Mundt 2010-10-27 48 if (data->irq == HD64461_IRQBASE + 13)
135210b378d26f arch/sh/cchips/hd6446x/hd64461.c Matt Fleming 2008-11-28 49 __raw_writeb(0x00, HD64461_PCC1CSCR);
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 50 #endif
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 51 }
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 52
135210b378d26f arch/sh/cchips/hd6446x/hd64461.c Matt Fleming 2008-11-28 53 static struct irq_chip hd64461_irq_chip = {
135210b378d26f arch/sh/cchips/hd6446x/hd64461.c Matt Fleming 2008-11-28 54 .name = "HD64461-IRQ",
19add7e11656dc arch/sh/cchips/hd6446x/hd64461.c Paul Mundt 2010-10-27 55 .irq_mask = hd64461_mask_irq,
19add7e11656dc arch/sh/cchips/hd6446x/hd64461.c Paul Mundt 2010-10-27 56 .irq_mask_ack = hd64461_mask_and_ack_irq,
19add7e11656dc arch/sh/cchips/hd6446x/hd64461.c Paul Mundt 2010-10-27 57 .irq_unmask = hd64461_unmask_irq,
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 58 };
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 59
bd0b9ac405e179 arch/sh/cchips/hd6446x/hd64461.c Thomas Gleixner 2015-09-14 60 static void hd64461_irq_demux(struct irq_desc *desc)
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 61 {
9d56dd3b083a3b arch/sh/cchips/hd6446x/hd64461.c Paul Mundt 2010-01-26 62 unsigned short intv = __raw_readw(HD64461_NIRR);
3bf509230a626d arch/sh/cchips/hd6446x/hd64461.c Rafael Ignacio Zurita 2009-03-20 63 unsigned int ext_irq = HD64461_IRQBASE;
3bf509230a626d arch/sh/cchips/hd6446x/hd64461.c Rafael Ignacio Zurita 2009-03-20 64
3bf509230a626d arch/sh/cchips/hd6446x/hd64461.c Rafael Ignacio Zurita 2009-03-20 65 intv &= (1 << HD64461_IRQ_NUM) - 1;
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 66
b06ede84dd1473 arch/sh/cchips/hd6446x/hd64461.c Paul Mundt 2010-02-05 67 for (; intv; intv >>= 1, ext_irq++) {
b06ede84dd1473 arch/sh/cchips/hd6446x/hd64461.c Paul Mundt 2010-02-05 68 if (!(intv & 1))
b06ede84dd1473 arch/sh/cchips/hd6446x/hd64461.c Paul Mundt 2010-02-05 69 continue;
b06ede84dd1473 arch/sh/cchips/hd6446x/hd64461.c Paul Mundt 2010-02-05 70
b06ede84dd1473 arch/sh/cchips/hd6446x/hd64461.c Paul Mundt 2010-02-05 71 generic_handle_irq(ext_irq);
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 72 }
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 73 }
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 74
1e21acb7fbfb15 arch/sh/cchips/hd6446x/hd64461.c Artur Rojek 2024-02-11 75 static int __init setup_hd64461(void)
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 76 {
051f923d922d10 arch/sh/cchips/hd6446x/hd64461.c Paul Mundt 2012-05-18 77 int irq_base, i;
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 78
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 79 printk(KERN_INFO
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 80 "HD64461 configured at 0x%x on irq %d(mapped into %d to %d)\n",
62669e61a5f559 arch/sh/cchips/hd6446x/hd64461.c Paul Mundt 2009-05-20 81 HD64461_IOBASE, CONFIG_HD64461_IRQ, HD64461_IRQBASE,
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 82 HD64461_IRQBASE + 15);
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 83
135210b378d26f arch/sh/cchips/hd6446x/hd64461.c Matt Fleming 2008-11-28 84 /* Should be at processor specific part.. */
135210b378d26f arch/sh/cchips/hd6446x/hd64461.c Matt Fleming 2008-11-28 85 #if defined(CONFIG_CPU_SUBTYPE_SH7709)
135210b378d26f arch/sh/cchips/hd6446x/hd64461.c Matt Fleming 2008-11-28 @86 __raw_writew(0x2240, INTC_ICR1);
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 87 #endif
135210b378d26f arch/sh/cchips/hd6446x/hd64461.c Matt Fleming 2008-11-28 88 __raw_writew(0xffff, HD64461_NIMR);
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 89
051f923d922d10 arch/sh/cchips/hd6446x/hd64461.c Paul Mundt 2012-05-18 90 irq_base = irq_alloc_descs(HD64461_IRQBASE, HD64461_IRQBASE, 16, -1);
051f923d922d10 arch/sh/cchips/hd6446x/hd64461.c Paul Mundt 2012-05-18 91 if (IS_ERR_VALUE(irq_base)) {
051f923d922d10 arch/sh/cchips/hd6446x/hd64461.c Paul Mundt 2012-05-18 92 pr_err("%s: failed hooking irqs for HD64461\n", __func__);
051f923d922d10 arch/sh/cchips/hd6446x/hd64461.c Paul Mundt 2012-05-18 93 return irq_base;
6eb6f98396f7bd arch/sh/cchips/hd6446x/hd64461.c Paul Mundt 2010-02-02 94 }
6eb6f98396f7bd arch/sh/cchips/hd6446x/hd64461.c Paul Mundt 2010-02-02 95
051f923d922d10 arch/sh/cchips/hd6446x/hd64461.c Paul Mundt 2012-05-18 96 for (i = 0; i < 16; i++)
051f923d922d10 arch/sh/cchips/hd6446x/hd64461.c Paul Mundt 2012-05-18 97 irq_set_chip_and_handler(irq_base + i, &hd64461_irq_chip,
135210b378d26f arch/sh/cchips/hd6446x/hd64461.c Matt Fleming 2008-11-28 98 handle_level_irq);
^1da177e4c3f41 arch/sh/cchips/hd6446x/hd64461/setup.c Linus Torvalds 2005-04-16 99
fcb8918fd242f3 arch/sh/cchips/hd6446x/hd64461.c Thomas Gleixner 2011-03-24 100 irq_set_chained_handler(CONFIG_HD64461_IRQ, hd64461_irq_demux);
fcb8918fd242f3 arch/sh/cchips/hd6446x/hd64461.c Thomas Gleixner 2011-03-24 101 irq_set_irq_type(CONFIG_HD64461_IRQ, IRQ_TYPE_LEVEL_LOW);
3bf509230a626d arch/sh/cchips/hd6446x/hd64461.c Rafael Ignacio Zurita 2009-03-20 102
:::::: The code at line 27 was first introduced by commit
:::::: 135210b378d26f9a9a0c901d0089522c06b5807a sh: Switch HD64461 from hw_interrupt_type to irq_chip
:::::: TO: Matt Fleming <mjf@...too.org>
:::::: CC: Paul Mundt <lethal@...ux-sh.org>
--
0-DAY CI Kernel Test Service
https://github.com/intel/lkp-tests/wiki
Powered by blists - more mailing lists