提交 afe391ad 编写于 作者: S Sergei Shtylyov 提交者: David S. Miller

sh_eth: create initial ID table

We are trying to get away from the current driver's scheme of identifying a SoC
based on #ifdef's and the platform device ID table matching seems to be a good
replacement -- we can use the 'driver_data' field of 'struct platform_device_id'
as a pointer to a 'struct sh_eth_cpu_data'. Start by creating the initial table
with driver's name as the only entry without the driver data. Check  the driver
data in the probe() method and if it's not NULL override 'mdp->cd' from it.
Signed-off-by: NSergei Shtylyov <sergei.shtylyov@cogentembedded.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 e8b265e8
...@@ -2519,6 +2519,7 @@ static int sh_eth_drv_probe(struct platform_device *pdev) ...@@ -2519,6 +2519,7 @@ static int sh_eth_drv_probe(struct platform_device *pdev)
struct net_device *ndev = NULL; struct net_device *ndev = NULL;
struct sh_eth_private *mdp = NULL; struct sh_eth_private *mdp = NULL;
struct sh_eth_plat_data *pd = pdev->dev.platform_data; struct sh_eth_plat_data *pd = pdev->dev.platform_data;
const struct platform_device_id *id = platform_get_device_id(pdev);
/* get base addr */ /* get base addr */
res = platform_get_resource(pdev, IORESOURCE_MEM, 0); res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
...@@ -2582,6 +2583,8 @@ static int sh_eth_drv_probe(struct platform_device *pdev) ...@@ -2582,6 +2583,8 @@ static int sh_eth_drv_probe(struct platform_device *pdev)
#else #else
mdp->cd = &sh_eth_my_cpu_data; mdp->cd = &sh_eth_my_cpu_data;
#endif #endif
if (id->driver_data)
mdp->cd = (struct sh_eth_cpu_data *)id->driver_data;
sh_eth_set_default_cpu_data(mdp->cd); sh_eth_set_default_cpu_data(mdp->cd);
/* set function */ /* set function */
...@@ -2696,9 +2699,16 @@ static const struct dev_pm_ops sh_eth_dev_pm_ops = { ...@@ -2696,9 +2699,16 @@ static const struct dev_pm_ops sh_eth_dev_pm_ops = {
#define SH_ETH_PM_OPS NULL #define SH_ETH_PM_OPS NULL
#endif #endif
static struct platform_device_id sh_eth_id_table[] = {
{ CARDNAME },
{ }
};
MODULE_DEVICE_TABLE(platform, sh_eth_id_table);
static struct platform_driver sh_eth_driver = { static struct platform_driver sh_eth_driver = {
.probe = sh_eth_drv_probe, .probe = sh_eth_drv_probe,
.remove = sh_eth_drv_remove, .remove = sh_eth_drv_remove,
.id_table = sh_eth_id_table,
.driver = { .driver = {
.name = CARDNAME, .name = CARDNAME,
.pm = SH_ETH_PM_OPS, .pm = SH_ETH_PM_OPS,
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册