From dedb5bd3876d14b667e506fc41b9a630c4a03551 Mon Sep 17 00:00:00 2001 From: Ralph Metzler Date: Fri, 2 Mar 2018 10:46:28 +0100 Subject: [PATCH] fixes for 3.x kernels --- ddbridge/ddbridge-main.c | 21 +++++++++++++++++++++ dvb-core/dvb_net.c | 2 +- 2 files changed, 22 insertions(+), 1 deletion(-) diff --git a/ddbridge/ddbridge-main.c b/ddbridge/ddbridge-main.c index 61e72aa..abe1066 100644 --- a/ddbridge/ddbridge-main.c +++ b/ddbridge/ddbridge-main.c @@ -32,10 +32,27 @@ MODULE_PARM_DESC(msi, #endif #if (KERNEL_VERSION(4, 8, 0) > LINUX_VERSION_CODE) +#if (KERNEL_VERSION(3, 19, 0) > LINUX_VERSION_CODE) +#define msi_desc_to_dev(desc) (&(desc)->dev.dev) +#define dev_to_msi_list(dev) (&to_pci_dev((dev))->msi_list) +#define first_msi_entry(dev) \ + list_first_entry(dev_to_msi_list((dev)), struct msi_desc, list) +#define for_each_msi_entry(desc, dev) \ + list_for_each_entry((desc), dev_to_msi_list((dev)), list) + +#ifdef CONFIG_PCI_MSI +#define first_pci_msi_entry(pdev) first_msi_entry(&(pdev)->dev) +#define for_each_pci_msi_entry(desc, pdev) \ + for_each_msi_entry((desc), &(pdev)->dev) +#endif + +#endif + #include int pci_irq_vector(struct pci_dev *dev, unsigned int nr) { +#ifdef CONFIG_PCI_MSI if (dev->msix_enabled) { struct msi_desc *entry; int i = 0; @@ -48,6 +65,8 @@ int pci_irq_vector(struct pci_dev *dev, unsigned int nr) WARN_ON_ONCE(1); return -EINVAL; } +/* This does not work < 3.19 because nvec_used is used differently. */ +#if (KERNEL_VERSION(3, 19, 0) <= LINUX_VERSION_CODE) if (dev->msi_enabled) { struct msi_desc *entry = first_pci_msi_entry(dev); @@ -57,6 +76,8 @@ int pci_irq_vector(struct pci_dev *dev, unsigned int nr) if (WARN_ON_ONCE(nr > 0)) return -EINVAL; } +#endif +#endif return dev->irq + nr; } #endif diff --git a/dvb-core/dvb_net.c b/dvb-core/dvb_net.c index e22fbef..481db2d 100644 --- a/dvb-core/dvb_net.c +++ b/dvb-core/dvb_net.c @@ -1382,7 +1382,7 @@ static int dvb_net_add_if(struct dvb_net *dvbnet, u16 pid, u8 feedtype) return -EINVAL; net = alloc_netdev(sizeof(struct dvb_net_priv), "dvb", -#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 14, 0)) +#if (LINUX_VERSION_CODE >= KERNEL_VERSION(3, 17, 0)) NET_NAME_UNKNOWN, #endif dvb_net_setup);