当前位置: 首页 > news >正文

【单片机】DS2431英文手册,中文手册,翻译

DS2431是一款1024位的1-Wire® EEPROM芯片,以每个256位的四个内存页面组织。数据被写入8字节的暂存区,经过验证,然后复制到EEPROM存储器中。作为一个特殊功能,四个内存页面可以单独地被写保护,或者被置于EPROM仿真模式,其中位只能从1更改为0。DS2431通过单导线1-Wire总线进行通信。通信遵循标准的1-Wire协议。每个设备都有自己不可更改的独特的64位ROM注册号,这个号码在芯片上由工厂激光刻写。
在这里插入图片描述
优势与特点:

● 轻松为任何个体系统添加可追溯性和相关信息

  • 1024位的EEPROM存储器,分为四个256位的页面
  • 可以单独对每个内存页面进行永久写保护,或置于EPROM仿真模式(写为0)
  • 切换点滞后和滤波以在噪声存在的情况下优化性能

● 简约的1-Wire接口降低成本和接口复杂性

  • IEC 1000-4-2 Level 4 静电放电保护(±8kV 接触,±15kV 空气,典型值)
  • 在从 -40°C 到 +85°C 的广泛电压范围内读写
  • 通过单一数字信号以15.4kbps或125kbps与主机通信

在这里插入图片描述

DS2431将1024位的EEPROM、一个带有最多7个用户读/写字节的8字节寄存器/控制页,以及一个功能齐全的1-Wire接口融合在单个芯片中。每个DS2431都有自己的64位ROM注册号,由工厂激光刻写到芯片中,以提供绝对可追溯性的确保唯一身份。数据通过1-Wire协议进行串行传输,仅需要一个数据引脚和一个地线返回。DS2431还有一个额外的内存区域,称为暂存区,用作在写入主存储器或寄存器页时的缓冲区。数据首先写入暂存区,然后可以读取回来。在数据经过验证后,复制暂存区命令将数据传输到其最终的存储位置。DS2431的应用包括附件/PCB识别、医疗传感器校准数据存储、模拟传感器校准,包括IEEE P1451.4智能传感器,墨盒和硒鼓打印机识别,以及后市场耗材管理。

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

1-Wire协议的分层结构如图2所示。总线主机首先必须提供七种ROM功能命令之一:读取ROM、匹配ROM、搜索ROM、跳过ROM、恢复、过载-跳过ROM或过载-匹配ROM。在以标准速度执行完成过载-跳过ROM或过载-匹配ROM命令字节后,设备进入过载模式,随后的所有通信都以更高的速度进行。这些ROM功能命令所需的协议在图9中描述。成功执行ROM功能命令后,内存功能变得可访问,主机可以提供其中任何一个四种内存功能命令之一。这些内存功能命令的协议在图7中描述。所有数据都是以最低有效位优先进行读取和写入。

64位激光刻写的ROM:每个DS2431包含一个64位长的唯一ROM代码。前8位是1-Wire家族代码。接下来的48位是唯一的序列号。最后8位是前56位的循环冗余校验(CRC)。详细信息请参见图3。1-Wire CRC使用一个移位寄存器和异或门组成的多项式生成器生成,如图4所示。多项式为X8 + X5 + X4 + 1。

移位寄存器位初始化为0。然后,从家族代码的最低有效位开始,一次将一个位进行移位。在输入完家族代码的第8位后,输入序列号。在输入完序列号的最后一位后,移位寄存器包含CRC值。将CRC的8位进行移位会将移位寄存器恢复为全部为0。

在这里插入图片描述

内存访问:数据内存和寄存器位于线性地址空间中,如图5所示。数据内存和寄存器具有无限制的读取访问权限。DS2431的EEPROM数组由18行,每行8字节组成。

前16行平均分成四个内存页面(每个32字节)。这四个页面是主要的数据内存。每个页面可以通过在寄存器行中设置相关的保护字节,单独设置为开放(未受保护)、写保护或EPROM模式。作为出厂默认设置,整个数据内存是未受保护的,其内容是未定义的。最后两行包含保护寄存器和保留字节。寄存器行包括4个保护控制字节、一个复制保护字节、一个工厂字节和2个用户字节/制造商ID字节。制造商ID可以是客户提供的标识代码,有助于应用软件识别与DS2431相关的产品。

在这里插入图片描述
请与工厂联系以设置和注册自定义制造商ID。最后一行保留供将来使用。在读/写功能方面,它是未定义的,不应使用。

除了主EEPROM数组外,还包括8字节的易失性暂存区。对EEPROM数组的写操作是一个两步过程。首先,数据被写入暂存区,然后复制到主数组中。这允许用户在复制到主数组之前先验证写入暂存区的数据。设备仅支持完整行(8字节)的复制操作。为了使暂存区中的数据对复制操作有效,使用写暂存区命令提供的地址必须从行边界开始,并且必须将8个完整字节写入暂存区。

