AHB to Sram设计

发布时间 2024-01-10 14:56:49作者: Icer_Newer

规格说明

  • 现在要对addr1进行操作(原addr1中存储的数据为data),现在需要写入data1,下一拍对addr1进行读操作,需要读出data1(读出最新的数据data1,而不是data),这时候需要一个buffer,将上一拍的data1作为读数据进行返回,因为data1可能还没有写到sram中.

接口

AHB读时序

AHB写时序

  • 第一拍给出地址和控制信号
  • 在hready为高的时候,在第二拍给出写数据

SRAM读时序

  • SRAMCS是片选信号,chip select,只有为高的时候SRAM才会真正的工作;
  • 不考虑反压和错误的情况下,时序与AHB读时序相同

SRAM写时序

  • 第一拍给出地址的同时给出写数据,和AHB总线不同,AHB总线是在下一拍给出写数据

时序转换

全部是读的情况

  • 使用组合逻辑,将AHB的读写地址给到SRAM的读写地址,在下一拍将读数据给到AHB读数据

全部是写的情况


*** 由于SRAM的写操作命令地址和数据是在一拍完成的,而AHB写数据要在第二拍才能写入,所以需要将AHB中的地址延迟一拍再与SRAM中的地址进行同步,**这样地址数据就满足了sram接口要求。

  • 将AHB的地址和控制信号打一拍之后,再将地址和控制信号给到SRAM

先读后写

先读后写:先读后写实际上不涉及数据更新,就是写跟在读后面而已,下面时序稍微有点问题,对于读这一部分ADDR和DATA。AHB和SRAM两侧应该是同一拍的。

先写后读

读写地址相同,当读写地址相同的时候,需要完成读数据的拼接以及更新。

  • 首先判断是否是先写后读,我们需要把写的控制信号打一拍。如果这一拍是读,上一拍是写同时满足,则说明出现了先写后读。buf_pend代表buffer write data valid。
  • 判断是否读写地址相同,上一拍的地址和这一拍的地址相同,则代表读写地址相同。


  • 可以将buf_pend拉高。并且地址也相同,因此buf_hit也会拉高。这个时候HRDATA返回的数据就应该是完成替换以后的值。

数据更新

  • 对读数据更新,可以看到如果buf_hit并且buf_we有效,则代表上一拍确实写了这个字节,这种情况下我们就应该把这一字节替换成上一拍写的值,而不是用SRAM读出来的值。
  • addr2写操作不会在下一拍就写进去SRAM,因为出现了先写后读,这个写SRAM的操作会被暂时的pending住!当addr3来的时候,这个时候addr对应的data2才能够写进去。