串行是所有“时分复用”的总称,使用一个昂贵的术语。这意味着数据会随着时间的推移而分散发送,通常是一位接一位。您命名的所有协议都是串行协议。
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,但没有人这样做。)
时序依赖性是 UART 的一大缺点,解决方案是USART,用于通用同步/异步接收器发送器。这个可以做UART,也可以做同步协议。在同步中,不仅有数据,还有时钟传输。每个位都有一个时钟脉冲告诉接收器它应该锁存那个位。同步协议要么需要更高的带宽,比如曼彻斯特编码,要么需要额外的时钟线,比如 SPI 和 I2C。
SPI(串行外设接口)是另一种非常简单的串行协议。主机发送一个时钟信号,并且在每个时钟脉冲上,它向从机移出一位,从从机移出一位。因此,信号名称为 SCK 表示时钟,MOSI 表示 Master Out Slave In,MISO 表示 Master In Slave Out。通过使用 SS(从机选择)信号,主机可以控制总线上的多个从机。将多个从设备连接到一个主设备有两种方法,一种是上面提到的即使用从设备选择,另一种是菊花链,它使用较少的硬件引脚(选择线),但软件变得复杂。
I2C(Inter-Integrated Circuit,发音为“I squared C”)也是一种同步协议,它是我们看到的第一个包含一些“智能”的协议;其他的笨拙地把位移进移出,就是这样。I2C 仅使用 2 根线,一根用于时钟 (SCL),一根用于数据 (SDA)。这意味着主机和从机通过同一条线路发送数据,再次由创建时钟信号的主机控制。I2C 不使用单独的从机选择来选择特定设备,但具有寻址功能。主机发送的第一个字节包含一个 7 位地址(以便您可以使用总线上的 127 个设备)和一个读/写位,指示下一个字节是否也将来自主机或应该来自奴隶。在每个字节之后,接收器必须发送一个“0”以确认接收到该字节,主机用第 9 个时钟脉冲锁存。如果主机想要写入一个字节,则重复相同的过程:主机将一位接一位地放在总线上,并且每次都会给出一个时钟脉冲来表示数据已准备好读取。如果主机想要接收数据,它只生成时钟脉冲。当给定时钟脉冲时,从机必须注意下一位已准备好。该协议由 NXP(原 Phillips)申请专利,为了节省许可成本,Atmel 使用了与 I2C 完全相同的 TWI(2-wire interface)一词,因此任何 AVR 设备都不会有 I2C,但会有 TWI。如果主机想要接收数据,它只生成时钟脉冲。当给定时钟脉冲时,从机必须注意下一位已准备好。该协议由 NXP(原 Phillips)申请专利,为了节省许可成本,Atmel 使用了与 I2C 完全相同的 TWI(2-wire interface)一词,因此任何 AVR 设备都不会有 I2C,但会有 TWI。如果主机想要接收数据,它只生成时钟脉冲。当给定时钟脉冲时,从机必须注意下一位已准备好。该协议由 NXP(原 Phillips)申请专利,为了节省许可成本,Atmel 使用了与 I2C 完全相同的 TWI(2-wire interface)一词,因此任何 AVR 设备都不会有 I2C,但会有 TWI。
同一线上的两个或多个信号可能会导致冲突,如果一个设备发送“1”而另一个设备发送“0”,您就会遇到问题。因此总线是线或的:两个电阻将总线拉到高电平,设备只发送低电平。如果他们想发送一个高电平,他们只需释放总线。
TTL(晶体管晶体管逻辑)不是协议。这是一种较旧的数字逻辑技术,但该名称通常用于指代 5 V 电源电压,通常错误地指代应称为 UART 的东西。
关于这些,你可以写一本书,看起来我进展顺利。这只是一个非常简短的概述,如果有些事情需要澄清,请告诉我们。