保护控制寄存器确定在写暂存区命令中的传入数据如何加载到暂存区。保护设置为55h(写保护)会导致传入的数据被忽略,目标地址主内存数据被加载到暂存区。保护设置为AAh(EPROM模式)会导致传入数据和目标地址主内存数据的逻辑与被加载到暂存区。任何其他保护控制寄存器设置会使相关内存页面开放,可以无限制地进行写入访问。

注:要使EPROM模式正常工作,首先必须将受影响的整个内存页面编程为FFh。

保护控制字节设置为55h或AAh也会写保护保护控制字节。保护控制字节设置为55h不会阻止复制。这允许刷新(即使用当前数据重新编程)受写保护的数据。

复制保护字节用于更高级别的安全性,只应在所有其他保护控制字节、用户字节和写保护页面设置为最终值后使用。如果复制保护字节设置为55h或AAh,则会阻止对寄存器行和用户字节行的所有复制尝试。此外,所有复制尝试写保护的主内存页面(即刷新)都会被阻止。

地址寄存器和传输状态:DS2431使用三个地址寄存器:TA1、TA2和E/S(图6)。这些寄存器对许多其他1-Wire设备是共用的,但在DS2431中的操作稍有不同。寄存器TA1和TA2必须加载目标地址,该地址是要写入数据的地址或要从中读取数据的地址。寄存器E/S是一个只读的传输状态寄存器,用于通过写命令验证数据完整性。寄存器E/S的位E[2:0]在写暂存区命令上加载传入的T[2:0],并在每个后续数据字节上递增。这实际上是在8字节暂存区内的字节结束偏移计数器。寄存器E/S的第5位,称为PF,如果暂存区中的数据由于断电或主机发送的字节数不足以达到暂存区末端而无效,它为逻辑1。对于对暂存区的有效写入,T[2:0]必须为0,且主机必须发送了8个数据字节。位3、4和6没有功能,它们总是读取0。寄存器E/S的最高位,称为授权接受(AA),作为一个标志,指示已经将存储在暂存区中的数据复制到目标内存地址。将数据写入暂存区会清除此标志。

在这里插入图片描述

带验证的写入:要将数据写入DS2431,必须使用暂存区作为中间存储。首先,主机发出写暂存区命令来指定所需的目标地址,然后是要写入暂存区的数据。请注意,复制暂存区命令必须在8字节边界上执行,即目标地址的三个最低有效位(T2、T1、T0)必须等于000b。

如果T[2:0]的值为非零值,则复制功能被阻止。在某些条件下(请参阅写暂存区[0Fh]部分),主机在写暂存区命令序列结束时会接收到命令、地址(实际发送的地址)和数据的反向CRC-16。在知道此CRC值的情况下,主机可以将其与其计算的值进行比较,以确定通信是否成功,并继续执行复制暂存区命令。如果主机无法接收到CRC-16,则应发送读暂存区命令以验证数据的完整性。在暂存区数据的前导码中,DS2431会重复目标地址TA1和TA2,并发送E/S寄存器的内容。如果PF标志被设置,表示数据没有正确到达暂存区,或者自上次写入暂存区的数据以来断电。主机无需继续读取,可以开始新的尝试将数据写入暂存区。类似地,将设置的AA标志与清除的PF标志一起,表示设备未能识别写命令。

如果一切都进行得正确,两个标志都会被清除。现在主机可以继续读取和验证每个数据字节。主机在验证了数据后,可以发送复制暂存区命令,例如。该命令必须紧随目标地址寄存器TA1、TA2和E/S的数据。主机应通过读取暂存区来获取这些寄存器的内容。

内存功能命令:内存功能流程图(图7)描述了访问DS2431内存所需的协议。如何使用这些功能来写入和读取设备的示例在内存功能示例部分中。主机与DS2431之间的通信可以在标准速度(默认,OD = 0)或过载速度(OD = 1)下进行。如果未显式设置为过载模式,DS2431将假定标准速度。

写暂存区[0Fh]:写暂存区命令适用于数据内存和寄存器页中的可写地址。

为使暂存区数据对复制到数组有效,用户必须从有效的行边界开始执行8字节的写暂存区命令。写暂存区命令接受无效地址和部分行,但后续的复制暂存区命令将被阻止。

发出写暂存区命令后,主机必须首先提供2字节的目标地址,然后是要写入暂存区的数据。数据从T[2:0]的字节偏移开始写入暂存区。

E/S位E[2:0]加载了起始字节偏移,并随后的每个字节递增。实际上,E[2:0]是写入暂存区的最后一个完整字节的字节偏移。只接受完整的数据字节。

