微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > MCU和DSP > W5500 数据手册 Version 1.0 之:寄存器和内存构成

W5500 数据手册 Version 1.0 之:寄存器和内存构成

时间:09-18 来源:3721RD 点击:

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的介绍。

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top