Hi Holger,

[auto build test ERROR on char-misc/char-misc-testing]
[also build test ERROR on v4.9]
[cannot apply to ljones-mfd/for-mfd-next next-20161213]
[if your patch is applied to the wrong git tree, please drop us a note to help 
improve the system]

url:    
https://github.com/0day-ci/linux/commits/Holger-Dengler/Eberspaecher-Flexcard-PMC-II-base-support/20161214-082350
config: arm-allmodconfig (attached as .config)
compiler: arm-linux-gnueabi-gcc (Debian 6.1.1-9) 6.1.1 20160705
reproduce:
        wget 
https://git.kernel.org/cgit/linux/kernel/git/wfg/lkp-tests.git/plain/sbin/make.cross
 -O ~/bin/make.cross
        chmod +x ~/bin/make.cross
        # save the attached .config to linux build tree
        make.cross ARCH=arm 

All error/warnings (new ones prefixed by >>):

   drivers/mfd/flexcard_irq.c: In function 'flexcard_demux':
>> drivers/mfd/flexcard_irq.c:111:3: error: implicit declaration of function 
>> 'generic_handle_irq' [-Werror=implicit-function-declaration]
      generic_handle_irq(cur);
      ^~~~~~~~~~~~~~~~~~
   drivers/mfd/flexcard_irq.c: In function 'flexcard_irq_ack':
>> drivers/mfd/flexcard_irq.c:119:33: error: implicit declaration of function 
>> 'irq_data_get_irq_chip_data' [-Werror=implicit-function-declaration]
     struct flexcard_device *priv = irq_data_get_irq_chip_data(d);
                                    ^~~~~~~~~~~~~~~~~~~~~~~~~~
>> drivers/mfd/flexcard_irq.c:119:33: warning: initialization makes pointer 
>> from integer without a cast [-Wint-conversion]
>> drivers/mfd/flexcard_irq.c:120:51: error: dereferencing pointer to 
>> incomplete type 'struct irq_data'
     const struct fc_irq_tab *tp = &flexcard_irq_tab[d->hwirq];
                                                      ^~
   drivers/mfd/flexcard_irq.c: In function 'flexcard_irq_mask':
   drivers/mfd/flexcard_irq.c:128:33: warning: initialization makes pointer 
from integer without a cast [-Wint-conversion]
     struct flexcard_device *priv = irq_data_get_irq_chip_data(d);
                                    ^~~~~~~~~~~~~~~~~~~~~~~~~~
   drivers/mfd/flexcard_irq.c: In function 'flexcard_irq_unmask':
   drivers/mfd/flexcard_irq.c:141:33: warning: initialization makes pointer 
from integer without a cast [-Wint-conversion]
     struct flexcard_device *priv = irq_data_get_irq_chip_data(d);
                                    ^~~~~~~~~~~~~~~~~~~~~~~~~~
   drivers/mfd/flexcard_irq.c: At top level:
