android底层wifi连接指定ap,Android Wifi驱动--底层&& WIFI手动命令行连接AP

http://blog.csdn.net/dwyane_zhang/article/details/6919074

由于在这个项目中,WIFI模块是采用SDIO总线来控制的,所以先记录下CLIENT DRIVER的SDIO部分的结构,这部分的SDIO分为三层:SdioDrv、SdioAdapter、SdioBusDrv。其中SdioBusDrv是Client Driver中SDIO与WIFI模块的接口,SdioAdapter是SdioDrv和SdioBusDrv之间的适配层,SdioDrv是Client Driver中SDIO与LINUX KERNEL中的MMC SDIO的接口。这三部分只需要关注一下SdioDrv就可以了,另外两层都只是对它的封装罢了。

在SdioDrv中提供了这几个功能:

(1)static struct sdio_driver tiwlan_sdio_drv = {

.probe          = tiwlan_sdio_probe,

.remove         = tiwlan_sdio_remove,

.name           = "sdio_tiwlan",

.id_table       = tiwl12xx_devices,

};

(2)int sdioDrv_EnableFunction(unsigned int uFunc)

(3)int sdioDrv_EnableInterrupt(unsigned int uFunc)

(4)SDIO的读写,实际是调用了MMC\Core中的  static int mmc_io_rw_direct_host()功能。

SDIO功能部分简单了解下就可以,一般HOST部分芯片厂商都会做好。我的主要任务还是WIFI模块。

首先从WIFI模块的入口函数wlanDrvIf_ModuleInit()看起,这里调用了wlanDrvIf_Create()。

代码主体部分:

static int wlanDrvIf_Create(void)

{

TWlanDrvIfObj *drv; //这个结构体为代表设备,包含LINUX网络设备结构体net_device

pDrvStaticHandle = drv;  /* save for module destroy */

drv->pWorkQueue = create_singlethread_workqueue (TIWLAN_DRV_NAME);//创建了工作队列

/* Setup driver network interface. */

rc = wlanDrvIf_SetupNetif (drv);  //这个函数超级重要,后面详细的看

drv->wl_sock = netlink_kernel_create( NETLINK_USERSOCK, 0, NULL, NULL, THIS_MODULE );

// 创建了接受wpa_supplicant的SOCKET接口

/* Create all driver modules and link their handles */

rc = drvMain_Create (drv,

&drv->tCommon.hDrvMain,

&drv->tCommon.hCmdHndlr,

&drv->tCommon.hContext,

&drv->tCommon.hTxDataQ,

&drv->tCommon.hTxMgmtQ,

&drv->tCommon.hTxCtrl,

&drv->tCommon.hTWD,

&drv->tCommon.hEvHandler,

&drv->tCommon.hCmdDispatch,

&drv->tCommon.hReport,

&drv->tCommon.hPwrState);

/*

*  Initialize interrupts (or polling mode for debug):

*/

/* Normal mode: Interrupts (the default mode) */

rc = hPlatform_initInterrupt (drv, (void*)wlanDrvIf_HandleInterrupt);

return 0;

}

在调用完wlanDrvIf_Create()这个函数后,实际上WIFI模块的初始化就结束了,下面分析如何初始化的。先看wlanDrvIf_SetupNetif (drv)这个函数的主体,

static int wlanDrvIf_SetupNetif (TWlanDrvIfObj *drv)

{

struct net_device *dev;

int res;

/* Allocate network interface structure for the driver */

dev = alloc_etherdev (0);//申请LINUX网络设备

if (dev == NULL)

/* Setup the network interface */

ether_setup (dev);//建立网络接口 ,这两个都是LINUX网络设备驱动的标准函数

dev->netdev_ops = &wlan_netdev_ops;

/* Initialize Wireless Extensions interface (WEXT) */

wlanDrvWext_Init (dev);

res = register_netdev (dev);

/* Setup power-management callbacks */

hPlatform_SetupPm(wlanDrvIf_Suspend, wlanDrvIf_Resume, pDrvStaticHandle);

}

注意,在这里初始化了wlanDrvWext_Inti(dev),这就说明wpa_supplicant与Driver直接的联系是走的WEXT这条路。也就是说event的接收,处理也应该是在WEXT部分来做的,确定这个,剩下的工作量顿减三分之一,哈哈哈。后面还注册了网络设备dev。而在wlan_netdev_ops中定义的功能如下:

static const struct net_device_ops wlan_netdev_ops = {

.ndo_open             = wlanDrvIf_Open,

.ndo_stop             = wlanDrvIf_Release,

.ndo_do_ioctl         = NULL,

.ndo_start_xmit       = wlanDrvIf_Xmit,

.ndo_get_stats        = wlanDrvIf_NetGetStat,

.ndo_validate_addr    = NULL,

};

功能一看名字就知道了,不说了,这几个对应的都是LINUX网络设备驱动都有的命令字,详见《LINUX设备驱动开发详解》第十六章。

在这之后,又调用了rc =drvMain_CreateI。

在这个函数里完成了相关模块的初始化工作。具体不说了。接下来就是等待Android上层发送来的事件了。

http://blog.csdn.net/dwyane_zhang/article/details/7242787

在我们调试WIFI模块的时候经常碰到这样那样的问题,关键是要找到问题出现在哪层,然后再深入分析。

找问题出现在哪一层,用手动命令是最直接的方法。一下就可以分辨出到底是上层还是底层的问题,下面列出WIFI的手动命令行:

关于wpa_supplicant:

用到wpa_cli命令

wpa_cli -iwlan0 add_network             // wlan0 是无线网络设备的名字,增加一个网络,会返回一个数字,假设为1

wpa_cli -iwlan0 set_network 1 ssid '"……"'    //这里ssid是要连接的网络名,注意 后面是单引号+双引号

wpa_cli -iwlan0 set_network 1 psk '"……"'     //这里psk是密码

wpa_cli -iwlan0 enable_network 1

wpa_cli -iwlan0 select_network 1

wpa_cli -iwlan0 save_config

dhclient -r wlan0

dhclient wlan0

//注意可能wlan0是down的状态,有时需要  ifconfig wlan0 up

或者/etc/init.d/networking restart

其他辅助命令

wpa_cli -iwlan0 list_network

wpa_cli -iwlan0 remove_network 1

开启wpa_supplicant  服务

wpa_supplicant -iwlan0 -c/etc/wpa_supplicant.conf -B

加密方式

wpa_passphrase ssid psk > /etc/wpa_supplicant.conf     //这个文件可以变动

尚不完全清楚内容

ctrl_interface = /var/run/wpa_supplicant

update_config =1

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值