4

我有一个关于 UART 控制器的问题。

UART控制器是通用名称吗?

我的意思是,如果我们使用 RS-232 协议,我们应该将此 UART 控制器命名为 RS-232 控制器,如果我们使用 RS-485 作为协议,我们应该将此 UART 控制器称为 RS-485 控制器等等?

我注意到我们通常说网络控制器(协议:以太网,令牌环,ATM,..),如果实现的协议是以太网,例如,我们说以太网控制器。UART控制器和网络控制器之间的正确比较是否意味着它们都是通用名称?

非常感谢您的澄清

4

3 回答 3

10

参考书目:

串行是所有“时分复用”的总称,使用一个昂贵的术语。这意味着数据会随着时间的推移而分散发送,通常是一位接一位。您命名的所有协议都是串行协议。

UART,对于 Universal Asynchronous Receiver Transmitter,是最常用的串行协议之一。它几乎和我一样古老,而且非常简单。大多数控制器板载硬件 UART。它使用单根数据线发送数据,一根数据线接收数据。最常见的 8 位数据传输如下:1 个起始位,低电平,8 个数据位,1 个停止位,高电平。低电平起始位和高电平停止位意味着总是有一个从高到低的转换来启动通信。这就是UART的描述。没有电压电平,因此您可以将其设置为 3.3 V 或 5 V,无论您使用哪种微控制器。请注意,想要通过 UART 进行通信的微控制器必须就传输速度和比特率达成一致,因为它们只有起始位的下降沿才能同步。这就是所谓的异步通信。

对于长距离通信(不一定是数百米),5 V UART 不是很可靠,这就是为什么它被转换为更高电压的原因,通常 +12 V 用于“0”,-12 V 用于“1”。数据格式保持不变。然后你有RS-232(你实际上应该称之为 EIA-232,但没有人这样做。)

重要提示:RS-232 与 TTL 串行通信 - SparkFun Electronics http://goo.gl/0IFYTl

时序依赖性是 UART 的一大缺点,解决方案是USART,用于通用同步/异步接收器发送器。这个可以做UART,也可以做同步协议。在同步中,不仅有数据,还有时钟传输。每个位都有一个时钟脉冲告诉接收器它应该锁存那个位。同步协议要么需要更高的带宽,比如曼彻斯特编码,要么需要额外的时钟线,比如 SPI 和 I2C。

串行编程/典型 RS232 硬件配置 - Wikibooks,开放世界的开放书籍http://goo.gl/uTknU6

RS232      +-----------+   +-----------+   +-----------+   +-----------+
Interface  | Line      |   |           |   | Interface |   |           |
-----------+ Driver /  +---+   UART    +---+ Logic     +---+    CPU    |
           | Receiver  |   |           |   |           |   |           |
           +-----------+   +-----+-----+   +-----+-----+   +-----------+
                                 |               |
                                 |               |
                           +-----+-----+         |
                           | Baud Rate |         |
                           | Generator +---------+
                           |           |
                           +-----------+

UART(通用异步接收发送器)是串行硬件的核心。它是用于在并行数据和串行数据之间进行转换的芯片或芯片的一部分。RS-232 UART 通常还在发送时添加必要的开始/停止和奇偶校验位,并在接收时解码此信息。

UART 通常完全依靠计算机逻辑电压运行。它的串行数据输入/输出电压是计算机逻辑电压,而不是串行线电压。它们将实际的线路接口留给特定的线路驱动器/接收器。该线路驱动器/接收器不一定需要是RS-232线路驱动器/接收器,但也可以是例如RS-422差分驱动器/接收器。这一点,以及波特率、奇偶校验、停止位数、数据位数是可编程的这一事实是 UART 被称为通用的原因。如果 UART 和线路驱动器/接收器都放置在同一个芯片中,它们之间的区别就会变得模糊。此类芯片通常也以“UART”标签出售。

UART 被称为异步,因为它们不使用特殊的时钟信号与远程端同步。相反,它们使用开始/停止位来识别串行流中的数据位。

多亏了 UART,其余的硬件以及软件应用程序可以处理普通字节来保存通信数据。UART 的工作是在发送时将一个字节切割成一系列串行位,并在接收时将一系列位组装成一个字节。UART 通常包含 8 位宽的接收器和传输缓冲器。如果例如使用 7 位传输,则可能不会使用其中的所有位。接收到的串行数据并行提供在接收缓冲区中,待发送数据并行写入发送缓冲区。根据 UART,缓冲区可能只有一个字节或几个字节的深度(在 15 或 16 字节的范围内)。缓冲区越浅,与 CPU 的通信需要越精确。例如,如果接收缓冲区只有一个字节的深度,

