mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-16 23:46:30 +07:00
brcm80211: fmac: remove primary mac address handling from brcmf_net_attach
The mac address for the primary interface was handled different from the other interfaces. The code has been restructured such that the brcmf_net_attach function treats the interfaces equal. Reviewed-by: Pieter-Paul Giesberts <pieterpg@broadcom.com> Reviewed-by: Franky (Zhenhui) Lin <frankyl@broadcom.com> Signed-off-by: Arend van Spriel <arend@broadcom.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
parent
75c49904c9
commit
3625c149d6
@ -843,27 +843,26 @@ static const struct net_device_ops brcmf_netdev_ops_pri = {
|
|||||||
.ndo_set_rx_mode = brcmf_netdev_set_multicast_list
|
.ndo_set_rx_mode = brcmf_netdev_set_multicast_list
|
||||||
};
|
};
|
||||||
|
|
||||||
static int brcmf_net_attach(struct brcmf_pub *drvr, int ifidx)
|
static int brcmf_net_attach(struct brcmf_if *ifp)
|
||||||
{
|
{
|
||||||
|
struct brcmf_pub *drvr = ifp->drvr;
|
||||||
struct net_device *ndev;
|
struct net_device *ndev;
|
||||||
u8 temp_addr[ETH_ALEN] = {
|
u8 temp_addr[ETH_ALEN];
|
||||||
0x00, 0x90, 0x4c, 0x11, 0x22, 0x33};
|
|
||||||
|
|
||||||
brcmf_dbg(TRACE, "ifidx %d\n", ifidx);
|
brcmf_dbg(TRACE, "ifidx %d\n", ifp->idx);
|
||||||
|
|
||||||
ndev = drvr->iflist[ifidx]->ndev;
|
ndev = drvr->iflist[ifp->idx]->ndev;
|
||||||
ndev->netdev_ops = &brcmf_netdev_ops_pri;
|
ndev->netdev_ops = &brcmf_netdev_ops_pri;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* We have to use the primary MAC for virtual interfaces
|
* determine mac address to use
|
||||||
*/
|
*/
|
||||||
if (ifidx != 0) {
|
if (is_valid_ether_addr(ifp->mac_addr))
|
||||||
/* for virtual interfaces use the primary MAC */
|
memcpy(temp_addr, ifp->mac_addr, ETH_ALEN);
|
||||||
|
else
|
||||||
memcpy(temp_addr, drvr->mac, ETH_ALEN);
|
memcpy(temp_addr, drvr->mac, ETH_ALEN);
|
||||||
|
|
||||||
}
|
if (ifp->idx == 1) {
|
||||||
|
|
||||||
if (ifidx == 1) {
|
|
||||||
brcmf_dbg(TRACE, "ACCESS POINT MAC:\n");
|
brcmf_dbg(TRACE, "ACCESS POINT MAC:\n");
|
||||||
/* ACCESSPOINT INTERFACE CASE */
|
/* ACCESSPOINT INTERFACE CASE */
|
||||||
temp_addr[0] |= 0X02; /* set bit 2 ,
|
temp_addr[0] |= 0X02; /* set bit 2 ,
|
||||||
@ -879,7 +878,7 @@ static int brcmf_net_attach(struct brcmf_pub *drvr, int ifidx)
|
|||||||
memcpy(ndev->dev_addr, temp_addr, ETH_ALEN);
|
memcpy(ndev->dev_addr, temp_addr, ETH_ALEN);
|
||||||
|
|
||||||
/* attach to cfg80211 for primary interface */
|
/* attach to cfg80211 for primary interface */
|
||||||
if (!ifidx) {
|
if (!ifp->idx) {
|
||||||
drvr->config = brcmf_cfg80211_attach(ndev, drvr->dev, drvr);
|
drvr->config = brcmf_cfg80211_attach(ndev, drvr->dev, drvr);
|
||||||
if (drvr->config == NULL) {
|
if (drvr->config == NULL) {
|
||||||
brcmf_dbg(ERROR, "wl_cfg80211_attach failed\n");
|
brcmf_dbg(ERROR, "wl_cfg80211_attach failed\n");
|
||||||
@ -940,7 +939,7 @@ brcmf_add_if(struct device *dev, int ifidx, char *name, u8 *mac_addr)
|
|||||||
if (mac_addr != NULL)
|
if (mac_addr != NULL)
|
||||||
memcpy(&ifp->mac_addr, mac_addr, ETH_ALEN);
|
memcpy(&ifp->mac_addr, mac_addr, ETH_ALEN);
|
||||||
|
|
||||||
if (brcmf_net_attach(drvr, ifp->idx)) {
|
if (brcmf_net_attach(ifp)) {
|
||||||
brcmf_dbg(ERROR, "brcmf_net_attach failed");
|
brcmf_dbg(ERROR, "brcmf_net_attach failed");
|
||||||
free_netdev(ifp->ndev);
|
free_netdev(ifp->ndev);
|
||||||
drvr->iflist[ifidx] = NULL;
|
drvr->iflist[ifidx] = NULL;
|
||||||
|
Loading…
Reference in New Issue
Block a user