net-next: stmmac: add optional setup function
Instead of adding more ifthen logic for adding a new mac_device_info setup function, it is easier to add a function pointer to the function needed. Signed-off-by: Corentin Labbe <clabbe.montjoie@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
3874191898
commit
ec33d71de7
|
@ -3933,7 +3933,9 @@ static int stmmac_hw_init(struct stmmac_priv *priv)
|
||||||
struct mac_device_info *mac;
|
struct mac_device_info *mac;
|
||||||
|
|
||||||
/* Identify the MAC HW device */
|
/* Identify the MAC HW device */
|
||||||
if (priv->plat->has_gmac) {
|
if (priv->plat->setup) {
|
||||||
|
mac = priv->plat->setup(priv);
|
||||||
|
} else if (priv->plat->has_gmac) {
|
||||||
priv->dev->priv_flags |= IFF_UNICAST_FLT;
|
priv->dev->priv_flags |= IFF_UNICAST_FLT;
|
||||||
mac = dwmac1000_setup(priv->ioaddr,
|
mac = dwmac1000_setup(priv->ioaddr,
|
||||||
priv->plat->multicast_filter_bins,
|
priv->plat->multicast_filter_bins,
|
||||||
|
|
|
@ -177,6 +177,7 @@ struct plat_stmmacenet_data {
|
||||||
void (*fix_mac_speed)(void *priv, unsigned int speed);
|
void (*fix_mac_speed)(void *priv, unsigned int speed);
|
||||||
int (*init)(struct platform_device *pdev, void *priv);
|
int (*init)(struct platform_device *pdev, void *priv);
|
||||||
void (*exit)(struct platform_device *pdev, void *priv);
|
void (*exit)(struct platform_device *pdev, void *priv);
|
||||||
|
struct mac_device_info *(*setup)(void *priv);
|
||||||
void *bsp_priv;
|
void *bsp_priv;
|
||||||
struct clk *stmmac_clk;
|
struct clk *stmmac_clk;
|
||||||
struct clk *pclk;
|
struct clk *pclk;
|
||||||
|
|
Loading…
Reference in New Issue