在执行写暂存区命令时,DS2431内部的CRC生成器(图13)会计算整个数据流的CRC,从命令代码开始,到由主机发送的最后一个数据字节结束。这个CRC是使用CRC-16多项式生成的,首先清除CRC生成器,然后将写暂存区命令的命令代码(0Fh)、目标地址(TA1和TA2)以及所有数据字节都移入。请注意,CRC-16计算是使用主机实际发送的TA1、TA2和数据进行的。主机可以随时结束写暂存区命令。然而,如果到达暂存区的末尾(E[2:0] = 111b),主机可以发送16个读时间槽,并接收由DS2431生成的CRC。

如果尝试将写暂存区命令写入受写保护的位置,则暂存区会加载已经存在于内存中的数据,而不是传输的数据。

同样,如果目标地址页处于EPROM模式,则暂存区会加载传输数据和已经存在于内存中的数据的位逻辑与。

在这里插入图片描述
读取暂存区命令[AAh]:读取暂存区命令用于验证目标地址和暂存区数据的完整性。发出命令代码后,主机开始读取。

前两个字节是目标地址。接下来的字节是结束偏移/数据状态字节(E/S),后面是暂存区数据,可能与主机最初发送的数据不同。如果目标地址位于寄存器页内或处于写保护模式或EPROM模式的页面内,这一点尤为重要。有关详细信息,请参阅写暂存区[0Fh]部分。主机应该逐个读取整个暂存区(E[2:0] - T[2:0] + 1字节),在读取完CRC后,它将接收到由DS2431根据数据生成的反向CRC。如果主机在CRC之后继续读取,所有数据将为逻辑1。

复制暂存区[55h]:复制暂存区命令用于将数据从暂存区复制到可写的内存部分。发出复制暂存区命令后,主机必须提供一个3字节的授权模式,这应该是紧随其后的读暂存区命令获取的。这个3字节的模式必须与三个地址寄存器(TA1、TA2、E/S,按顺序排列)中的数据完全匹配。如果模式匹配,目标地址有效,PF标志未设置,目标内存未被复制保护,则设置AA标志并开始复制。所有8个字节的暂存区内容都会复制到目标内存位置。设备内部数据传输的持续时间为tPROG,在此期间,1-Wire总线上的电压不能低于2.8V。在数据复制完成后,将传输0和1交替的模式,直到主机发出复位脉冲。如果设置了PF标志或目标内存被复制保护,复制将不会开始,AA标志也不会被设置。

读取内存[F0h]:读取内存命令是从DS2431读取数据的一般功能。发出命令后,主机必须提供2字节的目标地址。在这两个字节之后,主机从目标地址开始读取数据,可以一直读取到地址008Fh。如果主机继续读取,结果将是逻辑1。设备的内部TA1、TA2、E/S和暂存区内容不会受到读取内存命令的影响。

1-Wire总线系统:1-Wire总线是一个系统,有一个总线主机和一个或多个从设备。在所有情况下,DS2431都是从设备。总线主机通常是微控制器。关于这个总线系统的讨论分为三个主题:硬件配置、事务序列和1-Wire信号(信号类型和时序)。

硬件配置:1-Wire总线仅有一根线,根据定义,每个总线上的设备在适当的时间必须能够驱动它。为了实现这一点,连接到1-Wire总线的每个设备必须具有开漏或三态输出。DS2431的1-Wire端口是开漏的,内部电路与图8中所示的等效。

多点总线由一个1-Wire总线和多个附加的从设备组成。DS2431支持标准通信速度和过载通信速度,分别为15.4kbps(最大)和125kbps(最大)。请注意,传统的1-Wire产品支持标准通信速度为16.3kbps和过载速度为142kbps。DS2431的略微降低的速率是由于额外的恢复时间导致的,而这又是由于1

-Wire物理接口增强以提高抗干扰能力。上拉电阻的值主要取决于网络大小和负载条件。DS2431在任何速度下都需要一个2.2kΩ(最大)的上拉电阻。

1-Wire总线的空闲状态是高电平。如果由于任何原因需要暂停事务,如果事务要恢复,则总线必须保持在空闲状态。如果这不发生,总线在过载速度下保持低电平超过16μs,或在标准速度下保持低电平超过120μs,可能会重置总线上的一个或多个设备。

事务序列:通过1-Wire端口访问DS2431的协议如下: ● 初始化 ● ROM功能命令 ● 内存功能命令 ● 事务/数据

初始化:1-Wire总线上的所有事务都以初始化序列开始。初始化序列由总线主机发送的复位脉冲和从设备发送的存在脉冲组成。存在脉冲让总线主机知道DS2431位于总线上并且已准备好操作。有关更多详细信息,请参阅1-Wire信号部分。

