一种残膜回收机防缠绕挑膜装置的制 一种秧草收获机用电力驱动行走机构

静态随机存储器、处理器及数据读取方法与流程

2021-02-20 13:25:00 来源:中国专利 TAG:存储器 静态 读取 随机 器及


[0001]
本申请涉及计算机领域,具体而言,涉及一种静态随机存储器、处理器及数据读取方法。


背景技术:

[0002]
现有技术中,当静态随机存储器从存储单元阵列的目标存储单元(bit cell)读取数据时,该目标存储单元在存储单元阵列所属的行对应的字线(word line,简称wl)置1,存储单元阵列其他行对应的wl置0。wl置1,将该目标存储单元所属的行内的全部存储单元分别连接的bl线与blb线之间拉出电压差,并在同一行的各列存储单元对应的bl线与blb线均拉出电压差后,wl置0。
[0003]
选择器导通目标存储单元所属的列对应的开关,使灵敏放大器对目标存储单元对应的bl线与blb线之间的电压差进行放大,并在灵敏放大器对电压差进行放大后,静态随机存储器控制充电电路为各列存储单元对应的bl线与blb线进行充电。
[0004]
对于从存储单元阵列同行不同列的存储单元连续读取电压差时,会多次执行wl将该行全部存储单元对应的bl与blb之间拉出电压差,充电电路为各列存储单元对应的bl线与blb线进行充电的过程,从而会造成电能的浪费。


技术实现要素:

