驱动中platform resource 和 porbe 之间的关系
1. platform_device 会包含platform_data 和 resource定义:
一般platform device信息,会定义在 arch/arm/mach-xxx/board-xxx.c 中。
如这里的sarac模块,被定义在arch/arm/mach-cartesio/core-sta2065.c中
- static struct platform_device sarac_device = {
- .name = "cartesio-sarac",
- .id = 1,
- .dev = {
- .init_name = "cartesio-sarac",
- //设备中包含的 platform数据
- .platform_data = &sarac_platform_data,
- },
- .num_resources = ARRAY_SIZE(sarac_resource),
- //包含的资源
- .resource = sarac_resource,
- };
这里的 .name 很重要,驱动会根据这个名字,在probe的时候进行匹配,如果有名字相同,就会匹配上。
platform_device 的定义如下:
- struct platform_device {
- const char * name;
- int id;
- struct device dev;
- u32 num_resources;
- struct resource * resource;
- const struct platform_device_id *id_entry;
- /* arch specific additions */
- struct pdev_archdata archdata;
- };
他包含了一个设备dev,还有resource. 这些都是platform的优势,可以包含很多信息。
如上面的sarac_device,就包含了sarac_platform_data 和 sarac_resource 两块内容,具体定义如下:
- static struct sarac_platform_data_container sarac_platform_data = {
- //这个platform data 其实就是一个DMA slave 的定义
- .mem2sarac_slave = {
- .dma_dev = &dma0_device.dev, /* SARAC bound to DMA0 */
- .tx_req_line = DMA0_REQ_SRC_DMA_DRE,
- .rx_req_line = DMA0_REQ_SRC_DMA_DRF,
- .nr_descs = 2048,
- .channel = DMA_CHANNEL_AUTO,
- .slave_width = DMA_TRANSFER_WIDTH_32BIT,
- .flow_ctrlr = DMA_FLOW_CONTROLLER_DMA,
- .burst_size = DMA_BURST_SIZE_1, /* fifo packet size */
- .ahb_master = DMA_AHB_MASTER_0,
- },
- };
- static struct resource sarac_resource[] = {
- //resource 包含了两块,一块是寄存器访问地址, 一块是中断号信息
- [0] = {
- .start = CARTESIO_SARAC_BASE,
- .end = CARTESIO_SARAC_BASE + SZ_4K - 1,
- .name = "SaRaC registers",
- .flags = IORESOURCE_MEM,
- },
- [1] = {
- .start = IRQ_SARAC_DRF,
- .end = IRQ_SARAC_DRF,
- .name = "CartesioPlus SaRaC interrupt",
- .flags = IORESOURCE_IRQ,
- },
- };
2. 驱动probe中对platform的使用
模块加载时,会注册platform driver: 也就是 platform_driver_register()函数;
- static int __init cartesio_sarac_init(void)
- {
- return platform_driver_register(&cartesio_sarac_driver);
- }
- module_init(cartesio_sarac_init);
cartesio_sarac_driver的定义如下:
- static struct platform_driver cartesio_sarac_driver = {
- .probe = cartesio_sarac_probe,
- .remove = __devexit_p(cartesio_sarac_remove),
- .driver = {
- .name = DEVICE_NAME,
- .owner = THIS_MODULE,
- },
- };
这里的.name 定义必须跟之前platform定义中的.name 一致,这样platform驱动和设备才能匹配上。
- /*
- * Asynchronous SaRaC device name
- */
- #define DEVICE_NAME "cartesio-sarac"
该驱动被加载时,会自动运行cartesio_sarac_probe 函数:
- static int __devinit cartesio_sarac_probe(struct platform_device *pdev)
- {
- struct sarac_device_data *sarac_device;
- struct resource *res;
- struct sarac_platform_data_container *sarac_plat_data=NULL;
- int ret;
- sarac_device = kzalloc(sizeof(struct sarac_device_data), GFP_KERNEL);
- if (!sarac_device) {
- dev_err(&pdev->dev, "not enough memory for driver status\n");
- return -ENOMEM;
- }
- //通过这个函数,就把 platform_device 中的内容,赋给 sarac_device,就可以在这驱动中使用了
- //这里的pdev 就是指向platform_device的指针。
- platform_set_drvdata(pdev, sarac_device);
- printk("SARAC probe called\n");
- //该函数用来获取platform中的resource资源
- res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
- if (!res) {
- dev_err(&pdev->dev, "register area not defined\n");
- ret = -ENODEV;
- goto out_free;
- }
- //把IO空间,赋值给sarac_device
- sarac_device->base_addr = ioremap(res->start, resource_size(res));
- if (!sarac_device->base_addr) {
- dev_err(&pdev->dev, "unable to remap register area\n");
- ret = -ENODEV;
- goto out_free;
- }
- //把platform_device->dev.platform_data 赋值过来
- sarac_plat_data = pdev->dev.platform_data;
- if (sarac_plat_data->mem2sarac_slave.dma_dev) {
- sarac_device->dma_to_sarac_client = &sarac_plat_data->mem2sarac_slave;
- sarac_device->dma_to_sarac_client->tx_reg = res->start + SARAC_DILR;
- sarac_device->dma_from_sarac_address = res->start + SARAC_DOLR;
- } else {
- dev_err(&pdev->dev, "DMA info not found in platform data\n");
- ret = -1;
- goto dma_err;
- }
- //把platform_device 中的IRQ 信息赋值过来
- sarac_device->irq = platform_get_irq(pdev, 0);
- //注册中断
- ret = request_irq(sarac_device->irq, cartesio_sarac_irq_handler, 0,
- dev_name(&pdev->dev), &pdev->id);
- if (ret) {
- dev_err(&pdev->dev, "failed to allocate IRQ %d\n", sarac_device->irq);
- goto out_unmap;
- }
- else {
- aab_peripheral_enable(AAB_SARAC, AAB_AC_WRITE | AAB_AC_READ);
- }
- //在sys中创建信息接口
- sarac_kobj = kobject_create_and_add("audio_sarac", NULL);
- if (!sarac_kobj)
- return -ENOMEM;
- ret = sysfs_create_group(sarac_kobj, &cartesio_sarac_attr_group);
- if (ret)
- return ret;
- dev_info(&pdev->dev, "Module initialized, version" DRV_VERSION "\n");
- return 0;
- dma_err:
- out_unmap:
- iounmap(sarac_device->base_addr);
- out_free:
- kfree(sarac_device);
- return ret;
- }
驱动中platform resource 和 porbe 之间的关系相关推荐
- sql语句和java的关系_java中Statement 与 PreparedStatement接口之间的关系和区别
Statement 和 PreparedStatement之间的关系和区别. 关系:PreparedStatement继承自Statement,都是接口 区别:PreparedStatement可以使 ...
- 显卡,GPU,显卡驱动,CUDA ,CUDA Toolkit之间的关系
相关知识收集于网络,主要来自 显卡,显卡驱动,nvcc, cuda driver,cudatoolkit,cudnn到底是什么? GPU 和显卡是什么关系? 显卡.显卡驱动.cuda 之间的关系是什么 ...
- gnocchi中的resource/metric/measure等的关系
ceilometer和gnocchi中相对应的概念 ceilometer gnocchi resource resource meter metric sample/event measure cei ...
- Java中基本数据类型和Object之间的关系
1.基本数据类型和Object之间是没有关系的 2.基本数据类型的包装类 例如int 的包装类Integer的父类则是Object 输入:12 解释:在赋值的过程中进行自动装箱
- GPU、GPU驱动、OpenGL、游戏引擎之间的关系
游戏引擎使用OpenGL渲染,OpenGL调用显卡驱动告诉GPU干活,GPU经过各种计算把最终的图像渲染出来. 游戏引擎:用于制作游戏或其它实时交互交互图形程序的软件,大多数游戏引擎都包含了渲染.UI ...
- Java中JDK,JRE和JVM之间的关系
初学JAVA很容易被其中的很多概念弄的傻傻分不清楚,首先从概念上理解一下吧,JDK(Java Development Kit)简单理解就是Java开发工具包,JRE(Java Runtime Envi ...
- Spring源码分析之Aop中拦截器,适配器,通知之间的关系
首先举一个例子: public class MethodBeforeAdviceInterceptor implements MethodInterceptor, Serializable {priv ...
- android类之间的关系,Android 中Activity,Window和View之间的关系
Activity是Android应用程序的载体,允许用户在其上创建一个用户界面,并提供用户处理事件的API,如 onKeyEvent, onTouchEvent等. 并维护应用程序的生命周期.Acti ...
- Java中的类与对象之间的关系
目录 1 面向对象思想 2 类和对象 1 类 2 对象 3 类与对象的关系 3 类的定义 4 对象的使用 5 成员变量的默认值 1 面向对象思想 对象泛指现实中的一切事物,每种事物都具备自己的属性和行 ...
最新文章
- 一文详解激光点云的物体聚类
- aspx ttf文件加载不出来_加载页面信息,刷不出来心态都崩了
- Yii2 behavior运用
- 一段简单的html 5 音频,5个用于处理HTML5音频的库和API
- 千兆网线8根线定义图_网线水晶头如何制作及怎么测试?
- 下载丨2020 PG亚洲大会(PPT汇总)
- php检查函数是否存在,php判断类是否存在函数class_exists用法分析
- c#实现list集合移除某些列_List方法
- 你知道什么是 MySQL 的模糊查询?
- 粒子群算法离散化各代表什么_粒子群优化算法(PSO)之基于离散化的特征选择(FS)(三)...
- [Ubuntu Error]无法获得锁 /var/lib/dpkg/lock - open (11: 资源暂时不可用)
- php mkdir创建多级目录
- C#枚举器:foreach语句、IEnumerable、IEnumerator以及yield return (一)
- 微运行库2015_vc2015运行库下载-Visual C++ 2015(vc2015)下载V14.0.24123 官方版【32位|64位|】-西西软件下载...
- 春节宅家玩什么?8款小游戏陪你一起过年
- quicktime for java,QuickTime是什么意思
- 三种健身妙法-每天五分钟简便易行有宏效
- 研究生期间如何赚外快
- 笔记本屏幕 亮度 背光调节 工具 c++ 用来解决亮度调节功能键失效问题
- 10亿个数中找出最大的10000个数之top K问题