1-Wire ROM功能命令:一旦总线主机检测到存在,它可以发出DS2431支持的七个ROM功能命令之一。所有ROM功能命令的长度为8位。以下是这些命令的列表(参见图9中的流程图)。

读取ROM [33h]:读取ROM命令允许总线主机读取DS2431的8位家族代码、独特的48位序列号和8位CRC。仅当总线上有一个从设备时才能使用此命令。如果总线上存在多个从设备,当所有从设备尝试同时传输时(开漏输出产生有线AND结果),会发生数据碰撞。由此产生的家族代码和48位序列号导致CRC不匹配。

匹配ROM [55h]:匹配ROM命令,后跟一个64位ROM序列,允许总线主机在多点总线上寻址特定的DS2431。只有与64位ROM序列完全匹配的DS2431才会响应后续的内存功能命令。所有其他从设备等待复位脉冲。此命令可用于单个设备或总线上的多个设备。

搜索ROM [F0h]:当系统首次启动时,总线主机可能不知道1-Wire总线上的设备数量或其注册号。通过利用总线的有线AND特性,主机可以使用排除法来识别所有从设备的注册号。对于每个注册号位,从最低有效位开始,总线主机发出一组三个时间槽。在第一个时间槽上,参与搜索的每个从设备输出其注册号位的真值。在第二个时间槽上,参与搜索的每个从设备输出其注册号位的补码值。在第三个时间槽上,主机将要选择的位的真值写入。所有与主机写入的位不匹配的从设备停止参与搜索。

如果两个读取的位都为零,主机就知道存在具有位的两种状态的从设备。通过选择要写入的状态,总线主机在ROM代码树中进行分支。经过一次完整的传递,总线主机就知道了单个设备的注册号。进一步的传递可以识别出其余设备的注册号。有关详细讨论,请参阅应用笔记187:1-Wire搜索算法,包括一个示例。

跳过ROM [CCh]:在单点总线系统中,此命令可以通过允许总线主机在不提供64位ROM代码的情况下访问内存功能来节省时间。如果总线上存在多个从设备,例如在跳过ROM命令后发出读取命令,多个从设备同时传输时会在总线上发生数据碰撞(开漏下拉产生有线AND结果)。

恢复 [A5h]:为了在多点环境中最大化数据吞吐量,提供了恢复命令。此命令检查RC位的状态,如果设置了RC位,则直接将控制传递给内存功能命令,类似于跳过ROM命令。设置RC位的唯一方式是通过成功执行匹配ROM、搜索ROM或超速匹配ROM命令。一旦设置了RC位,可以通过恢复命令重复访问设备。在总线上访问另一个设备会清除RC位,防止两个或多个设备同时响应恢复命令。

超速跳过ROM [3Ch]:在单点总线上,此命令可以节省时间,允许总线主机在不提供64位ROM代码的情况下访问内存功能。与正常的跳过ROM命令不同,超速跳过ROM命令将DS2431设置为超速模式(OD = 1)。此命令之后的所有通信都必须以超速速度进行,直到最短480μs的复位脉冲将总线上的所有设备重置为标准速度(OD = 0)为止。

在多点总线上发出此命令会将所有支持超速的设备设置为超速模式。要随后寻址特定的支持超速的设备,必须发出超速速度的复位脉冲,然后是匹配ROM或搜索ROM命令序列。这加快了搜索过程的时间。如果总线上存在支持超速的多个从设备,并且超速跳过ROM命令之后是读取命令,多个从设备同时传输时会在总线上发生数据碰撞(开漏下拉产生有线AND结果)。

超速匹配ROM [69h]:超速匹配ROM命令后跟一个以超速速度传输的64位ROM序列,允许总线主机在多点总线上寻址特定的DS2431并同时将其设置为超速模式。

只有与64位ROM序列完全匹配的DS2431才会响应后续的内存功能命令。已经在先前的超速跳过ROM或成功的超速匹配ROM命令中处于超速模式的从设备将保持超速模式。所有支持超速的从设备在下一个最短480μs的复位脉冲时返回标准速度。超速匹配ROM命令可以用于单个设备或总线上的多个设备。

1-Wire Signaling

DS2431需要严格的协议以确保数据完整性。协议在一条线上包含四种类型的信号:带有复位脉冲和存在脉冲的复位序列,写零,写一和读数据。除了存在脉冲外,总线主机引发所有下降沿。

DS2431可以以两种不同的速度进行通信:标准速度和超速速度。如果没有明确设置为超速模式,DS2431将以标准速度进行通信。在超速模式下,快速时序适用于所有波形。

要从空闲到活动,1-Wire线上的电压需要从VPUP下降到阈值VTL以下。要从活动返回到空闲,电压需要从VILMAX上升超过阈值VTH。电压完成这次上升所需的时间在图10中表示为ε,并且其持续时间取决于使用的上拉电阻(RPUP)和连接的1-Wire网络的电容。电压VILMAX在确定逻辑电平时与DS2431相关,而不会触发任何事件。