>> drivers/mfd/flexcard_irq.c:175:15: error: variable 'flexcard_irq_chip' has 
>> initializer but incomplete type
    static struct irq_chip flexcard_irq_chip = {
                  ^~~~~~~~
>> drivers/mfd/flexcard_irq.c:176:2: error: unknown field 'name' specified in 
>> initializer
     .name  = "flexcard_irq",
     ^
>> drivers/mfd/flexcard_irq.c:176:11: warning: excess elements in struct 
>> initializer
     .name  = "flexcard_irq",
              ^~~~~~~~~~~~~~
   drivers/mfd/flexcard_irq.c:176:11: note: (near initialization for 
'flexcard_irq_chip')
>> drivers/mfd/flexcard_irq.c:177:2: error: unknown field 'irq_ack' specified 
>> in initializer
     .irq_ack = flexcard_irq_ack,
     ^
   drivers/mfd/flexcard_irq.c:177:13: warning: excess elements in struct 
initializer
     .irq_ack = flexcard_irq_ack,
                ^~~~~~~~~~~~~~~~
   drivers/mfd/flexcard_irq.c:177:13: note: (near initialization for 
'flexcard_irq_chip')
>> drivers/mfd/flexcard_irq.c:178:2: error: unknown field 'irq_mask' specified 
>> in initializer
     .irq_mask = flexcard_irq_mask,
     ^
   drivers/mfd/flexcard_irq.c:178:14: warning: excess elements in struct 
initializer
     .irq_mask = flexcard_irq_mask,
                 ^~~~~~~~~~~~~~~~~
   drivers/mfd/flexcard_irq.c:178:14: note: (near initialization for 
'flexcard_irq_chip')
>> drivers/mfd/flexcard_irq.c:179:2: error: unknown field 'irq_unmask' 
>> specified in initializer
     .irq_unmask = flexcard_irq_unmask,
     ^
   drivers/mfd/flexcard_irq.c:179:16: warning: excess elements in struct 
initializer
     .irq_unmask = flexcard_irq_unmask,
                   ^~~~~~~~~~~~~~~~~~~
   drivers/mfd/flexcard_irq.c:179:16: note: (near initialization for 
'flexcard_irq_chip')
   drivers/mfd/flexcard_irq.c: In function 'flexcard_irq_domain_map':
>> drivers/mfd/flexcard_irq.c:187:2: error: implicit declaration of function 
>> 'irq_set_chip_and_handler_name' [-Werror=implicit-function-declaration]
     irq_set_chip_and_handler_name(irq, &flexcard_irq_chip,
     ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~
>> drivers/mfd/flexcard_irq.c:188:11: error: 'handle_level_irq' undeclared 
>> (first use in this function)
              handle_level_irq, "flexcard");
              ^~~~~~~~~~~~~~~~
   drivers/mfd/flexcard_irq.c:188:11: note: each undeclared identifier is 
reported only once for each function it appears in
>> drivers/mfd/flexcard_irq.c:189:2: error: implicit declaration of function 
>> 'irq_set_chip_data' [-Werror=implicit-function-declaration]
     irq_set_chip_data(irq, priv);
     ^~~~~~~~~~~~~~~~~
>> drivers/mfd/flexcard_irq.c:190:2: error: implicit declaration of function 
>> 'irq_modify_status' [-Werror=implicit-function-declaration]
     irq_modify_status(irq, IRQ_NOREQUEST | IRQ_NOAUTOEN, IRQ_NOPROBE);
     ^~~~~~~~~~~~~~~~~
>> drivers/mfd/flexcard_irq.c:190:25: error: 'IRQ_NOREQUEST' undeclared (first 
>> use in this function)
     irq_modify_status(irq, IRQ_NOREQUEST | IRQ_NOAUTOEN, IRQ_NOPROBE);
                            ^~~~~~~~~~~~~
>> drivers/mfd/flexcard_irq.c:190:41: error: 'IRQ_NOAUTOEN' undeclared (first 
>> use in this function)
     irq_modify_status(irq, IRQ_NOREQUEST | IRQ_NOAUTOEN, IRQ_NOPROBE);
                                            ^~~~~~~~~~~~
>> drivers/mfd/flexcard_irq.c:190:55: error: 'IRQ_NOPROBE' undeclared (first 
>> use in this function)
     irq_modify_status(irq, IRQ_NOREQUEST | IRQ_NOAUTOEN, IRQ_NOPROBE);
                                                          ^~~~~~~~~~~
   drivers/mfd/flexcard_irq.c: At top level:
>> drivers/mfd/flexcard_irq.c:175:24: error: storage size of 
>> 'flexcard_irq_chip' isn't known
    static struct irq_chip flexcard_irq_chip = {
                           ^~~~~~~~~~~~~~~~~
   cc1: some warnings being treated as errors

vim +/generic_handle_irq +111 drivers/mfd/flexcard_irq.c

   105  
   106          stat = readl(&priv->bar0->conf.irs) & VALID_DEVIRQ_MSK;
   107          while (stat) {
   108                  slot = __ffs(stat);
   109                  stat &= (1 << slot);
   110                  cur = irq_linear_revmap(priv->irq_domain, slot);
 > 111                  generic_handle_irq(cur);
   112                  ret = IRQ_HANDLED;
   113          }
   114          return ret;
   115  }
   116  
   117  static void flexcard_irq_ack(struct irq_data *d)
   118  {
 > 119          struct flexcard_device *priv = irq_data_get_irq_chip_data(d);
 > 120          const struct fc_irq_tab *tp = &flexcard_irq_tab[d->hwirq];
   121          void __iomem *p = (void __iomem *)priv->bar0 + tp->ackoffs;
   122  
   123          writel(tp->ack, p);
   124  }
   125  
   126  static void flexcard_irq_mask(struct irq_data *d)
   127  {
 > 128          struct flexcard_device *priv = irq_data_get_irq_chip_data(d);
   129          const struct fc_irq_tab *tp = &flexcard_irq_tab[d->hwirq];
   130          void __iomem *p = (void __iomem *)priv->bar0 + tp->mskoffs;
   131          u32 *msk = (void *)priv + tp->mskcache;
   132  
   133          raw_spin_lock(&priv->irq_lock);
   134          *msk &= ~tp->msk;
   135          writel(*msk, p);
   136          raw_spin_unlock(&priv->irq_lock);
   137  }
   138  
   139  static void flexcard_irq_unmask(struct irq_data *d)
   140  {
 > 141          struct flexcard_device *priv = irq_data_get_irq_chip_data(d);
   142          const struct fc_irq_tab *tp = &flexcard_irq_tab[d->hwirq];
   143          void __iomem *p = (void __iomem *)priv->bar0 + tp->mskoffs;
   144          u32 *msk = (void *)priv + tp->mskcache;
   145  
   146          raw_spin_lock(&priv->irq_lock);
   147          *msk |= tp->msk;
   148          writel(*msk, p);
   149          raw_spin_unlock(&priv->irq_lock);
   150  }
   151  
   152  static int flexcard_req_irq(struct pci_dev *pdev)
   153  {
   154          struct flexcard_device *priv = pci_get_drvdata(pdev);
   155          int ret;
   156  
   157          ret = pci_enable_msi(pdev);
   158          if (ret) {
   159                  dev_warn(&pdev->dev, "could not enable MSI\n");
   160                  /* shared PCI irq fallback */
   161                  return request_irq(pdev->irq, flexcard_demux,
   162                                     IRQF_NO_THREAD | IRQF_SHARED,
   163                                     "flexcard", priv);
   164          }
   165          dev_info(&pdev->dev, "MSI enabled\n");
   166  
   167          ret = request_irq(pdev->irq, flexcard_demux, IRQF_NO_THREAD,
   168                            "flexcard", priv);
   169          if (ret)
   170                  pci_disable_msi(pdev);
   171  
   172          return ret;
   173  }
   174  
 > 175  static struct irq_chip flexcard_irq_chip = {
 > 176          .name           = "flexcard_irq",
 > 177          .irq_ack        = flexcard_irq_ack,
 > 178          .irq_mask       = flexcard_irq_mask,
 > 179          .irq_unmask     = flexcard_irq_unmask,
   180  };
   181  
   182  static int flexcard_irq_domain_map(struct irq_domain *d, unsigned int 
irq,
   183                                     irq_hw_number_t hw)
   184  {
   185          struct flexcard_device *priv = d->host_data;
   186  
 > 187          irq_set_chip_and_handler_name(irq, &flexcard_irq_chip,
 > 188                                        handle_level_irq, "flexcard");
 > 189          irq_set_chip_data(irq, priv);
 > 190          irq_modify_status(irq, IRQ_NOREQUEST | IRQ_NOAUTOEN, 
 > IRQ_NOPROBE);
   191  
   192          return 0;
   193  }

---
0-DAY kernel test infrastructure                Open Source Technology Center
https://lists.01.org/pipermail/kbuild-all                   Intel Corporation

Attachment: .config.gz
Description: application/gzip

Reply via email to