W5500 数据手册 Version 1.0 之:寄存器和内存构成
3 寄存器和内存构成
W5500有1个通用寄存器,8个Socket寄存器区,以及对应每个Socket的收/发缓存区。每个区域均通过SPI数据帧的区域选择位(BSB[4:0])来选取。图20显示了区域选择位(BSB[4:0])选择的区域以及收/发缓存区的可用偏移地址范围。每一个Socket的发送缓存区都在一个16KB的物理发送内存中,初始化分配为2KB。每一个Socket的接收缓存区都在一个16KB的物理接收内存中,初始化分配为2KB。
无论给每个Socket分配多大的收/发缓存,都必须在16位的偏移地址范围内(从0x0000 到 0xFFFF)。
关于16KB收/发内存的构成及访问方式的更多信息,请参考‘3.3章节’。
图 20 寄存器及内存构成
3.1 通用寄存器区
通用寄存器区配置了W5500的基本信息,例如:IP及MAC地址。该区域可以通过SPI数据帧的区域选择位(BSB[4:0])的值选定。
表3描述了该区域寄存器的偏移地址。对于每个寄存器的详细信息,请参考‘4.1章节’。
表格 4 通用寄存器的偏移地址
3.2 Socket 寄存器区
W5500支持8个Socket作为通讯信道。
每一个Socket通过Socket n寄存器区控制(0≤n≤7)。Socket n寄存器可以通过SPI数据帧中的区域选择寄存器(BSB[4:0])来选定对应的寄存器n。
<表5>定义了Socket n 寄存器区对应的16位偏移地址。
关于每个寄存器,详情参考‘4.2章节’
表格 5 Socket n 寄存器区中的偏移地址(0≤n≤7)
3.3 内存 Memory
W5500有一个16KB的发送内存用于Socket n的发送缓存区,以及一个16KB的接收内存用于Socket n的接收缓存区。
16KB的发送内存初始化被分配为每个Socket 2KB发送缓存区(2KB X 8 = 16KB)。初始化分配的2KB Socket发送缓存,可以通过使用Socket 发送缓存大小寄存器(Sn_TXBUF_SIZE)重新分配。
一旦所有的Socket发送缓存大小寄存器(Sn_TXBUF_SIZE)配置完成,16KB的发送内存就会按照配置分配给每个Socket的发送缓存,并按照从Socket 0 到7顺序分配。16KB物理内存的地址是可以自增的。但是,为了避免数据传输错误,需要避免发送缓存大小寄存器(Sn_TXBUF_SIZE)的和超过16。
16KB的读取内存的分派方式与16KB的发送内存一样。16KB的接收内存初始化被分配为每个Socket 2KB接收缓存区(2KB X 8 = 16KB)。初始化分配的2KB Socket接收缓存,可以通过使用Socket 接收缓存大小寄存器(Sn_XBUF_SIZE)重新分配。
一旦所有的Socket发缓存大小寄存器(Sn_TXBUF_SIZE)配置完成,16KB的发送内存就会按照配置分配给每个Socket的发送缓存,并按照从Socket 0 到7顺序分配。16KB物理内存的地址是可以自增的。但是,为了避免数据传输错误,需要避免发送缓存大小寄存器(Sn_TXBUF_SIZE)的和超过16。
对于16字节收/发内存的分配,请参考‘第4.2章节’Sn_TXBUF_SIZE 和
Sn_RXBUF_SIZE的相关描述。
16KB的发送内存中分配了对应Socket n的发送缓存区,用于为来自主机传输的数据做缓存。Socket n的发送缓存区。Socket n发送缓存区的16位偏移地址支持64KB的寻址范围(从0x000到0xFFFF),关于他的配置请参考‘Socket n发送写指针寄存器(Sn_TX_WR)’以及Socket n发送读指针寄存器(Sn_RX_WR)。然而,这16位偏移地址会自动转化为指定的16KB发送内存的物理地址,如图20所示。请参考‘4.2章节’中,关于Sn_TX_WR & Sn_TX_RD的介绍。
16KB的接收内存中分配了对应Socket n的接收缓存区,用于为来自网络传输的数据做缓存。Socket n的接收缓存区。Socket n接收缓存区的16位偏移地址支持64KB的寻址范围(从0x000到0xFFFF),关于他的配置请参考‘Socket n接受读指针寄存器(Sn_RX_RD)’以及Socket n接受写指针寄存器(Sn_RX_WR)。然而,这16位偏移地址会自动转化为指定的16KB接收内存的物理地址,如图20所示。请参考‘4.2章节’中,关于Sn_RX_RD & Sn_RX_WR的介绍。
- W5500 数据手册 Version 1.0 之:引脚分配(09-18)
- W5500 数据手册 Version 1.0 之:主机接口(09-18)
- 多功能的单片网络接口芯片W5100完整数据手册和应用案例指南(09-18)
- 高性能32位移位寄存器单元的设计(06-14)
- STM32F之RTC(07-05)