图10显示了与DS2431开始任何通信所需的初始化序列。复位脉冲后跟存在脉冲表明DS2431已准备好接收数据,前提是给出了正确的ROM和存储器功能命令。如果总线主机在下降沿上使用斜率控制,则必须在tRSTL + tF内将线拉低以补偿边缘。持续时间为480微秒或更长的tRSTL会退出超速模式,将设备恢复到标准速度。如果DS2431处于超速模式并且tRSTL不超过80微秒,则设备仍然处于超速模式。如果设备处于超速模式并且tRSTL在80微秒和480微秒之间,则设备会复位,但通信速度无法确定。

总线主机释放线路后,它进入接收模式。现在,通过上拉电阻将1-Wire总线拉到VPUP,或者在DS2482-x00或DS2480B驱动程序的情况下,通过主动电路。当越过阈值VTH时,DS2431会等待tPDH,然后通过将线路拉低tPDL来发送存在脉冲。为了检测存在脉冲,主机必须在tMSP时测试1-Wire线路的逻辑状态。

tRSTH窗口的持续时间必须至少为tPDHMAX,tPDLMAX和tRECMIN的总和。在tRSTH过期后,DS2431已准备好进行数据通信。在混合种群网络中,tRSTH应在标准速度下至少延长到480微秒,在超速速度下至少延长到48微秒,以适应其他1-Wire设备。

读/写时间槽
与DS2431的数据通信在时间槽中进行,每个时间槽携带一个位。写时间槽将数据从总线主机传输到从属设备。读时间槽将数据从从属设备传输到主机。图11说明了写和读时间槽的定义。

所有通信始于主机将数据线拉低。当1-Wire线上的电压降至阈值VTL以下时,DS2431启动其内部计时发生器,该发生器确定在写时间槽期间何时对数据线进行采样,以及在读时间槽期间数据有效的持续时间。

主机到从属设备对于写一时间槽,数据线上的电压必须在写一低电平时间tW1LMAX过期之前越过VTH阈值。对于写零时间槽,数据线上的电压必须在写零低电平时间tW0LMIN过期之前保持低于VTH阈值。

为了实现最可靠的通信,在整个tW0L或tW1L窗口期间,数据线上的电压不应超过VILMAX。在越过VTH阈值后,DS2431需要恢复时间tREC,然后才能准备好进行下一个时间槽。

从属设备到主机读取数据时间槽开始时类似于写一时间槽。

在读取低电平时间tRL过期之前,数据线上的电压必须保持低于VTL。在tRL窗口期间,当以0回应时,DS2431开始将数据线拉低;其内部计时发生器确定何时结束这次拉低并且电压开始上升。当以1回应时,DS2431根本不保持数据线低电平,电压会在tRL结束后立即开始上升。

tRL + δ(上升时间)与DS2431的内部计时发生器的和定义了主机采样窗口(从tMSRMIN到tMSRMAX),在该窗口中主机必须从数据线上进行读取。

为了实现最可靠的通信,tRL应尽可能短,主机应在tMSRMAX之前但不迟于tMSRMAX时进行读取。从数据线读取后,主机必须等待tSLOT过期。这保证了DS2431有足够的恢复时间tREC来准备好下一个时间槽。请注意,此处指定的tREC仅适用于连接到1-Wire线的单个DS2431。对于多设备配置,必须延长tREC以适应额外的1-Wire设备输入电容。或者,可以使用在1-Wire恢复时间内执行主动上拉的接口,例如DS2482-x00或DS2480B 1-Wire线驱动程序。

Improved Network Behavior (Switchpoint Hysteresis)

在1-Wire环境中,线路终端仅在总线主机(1-Wire驱动程序)控制的瞬态期间才可能出现。因此,1-Wire网络容易受到来自不同来源的噪声影响。根据网络的物理尺寸和拓扑结构,来自端点和分支点的反射可能在一定程度上累积或抵消。这种反射在1-Wire通信线上会表现为故障或振铃。从外部源耦合到1-Wire线上的噪声也可能导致信号故障。在时间槽上升沿期间出现故障可能导致从属设备失去与主机的同步,从而导致搜索ROM命令陷入死胡同或导致特定于设备的功能命令中止。为了在网络应用中获得更好的性能,DS2431使用了新的1-Wire前端,使其对噪声的敏感性降低。

DS2431的1-Wire前端与传统的从属设备有三个特点不同。

  1. 电路中检测时间槽开始时下降沿的部分增加了低通滤波。

这减少了对高频噪声的敏感性。