由于串行接口上​​的时序很重要,因此 UART 通常连接到波特率发生器,要么是 UART 芯片的内部,要么是外部的。

SPI(串行外设接口)是另一种非常简单的串行协议。主机发送一个时钟信号,并且在每个时钟脉冲上,它向从机移出一位,从从机移入一位。因此,信号名称为 SCK 表示时钟,MOSI 表示 Master Out Slave In,MISO 表示 Master In Slave Out。通过使用 SS(从机选择)信号,主机可以控制总线上超过 1 个从机。将多个从设备连接到一个主设备有两种方法,一种是上面提到的即使用从设备选择,另一种是菊花链,它使用较少的硬件引脚(选择线),但软件变得复杂。

I2C(Inter-Integrated Circuit,发音为“I squared C”)也是一种同步协议,它是我们看到的第一个包含一些“智能”的协议;其他的笨拙地把位移进移出,就是这样。I2C 仅使用 2 根线,一根用于时钟 (SCL),一根用于数据 (SDA)。这意味着主机和从机通过同一条线路发送数据,再次由创建时钟信号的主机控制。I2C 不使用单独的从选择来选择特定设备,但具有寻址功能。主机发送的第一个字节包含一个 7 位地址(以便您可以使用总线上的 127 个设备)和一个读/写位,指示下一个字节是否也将来自主机,应该来自奴隶。在每个字节接收方必须发送一个“0”来确认接收到该字节后,主机用第 9 个时钟脉冲锁存。如果主机想要写入一个字节,则重复相同的过程:主机将一位接一位地放在总线上,并且每次都会给出一个时钟脉冲来表示数据已准备好读取。如果主机想要接收数据,它只生成时钟脉冲。当给定时钟脉冲时,从机必须注意下一位已准备好。该协议是NXP(原飞利浦)的专利,为了节省许可成本,Atmel 使用了与I2C 完全相同的TWI(2-wire interface)一词,因此任何AVR 设备都不会有I2C,但会有TWI。如果主机想要接收数据,它只生成时钟脉冲。当给定时钟脉冲时,从机必须注意下一位已准备好。该协议是NXP(原飞利浦)的专利,为了节省许可成本,Atmel 使用了与I2C 完全相同的TWI(2-wire interface)一词,因此任何AVR 设备都不会有I2C,但会有TWI。如果主机想要接收数据,它只生成时钟脉冲。当给定时钟脉冲时,从机必须注意下一位已准备好。该协议是NXP(原飞利浦)的专利,为了节省许可成本,Atmel 使用了与I2C 完全相同的TWI(2-wire interface)一词,因此任何AVR 设备都不会有I2C,但会有TWI。

同一线上的两个或多个信号可能会导致冲突,如果一个设备发送“1”而另一个设备发送“0”,您就会遇到问题。因此总线是线或的:两个电阻将总线拉到高电平,设备只发送低电平。如果他们想发送一个高电平,他们只需释放总线。

TTL(晶体管晶体管逻辑)不是协议。这是一种较旧的数字逻辑技术,但该名称通常用于指代 5 V 电源电压,通常错误地指代应称为 UART 的东西。


关于这些,你可以写一本书,看起来我进展顺利。这只是一个非常简短的概述,如果有些事情需要澄清,请告诉我们。

于 2014-04-26T11:49:41.377 回答
1

UART(通用异步接收器发送器)是/曾经是在并行总线信号和串行信号之间移动的芯片。首先,我经常使用 AFAIR 是 8250。这些天,RS232 的使用越来越少,并且经常通过 USB、蓝牙和其他连接进行仿真,因此物理 UART 可能不再存在。适当地,您应该指定适用的协议、电压级别和连接器。

于 2013-08-27T07:37:10.283 回答
1

UART:通用异步接收器/发送器,其姊妹设备USART(同步/异步)。这些设备在早期的个人电脑中很常见,并且被用于许多事情。它们主要用于 RS-232 通信,但它们足够灵活,可用于 RS-485 和其他系统,具体取决于它们的编程方式。几十年来我都没有见过,因为它们已被 USB 设备取代,或者它们的功能现在已在软件中实现。

至于你的问题:用最符合其功能的名称来引用它。

于 2013-08-27T07:40:26.177 回答