linux uart驱动——uart platfrom 注册(三)
一:注册platform device
注册一个platfrom device一般需要初始化两个内容,设备占用的资源resource和设备私有数据dev.platfrom_data。设备的resource占用的资源主要包含两个方面:IO内存和IRQ资源信息,有时也包含DMA。
resource结构:
1: struct resource {
2: resource_size_t start;//定义资源的起始地址
3: resource_size_t end;//定义资源的结束地址
4: const char *name;//定义资源的名称
5: unsigned long flags;//定义资源的类型,比如MEM,IO,IRQ,DMA类型
6: struct resource *parent, *sibling, *child;//资源链表指针
7: };
.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }
笔者当前的君正board有三个串口:
1: #ifdef CONFIG_SERIAL_JZ47XX_UART0
2: /* UART ( uart controller) */
3: static struct resource jz_uart0_resources[] = {
4: [0] = {
5: .start = UART0_IOBASE,
6: .end = UART0_IOBASE + 0x1000 - 1,
7: .flags = IORESOURCE_MEM,
8: },
9: [1] = {
10: .start = IRQ_UART0,
11: .end = IRQ_UART0,
12: .flags = IORESOURCE_IRQ,
13: },
14: #ifdef CONFIG_SERIAL_JZ47XX_UART0_DMA
15: [2] = {
16: .start = JZDMA_REQ_UART0,
17: .flags = IORESOURCE_DMA,
18: },
19: #endif
20: };
21:
22: struct platform_device jz_uart0_device = {
23: .name = "jz-uart",
24: .id = 0,
25: .num_resources = ARRAY_SIZE(jz_uart0_resources),
26: .resource = jz_uart0_resources,
27: };
28: #endif
29: #ifdef CONFIG_SERIAL_JZ47XX_UART1
30: static struct resource jz_uart1_resources[] = {
31: [0] = {
32: .start = UART1_IOBASE,
33: .end = UART1_IOBASE + 0x1000 - 1,
34: .flags = IORESOURCE_MEM,
35: },
36: [1] = {
37: .start = IRQ_UART1,
38: .end = IRQ_UART1,
39: .flags = IORESOURCE_IRQ,
40: },
41: #ifdef CONFIG_SERIAL_JZ47XX_UART1_DMA
42: [2] = {
43: .start = JZDMA_REQ_UART1,
44: .flags = IORESOURCE_DMA,
45: },
46: #endif
47: };
48: struct platform_device jz_uart1_device = {
49: .name = "jz-uart",
50: .id = 1,
51: .num_resources = ARRAY_SIZE(jz_uart1_resources),
52: .resource = jz_uart1_resources,
53: };
54: #endif
55: #ifdef CONFIG_SERIAL_JZ47XX_UART2
56: static struct resource jz_uart2_resources[] = {
57: [0] = {
58: .start = UART2_IOBASE,
59: .end = UART2_IOBASE + 0x1000 - 1,
60: .flags = IORESOURCE_MEM,
61: },
62: [1] = {
63: .start = IRQ_UART2,
64: .end = IRQ_UART2,
65: .flags = IORESOURCE_IRQ,
66: },
67: #ifdef CONFIG_SERIAL_JZ47XX_UART2_DMA
68: [2] = {
69: .start = JZDMA_REQ_UART2,
70: .flags = IORESOURCE_DMA,
71: },
72: #endif
73: };
74:
75: struct platform_device jz_uart2_device = {
76: .name = "jz-uart",
77: .id = 2,
78: .num_resources = ARRAY_SIZE(jz_uart2_resources),
79: .resource = jz_uart2_resources,
80: };
81: #endif
.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }
platform_device_register(&jz_uartXX_device);
注册成功后:(多个device)
ls /sys/bus/platform/devices/
jz-uart.0/ jz-uart.2/
二:注册platfrom driver
1: /* serial platfrom driver */
2: static struct platform_driver serial_jz47xx_driver = {
3: .probe = serial_jz47xx_probe,
4: .remove = serial_jz47xx_remove,
5:
6: .driver = {
7: .name = "jz-uart",
8: .owner = THIS_MODULE,
9: #ifdef CONFIG_PM
10: .pm = &serial_jz47xx_pm_ops,
11: #endif
12: },
13: };
14:
15: int __init serial_jz47xx_init(void)
16: {
17: int ret;
18: /* 功能:uart_register_driver用于将串口驱动uart_driver注册到内核(串口核心层)中,
19: 通常在模块初始化函数调用该函数。
20: * 参数 drv:要注册的uart_driver
21: * 返回值: 成功,返回0;否则返回错误码
22: */
23: ret = uart_register_driver(&serial_jz47xx_reg);
24: if (ret != 0)
25: return ret;
26:
27: /* 注册serial platfrom驱动 */
28: ret = platform_driver_register(&serial_jz47xx_driver);
29: if (ret != 0)
30: uart_unregister_driver(&serial_jz47xx_reg);
31:
32: return ret;
33: }
34:
35: void __exit serial_jz47xx_exit(void)
36: {
37: platform_driver_unregister(&serial_jz47xx_driver);
38: uart_unregister_driver(&serial_jz47xx_reg);
39: }
40:
41:
42: #ifdef CONFIG_EARLY_INIT_RUN
43: rootfs_initcall(serial_jz47xx_init);/*先于module注册*/
44:
45: #else
46: module_init(serial_jz47xx_init);
47:
48: #endif
49:
50: module_exit(serial_jz47xx_exit);
51:
52: MODULE_LICENSE("GPL");
53: MODULE_ALIAS("platform:jz47xx-uart");
.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }
注册成功后:(一个driver对应多个device)
ls /sys/bus/platform/drivers/jz-uart/
bind jz-uart.0 jz-uart.2 uevent unbind
linux uart驱动——uart platfrom 注册(三)的更多相关文章
- linux设备驱动归纳总结(三):3.设备驱动面向对象思想和lseek的实现【转】
本文转自自:http://blog.chinaunix.net/uid-25014876-id-59418.html linux设备驱动归纳总结(三):3.设备驱动面向对象思想和lseek的实现 一. ...
- linux设备驱动归纳总结(三):2.字符型设备的操作open、close、read、write【转】
本文转载自:http://blog.chinaunix.net/uid-25014876-id-59417.html linux设备驱动归纳总结(三):2.字符型设备的操作open.close.rea ...
- linux设备驱动归纳总结(三):1.字符型设备之设备申请【转】
本文转载自:http://blog.chinaunix.net/uid-25014876-id-59416.html linux设备驱动归纳总结(三):1.字符型设备之设备申请 操作系统:Ubunru ...
- linux设备驱动归纳总结(三):3面向对象思想和lseek、container_of、write、read 【转】
linux设备驱动归纳总结(三):3.设备驱动面向对象思想和lseek的实现 转自:http://blog.chinaunix.net/uid-25014876-id-59418.html 一.结构体 ...
- 【Linux开发】linux设备驱动归纳总结(三):3.设备驱动面向对象思想和lseek的实现
linux设备驱动归纳总结(三):3.设备驱动面向对象思想和lseek的实现 一.结构体struct file和struct inode 在之前写的函数,全部是定义了一些零散的全局变量.有没有办法整合 ...
- 【Linux开发】linux设备驱动归纳总结(三):2.字符型设备的操作open、close、read、write
linux设备驱动归纳总结(三):2.字符型设备的操作open.close.read.write 一.文件操作结构体file_operations 继续上次没讲完的问题,文件操作结构体到底是什么东西, ...
- 【Linux开发】linux设备驱动归纳总结(三):1.字符型设备之设备申请
linux设备驱动归纳总结(三):1.字符型设备之设备申请 操作系统:Ubunru 10.04 实验平台:S3C2440 + linux2.6.29内核 注:在今后驱动程序的学习中经常需要查看内核源代 ...
- linux设备驱动归纳总结(三):7.异步通知fasync【转】
本文转载自:http://blog.chinaunix.net/uid-25014876-id-62725.html linux设备驱动归纳总结(三):7.异步通知fasync xxxxxxxxxxx ...
- linux设备驱动归纳总结(三):6.poll和sellct【转】
本文转载自:http://blog.chinaunix.net/uid-25014876-id-61749.html linux设备驱动归纳总结(三):6.poll和sellct xxxxxxxxxx ...
- linux设备驱动归纳总结(三):5.阻塞型IO实现【转】
本文转载自:http://blog.chinaunix.net/uid-25014876-id-60025.html linux设备驱动归纳总结(三):5.阻塞型IO实现 xxxxxxxxxxxxxx ...
随机推荐
- Javascript&Html-延迟调用和间歇调用
Javascript&Html-延迟调用和间歇调用 Javascript 是一种单线程语言,所有的javascript任务都会放到一个任务列表中,这些javascript任务会按照插入到列表中 ...
- 练习题 求a[i]到a[j]累积和为最大的部分
原文发布时间为:2009-03-09 -- 来源于本人的百度文章 [由搬家工具导入] 1、有一个数组a[n],里面的数只有两种:-1或1。i,j是两个整数,假设0<=i<=j<=n- ...
- Android Win7 上使用cmd生成Jks
Android Win7 上使用cmd生成Jks cmd 命令 C:\Program Files\Java\jre1.8.0_111\bin>keytool -genkeypair -alias ...
- duilib入门简明教程 -- VS环境配置(2) (转)
原文转自:http://www.cnblogs.com/Alberl/p/3342030.html 既然是入门教程,那当然得基础点,因为搜索duilib相关资料时,发现有些小伙伴到处都是编译错 ...
- 【CDockablePane】关于CDockablePane
1.DockPane是CFrameWndEx框架窗口的函数,不能用于基于对话框的应用程序,也不能用于老版本VC,只能用于基于单文档和多文档的应用程序. 2.最佳变通实现办法:创建CFormView基类 ...
- 【Linux】可重入函数和线程安全的区别与联系【转】
转自:http://blog.csdn.net/scenlyf/article/details/52074444 版权声明:本文为博主原创文章,未经博主允许不得转载. *****可重入函数 函数被不同 ...
- linux下的程序调试方法汇总
搞电子都知道,电路不是焊接出来的,是调试出来的.程序员也一定认同,程序不是写出来的,是调试出来的.那么调试工具就显得尤为重要,linux作为笔者重要的开发平台,在linux中讨论调试工具主要是为那些入 ...
- luogu P1651 塔
题目描述 小明很喜欢摆积木,现在他正在玩的积木是由N个木块组成的,他想用这些木块搭出两座高度相同的塔,一座塔的高度是搭建它的所有木块的高度和,并且一座塔至少要用一个木块.每个木块只能用一次,也可以不用 ...
- 笔记-迎难而上之Java基础进阶-终
使用Stream流的方式,遍历集合 import java.util.*; public class StreamDemo{ public static void main(String[] args ...
- Java NIO.2 Files类的常用方法
Files类是一个工具类,提供了大量的静态方法来操作文件.文件夹. Files类常用方法: long size(Path path) //返回文件大小 boolean isDirectory ...