diff options
author | Brajesh Dave <brajeshd@marvell.com> | 2007-11-20 17:44:14 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2008-01-28 18:04:52 -0500 |
commit | 01d77d8d4747d73cfb6daf35cdc906a2db8ded9d (patch) | |
tree | 2b6263df131d602fae21365ecb10f0c1a1e88ea0 /drivers/net/wireless/libertas/join.c | |
parent | 798fbfec9ca1dfd656963debb14d049868d24465 (diff) |
libertas: separate mesh connectivity from that of the main interface
The transmit and receive traffic as soon as the mesh interface is
brought up.
Test case 1: Bring up only the mesh interface and ping. No need for
any iwconfig commands on the main interface.
$ ifconfig msh0 192.168.5.3
$ iwconfig msh0 channel X
$ ping 192.168.5.2
If ping succeeds, PASS
Test case 2: Associate with the main interface, and turn off AP. Mesh
interface should not lose connectivity.
$ iwconfig eth0 mode managed essid "my_ssid"
$ ifconfig msh0 192.168.5.3
$ ping 192.168.5.2
<turn off access point>
If ping continues uninterrupted, PASS
This feature requires firmware version 5.110.19.p0 or newer, available
here: http://dev.laptop.org/pub/firmware/libertas/
Signed-off-by: Ashish Shukla <ashishs@marvell.com>
Signed-off-by: Javier Cardona <javier@cozybit.com>
Signed-off-by: Dan Williams <dcbw@redhat.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/libertas/join.c')
-rw-r--r-- | drivers/net/wireless/libertas/join.c | 9 |
1 files changed, 0 insertions, 9 deletions
diff --git a/drivers/net/wireless/libertas/join.c b/drivers/net/wireless/libertas/join.c index 90c25f478123..3854d91c90e2 100644 --- a/drivers/net/wireless/libertas/join.c +++ b/drivers/net/wireless/libertas/join.c | |||
@@ -795,10 +795,6 @@ int lbs_ret_80211_associate(lbs_private *priv, | |||
795 | netif_carrier_on(priv->dev); | 795 | netif_carrier_on(priv->dev); |
796 | netif_wake_queue(priv->dev); | 796 | netif_wake_queue(priv->dev); |
797 | 797 | ||
798 | if (priv->mesh_dev) { | ||
799 | netif_carrier_on(priv->mesh_dev); | ||
800 | netif_wake_queue(priv->mesh_dev); | ||
801 | } | ||
802 | 798 | ||
803 | memcpy(wrqu.ap_addr.sa_data, adapter->curbssparams.bssid, ETH_ALEN); | 799 | memcpy(wrqu.ap_addr.sa_data, adapter->curbssparams.bssid, ETH_ALEN); |
804 | wrqu.ap_addr.sa_family = ARPHRD_ETHER; | 800 | wrqu.ap_addr.sa_family = ARPHRD_ETHER; |
@@ -884,11 +880,6 @@ int lbs_ret_80211_ad_hoc_start(lbs_private *priv, | |||
884 | netif_carrier_on(priv->dev); | 880 | netif_carrier_on(priv->dev); |
885 | netif_wake_queue(priv->dev); | 881 | netif_wake_queue(priv->dev); |
886 | 882 | ||
887 | if (priv->mesh_dev) { | ||
888 | netif_carrier_on(priv->mesh_dev); | ||
889 | netif_wake_queue(priv->mesh_dev); | ||
890 | } | ||
891 | |||
892 | memset(&wrqu, 0, sizeof(wrqu)); | 883 | memset(&wrqu, 0, sizeof(wrqu)); |
893 | memcpy(wrqu.ap_addr.sa_data, adapter->curbssparams.bssid, ETH_ALEN); | 884 | memcpy(wrqu.ap_addr.sa_data, adapter->curbssparams.bssid, ETH_ALEN); |
894 | wrqu.ap_addr.sa_family = ARPHRD_ETHER; | 885 | wrqu.ap_addr.sa_family = ARPHRD_ETHER; |