这种额外的滤波不适用于超速速度。

  1. 在低至高切换阈值VTH处存在滞后。如果负的故障越过VTH但不低于VTH - VHY,它不会被识别(图12,情况A)。这种滞后在任何1-Wire速度下都有效。

  2. 在上升沿保持时间tREH内存在一个时间窗口,在此窗口内忽略故障,即使它们在VTH - VHY阈值以下延伸(图12,情况B,tGL < tREH)。在越过VTH阈值后出现的深电压降或故障,并且超出tREH窗口,无法被滤除,并被视为新时间槽的开始(图12,情况C,tGL ≥ tREH)。

具有在其电气特性中指定的参数VHY和tREH的设备使用了改进的1-Wire前端。

CRC生成DS2431使用两种不同类型的CRC。其中一个CRC是8位类型,存储在64位ROM的最高有效字节中。总线主机可以根据64位ROM的前56位计算CRC值,并将其与DS2431内部存储的值进行比较,以确定ROM数据是否已无误接收。这个CRC的等效多项式函数是X8 + X5 + X4 + 1。此8位CRC以真(非反转)形式接收。它在工厂中计算并刻入ROM。

另一个CRC是16位类型,根据标准化的CRC-16多项式函数X16 + X15 + X2 + 1生成。在写入或从临时存储器读取时,此CRC用于快速验证数据传输。与8位CRC不同,16位CRC始终以反转形式传输。DS2431芯片内部的CRC生成器(图13)根据命令流程图(图7)计算一个新的16位CRC。总线主机将从设备读取的CRC值与从数据计算的CRC值进行比较,并决定是否继续操作或重新读取带有CRC错误的数据部分。

通过写入临时存储器命令,CRC是通过首先清除CRC生成器,然后按命令代码、目标地址TA1和TA2,以及总线主机发送的所有数据字节进行移位来生成的。只有在E[2:0] = 111b时,DS2431才会传输此CRC。

通过读取临时存储器命令,CRC是通过首先清除CRC生成器,然后按命令代码、目标地址TA1和TA2,E/S字节以及DS2431发送的临时存储器数据进行移位来生成的。只有在读取继续到临时存储器末尾时,DS2431才会传输此CRC。

有关生成CRC值的更多信息,请参阅应用笔记27。

在这里插入图片描述

在这里插入图片描述

相关文章:

【单片机】DS2431英文手册,中文手册,翻译

DS2431是一款1024位的1-Wire EEPROM芯片&#xff0c;以每个256位的四个内存页面组织。数据被写入8字节的暂存区&#xff0c;经过验证&#xff0c;然后复制到EEPROM存储器中。作为一个特殊功能&#xff0c;四个内存页面可以单独地被写保护&#xff0c;或者被置于EPROM仿真模式&a…...

centos7部署openldap开启memberof并接入jumpserver

文章目录 前言1.yum安装openldap2.配置密码3.导入配置4.定义域5.配置memberof6.配置base dn7.安装phpldapadmin管理8.调整httpd的配置9.调整php的配置10.登陆php管理页面11.同步旧ldapsever用户数据(可省略)12.客户端配置13.对接jumpserver 前言 介绍如何在centos7上部署openl…...

Unity游戏源码分享-仿开心消消乐Match3Jewel

Unity游戏源码分享-仿开心消消乐Match3Jewel 工程地址&#xff1a; https://download.csdn.net/download/Highning0007/88198762...

知识图谱基本工具Neo4j使用笔记 四 :使用csv文件批量导入图谱数据

文章目录 一、系统说明二、说明三、简单介绍1. 相关代码以及参数2. 简单示例 四、实际数据实践1. 前期准备&#xff08;1&#xff09; 创建一个用于测试的neo4j数据库&#xff08;2&#xff09;启动neo4j 查看数据库 2. 实践&#xff08;1&#xff09; OK 上面完成后&#xff0…...

[bug修复]状态数据在useEffect初始化时更新无效

&#xff08;bug修复类型的博客还是用汉语写捏&#xff09; 前两天在做一个管理页面前端的时候&#xff0c;出现了这样的问题 function Son(props){const [a,seta]useState(0)useEffect(()>{seta(props.name)},[])return(<div>{a}</div>) } 这是当时情况的一…...

使用 API Gateway Integrator 在 Quarkus 中实施适用于 AWS Lambda 的 OpenAPI

AWS API Gateway 集成使得使用符合 OpenAPI 标准的 Lambda Function 轻松实现 REST API。 关于开放API 它是一个 允许以标准方式描述 REST API 的规范。 OpenAPI规范 (OAS) 为 REST API 定义了与编程语言无关的标准接口描述。这使得人类和计算机都可以发现和理解服务的功能&am…...

【JVM】JVM中的分代回收

文章目录 分代收集算法什么是分代分代收集算法-工作机制MinorGC、 Mixed GC 、 FullGC的区别是什么 分代收集算法 什么是分代 在java8时&#xff0c;堆被分为了两份&#xff1a; 新生代和老年代【1&#xff1a;2】 其中&#xff1a; 对于新生代&#xff0c;内部又被分为了三…...

