2

我目前的任务是将一些 16550 兼容芯片的驱动程序从 QNX 移植到 Linux。该芯片提供了几个 UART,每个都被视为标准的 16550 串行端口,尽管有一些扩展。

现在,在 QNX 中,整个设备驱动程序被打包到一个独立的可执行文件中,它既作为驱动程序又作为提供的 UART(波特率、环回模式等)的初始配置器。这在 QNX 中很自然,因为有设备驱动程序在用户空间中运行,只不过是标准的可执行文件。

在 Linux OTOH 上,驱动程序现在被实现为内核模块,可以随意加载。此外,该模块是由生产者提供的,所以我不想对其进行太多修改或修补。

对我来说,剩下的任务是提供一些机制来设置这些 UART 的参数。它们被视为 /dev/ttyPREFIXX 设备。我打算通过在感兴趣的串行端口上调用标准 termios(即 tcsetattr() 或 ioctls)的标准 C 编程可执行文件来做到这一点。

这让我想到了一个问题:我的方法对吗?而且,如果是,那么如何实现持久配置?据我所知(从这个例子:http ://www.easysw.com/~mike/serial/serial.html ),termios 函数作用于 OPEN 设备。简而言之:他们打开设备,设置参数,读取或写入,然后关闭端口。关闭端口后,配置(波特率等)是否丢失?我希望它不是,因为它已经存储在硬件中。

有人可以向我确认配置是持久的吗?并且,如果没有,如何为将来会再次打开该端口并期望它带有一些预先建立的参数的应用程序实现这种持久性?如果不是,我是否应该修改模块内核以接受一些参数,然后在加载时进行配置?

我现在打算的方法是编写打开端口的 C 可执行文件,设置它们的配置,然后关闭端口。我希望后面的应用程序会看到具有所需配置的端口。

谢谢你。

4

2 回答 2

1

你可能想看看sttyand setserial。古老的Serial-HOWTO(哇,我最后一次向任何人推荐 HOWTO 是什么时候?)可能也是一个很好的起点。

于 2012-08-15T20:53:22.887 回答
0

好吧,我在这里找到了答案:http ://www.gnu.org/software/libc/manual/html_node/Mode-Functions.html#Mode-Functions

引用:“虽然 tcgetattr 和 tcsetattr 使用文件描述符指定终端设备,但属性是终端设备本身的属性,而不是文件描述符的属性。这意味着更改终端属性的效果是持久的;如果另一个进程打开终端稍后,它会看到更改的属性,即使它与您最初在更改属性时指定的打开文件描述符没有任何关系。”

这解决了这个问题。

于 2012-08-17T19:10:40.267 回答