[0005]
本申请实施例的目的在于提供一种静态随机存储器、处理器及数据读取方法,用以改善现有技术造成电能浪费的问题。
[0006]
第一方面,本申请实施例提供了一种静态随机存储器,包括存储单元阵列、读探测电路以及读控制电路;所述存储单元阵列包括m列n行的存储单元、m个开关组和m个bl充电电路,m列所述存储单元与m个开关组一一对应,每列所述存储单元受对应的开关组控制;m个bl充电电路与m列所述存储单元一一对应,所述bl充电电路用于根据所述读控制电路的控制,为与对应列的存储单元连接的bl线、blb线充电;所述读探测电路用于:在检测到静态随机存储器从位于同一行的不同列的存储单元连续读取数据时,向所述读控制电路输出表征连续读确认的高电平信号;所述读控制电路用于在接收到所述读探测电路输出的高电平信号时,维持所述存储单元所在的行对应的wl驱动信号为低,以及维持m个bl充电电路处于停止充电状态,以保持所述位于同一行且不同列的m个存储单元各自对应的bl线与blb线之间的电压差不变。
[0007]
在上述的实施方式中,读探测电路在检测到静态随机存储器从位于同一行不同列的存储单元连续读取数据时,向读控制电路输出高电平信号。读控制电路在接收到读探测电路传输的高电平信号时,维持存储单元所在的行的wl驱动信号为低,从而在将与存储单元连接的bl线与blb线之间拉出电压差后,保持bl线与blb线之间的电压差;维持m个bl充电电路处于停止充电状态,可以避免对bl线及blb线进行充电,从而实现了拉出一次电压差后,便能够进行同一行不同列的多个存储单元的电压差的多次读取,不需频繁地执行拉出
电压差、充电的循环过程。
[0008]
在一个可能的设计中,所述读探测电路包括列探测子电路、行探测子电路、连续读探测子电路以及第一与运算器,所述列探测子电路、行探测子电路以及所述连续读探测子电路均与所述第一与运算器连接;所述列探测子电路用于将当前时钟周期接收到的列地址与前一时钟周期接收到的列地址进行比较,在所述当前时钟周期的列地址与前一时钟周期的列地址不同时,向所述第一与运算器输出高电平信号;所述行探测子电路用于将当前时钟周期接收到的行地址与前一时钟周期接收到的行地址进行比较,在所述当前时钟周期的行地址与前一时钟周期的行地址相同时,向所述第一与运算器输出高电平信号;所述连续读探测子电路用于判断当前时钟周期与前一时钟周期是否均接收到读信号,在所述当前时钟周期与前一时钟周期均接收到读信号时,向所述第一与运算器输出高电平信号;所述第一与运算器用于在接收到表征列地址不同的高电平信号、表征行地址相同的高电平信号、以及表征连续两个时钟周期接收到读信号的高电平信号时,向所述读控制电路输出高电平信号。
[0009]
在上述的实施方式中,读探测电路包括的列探测子电路、行探测子电路以及连续读探测子电路。其中,列探测子电路用于探测连续两个时钟周期的列地址是否相同,列地址相同,则输出低电平;列地址不同,则输出高电平。行探测子电路用于探测连续两个时钟周期的行地址是否相同,行地址不同,则输出低电平;行地址相同,则输出高电平。连续读探测子电路用于判断是否连续两个时钟周期均接收到读信号,若是,则输出高电平;若否则输出低电平。第一与运算器对上述三个子电路的输出结果进行相与运算,得到的运算结果便为读探测电路的输出结果。读探测电路通过三个子电路分别对列地址、行地址、是否连续读取进行探测,三者的探测过程相互独立,减少了探测失误的可能性。
[0010]
在一个可能的设计中,所述列探测子电路包括第一触发器和异或运算器;所述第一触发器的输入端用于接收列地址数据,所述第一触发器的输出端与所述异或运算器的第一输入端连接;所述异或运算器的第二输入端用于接收所述列地址数据,所述异或运算器的输出端与所述第一与运算器连接。
[0011]
在上述的实施方式中,第一触发器的输入端接收列地址数据,并可以将列地址数据延迟一个时钟周期,异或运算器的第一输入端接收已延迟一个时钟周期的列地址数据,异或运算器的第二输入端接收未延迟时钟周期的列地址数据,异或运算器用于对上述两个列地址进行异或运算,若运算结果为1,则说明上述两个列地址不同;若运算结果为0,则说明上述两个列地址相同。
[0012]
在一个可能的设计中,所述行探测子电路包括第二触发器和同或运算器;所述第二触发器的输入端用于接收行地址数据,所述第二触发器的输出端与所述同或运算器的第一输入端连接;所述同或运算器的第二输入端用于接收所述行地址数据,所述同或运算器的输出端与所述第一与运算器连接。
[0013]
在上述的实施方式中,第二触发器的输入端接收行地址数据,并可以将行地址数据延迟一个时钟周期,同或运算器的第一输入端接收已延迟一个时钟周期的行地址数据。同或运算器的第二输入端接收未延迟时钟周期的行地址数据,同或运算器用于对上述两个行地址进行同或运算,若运算结果为1,则说明上述两个行地址相同;若运算结果为0,则说明上述两个行地址不同。
[0014]
在一个可能的设计中,所述连续读探测子电路包括第三触发器和第二与运算器;所述第三触发器的输入端用于接收所述读信号,所述第三触发器的输出端与所述第二与运算器的第一输入端连接;所述第二与运算器的第二输入端用于接收所述读信号,所述第二与运算器的输出端与所述第一与运算器连接。
[0015]
在上述的实施方式中,第三触发器的输入端接收读信号,并可以将读信号延迟一个时钟周期,第二与运算器的第一输入端接收已延迟一个时钟周期的读信号,第二与运算器的第二输入端接收未延迟时钟周期的读信号。第二与运算器用于对连续两个读信号进行相与运算。若连续两个读信号均为高电平,则运算结果为1;若连续两个读信号中存在至少一个读信号不为高电平,则运算结果为0。
[0016]
在一个可能的设计中,所述读探测电路还包括锁存器,所述锁存器的输入端与所述第一与运算器的输出端连接。
[0017]
在上述的实施方式中,锁存器可以在时钟信号为高电平时,将第一与运算器的输出结果锁住,在时钟信号为低电平时,再变更第一与运算器的输出结果,从而可以提高整个电路的运行稳定性。
[0018]
在一个可能的设计中,所述读控制电路包括反相器、第三与运算器以及或运算器;所述反相器用于将所述读探测电路输出的电平信号取反,并将取反后的电平信号传输向所述第三与运算器;所述第三与运算器用于对所述反相器输出的电平信号以及wl线的电平信号进行与运算,获得第一处理结果,其中,所述第一处理结果为所述wl驱动信号;所述或运算器用于对所述读探测电路输出的电平信号以及充电控制信号进行或运算,获得第二处理结果,其中,所述第二处理结果为切换m个bl充电电路充电或停止充电的控制信号。
[0019]
在上述的实施方式中,可以将读探测电路输出的电平信号取反后与wl线相与,将读探测电路输出的电平信号与充电控制信号相或,从而实现利用读探测电路输出的电平信号对wl线的电平信号、充电控制信号进行影响,使得在读探测电路输出的电平信号为高时,wl线的电平信号、充电控制信号无论高低,都不会造成wl驱动信号及控制信号的变化。
[0020]
在一个可能的设计中,还包括选择器,所述选择器与所述m个开关组连接,所述选择器用于根据接收到的地址,从所述m个开关组中选择一个开关组,并令选中的开关组导通。
[0021]
在上述的实施方式中,选择器选中的开关组被导通,使得与被导通的开关组对应的存储单元拉出的bl线与blb线之间的电压差可以被传输到下级的灵敏放大器。
[0022]
第二方面,本申请实施例提供了一种处理器,包括第一方面及第一方面的任一可能的设计所述的静态随机存储器。
[0023]
在上述的实施方式中,包括静态随机存储器的处理器可以实现在拉出一次电压差后,便能够进行同一行不同列的多个存储单元的电压差的多次读取,不需频繁地执行拉出电压差、充电的循环过程,从而节约了电能。
[0024]
第三方面,本申请提供一种数据读取方法,所述方法包括:所述静态随机存储器中的读探测电路在检测到所述静态随机存储器从位于同一行且不同列的存储单元连续读取数据时,向所述静态随机存储器中的读控制电路传输表征连续读确认的高电平信号;所述读控制电路在接收到读探测电路输出的高电平信号后,维持所述同一行且不同列的存储单元所在的行对应的wl驱动信号为低,维持所述同一行且不同列的存储单元分别对应的bl充
电电路处于停止充电状态,以保持所述位于同一行且不同列的存储单元各自对应的bl线与blb线之间的电压差不变,其中,所述bl充电电路的数量与存储单元的列数相同。
[0025]
在上述的实施方式中,读探测电路在检测到静态随机存储器从位于同一行不同列的存储单元连续读取数据时,向读控制电路输出高电平信号。读控制电路在接收到读探测电路传输的高电平信号时,维持存储单元所在的行的wl驱动信号为低,从而在将与存储单元连接的bl线与blb线之间拉出电压差后,保持bl线与blb线之间的电压差;维持m个bl充电电路处于停止充电状态,可以避免对bl线及blb线进行充电,从而实现了拉出一次电压差后,便能够进行同一行不同列的多个存储单元的电压差的多次读取,不需频繁地执行拉出电压差、充电的循环过程。
[0026]
在一个可能的设计中,所述读探测电路包括列探测子电路、行探测子电路、连续读探测子电路以及第一与运算器,所述列探测子电路、行探测子电路以及连续读探测子电路均与所述第一与运算器连接;所述读探测电路在检测到:静态随机存储器从位于同一行且不同列的存储单元连续读取数据时,输出表征连续读确认的高电平信号,包括:所述第一与运算器在接收到所述列探测子电路发送的表征列地址不同的高电平信号、所述行探测子电路发送的表征行地址相同的高电平信号、以及所述连续读探测子电路发送的表征连续两个时钟周期接收到读信号的高电平信号时,输出高电平信号。
[0027]
在上述的实施方式中,第一与运算器对上述三个子电路的输出结果进行相与运算,得到的运算结果便为读探测电路的输出结果。读探测电路通过三个子电路分别对列地址、行地址、是否连续读取进行探测,三者的探测过程相互独立,减少了探测失误的可能性。
[0028]
在一个可能的设计中,所述列探测子电路包括第一触发器和异或运算器;所述第一触发器的输入端用于接收列地址数据,所述第一触发器的输出端与所述异或运算器的第一输入端连接;所述异或运算器的第二输入端用于接收所述列地址数据;在所述第一与运算器在接收到所述列探测子电路发送的表征列地址不同的高电平信号、所述行探测子电路发送的表征行地址相同的高电平信号、以及所述连续读探测子电路发送的表征连续两个时钟周期接收到读信号的高电平信号时,输出高电平信号之前,所述方法还包括:所述列探测子电路将当前时钟周期的列地址与前一时钟周期的列地址进行比较,在所述当前时钟周期的列地址与前一时钟周期的列地址不同时,向所述第一与运算器输出高电平信号。
[0029]
在上述的实施方式中,第一触发器的输入端接收列地址数据,并可以将列地址数据延迟一个时钟周期,异或运算器的第一输入端接收已延迟一个时钟周期的列地址数据,异或运算器的第二输入端接收未延迟时钟周期的列地址数据,异或运算器用于对上述两个列地址进行异或运算,若运算结果为1,则说明上述两个列地址不同;若运算结果为0,则说明上述两个列地址相同。
[0030]
在一个可能的设计中,所述行探测子电路包括第二触发器和同或运算器;所述第二触发器的输入端用于接收行地址数据,所述第二触发器的输出端与所述同或运算器的第一输入端连接;所述同或运算器的第二输入端用于接收所述行地址数据;在所述第一与运算器在接收到所述列探测子电路发送的表征列地址不同的高电平信号、所述行探测子电路发送的表征行地址相同的高电平信号、以及所述连续读探测子电路发送的表征连续两个时钟周期接收到读信号的高电平信号时,输出高电平信号之前,所述方法还包括:所述行探测子电路将当前时钟周期的行地址与前一时钟周期的行地址进行比较,在所述当前时钟周期
的行地址与前一时钟周期的行地址相同时,向所述第一与运算器输出高电平信号。
[0031]
在上述的实施方式中,第二触发器的输入端接收行地址数据,并可以将行地址数据延迟一个时钟周期,同或运算器的第一输入端接收已延迟一个时钟周期的行地址数据。同或运算器的第二输入端接收未延迟时钟周期的行地址数据,同或运算器用于对上述两个行地址进行同或运算,若运算结果为1,则说明上述两个行地址相同;若运算结果为0,则说明上述两个行地址不同。
[0032]
在一个可能的设计中,所述连续读探测子电路包括第三触发器和第二与运算器;所述第三触发器的输入端用于接收所述读信号,所述第三触发器的输出端与所述第二与运算器的第一输入端连接;所述第二与运算器的第二输入端用于接收所述读信号;在所述第一与运算器在接收到所述列探测子电路发送的表征列地址不同的高电平信号、所述行探测子电路发送的表征行地址相同的高电平信号、以及所述连续读探测子电路发送的表征连续两个时钟周期接收到读信号的高电平信号时,输出高电平信号之前,所述方法还包括:所述连续读探测子电路判断当前时钟周期与前一时钟周期是否均接收到读信号,在所述当前时钟周期与前一时钟周期均接收到读信号时,向所述第一与运算器输出高电平信号。
[0033]
在上述的实施方式中,第三触发器的输入端接收读信号,并可以将读信号延迟一个时钟周期,第二与运算器的第一输入端接收已延迟一个时钟周期的读信号,第二与运算器的第二输入端接收未延迟时钟周期的读信号。第二与运算器用于对连续两个读信号进行相与运算。若连续两个读信号均为高电平,则运算结果为1;若连续两个读信号中存在至少一个读信号不为高电平,则运算结果为0。
[0034]
在一个可能的设计中,所述读控制电路包括反相器、第三与运算器以及或运算器;所述读控制电路在接收到读探测电路输出的高电平信号时,维持所述存储单元所在的行对应的wl驱动信号为低,维持m个bl充电电路处于停止充电状态,包括:所述反相器将所述读探测电路输出的电平信号取反,并传输向所述第三与运算器;所述第三与运算器对所述反相器输出的电平信号以及wl线的电平信号进行与运算,获得第一处理结果,其中,所述第一处理结果为所述wl驱动信号;所述或运算器对所述读探测电路输出的电平信号以及充电控制信号进行或运算,获得第二处理结果,其中,所述第二处理结果为切换m个bl充电电路充电或停止充电的控制信号。
[0035]
在上述的实施方式中,可以将读探测电路输出的电平信号取反后与wl线相与,将读探测电路输出的电平信号与充电控制信号相或,从而实现利用读探测电路输出的电平信号对wl线的电平信号、充电控制信号进行影响,使得在读探测电路输出的电平信号为高时,wl线的电平信号、充电控制信号无论高低,都不会造成wl驱动信号及控制信号的变化。
[0036]
为使本申请实施例所要实现的上述目的、特征和优点能更明显易懂,下文特举较佳实施例,并配合所附附图,作详细说明如下。
附图说明
[0037]
为了更清楚地说明本申请实施例的技术方案,下面将对本申请实施例中所需要使用的附图作简单地介绍,应当理解,以下附图仅示出了本申请的某些实施例,因此不应被看作是对范围的限定,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他相关的附图。
[0038]
图1示出了现有技术中的静态随机存储器的示意性结构框图;
[0039]
图2示出了本申请实施例提供的静态随机存储器的示意性结构框图;
[0040]
图3示出了图2中的读探测电路的示意性结构框图;
[0041]
图4示出了图2中的读控制电路的示意性结构框图;
[0042]
图5示出了本申请实施例提供的静态随机存储器的部分工作波形的示意图;
[0043]
图6示出了本申请实施例提供的数据读取方法的流程示意图;
[0044]
图7示出了图6中步骤s120的具体步骤的流程示意图。
具体实施方式
[0045]
请参见图1,图1示出了对照实施例中的存储单元110(bit cell)组成的存储单元阵列的示意图,图1示出的存储单元阵列有n行、4列,其中,n为正整数。存储单元阵列中,位于同一行的存储单元110共用同一根字线(word line,简称wl),不同行的存储单元110对应各自的wl,则n行存储单元110对应n根wl。同属一列的存储单元110与相同的bl线、blb线连接,bl线与blb线之间还连接有bl充电电路120,4列存储单元110与4个bl充电电路120一一对应。
[0046]
不同列的存储单元110对应有各自的开关,上述的开关可以由选择器200根据地址信号进行选择,被选择器200选中的开关闭合,未被选择器200选中的开关断开。请参见图1,4列存储单元110对应有四个开关y0、y1、y2、y3,四个开关可以被addr[0]、addr[1]两位地址选择。addr[0]、addr[1]两位地址共有四种地址组合:00、01、10、11,四种地址组合可以分别对应四个开关中的一个开关,地址组合与开关的对应关系不应理解为对本申请的限制。四个开关均可以为pmos管。
[0047]
在开关的远离bl充电电路120的一端还连接有4个数据充电电路130,详情请参见图1,4个数据充电电路130分别连接于各自对应的dl与dlb之间,4个数据充电电路130均与控制器连接,可以在控制器的dl_pre信号的控制下,为对应的dl与dlb充电。
[0048]
在一些实施例中,存储单元阵列还可以包括多于4列的列数,也可以包括少于4列的列数,存储单元阵列的存储单元110的具体的列数不应当理解为是对本申请的限制。
[0049]
为便于描述,不妨以从wl[0]对应的行、0列所对应的目标存储单元110读取数据为例,对读取数据的过程进行说明:
[0050]
首先,令wl[0]置1,wl[1]、wl[2]

