media: ddbridge: move device ID table to ddbridge-hw
authorDaniel Scheller <d.scheller@gmx.net>
Sun, 20 Aug 2017 10:41:11 +0000 (06:41 -0400)
committerMauro Carvalho Chehab <mchehab@s-opensource.com>
Sun, 20 Aug 2017 11:31:37 +0000 (07:31 -0400)
This further cleans up ddbridge-main from hardware-related data and moves
the exact card type determination into ddbridge-hw.c:get_ddb_info(), right
to the hardware maps/structs. Also, const'ify more structs and pointers.

Signed-off-by: Daniel Scheller <d.scheller@gmx.net>
Signed-off-by: Mauro Carvalho Chehab <mchehab@s-opensource.com>
drivers/media/pci/ddbridge/ddbridge-core.c
drivers/media/pci/ddbridge/ddbridge-hw.c
drivers/media/pci/ddbridge/ddbridge-hw.h
drivers/media/pci/ddbridge/ddbridge-main.c
drivers/media/pci/ddbridge/ddbridge.h

index 98a12c644e4402df2400f3255b772f9f7849cee4..c80e1d8498d36e9259dc222279b95c1ae5a396ff 100644 (file)
@@ -2430,7 +2430,7 @@ static void output_handler(unsigned long data)
 
 static struct ddb_regmap *io_regmap(struct ddb_io *io, int link)
 {
-       struct ddb_info *info;
+       const struct ddb_info *info;
 
        if (link)
                info = io->port->dev->link[io->port->lnr].info;
@@ -2564,7 +2564,7 @@ void ddb_ports_init(struct ddb *dev)
 {
        u32 i, l, p;
        struct ddb_port *port;
-       struct ddb_info *info;
+       const struct ddb_info *info;
        struct ddb_regmap *rm;
 
        for (p = l = 0; l < DDB_MAX_LINK; l++) {
@@ -3527,7 +3527,7 @@ static int tempmon_init(struct ddb_link *link, int first_time)
 
 static int ddb_init_tempmon(struct ddb_link *link)
 {
-       struct ddb_info *info = link->info;
+       const struct ddb_info *info = link->info;
 
        if (!info->tempmon_irq)
                return 0;
@@ -3545,7 +3545,7 @@ static int ddb_init_tempmon(struct ddb_link *link)
 
 static int ddb_init_boards(struct ddb *dev)
 {
-       struct ddb_info *info;
+       const struct ddb_info *info;
        struct ddb_link *link;
        u32 l;
 
index 317dc865e99c031978bab970cb32e3db245fb7d7..3b208d5bf4ad0ecace3ad14b134c4d2c2e1d09db 100644 (file)
@@ -17,6 +17,7 @@
  */
 
 #include "ddbridge.h"
+#include "ddbridge-hw.h"
 
 /******************************************************************************/
 
@@ -309,3 +310,67 @@ const struct ddb_info ddb_s2_48 = {
        .board_control = 1,
        .tempmon_irq = 24,
 };
+
+/****************************************************************************/
+/****************************************************************************/
+/****************************************************************************/
+
+#define DDB_DEVID(_device, _subdevice, _info) { \
+       .vendor = DDVID, \
+       .device = _device, \
+       .subvendor = DDVID, \
+       .subdevice = _subdevice, \
+       .info = &_info }
+
+static const struct ddb_device_id ddb_device_ids[] = {
+       /* PCIe devices */
+       DDB_DEVID(0x0002, 0x0001, ddb_octopus),
+       DDB_DEVID(0x0003, 0x0001, ddb_octopus),
+       DDB_DEVID(0x0005, 0x0004, ddb_octopusv3),
+       DDB_DEVID(0x0003, 0x0002, ddb_octopus_le),
+       DDB_DEVID(0x0003, 0x0003, ddb_octopus_oem),
+       DDB_DEVID(0x0003, 0x0010, ddb_octopus_mini),
+       DDB_DEVID(0x0005, 0x0011, ddb_octopus_mini),
+       DDB_DEVID(0x0003, 0x0020, ddb_v6),
+       DDB_DEVID(0x0003, 0x0021, ddb_v6_5),
+       DDB_DEVID(0x0006, 0x0022, ddb_v7),
+       DDB_DEVID(0x0006, 0x0024, ddb_v7a),
+       DDB_DEVID(0x0003, 0x0030, ddb_dvbct),
+       DDB_DEVID(0x0003, 0xdb03, ddb_satixS2v3),
+       DDB_DEVID(0x0006, 0x0031, ddb_ctv7),
+       DDB_DEVID(0x0006, 0x0032, ddb_ctv7),
+       DDB_DEVID(0x0006, 0x0033, ddb_ctv7),
+       DDB_DEVID(0x0007, 0x0023, ddb_s2_48),
+       DDB_DEVID(0x0008, 0x0034, ddb_ct2_8),
+       DDB_DEVID(0x0008, 0x0035, ddb_c2t2_8),
+       DDB_DEVID(0x0008, 0x0036, ddb_isdbt_8),
+       DDB_DEVID(0x0008, 0x0037, ddb_c2t2i_v0_8),
+       DDB_DEVID(0x0008, 0x0038, ddb_c2t2i_8),
+       DDB_DEVID(0x0006, 0x0039, ddb_ctv7),
+       DDB_DEVID(0x0011, 0x0040, ddb_ci),
+       DDB_DEVID(0x0011, 0x0041, ddb_cis),
+       DDB_DEVID(0x0012, 0x0042, ddb_ci),
+       DDB_DEVID(0x0013, 0x0043, ddb_ci_s2_pro),
+       DDB_DEVID(0x0013, 0x0044, ddb_ci_s2_pro_a),
+};
+
+/****************************************************************************/
+
+const struct ddb_info *get_ddb_info(u16 vendor, u16 device,
+                                   u16 subvendor, u16 subdevice)
+{
+       int i;
+
+       for (i = 0; i < ARRAY_SIZE(ddb_device_ids); i++) {
+               const struct ddb_device_id *id = &ddb_device_ids[i];
+
+               if (vendor == id->vendor &&
+                   device == id->device &&
+                   subvendor == id->subvendor &&
+                   ((subdevice == id->subdevice) ||
+                    (id->subdevice == 0xffff)))
+                       return id->info;
+       }
+
+       return &ddb_none;
+}
index d26cd9c977d831bc8751dcfb64d54dc17b50d349..1a985d0a1a979482785bad86962c0de3411c0716 100644 (file)
 
 /******************************************************************************/
 
+#define DDVID 0xdd01 /* Digital Devices Vendor ID */
+
+/******************************************************************************/
+
+struct ddb_device_id {
+       u16 vendor;
+       u16 device;
+       u16 subvendor;
+       u16 subdevice;
+       const struct ddb_info *info;
+};
+
+/******************************************************************************/
+
 extern const struct ddb_info ddb_none;
 extern const struct ddb_info ddb_octopus;
 extern const struct ddb_info ddb_octopusv3;
@@ -53,4 +67,9 @@ extern const struct ddb_info ddb_c2t2i_8;
 
 extern const struct ddb_info ddb_s2_48;
 
+/****************************************************************************/
+
+const struct ddb_info *get_ddb_info(u16 vendor, u16 device,
+                                   u16 subvendor, u16 subdevice);
+
 #endif /* _DDBRIDGE_HW_H */
index 3cb6bb265172cb9cdddfb9c814ee1f4fb01caec7..ec608c496b69e09471cd5bd4de6df26d8c149070 100644 (file)
@@ -231,10 +231,12 @@ static int ddb_probe(struct pci_dev *pdev,
        dev->link[0].ids.vendor = id->vendor;
        dev->link[0].ids.device = id->device;
        dev->link[0].ids.subvendor = id->subvendor;
-       dev->link[0].ids.subdevice = id->subdevice;
+       dev->link[0].ids.subdevice = pdev->subsystem_device;
 
        dev->link[0].dev = dev;
-       dev->link[0].info = (struct ddb_info *) id->driver_data;
+       dev->link[0].info = get_ddb_info(id->vendor, id->device,
+                                        id->subvendor, pdev->subsystem_device);
+
        dev_info(&pdev->dev, "detected %s\n", dev->link[0].info->name);
 
        dev->regs_len = pci_resource_len(dev->pdev, 0);
@@ -286,46 +288,11 @@ fail:
 /****************************************************************************/
 /****************************************************************************/
 
-#define DDVID 0xdd01 /* Digital Devices Vendor ID */
-
-#define DDB_DEVICE(_device, _subdevice, _driver_data) { \
-               PCI_DEVICE_SUB(DDVID, _device, DDVID, _subdevice), \
-                       .driver_data = (kernel_ulong_t) &_driver_data }
-
-#define DDB_DEVICE_ANY(_device) { \
-               PCI_DEVICE_SUB(DDVID, _device, DDVID, PCI_ANY_ID), \
-                       .driver_data = (kernel_ulong_t) &ddb_none }
+#define DDB_DEVICE_ANY(_device) \
+               { PCI_DEVICE_SUB(DDVID, _device, DDVID, PCI_ANY_ID) }
 
 static const struct pci_device_id ddb_id_table[] = {
-       DDB_DEVICE(0x0002, 0x0001, ddb_octopus),
-       DDB_DEVICE(0x0003, 0x0001, ddb_octopus),
-       DDB_DEVICE(0x0005, 0x0004, ddb_octopusv3),
-       DDB_DEVICE(0x0003, 0x0002, ddb_octopus_le),
-       DDB_DEVICE(0x0003, 0x0003, ddb_octopus_oem),
-       DDB_DEVICE(0x0003, 0x0010, ddb_octopus_mini),
-       DDB_DEVICE(0x0005, 0x0011, ddb_octopus_mini),
-       DDB_DEVICE(0x0003, 0x0020, ddb_v6),
-       DDB_DEVICE(0x0003, 0x0021, ddb_v6_5),
-       DDB_DEVICE(0x0006, 0x0022, ddb_v7),
-       DDB_DEVICE(0x0006, 0x0024, ddb_v7a),
-       DDB_DEVICE(0x0003, 0x0030, ddb_dvbct),
-       DDB_DEVICE(0x0003, 0xdb03, ddb_satixS2v3),
-       DDB_DEVICE(0x0006, 0x0031, ddb_ctv7),
-       DDB_DEVICE(0x0006, 0x0032, ddb_ctv7),
-       DDB_DEVICE(0x0006, 0x0033, ddb_ctv7),
-       DDB_DEVICE(0x0007, 0x0023, ddb_s2_48),
-       DDB_DEVICE(0x0008, 0x0034, ddb_ct2_8),
-       DDB_DEVICE(0x0008, 0x0035, ddb_c2t2_8),
-       DDB_DEVICE(0x0008, 0x0036, ddb_isdbt_8),
-       DDB_DEVICE(0x0008, 0x0037, ddb_c2t2i_v0_8),
-       DDB_DEVICE(0x0008, 0x0038, ddb_c2t2i_8),
-       DDB_DEVICE(0x0006, 0x0039, ddb_ctv7),
-       DDB_DEVICE(0x0011, 0x0040, ddb_ci),
-       DDB_DEVICE(0x0011, 0x0041, ddb_cis),
-       DDB_DEVICE(0x0012, 0x0042, ddb_ci),
-       DDB_DEVICE(0x0013, 0x0043, ddb_ci_s2_pro),
-       DDB_DEVICE(0x0013, 0x0044, ddb_ci_s2_pro_a),
-       /* in case sub-ids got deleted in flash */
+       DDB_DEVICE_ANY(0x0002),
        DDB_DEVICE_ANY(0x0003),
        DDB_DEVICE_ANY(0x0005),
        DDB_DEVICE_ANY(0x0006),
index 91b58eff951cfaf9c696def4ea71d35855842d11..60fe5ec93f3d1721e0c455346cc1520f62dfc762 100644 (file)
@@ -307,7 +307,7 @@ struct ddb_lnb {
 
 struct ddb_link {
        struct ddb            *dev;
-       struct ddb_info       *info;
+       const struct ddb_info *info;
        u32                    nr;
        u32                    regs;
        spinlock_t             lock;