C# Linq源码分析之Take方法

概要 Take方法作为IEnumerable的扩展方法&#xff0c;具体对应两个重载方法。本文主要分析第一个接收整数参数的重载方法。 源码解析 Take方法的基本定义 public static System.Collections.Generic.IEnumerable Take (this System.Collections.Generic.IEnumerable source…...

从后往前读取列表的方法

从后往前读取列表的方法 方法1&#xff1a;使用for循环遍历列表时&#xff0c;可以使用reverse()函数将列表反转&#xff0c;然后再遍历。 # 列表 num [0, 1, 2, 3]# 反向遍历 for i in reversed(num):print(i)输出结果&#xff1a; 3 2 1 0方法2&#xff1a;先计算列表长度…...

数据库--数据类型

数据库相关链接&#xff1a; 数据库基础操作--增删改查&#xff1a;http://t.csdn.cn/189CF 数据库--三大范式、多表查询、函数sql&#xff1a;http://t.csdn.cn/udJSG 数据类型 创建表的时候&#xff0c;我们在类型这里给出了不同的选项&#xff0c;比如有int &#xff0c;…...

小型双轮差速底盘机器人实现红外跟随功能

1. 功能说明 本文示例将实现R023样机小型双轮差速底盘跟随人移动的功能。在小型双轮差速底盘前方按下图所示安装3个 近红外传感器&#xff0c;制作一个红外线发射源&#xff0c;实现当红外发射源在机器人的检测范围内任意放置或移动时&#xff0c;机器人能追踪该发射源。 2. 电…...

TCP协议网络编程 回显服务器,客户端实现

回显服务器表示客户端传来的请求是什么&#xff0c;服务器就回应什么&#xff0c;客户端不用对传来的数据进行处理&#xff0c;主要是为了熟悉TCP协议提供的API的使用 对于代码的解释全作为注释写在了代码上&#xff0c;推荐复制到编程软件中查看 UDP协议实现回显服务器可以看…...

3.4 Spring MVC注解

注解名称 注解说明 RequestMapping 用来处理请求地址映射的注解&#xff0c;可以在接口、类和方法上使用 value属性 表示请求地址&#xff0c;与path属性一致 method属性 表示接收HTTP请求方法&#xff0c;默认接收所有请求方法&#xff0c;请求包括GET、POST、PUT、DEL…...

OpenCV实例(八)车牌字符识别技术(三)汉字识别

车牌字符识别技术&#xff08;三&#xff09;汉字识别 1.代码实例2.遇到问题3.汉字识别代码实例 相较于数字和英文字符的识别&#xff0c;汽车牌照中的汉字字符识别的难度更大&#xff0c;主要原因有以下4个方面&#xff1a; (1)字符笔画因切分误差导致非笔画或笔画流失。 (2…...

运维监控学习笔记2

硬件监控&#xff1a; 1&#xff09;使用IPMI 2&#xff09;机房巡检 路由器和交换机&#xff1a; 使用SNMP&#xff08;简单网络管理协议&#xff09;进行监控。 Linux 安装snmp&#xff1a; yum install -y net-snmp net-snmp-utils 说明&#xff1a;net-snmp是安装在snm…...

【深度学习】遗传算法[选择、交叉、变异、初始化种群、迭代优化、几何规划排序选择、线性交叉、非均匀变异]

目录 一、遗传算法二、遗传算法概述2.1 选择2.2 交叉2.3 变异 三、遗传算法的基本步骤3.1 编码3.2 初始群体的生成3.3 适应度评估3.4 选择3.5 交叉3.6 变异3.7 总结 四、遗传算法工具箱4.1 initializega4.2 ga4.3 normGeomSelect4.4 arithXover4.5 nonUnifMutation 五、遗传算法…...

【小吉带你学Git】讲解GitHub操作,码云操作,GitLab操作

&#x1f38a;专栏【Git】 &#x1f354;喜欢的诗句&#xff1a;更喜岷山千里雪 三军过后尽开颜。 &#x1f386;音乐分享【如愿】 &#x1f33a;欢迎并且感谢大家指出小吉的问题&#x1f970; 文章目录 &#x1f354;GitHub操作⭐安装GitHub插件⭐在idea中设置GitHub账号&…...

nginx基础

nginx 具体就是一个轻量级以及高性能的web服务软件。 nginx特点 1、稳定性高。&#xff08;但不如apache&#xff09; 2、系统资源消耗比较低。&#xff08;处理http请求的并发能力较高&#xff0c;单台处理器可以处理3w-5w的并发请求&#xff09; 注&#xff1a;一般在企…...

【Windows API】获取卷标、卷名