wl[n-1]均置0,则在wl[0]对应的行中:
[0051]
0列对应的目标存储单元将bl0与blb0之间拉出电压差;
[0052]
1列对应的存储单元也会将bl1与blb1之间拉出电压差;
[0053]
2列对应的存储单元也会将bl2与blb2之间拉出电压差;
[0054]
3列对应的存储单元也会将bl3与blb3之间拉出电压差。
[0055]
在上述各列对应的bl与blb之间均拉出电压差后,wl[0]置0。
[0056]
选择器200选择y0导通,y1、y2、y3均断开。此时,dl为bl0,dlb为blb0。
[0057]
灵敏放大器sa将dl与dlb之间的电压差放大至逻辑电平,并将该逻辑电平传输至锁存器latch,由锁存器latch将该逻辑电平锁存。
[0058]
在逻辑电平被锁存在锁存器latch后,y0断开。随后,bl_pre为各列对应的bl、blb充电,dl_pre为dl、dlb充电,使得bl、blb、dl、dlb的电平都充至原本电平vdd。
[0059]
若下一次再从某存储单元110读取数据,则重复执行上述过程。
[0060]
对照实施例在读取数据的过程中,如果连续从同行不同列对应的存储单元110读取电压差,则会多次执行wl将bl与blb之间拉出电压差,bl_pre为各列对应的bl、blb充电的过程,会造成电能的浪费。
[0061]
本申请实施例提供的静态随机存储器通过对wl驱动信号及m个bl充电电路120进行影响,可以实现在拉出一次电压差后,便能够进行同一行不同列的多个存储单元110对应的电压差的多次读取,不需频繁地执行拉出电压差、充电的循环过程,从而节约了电能,降低了功耗。
[0062]
下面将结合本申请实施例中的附图,对本申请实施例中的技术方案进行描述。
[0063]
请参见图2,图2示出了本申请实施例提供的静态随机存储器,该静态随机存储器包括存储单元阵列、选择器200、读探测电路300以及读控制电路400。
[0064]
存储单元110包括m列、n行的存储单元110,为便于说明,不妨设m为4,图2中仅示出n行中的某一行。
[0065]
读探测电路300用于在检测到:静态随机存储器从位于同一行且不同列的存储单元110连续读取数据时,输出表征连续读确认的高电平信号。
[0066]
读控制电路400用于在接收到读探测电路300输出的高电平信号时,维持所述存储单元110所在的行对应的wl驱动信号为低,维持m个bl充电电路120处于停止充电状态。
[0067]
读探测电路300在检测到静态随机存储器从位于同一行不同列的存储单元110连续读取数据时,向读控制电路400输出高电平信号。读控制电路400在接收到读探测电路300传输的高电平信号时,维持存储单元110所在的行的wl驱动信号为低,从而在将与存储单元110连接的bl线与blb线之间拉出电压差后,保持bl线与blb线之间的电压差;维持m个bl充电电路120处于停止充电状态,可以避免对bl线及blb线进行充电。本申请实施例提供的静态随机存储器可以实现在拉出一次电压差后,能够进行同一行不同列的多个存储单元110的电压差的多次读取,不需频繁地执行拉出电压差、充电的循环过程。
[0068]
读探测电路300包括列探测子电路310、行探测子电路320、连续读探测子电路330、第一与运算器i4以及锁存器i5。请参见图3,列探测子电路310的输出端、行探测子电路320的输出端以及连续读探测子电路330的输出端分别与第一与运算器i4的输入端连接,第一与运算器i4的输出端与锁存器i5的输入端连接。
[0069]
锁存器i5可以在时钟信号为高电平时,将第一与运算器i4的输出结果锁住;在时钟信号为低电平时,再根据第一与运算器i4的输入变更输出结果,可以提高整个电路的运行稳定性。
[0070]
列探测子电路310包括第一触发器i6和异或运算器i7。第一触发器i6的输入端用于接收列地址数据,第一触发器i6的输出端与异或运算器i7的第一输入端连接;异或运算器i7的第二输入端用于接收所述列地址数据。
[0071]
第一触发器i6的输入端接收列地址数据,并可以将列地址数据延迟一个时钟周期,异或运算器i7的第一输入端接收已延迟一个时钟周期的列地址数据,异或运算器i7的第二输入端接收未延迟时钟周期的列地址数据,异或运算器i7用于对上述两个列地址进行异或运算,若运算结果为1,则说明上述两个列地址不同;若运算结果为0,则说明上述两个列地址相同。列探测子电路310将当前时钟周期的列地址与前一时钟周期的列地址进行比
较,在当前时钟周期的列地址与前一时钟周期的列地址不同时,向第一与运算器i4输出高电平信号。
[0072]
行探测子电路320包括第二触发器i2和同或运算器i3。第二触发器i2的输入端用于接收行地址数据,第二触发器i2的输出端与同或运算器i3的第一输入端连接;同或运算器i3的第二输入端用于接收所述行地址数据。
[0073]
第二触发器i2的输入端接收行地址数据,并可以将行地址数据延迟一个时钟周期,同或运算器i3的第一输入端接收已延迟一个时钟周期的行地址数据。同或运算器i3的第二输入端接收未延迟时钟周期的行地址数据,同或运算器i3用于对上述两个行地址进行同或运算,若运算结果为1,则说明上述两个行地址相同;若运算结果为0,则说明上述两个行地址不同。行探测子电路320将当前时钟周期的行地址与前一时钟周期的行地址进行比较,在当前时钟周期的行地址与前一时钟周期的行地址相同时,向第一与运算器i4输出高电平信号。
[0074]
可选地,在上述的实施方式中,列地址数据可以是低位地址,行地址数据可以是高位地址,由于在上述实施方式中,列数为4,因此,列地址数据具体可以由低2位地址addr[1:0]表示,addr[1:0]有00、01、10、11四种情况,刚好可以与4列对应。相应地,行地址数据可以由高6位地址addr[7:2]表示。
[0075]
应当理解,若静态随机存储器的存储单元阵列的列数量超过4,则列地址需要由更多位的低位地址进行表示。例如,在另一具体实施方式中,存储单元阵列的列数量为6,则列地址可以由低3位地址addr[2:0]表示。addr[2:0]有000、001、010、011、100、101、110、111八种情况,可以从中任选6种情况与上述的6列分别对应。
[0076]
连续读探测子电路330包括第三触发器i0和第二与运算器i1;第三触发器i0的输入端用于接收读信号rd,第三触发器i0的输出端与第二与运算器i1的第一输入端连接;第二与运算器i1的第二输入端用于接收读信号rd。其中,rd为1,表示要读数据;rd为0,表示不读数据。
[0077]
第三触发器i0的输入端接收读信号rd,并可以将读信号rd延迟一个时钟周期。第二与运算器i1的第一输入端接收已延迟一个时钟周期的读信号rd,第二与运算器i1的第二输入端接收未延迟时钟周期的读信号rd。第二与运算器i1用于对连续两个读信号rd进行相与运算。若连续两个读信号rd均为高电平,则运算结果为1;若连续两个读信号rd中存在至少一个读信号rd不为高电平,则运算结果为0。
[0078]
连续读探测子电路330用于判断当前时钟周期与前一时钟周期是否均接收到读信号rd,在当前时钟周期与前一时钟周期均接收到读信号rd时,向第一与运算器i4输出高电平信号。
[0079]
第一与运算器i4用于在接收到表征列地址不同的高电平信号、表征行地址相同的高电平信号、以及表征连续两个时钟周期接收到读信号rd的高电平信号时,输出高电平信号burst_en。
[0080]
读控制电路400包括反相器i10、第三与运算器i8以及或运算器i9,请参见图4,反相器i10用于将读探测电路300输出的电平信号burst_en取反,并传输向第三与运算器i8。
[0081]
第三与运算器i8用于对反相器i10输出的电平信号以及wl线的电平信号wl进行与运算,获得第一处理结果,其中,第一处理结果为所述wl驱动信号wl_1。
[0082]
或运算器i9用于对读探测电路300输出的电平信号burst_en以及充电控制信号bl_pre进行或运算,获得第二处理结果,其中,第二处理结果为切换m个bl充电电路120充电或停止充电的控制信号bl_pre_1。
[0083]
将读探测电路300输出的电平信号取反后与wl线相与,将读探测电路300输出的电平信号与充电控制信号相或,从而实现利用读探测电路300输出的电平信号对wl线的电平信号、充电控制信号进行影响,使得在读探测电路300输出的电平信号为高时,wl线的电平信号、充电控制信号无论高低,都不会造成wl驱动信号wl_1及控制信号bl_pre_1的变化。
[0084]
请参见图5,图5示出了本申请实施例提供的静态随机存储器的部分工作波形的示意图。addr[7:0]共8位地址,其中,高6位addr[7:2]为行地址,低2位addr[1:0]为列地址。
[0085]
在图5示出的5个地址中:111100 00、111100 01、111100 10、11110011、111000 11,可知:
[0086]
111100 01与111100 00的行地址(即111100)相同,列地址(即01与00)不同;
[0087]
111100 10与111100 01的行地址(即111100)相同,列地址(即10与01)不同;
[0088]
111100 11与111100 10的行地址(即111100)相同,列地址(即11与10)不同;
[0089]
111000 11与111100 11的行地址(即111000与111100)不同,列地址(即11)相同。
[0090]
因此,详情参见图5,在满足行地址相同、列地址不同,且读信号rd为1的情况下,读探测电路300的输出信号burst_en为1。在行地址不同,或列地址相同,或读信号rd为0的情况下,读探测电路300的输出信号burst_en为0。
[0091]
请参见图5,在burst_en为1对应的时间段内,burst_en将充电控制信号bl_pre的低电平都调整为高电平,调整后的波形为控制信号bl_pre_1。控制信号bl_pre_1为高电平,可以使得bl充电电路120处于停止充电状态。
[0092]
在burst_en为1对应的时间段内,burst_en将wl线的电平信号wl的高电平都调整为低电平,调整后的波形为wl驱动信号wl_1。wl驱动信号wl_1为低电平,可以保持各列存储单元110对应的bl线与blb线之间的电压差,请参见图5中的如下四个波形:bl0/blb0、blb1/bl1、bl2/blb2、blb3/bl3。在burst_en为1对应的时间段内,上述四个波形均被拉出电压差并保持。
[0093]
图5中示出的y0、y1、y2、y3四个开关对应的波形显示了列地址与开关的具体对应关系,y0、y1、y2、y3四个开关均为pmos管,高电平对应开关导通,低电平对应开关断开。因此,列地址00对应开关y0导通;列地址01对应开关y1导通;列地址10对应开关y2导通;列地址11对应开关y3导通。其中,图5中的开关y3对应的波形的最后一个高电平对应不同行(即行地址为111000的行)的开关y3所在的列的存储单元110导通。
[0094]
本申请实施例还提供了一种处理器,该处理器可以包括上述的静态随机存储器。
[0095]
请参见图6,图6为本申请实施例提供的数据读取方法的一种流程示意图,该方法由上述的静态随机存储器执行,具体包括如下步骤s110至步骤s120:
[0096]
步骤s110,所述静态随机存储器中的读探测电路在检测到所述静态随机存储器从位于同一行且不同列的存储单元连续读取数据时,向所述静态随机存储器中的读控制电路传输表征连续读确认的高电平信号。
[0097]
步骤s120,读控制电路在接收到读探测电路输出的高电平信号后,维持所述同一行且不同列的存储单元所在的行对应的wl驱动信号为低,维持所述同一行且不同列的存储
单元分别对应的bl充电电路处于停止充电状态,以保持所述位于同一行且不同列的存储单元各自对应的bl线与blb线之间的电压差不变,其中,所述bl充电电路的数量与存储单元的列数相同。
[0098]
维持存储单元110所在的行的wl驱动信号为低,从而在将与存储单元110连接的bl线与blb线之间拉出电压差后,保持bl线与blb线之间的电压差;维持m个bl充电电路120处于停止充电状态,可以避免对bl线及blb线进行充电,从而实现了拉出一次电压差后,便能够进行同一行不同列的多个存储单元110的电压差的多次读取,不需频繁地执行拉出电压差、充电的循环过程。
[0099]
在一种具体实施方式中,步骤s110具体包括:
[0100]
步骤a:所述第一与运算器i4在接收到所述列探测子电路310发送的表征列地址不同的高电平信号、所述行探测子电路320发送的表征行地址相同的高电平信号、以及所述连续读探测子电路330发送的表征连续两个时钟周期接收到读信号的高电平信号时,输出高电平信号。
[0101]
第一与运算器i4对上述三个子电路的输出结果进行相与运算,得到的运算结果便为读探测电路300的输出结果。读探测电路300通过三个子电路分别对列地址、行地址、是否连续读取进行探测,三者的探测过程相互独立,减少了探测失误的可能性。
[0102]
在一种具体实施方式中,在步骤a之前,该方法还可以包括:所述列探测子电路310将当前时钟周期的列地址与前一时钟周期的列地址进行比较,在所述当前时钟周期的列地址与前一时钟周期的列地址不同时,向所述第一与运算器i4输出高电平信号。
[0103]
在一种具体实施方式中,在步骤a之前,该方法还可以包括:所述行探测子电路320将当前时钟周期的行地址与前一时钟周期的行地址进行比较,在所述当前时钟周期的行地址与前一时钟周期的行地址相同时,向所述第一与运算器i4输出高电平信号。
[0104]
在一种具体实施方式中,在步骤a之前,该方法还可以包括:所述连续读探测子电路330判断当前时钟周期与前一时钟周期是否均接收到读信号,在所述当前时钟周期与前一时钟周期均接收到读信号时,向所述第一与运算器i4输出高电平信号。
[0105]
请参见图7,在一种具体实施方式中,步骤s120具体包括如下步骤s121至步骤s123:
[0106]
步骤s121,所述反相器将所述读探测电路300输出的电平信号取反,并传输向所述第三与运算器。
[0107]
步骤s122,所述第三与运算器对所述反相器输出的电平信号以及wl线的电平信号进行与运算,获得第一处理结果,其中,所述第一处理结果为所述wl驱动信号。
[0108]
步骤s123,所述或运算器对所述读探测电路300输出的电平信号以及充电控制信号进行或运算,获得第二处理结果,其中,所述第二处理结果为切换m个bl充电电路120充电或停止充电的控制信号。
[0109]
将读探测电路300输出的电平信号取反后与wl线相与,将读探测电路300输出的电平信号与充电控制信号相或,从而实现利用读探测电路300输出的电平信号对wl线的电平信号、充电控制信号进行影响,使得在读探测电路300输出的电平信号为高时,wl线的电平信号、充电控制信号无论高低,都不会造成wl驱动信号及控制信号的变化。
[0110]
本申请实施例提供的静态随机存储器在从同一行不同列的存储单元110连续读取
对应的bl与blb之间的电压差时,可以只进行一次预充,后续对不同列的存储单元110的读取过程,可以直接读取在预充时建立的电压差,从而可以省去多次充放电的功耗,得到省功耗的目的。
[0111]
在本申请所提供的实施例中,应该理解到,所揭露设备和方法,可以通过其它的方式实现。以上所描述的设备实施例仅仅是示意性的,例如,所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,又例如,多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些通信接口,设备或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。
[0112]
另外,作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
[0113]
再者,在本申请各个实施例中的各功能模块可以集成在一起形成一个独立的部分,也可以是各个模块单独存在,也可以两个或两个以上模块集成形成一个独立的部分。
[0114]
在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。
[0115]
以上所述仅为本申请的实施例而已,并不用于限制本申请的保护范围,对于本领域的技术人员来说,本申请可以有各种更改和变化。凡在本申请的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本申请的保护范围之内。
再多了解一些

本文用于企业家、创业者技术爱好者查询,结果仅供参考。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

相关文献

  • 日榜
  • 周榜
  • 月榜