您的位置:首页 > 其它

[mmc subsystem] mmc core(第一章)——概述

2017-02-12 14:22 435 查看
mmc subsystem系列(持续更新中):

[mmc subsystem] 概念与框架

[mmc subsystem] mmc core(第一章)——概述

[mmc subsystem] mmc core(第二章)——数据结构和宏定义说明

[mmc subsystem] mmc core(第三章)——bus模块说明

[mmc subsystem] mmc core(第四章)——host模块说明

[mmc subsystem] mmc core(第五章)——card相关模块(mmc type card)

[mmc subsystem] mmc core(第六章)——mmc core主模块

建议先参考《[mmc subsystem] 概念与框架》和《[mmc subsystem] mmc core(第一章)——概述》对整体有一个了解。

=========================================================================================================

一、mmc core简单说明

对应代码路径为drivers/mmc/core/.

0、几个概念

首先要理解以下几个概念

mmc host:对应物理上的mmc控制器(host controller)。对应软件中的mmc_host结构体。

mmc card:对应物理上的mmc设备。对应软件中的mmc_card结构体。

mmc driver:用于驱动mmc card,实现对应的实际功能。对应软件中的mmc_driver。

1、框架说明

简单框架图如下:



(上图摘自蜗窝科技http://www.wowotech.net/comm/mmc_framework_arch.html

如上,主要分成了四个模块:

mmc core主模块

host模块

bus模块

card相关模块

mmc模块

sd模块

sdio模块

2、主要工作

按照框架的四个模块来说明其对应负责内容如下:

bus模块

对应代码bus.c。

抽象出虚拟mmc bus,实现mmc bus的操作。提供bus相关的操作,包括device的注册以及driver的注册的API。

参考《[mmc subsystem] mmc core(第三章)——bus模块说明

host模块

对应代码host.c。

为底层host controller driver实现mmc host的申请以及注册的API等等,以及host相关属性的实现。

参考《[mmc subsystem] mmc core(第四章)——host模块说明

card相关模块

mmc type card对应mmc.c、mmc_ops.c

sd type card对应sd.c、sd_ops.c

为对应card实现相应的操作,包括初始化操作、以及对应的总线操作集合。负责和对应card协议层相关的东西。

参考《[mmc subsystem] mmc core(第五章)——card相关模块(mmc type card)

mmc core主模块

对应代码core.c。

这部分是mmc subsystem的核心实现。

参考《[mmc subsystem] mmc core(第六章)——mmc core主模块

mmc bus虚拟总线的注册和维护

mmc host的管理(host的获取和释放)、操作接口(包括host的带宽配置、时钟设置,复位操作)等等

card设备的抽象,card的管理和操作接口,包括card检测接口等等。

实现基于mmc通讯规范的命令请求的接口以及命令处理的实现。

3、总线结构说明

mmc_opt_flow



(上图摘自蜗窝科技http://www.wowotech.net/comm/mmc_framework_arch.html

从硬件上来看,每一个mmc host对应一条实际的mmc总线。

但是mmc subsystem只存在一条虚拟的mmc bus。并且mmc host并不会作为这个设备驱动总线模型的一个部分。

相应的:

在mmc bus上挂载的device是由mmc core根据实际mmc设备抽象出来的card设备。

在mmc bus上挂载的driver是在card目录下实现的card driver,用于驱动虚拟card设备、对接其他subsystem,实现其实际的功能。

二、sys下的节点说明

1、bus节点

mmc bus节点的对应路径为/sys/bus/mmc。在mmc_register_bus中生成。

简单示例如下:

在devices目录下有如下节点
/sys/bus/mmc/devices/mmc0:0001
其中mmc0:0001就是mmc core抽象出来的card设备,对应于我们板子上的emmc。
对应代码参考mmc_alloc_card&mmc_add_card。

在drivers目录下有如下节点
/sys/bus/mmc/drivers/mmcblk
其中mmcblk就是block.c中实现的card driver。
对应代码参考mmc_register_driver。


2、host的class节点

mmc core实现了一个class用于维护和管理mmc host。其对应路径为/sys/class/mmc_host。

mmc core会为每个注册到mmc core中的mmc host在该class目录下添加一个对应的节点。在mmc_add_host中生成。

简单示例如下:

创建class的代码参考mmc_register_host_class

在/sys/class/mmc_host下有如下目录:
/sys/class/mmc_host/mmc0
/sys/class/mmc_host/mmc1
在msm8916平台中,注册了两个mmc host,而mmc0就是对应alias序号为0的host,而mmc1就是对应alias序号为1的host。
具体代码参考mmc_alloc_host。

其中,/sys/class/mmc_host/mmc0下有如下属性:
clk_scaling    clkgate_delay   device   mmc0:0001   perf   power   subsystem   uevent
具体代码参考mmc_add_host。


3、card对应的sys节点

mmc core把mmc设备抽象为card设备。

从两个地方可以找到其对应的sys节点。

简单示例如下:

以mmc0:0001设备为例,mmc0表示这个card挂载mmc0这个host上,0001表示card设备地址为0001(也就是RCA,协议的东西,后续会说明)
(1)/sys/bus/mmc/devices/mmc0:0001(因为是挂在mmc bus上)
(2)/sys/class/mmc_host/mmc0/mmc0:0001(因为card的parent device为mmc host的class device)
具体代码参考mmc_alloc_card & mmc_add_card。

其下面有如下属性:
block    cid   csd   date   driver   enhanced_area_offset   enhanced_area_size   erase_size   fwrev   hwrev
manfid    name   oemid   power   preferred_erase_size   prv   raw_rpmb_size_mult   rel_sectors
runtime_pm_timeout    serial   subsystem   type   uevent
相应属性意义参考mmc_type的实现。后续再说明。


4、debug节点

mmc core为每个注册到core中的host创建了对应的debug节点。

以mmc0这个host为例,其对应节点路径为/sys/kernel/debug/mmc0

/sys/kernel/debug/mmc0有如下属性
clk_delay    clock   ios   max_clock   mmc0:0001
具体代码参考mmc_add_host——》mmc_add_host_debugfs

mmc0:0001下有如下debug属性:
ext_csd    state   status   wr_pack_stats
具体代码参考mmc_add_card——》mmc_add_card_debugfs


三、数据结构说明

1、简述

struct mmc_host

mmc core由host controller抽象出来的结构体,用于代表一个mmc host控制器。

struct mmc_card

mmc core由mmc设备抽象出来的card设备的结构体,用于代表一个mmc设备。

struct mmc_driver

用于代表一个card drive。

struct mmc_bus_ops

mmc_bus_ops表示mmc host在总线上的操作集合,由host的card 设备来决定,mmc type card、sd type card相应的操作集合是不一样的。

mmc_command

表示一个mmc命令包

mmc_data

表示一个mmc数据包

mmc_request

表示一个mmc请求,包括了mmc命令包(mmc_command)和mmc数据包(mmc_data)。

mmc_async_req

表示一个mmc异步请求,包括了mmc_request。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  mmc kernel