新路程------uart驱动和tty(3)
2017-05-11 14:48
218 查看
这里主要讲讲dev/ttymx0是怎么长出来的,在static int serial_imx_probe(struct platform_device *pdev)我们讲到
这个ret = uart_add_one_port(&imx_reg, &sport->port);是长出dev/ttymx0的关键
那么来看看首先是imx_reg
static struct uart_driver imx_reg = {
.owner = THIS_MODULE,
.driver_name = DRIVER_NAME,
.dev_name = DEV_NAME, 这个name是#define DEV_NAME
"ttymxc"
.major = SERIAL_IMX_MAJOR,
.minor = MINOR_START,
.nr = ARRAY_SIZE(imx_ports),
.cons = IMX_CONSOLE,
};
第二个参数&sport->port就是ttymx n
在
int uart_add_one_port(struct uart_driver *drv, struct uart_port *uport)
{
tty_dev = tty_register_device(drv->tty_driver, uport->line, uport->dev);
}
然后是
struct device *tty_register_device(struct tty_driver *driver, unsigned index,
struct device *device)
{
char name[64];
dev_t dev = MKDEV(driver->major, driver->minor_start) + index;
char *name1=&name;
if (index >= driver->num) {
printk(KERN_ERR "Attempt to register invalid tty line number "
" (%d).\n", index);
return ERR_PTR(-EINVAL);
}
if (driver->type == TTY_DRIVER_TYPE_PTY)
pty_line_name(driver, index, name);
else
tty_line_name(driver, index, name); //这里组成了ttymxc0
printk("matt==========name1=%s\n",name1);
return device_create(tty_class, device, dev, NULL, name);
}
最后的device_create就是节点的建立
这个ret = uart_add_one_port(&imx_reg, &sport->port);是长出dev/ttymx0的关键
那么来看看首先是imx_reg
static struct uart_driver imx_reg = {
.owner = THIS_MODULE,
.driver_name = DRIVER_NAME,
.dev_name = DEV_NAME, 这个name是#define DEV_NAME
"ttymxc"
.major = SERIAL_IMX_MAJOR,
.minor = MINOR_START,
.nr = ARRAY_SIZE(imx_ports),
.cons = IMX_CONSOLE,
};
第二个参数&sport->port就是ttymx n
在
int uart_add_one_port(struct uart_driver *drv, struct uart_port *uport)
{
tty_dev = tty_register_device(drv->tty_driver, uport->line, uport->dev);
}
然后是
struct device *tty_register_device(struct tty_driver *driver, unsigned index,
struct device *device)
{
char name[64];
dev_t dev = MKDEV(driver->major, driver->minor_start) + index;
char *name1=&name;
if (index >= driver->num) {
printk(KERN_ERR "Attempt to register invalid tty line number "
" (%d).\n", index);
return ERR_PTR(-EINVAL);
}
if (driver->type == TTY_DRIVER_TYPE_PTY)
pty_line_name(driver, index, name);
else
tty_line_name(driver, index, name); //这里组成了ttymxc0
printk("matt==========name1=%s\n",name1);
return device_create(tty_class, device, dev, NULL, name);
}
最后的device_create就是节点的建立
相关文章推荐
- 新路程------uart驱动和tty(2)
- [5]ARM-Linux S5PV210 UART驱动----串口的open操作(tty_open、uart_open)
- Linux tty驱动学习 - 串口通信,UART及UART驱动概述
- 嵌入式Linux驱动笔记(七)------浅析tty与uart框架
- tty初探—uart驱动框架分析(二)uart_add_one_port
- tty初探—uart驱动框架分析
- tty初探—uart驱动框架分析
- Linux TTY驱动--Uart_driver底层
- tty初探—uart驱动框架分析(二)uart_add_one_port
- uart驱动与tty驱动
- 内核UART串口驱动开发文档,console,tty,kernel
- Linux tty驱动学习 - UART驱动的read操作流程
- Linux tty驱动学习 - UART驱动的open操作
- tty初探-uart驱动框架分析
- tty初探—uart驱动框架分析
- ARM-Linux S5PV210 UART驱动(5)----串口的open操作(tty_open、uart_open)
- uart_tty驱动架构分析
- Linux TTY驱动--Uart_driver底层
- Linux设备模型之tty&&uart驱动架构分析
- Linux TTY驱动--Uart_driver底层