linux uart驱动 uart_port.iotype
时间: 2023-11-21 19:05:19 浏览: 91
`uart_port.iotype` 是 Linux UART 驱动中的一个属性,用于指定串口的输入输出类型。当 `uart_port.iotype` 的值为 `SERIAL_IO_MEM` 时,串口的输入输出通过内存进行;而当 `uart_port.iotype` 的值为 `SERIAL_IO_PORT` 时,串口的输入输出通过端口进行。在 Linux 中,串口驱动的默认值为 `SERIAL_IO_MEM`,即通过内存进行输入输出。如果需要通过端口进行输入输出,需要在代码中显式地设置 `uart_port.iotype` 的值为 `SERIAL_IO_PORT`。
相关问题
linux uart驱动 uart_port.iotype access_32b
在 Linux 中,UART 驱动程序是用于控制串行通信接口的内核模块。其中包括 UART 硬件控制器的初始化、数据传输和中断处理等功能。
在 UART 驱动程序中,uart_port 结构体表示一个串口端口,用于保存串口的状态信息。其中 iotype 表示 IO 类型,可以是 IO_SPACE 或者 MEM_SPACE。access_32b 则表示访问端口时是否采用 32 位访问方式。
IO_SPACE 表示访问串口时使用的是 I/O 空间,即通过 in/out 指令进行读写操作。在这种情况下,access_32b 表示是否使用 32 位的 in/out 指令进行访问。
MEM_SPACE 表示访问串口时使用的是内存空间,即通过 mmap 系统调用将串口寄存器映射到用户空间。在这种情况下,access_32b 表示是否使用 32 位的内存访问方式进行访问。
static int phytium_uart_probe(struct amba_device *dev, const struct amba_id *id) { struct phytium_uart_port *pup; struct vendor_data *vendor = id->data; int portnr, ret; portnr = phytium_find_free_port(); if (portnr < 0) return portnr; pup = devm_kzalloc(&dev->dev, sizeof(struct phytium_uart_port), GFP_KERNEL); if(!pup) return -ENOMEM; pup->clk = devm_clk_get(&dev->dev, NULL); if(IS_ERR(pup->clk)) return PTR_ERR(pup->clk); pup->port.irq = dev->irq[0]; pup->port.line = portnr; pup->vendor = vendor; pup->fifosize = 32; pup->port.iotype = pup->vendor->access_32b ? UPIO_MEM32 : UPIO_MEM; pup->port.ops = &phytium_uart_ops; snprintf(pup->type, sizeof(pup->type), "PL011 rev%u", amba_rev(dev)); ret = phytium_setup_port(&dev->dev, pup, &dev->res, portnr); if (ret) return ret; amba_set_drvdata(dev, pup); return phytium_register_port(pup); }在这段linux内核驱动中加入读取acpi表中描述的固定波特率,并设置波特率的操作,给出详细代码
在这段驱动中,由于使用的是AMBA总线,因此无法直接使用ACPI匹配设备。不过,我们可以在驱动中添加代码来读取设备树中的固定波特率信息,从而设置波特率。
下面是一个简单的示例代码,用于在驱动中读取设备树中的固定波特率信息:
```
static int phytium_uart_probe(struct amba_device *dev, const struct amba_id *id)
{
struct phytium_uart_port *pup;
struct vendor_data *vendor = id->data;
int portnr, ret;
u32 baudrate;
// 获取波特率信息
if (of_property_read_u32(dev->dev.of_node, "baudrate", &baudrate)) {
dev_info(&dev->dev, "no baudrate specified, using default\n");
baudrate = 115200;
} else {
dev_info(&dev->dev, "using baudrate %u\n", baudrate);
}
portnr = phytium_find_free_port();
if (portnr < 0)
return portnr;
pup = devm_kzalloc(&dev->dev, sizeof(struct phytium_uart_port),
GFP_KERNEL);
if (!pup)
return -ENOMEM;
pup->clk = devm_clk_get(&dev->dev, NULL);
if (IS_ERR(pup->clk))
return PTR_ERR(pup->clk);
pup->port.irq = dev->irq[0];
pup->port.line = portnr;
pup->vendor = vendor;
pup->fifosize = 32;
pup->port.iotype = pup->vendor->access_32b ? UPIO_MEM32 : UPIO_MEM;
pup->port.ops = &phytium_uart_ops;
snprintf(pup->type, sizeof(pup->type), "PL011 rev%u", amba_rev(dev));
// 设置波特率
pup->port.uartclk = clk_get_rate(pup->clk);
baudrate = uart_get_baud_rate(&pup->port, baudrate, baudrate);
ret = phytium_setup_port(&dev->dev, pup, &dev->res, portnr);
if (ret)
return ret;
amba_set_drvdata(dev, pup);
return phytium_register_port(pup);
}
```
在这个示例代码中,我们使用了`of_property_read_u32()`函数来读取设备树中的`baudrate`属性。如果设备树中没有指定该属性,则默认使用115200作为波特率。接下来,我们使用`uart_get_baud_rate()`函数来获取实际使用的波特率,并将其传递给`phytium_setup_port()`函数来进行端口设置。
阅读全文