PCI: iproc: Use of_device_get_match_data() to simplify probe
authorBjorn Helgaas <bhelgaas@google.com>
Tue, 31 Jan 2017 22:36:32 +0000 (16:36 -0600)
committerBjorn Helgaas <bhelgaas@google.com>
Tue, 31 Jan 2017 22:36:32 +0000 (16:36 -0600)
The only way to call iproc_pcie_pltfm_probe() is to match an entry in
iproc_pcie_of_match_table[], so match cannot be NULL.

Use of_device_get_match_data() to retrieve the pcie->type.  No functional
change intended.

Based-on-suggestion-from: Geert Uytterhoeven <geert@linux-m68k.org>
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
drivers/pci/host/pcie-iproc-platform.c

index 22d814a78a78bc60eaa61da82ceee561e62eb4d2..f4909bb0b2ad1505c3e084820f36104387add8f5 100644 (file)
@@ -47,7 +47,6 @@ MODULE_DEVICE_TABLE(of, iproc_pcie_of_match_table);
 static int iproc_pcie_pltfm_probe(struct platform_device *pdev)
 {
        struct device *dev = &pdev->dev;
-       const struct of_device_id *of_id;
        struct iproc_pcie *pcie;
        struct device_node *np = dev->of_node;
        struct resource reg;
@@ -55,16 +54,12 @@ static int iproc_pcie_pltfm_probe(struct platform_device *pdev)
        LIST_HEAD(res);
        int ret;
 
-       of_id = of_match_device(iproc_pcie_of_match_table, dev);
-       if (!of_id)
-               return -EINVAL;
-
        pcie = devm_kzalloc(dev, sizeof(*pcie), GFP_KERNEL);
        if (!pcie)
                return -ENOMEM;
 
        pcie->dev = dev;
-       pcie->type = (enum iproc_pcie_type)of_id->data;
+       pcie->type = (enum iproc_pcie_type) of_device_get_match_data(dev);
 
        ret = of_address_to_resource(np, 0, &reg);
        if (ret < 0) {