aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/libertas/join.c
diff options
context:
space:
mode:
authorBrajesh Dave <brajeshd@marvell.com>2007-11-20 17:44:14 -0500
committerDavid S. Miller <davem@davemloft.net>2008-01-28 18:04:52 -0500
commit01d77d8d4747d73cfb6daf35cdc906a2db8ded9d (patch)
tree2b6263df131d602fae21365ecb10f0c1a1e88ea0 /drivers/net/wireless/libertas/join.c
parent798fbfec9ca1dfd656963debb14d049868d24465 (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.c9
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;