1、卷->卷标 使用FindFirstVolume()和FindNextVolume()函数体系&#xff0c;枚举系统所有卷&#xff08;Volume&#xff09;的例子&#xff0c;然后获取卷标、卷类型。这个方式可以枚举出没有驱动器号&#xff08;卷标&#xff09;的卷。 int TestMode1() {HANDLE hVolume…...

通过MATLAB自动产生Hamming编译码的verilog实现,包含testbench

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 1. 原理 1.1 编码规则 1.2 错误检测和纠正 2. 实现过程 2.1 编码过程 2.2 解码过程 3. 应用领域 3.1 数字通信 3.2 存储系统 3.3 ECC内存 3.4 数据传输 5.算法完整程序工程 1.算法…...

调用支付宝接口响应40004 SYSTEM_ERROR问题排查

在对接支付宝API的时候&#xff0c;遇到了一些问题&#xff0c;记录一下排查过程。 Body:{"datadigital_fincloud_generalsaas_face_certify_initialize_response":{"msg":"Business Failed","code":"40004","sub_msg…...

【Java学习笔记】Arrays类

Arrays 类 1. 导入包&#xff1a;import java.util.Arrays 2. 常用方法一览表 方法描述Arrays.toString()返回数组的字符串形式Arrays.sort()排序&#xff08;自然排序和定制排序&#xff09;Arrays.binarySearch()通过二分搜索法进行查找&#xff08;前提&#xff1a;数组是…...

使用van-uploader 的UI组件,结合vue2如何实现图片上传组件的封装

以下是基于 vant-ui&#xff08;适配 Vue2 版本 &#xff09;实现截图中照片上传预览、删除功能&#xff0c;并封装成可复用组件的完整代码&#xff0c;包含样式和逻辑实现&#xff0c;可直接在 Vue2 项目中使用&#xff1a; 1. 封装的图片上传组件 ImageUploader.vue <te…...

OPenCV CUDA模块图像处理-----对图像执行 均值漂移滤波(Mean Shift Filtering)函数meanShiftFiltering()

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 在 GPU 上对图像执行 均值漂移滤波&#xff08;Mean Shift Filtering&#xff09;&#xff0c;用于图像分割或平滑处理。 该函数将输入图像中的…...

AI书签管理工具开发全记录(十九):嵌入资源处理

1.前言 &#x1f4dd; 在上一篇文章中&#xff0c;我们完成了书签的导入导出功能。本篇文章我们研究如何处理嵌入资源&#xff0c;方便后续将资源打包到一个可执行文件中。 2.embed介绍 &#x1f3af; Go 1.16 引入了革命性的 embed 包&#xff0c;彻底改变了静态资源管理的…...

安宝特方案丨船舶智造的“AR+AI+作业标准化管理解决方案”(装配)

船舶制造装配管理现状&#xff1a;装配工作依赖人工经验&#xff0c;装配工人凭借长期实践积累的操作技巧完成零部件组装。企业通常制定了装配作业指导书&#xff0c;但在实际执行中&#xff0c;工人对指导书的理解和遵循程度参差不齐。 船舶装配过程中的挑战与需求 挑战 (1…...

CSS | transition 和 transform的用处和区别

省流总结&#xff1a; transform用于变换/变形&#xff0c;transition是动画控制器 transform 用来对元素进行变形&#xff0c;常见的操作如下&#xff0c;它是立即生效的样式变形属性。 旋转 rotate(角度deg)、平移 translateX(像素px)、缩放 scale(倍数)、倾斜 skewX(角度…...

LangFlow技术架构分析

&#x1f527; LangFlow 的可视化技术栈 前端节点编辑器 底层框架&#xff1a;基于 &#xff08;一个现代化的 React 节点绘图库&#xff09; 功能&#xff1a; 拖拽式构建 LangGraph 状态机 实时连线定义节点依赖关系 可视化调试循环和分支逻辑 与 LangGraph 的深…...

Python竞赛环境搭建全攻略

Python环境搭建竞赛技术文章大纲 竞赛背景与意义 竞赛的目的与价值Python在竞赛中的应用场景环境搭建对竞赛效率的影响 竞赛环境需求分析 常见竞赛类型&#xff08;算法、数据分析、机器学习等&#xff09;不同竞赛对Python版本及库的要求硬件与操作系统的兼容性问题 Pyth…...

在鸿蒙HarmonyOS 5中使用DevEco Studio实现指南针功能

指南针功能是许多位置服务应用的基础功能之一。下面我将详细介绍如何在HarmonyOS 5中使用DevEco Studio实现指南针功能。 1. 开发环境准备 确保已安装DevEco Studio 3.1或更高版本确保项目使用的是HarmonyOS 5.0 SDK在项目的module.json5中配置必要的权限 2. 权限配置 在mo…...