Commit 43874181 authored by Oliver Endriss's avatar Oliver Endriss Committed by Mauro Carvalho Chehab

V4L/DVB: ngene: Implement support for MSI

Add MSI support, may be enabled with firmware version 18.
Signed-off-by: default avatarOliver Endriss <o.endriss@gmx.de>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent eb05d155
...@@ -1299,11 +1299,14 @@ static void ngene_stop(struct ngene *dev) ...@@ -1299,11 +1299,14 @@ static void ngene_stop(struct ngene *dev)
ngwritel(0, NGENE_EVENT); ngwritel(0, NGENE_EVENT);
ngwritel(0, NGENE_EVENT_HI); ngwritel(0, NGENE_EVENT_HI);
free_irq(dev->pci_dev->irq, dev); free_irq(dev->pci_dev->irq, dev);
if (dev->msi_enabled)
pci_disable_msi(dev->pci_dev);
} }
static int ngene_start(struct ngene *dev) static int ngene_start(struct ngene *dev)
{ {
int stat; int stat;
unsigned long flags;
int i; int i;
pci_set_master(dev->pci_dev); pci_set_master(dev->pci_dev);
...@@ -1333,6 +1336,28 @@ static int ngene_start(struct ngene *dev) ...@@ -1333,6 +1336,28 @@ static int ngene_start(struct ngene *dev)
if (stat < 0) if (stat < 0)
goto fail; goto fail;
#ifdef CONFIG_PCI_MSI
/* enable MSI if kernel and card support it */
if (dev->card_info->msi_supported) {
ngwritel(0, NGENE_INT_ENABLE);
free_irq(dev->pci_dev->irq, dev);
stat = pci_enable_msi(dev->pci_dev);
if (stat) {
printk(KERN_INFO DEVICE_NAME
": MSI not available\n");
flags = IRQF_SHARED;
} else {
flags = 0;
dev->msi_enabled = true;
}
stat = request_irq(dev->pci_dev->irq, irq_handler,
flags, "nGene", dev);
if (stat < 0)
goto fail2;
ngwritel(1, NGENE_INT_ENABLE);
}
#endif
stat = ngene_i2c_init(dev, 0); stat = ngene_i2c_init(dev, 0);
if (stat < 0) if (stat < 0)
goto fail; goto fail;
...@@ -1358,10 +1383,16 @@ static int ngene_start(struct ngene *dev) ...@@ -1358,10 +1383,16 @@ static int ngene_start(struct ngene *dev)
bconf = BUFFER_CONFIG_3333; bconf = BUFFER_CONFIG_3333;
stat = ngene_command_config_buf(dev, bconf); stat = ngene_command_config_buf(dev, bconf);
} }
return stat; if (!stat)
return stat;
/* otherwise error: fall through */
fail: fail:
ngwritel(0, NGENE_INT_ENABLE); ngwritel(0, NGENE_INT_ENABLE);
free_irq(dev->pci_dev->irq, dev); free_irq(dev->pci_dev->irq, dev);
fail2:
if (dev->msi_enabled)
pci_disable_msi(dev->pci_dev);
return stat; return stat;
} }
......
...@@ -725,6 +725,7 @@ struct ngene { ...@@ -725,6 +725,7 @@ struct ngene {
u32 device_version; u32 device_version;
u32 fw_interface_version; u32 fw_interface_version;
u32 icounts; u32 icounts;
bool msi_enabled;
u8 *CmdDoneByte; u8 *CmdDoneByte;
int BootFirmware; int BootFirmware;
...@@ -797,6 +798,7 @@ struct ngene_info { ...@@ -797,6 +798,7 @@ struct ngene_info {
#define NGENE_VBOX_V2 7 #define NGENE_VBOX_V2 7
int fw_version; int fw_version;
bool msi_supported;
char *name; char *name;
int io_type[MAX_STREAM]; int io_type[MAX_STREAM];
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment