浅析wlan驱动和sd卡硬件绑定的简单流程
struct mmc_card *mmc_alloc_card(struct mmc_host *host)
{
struct mmc_card *card;
card = kzalloc(sizeof(struct mmc_card), GFP_KERNEL);
if (!card)
return ERR_PTR(-ENOMEM);
card->host = host;
device_initialize(&card->dev);
card->dev.parent = mmc_classdev(host);//该card对应parent为arm平台的SD控制器
card->dev.bus = &mmc_bus_type;//总线为mmc_bus_type,对应mmc_bus_match和mmc_bus_probe
card->dev.release = mmc_release_card;
return card;
}
static int mmc_bus_match(struct device *dev, struct device_driver *drv)
{
return 1;//始终返回1,所以mmc总线上设备匹配工作完全交由设备的驱动probe完成
}
static int mmc_bus_probe(struct device *dev)
{
struct mmc_driver *drv = to_mmc_driver(dev->driver);
struct mmc_card *card = dev_to_mmc_card(dev);
return drv->probe(card);
//对于sd卡drivers/mmc/card/block.c->module_init(mmc_blk_init)这是内核注册到mmc_bus上的驱动,也是这里调用的drv->probe驱动
//mmc_blk_probe
//感觉对于wlan来说,card并没有在总线上取得到驱动,仅仅func所在的sdio_bus_type总线上注册了wlan驱动
}
struct sdio_func *sdio_alloc_func(struct mmc_card *card)
{
struct sdio_func *func;
func = kzalloc(sizeof(struct sdio_func), GFP_KERNEL);
if (!func)
return ERR_PTR(-ENOMEM);
func->card = card;
device_initialize(&func->dev);
func->dev.parent = &card->dev;//设置sysfs系统视图中的parent
func->dev.bus = &sdio_bus_type;//设置所在bus总线,对应总线mach和probe分别为sdio_bus_match和sdio_bus_probe
func->dev.release = sdio_release_func;
return func;
}
sbi_register()->sdio_register_driver(&wlan_sdio);这样将wlan_sdio驱动注册到sdio_bus_type总线,当sd接口检测到sd设备插入,
之后,mmc_rescan()函数会生成插入设备的sdio_func结构体,并这些结构体填充成sysfs文件系统目录和文件,最后当调用sdio_add_func()
的device_add()的时候,会在device_attach()时,通过sdio_bus_match()调用和sdio_bus_probe()调用之后调用wlan_probe()函数,最后
将wlan驱动和插入到sd口的sdio网卡硬件绑定[gliethttp_20080626]!
|