mei: me: store irq number in the hw struct.
authorAlexander Usyskin <alexander.usyskin@intel.com>
Wed, 6 Nov 2019 22:38:40 +0000 (00:38 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 7 Nov 2019 08:35:48 +0000 (09:35 +0100)
Store irq number in hw struct to by used by synchronize_irq().
This is to allow working with mei devices
embedded within another pci devices, via MFD framework,
where mei device is represented as a platform device.

Bump the copyright year to 2019 on hw-me.c and hw-me.h

Signed-off-by: Alexander Usyskin <alexander.usyskin@intel.com>
Signed-off-by: Tomas Winkler <tomas.winkler@intel.com>
Link: https://lore.kernel.org/r/20191106223841.15802-3-tomas.winkler@intel.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/misc/mei/hw-me.c
drivers/misc/mei/hw-me.h
drivers/misc/mei/pci-me.c

index 7d241c70e3e02d89e67fb1716f1b2da553d3d09e..23606d0ddcd6f485faa3bd639273ec6a7d364f78 100644 (file)
@@ -323,9 +323,9 @@ static void mei_me_intr_disable(struct mei_device *dev)
  */
 static void mei_me_synchronize_irq(struct mei_device *dev)
 {
-       struct pci_dev *pdev = to_pci_dev(dev->dev);
+       struct mei_me_hw *hw = to_me_hw(dev);
 
-       synchronize_irq(pdev->irq);
+       synchronize_irq(hw->irq);
 }
 
 /**
index b39347faadf539e358304d391549c2b6e5e2dc36..c45b32a7cc46fa43009d4ae680572bae4527b706 100644 (file)
@@ -42,6 +42,7 @@ struct mei_cfg {
  *
  * @cfg: per device generation config and ops
  * @mem_addr: io memory address
+ * @irq: irq number
  * @pg_state: power gating state
  * @d0i3_supported: di03 support
  * @hbuf_depth: depth of hardware host/write buffer in slots
@@ -49,6 +50,7 @@ struct mei_cfg {
 struct mei_me_hw {
        const struct mei_cfg *cfg;
        void __iomem *mem_addr;
+       int irq;
        enum mei_pg_state pg_state;
        bool d0i3_supported;
        u8 hbuf_depth;
index e382ecca96d7ebbe4576d235654018a7d1435f5c..6233b3ca1c1dabba46f7d0c4097a4a58a89d47dd 100644 (file)
@@ -199,6 +199,7 @@ static int mei_me_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
        }
        hw = to_me_hw(dev);
        hw->mem_addr = pcim_iomap_table(pdev)[0];
+       hw->irq = pdev->irq;
 
        pci_enable_msi(pdev);