CN101438242A - 共享非易失性存储器体系结构 - Google Patents

共享非易失性存储器体系结构 Download PDF

Info

Publication number
CN101438242A
CN101438242A CNA2007800160526A CN200780016052A CN101438242A CN 101438242 A CN101438242 A CN 101438242A CN A2007800160526 A CNA2007800160526 A CN A2007800160526A CN 200780016052 A CN200780016052 A CN 200780016052A CN 101438242 A CN101438242 A CN 101438242A
Authority
CN
China
Prior art keywords
processing element
initialization
memory
nonvolatile memory
volatile memory
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CNA2007800160526A
Other languages
English (en)
Other versions
CN101438242B (zh
Inventor
M·R·曹
D·李
A·鲁贝格
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Lattice Semiconductor Corp
Original Assignee
Silicon Image Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Priority claimed from US11/690,629 external-priority patent/US7831778B2/en
Application filed by Silicon Image Inc filed Critical Silicon Image Inc
Priority to CN201310374264.9A priority Critical patent/CN103425623B/zh
Publication of CN101438242A publication Critical patent/CN101438242A/zh
Application granted granted Critical
Publication of CN101438242B publication Critical patent/CN101438242B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C8/00Arrangements for selecting an address in a digital store
    • G11C8/16Multiple access memory array, e.g. addressing one storage element via at least two independent addressing line groups
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C7/00Arrangements for writing information into, or reading information out from, a digital store
    • G11C7/22Read-write [R-W] timing or clocking circuits; Read-write [R-W] control signal generators or management 
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F13/00Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
    • G06F13/38Information transfer, e.g. on bus
    • G06F13/40Bus structure
    • G06F13/4004Coupling between buses
    • G06F13/4027Coupling between buses using bus bridges
    • G06F13/405Coupling between buses using bus bridges where the bridge performs a synchronising function
    • G06F13/4054Coupling between buses using bus bridges where the bridge performs a synchronising function where the function is bus cycle extension, e.g. to meet the timing requirements of the target bus
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F13/00Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
    • G06F13/38Information transfer, e.g. on bus
    • G06F13/42Bus transfer protocol, e.g. handshake; Synchronisation
    • G06F13/4204Bus transfer protocol, e.g. handshake; Synchronisation on a parallel bus
    • G06F13/4234Bus transfer protocol, e.g. handshake; Synchronisation on a parallel bus being a memory bus
    • G06F13/4243Bus transfer protocol, e.g. handshake; Synchronisation on a parallel bus being a memory bus with synchronous protocol
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C7/00Arrangements for writing information into, or reading information out from, a digital store
    • G11C7/10Input/output [I/O] data interface arrangements, e.g. I/O data control circuits, I/O data buffers
    • G11C7/1075Input/output [I/O] data interface arrangements, e.g. I/O data control circuits, I/O data buffers for multiport memories each having random access ports and serial ports, e.g. video RAM
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C2207/00Indexing scheme relating to arrangements for writing information into, or reading information out from, a digital store
    • G11C2207/10Aspects relating to interfaces of memory device to external buses
    • G11C2207/108Wide data ports

Abstract

一种使用共享非易失性存储器来初始化设备中多个处理部件的方法和系统。针对设备内各处理部件的启动逻辑和配置数据被存储于单个非易失性存储器中。一收到初始化该设备的命令,该共享存储器系统就将启动逻辑和配置数据从非易失性存储器复制到易失性主存储器。然后,各个处理部件访问该主存储器以找到其启动逻辑和配置数据、并开始执行。该共享存储器系统减少了用于初始化多个处理部件的非易失性存储器部件的数量。

Description

共享非易失性存储器体系结构
相关申请的交叉引用
本申请要求对2006年3月30日提交的题为“INTEGRATEDMULTI-PORT SERIAL MEMORY AND INTER-PROCESSORCOMMUNICATION(集成多端口串行存储器和处理器间通信)”的美国临时专利申请No.60/788,401(律师案号No.59472-8826.US00)的优先权,该申请通过引用结合于此。
背景
具有专用于单独任务的多个处理部件的移动设备正在变得越来越常用。例如,移动电话经常包含专用于处理呼叫的连接和断开的基带处理器、以及用于显示用户界面并接收来自用户的请求的单独的介质处理器。这些部件可共享非易失性主存储器以供在运行期间使用,或者各个部件可具有专用的存储器。各个部件可具有其自己的用于存储启动逻辑和配置数据的非易失性存储器。此外,各个部件可具有其自己的用于与其他部件通信的专用接口。
制造设备的成本与该设备所含部件的数量直接相关。因此,减少或消除冗余部件以节约资金是常见的制造目标。附加的部件还增大了设备的功耗,这直接影响了移动设备的电池寿命。因此,减少部件还能延长电池寿命。此外,部件之间总线和其他接口的数量增加了设备的复杂性。增加的复杂性带来了设计和测试设备的难度,并增加了将新产品投入市场所需的时间。
设备中格外昂贵的一个部件是用于初始化该设备的非易失性存储器。通常使用在工厂可用启动逻辑和配置数据闪存的EEPROM,有时称作闪存。闪存有两种类型可用:NAND和NOR,其指的是在闪存内用于存储数据的逻辑门的主要类型。NOR闪存速度快、具有微秒存取时间,而NAND闪存较慢、通常具有毫秒存取时间。然而,速度与价格相关,NOR闪存比NAND闪存更贵。设备制造商必须在闪存的速度与其成本之间作出权衡。消费者通常期望消费电子设备(例如,便携式电话和DVD播放机)有快速的启动时间,从而偏向于使用较快的闪存,所以闪存经常是设备的多个昂贵部件之一。在设备内包括有多个处理部件且各个部件具有其自己的闪存时,其成本就相当高了。
附图简述
图1是示出共享存储器系统的各个部件的框图。
图2是示出包含该共享存储器的设备在初始化期间的处理的流程图。
图3是示出在初始化期间设备中闪存的内容和随机存取存储器的内容的存储器示图。
图4是示出在初始化期间初始化逻辑的验证的流程图。
详细描述
提供一种使用共享非易失性存储器来初始化多个处理部件的方法和系统,该系统称为共享存储器系统。该共享存储器系统减少了设备中用来初始化多个处理部件的非易失性存储器部件的数量。在一些实施例中,用于处理设备中部件的启动逻辑和配置数据被存储在单个非易失性存储器中。在收到初始化该设备的命令后,共享存储器系统将启动逻辑和配置数据从非易失性存储器复制到易失性主存储器。然后,各个处理部件访问该主存储器以找到其启动逻辑和配置数据、并开始执行。主存储器通常比闪存快得多。因此,启动逻辑从非易失性存储器到主存储器的移动降低了该非易失性存储器速度的重要性,因为它只是初始复制期间的一个因素。这样,共享存储器系统使设备制造商能选择较便宜的非易失性存储器部件,而不对设备的启动速度产生显著影响。此外,因为设备制造商必须将各个部件设计成在正常运行期间访问主存储器,所以在来自主存储器的启动逻辑可用时无需设计用于访问非易失性存储器的附加接口。这样,共享存储器系统简化了各个部件的设计,导致较低的复杂性和功耗。
在一些实施例中,共享存储器系统利用串行端口存储器部件,诸如在2001年11月7日提交的题为“COMMUNICATIONS ARCHITECTUREFORMEMORY-BASED DEVICES(基于存储器设备的通信体系结构)”的美国专利申请No.10/045,297(律师案号No.59472-8812.USOO)中所描述的存储器链路(MemoryLink)体系结构,该申请通过引用结合于此。以上引用的申请描述了使诸如上述处理部件之类的多个器件能访问单个主存储器件的串行端口存储器。该体系结构包括用于访问存储器的机制、以及用于在设备之间传达事件以指示操作的完成的机制。在一些实施例中,各处理部件可具有连接它们的单独的接口,且处理部件使用该接口来同步它们的活动。
在一些实施例中,共享存储器系统将处理部件中的一个指定为主处理部件。主处理部件是附连到非易失性(例如闪存)存储器部件的唯一处理部件。在启动期间,主处理部件负责将非易失性存储器部件的内容复制到主存储器部件。在主处理部件已复制了非易失性存储器部件的内容之后,该主处理部件诸如通过使用上述信令机制信令其他处理部件开始它们的启动序列。该主处理部件也通过访问包含非易失性存储器部件的复制内容的主存储器部件开始它的启动序列。这样,只有一个处理部件被设计成具有与非易失性存储器部件的单独接口,然而该非易失性存储器部件的内容对每一个处理部件都是可用的。
图1是示出一些实施例中共享存储器系统的各个部件的框图。使用共享存储器系统的设备100包括:闪存部件110或其他非易失性存储器部件、第一处理部件120、至少一个其他处理部件130、以及主随机存取存储器(RAM)140或其他易失性存储器部件。闪存部件110包含在该共享存储器系统已掉电期间针对各个处理部件存储的启动逻辑和配置数据。第一处理部件120被配置成主处理部件,并附连到闪存部件110。在设备100启动期间,该第一处理部件120将闪存部件110的内容复制到随机存取存储器140。处理部件120和130中的每一个都与随机存取存储器140连接。一旦第一处理部件120已将闪存部件110的内容复制到随机存取存储器140,处理部件120和130中的每一个就通过直接从随机存取存储器140访问启动逻辑和配置数据来开始它们的启动序列。虽然图1中只描绘了两个处理部件,但可以理解任何数量的处理部件或其他部件可被耦合到该共享存储器。各个处理器还可相互不同,并执行不同的功能。例如,在移动应用中,一个处理器可以是基带处理器,而另一个处理器可以是应用处理器。
其上实现系统的设备可包括中央处理器、存储器、输入设备(例如键盘和定点设备)、输出设备(例如视觉显示器、音频扬声器)、以及存储设备(例如磁盘驱动器)。存储器和存储设备是可用实现所公开技术的计算机可执行指令编码的计算机可读介质,这表示包含适当指令的计算机可读介质。此外,数据结构和消息结构可经由数据传输介质来存储或传输,诸如通信链路上的信号。可使用各种通信链路,诸如因特网、局域网、广域网、点到点拨号连接、蜂窝电话网络等。
本系统的各实施例可在各种移动运行环境中实现,包括个人计算机、服务器计算机、手提或膝上型设备、多处理器系统、基于微处理器的系统、可编程消费电子产品、数码相机、网络PC、小型计算机、包括以上任何系统或设备的分布式计算环境等。该计算机系统可以是蜂窝电话、个人数字助理、智能电话、个人计算机、可编程消费电子产品、数字照相机等。
可在由一个或多个计算机或其他设备所执行的诸如程序模块之类的计算机可执行指令的普通上下文中对该系统进行描述。一般而言,各程序模块包括执行特殊任务或实现特殊抽象数据类型的硬件逻辑、例行程序、程序、对象、部件、数据结构等。通常,各程序模块的功能在各种实施例中可按需进行组合或分配。
图2是示出一个实施例中设备在初始化期间的处理的流程图。在电源第一次被施加到设备或在设备执行硬复位时,初始化发生。在框210,设备起动主处理器。在框220,该设备指示主处理器开始执行来自闪存部件(或其他非易失性存储器部件)的指令,这些指令指示该主处理器将闪存的内容复制到随机存取存储器(或其他易失性存储器)。在框230,该设备信令各个处理器使用该随机存取存储器部件开始初始化。在框240,第一处理器在随机存取存储器内定位其初始化指令,并开始执行该初始化指令。在框250,其他各处理器在随机存取存储器内定位其相应初始化指令,并开始执行这些初始化指令。在步骤250之后,该设备被初始化,且这些步骤终止。
图3是示出一个实施例中初始化期间闪存的内容和随机存取存储器的内容的存储器示图。该示图包含闪存305和随机存取存储器350。闪存305包含针对第一处理部件的初始化逻辑310、针对另一处理部件的初始化逻辑315、闪存描影逻辑(flash shadow logic)320、以及引导复位向量(boot resetvector)325。初始化逻辑310包含第一处理部件初始化其自身所需的信息。初始化逻辑310可包含用于验证该初始化逻辑的完整性和来源的签名312(以下进一步详细描述)。初始化逻辑315包含第二处理部件初始化其自身所需的信息。初始化逻辑315还可包含签名317。闪存描影逻辑320包含由将闪存的内容复制到随机存取存储器的主处理部件执行的指令。引导复位向量325是主处理器在复位后在其上开始执行的已知位置。引导复位向量325包含到闪存描影逻辑320的地址的转移。
随机存取存储器350包含指派给第一处理部件的区355、以及指派给第二处理部件的区375。指派给第一处理部件的区355包含从闪存处复制的初始化逻辑360。指派给第二处理部件的区375包含从闪存处复制的初始化逻辑380。一旦闪存描影逻辑320已完成复制初始化逻辑360和380,该闪存描影逻辑320就信令各个处理单元使用适当的存储区开始初始化。在一些实施例中,该描影复制逻辑320可嵌入处理部件中的一个,并且可不包含于闪存305内。在一些实施例中,各个区可与随机存取存储器350上的一端口相关联。在先前引用的题为“COMMUNICATIONS ARCHITECTUREFOR MEMORY-BASED DEVICES”的专利申请中公开了具有多个用于访问存储器的串行端口的存储器体系结构。
在一些实施例中,共享存储器不指定主处理部件。然而,共享存储器系统可包含用于将闪存部件的内容复制到随机存取存储器部件的专用硬件,从而不使用主处理部件。或者,各个处理部件可连接到闪存部件,且各处理部件可诸如通过确定哪个处理单元最快来确定它们中的哪一个将复制闪存的内容。
在一些实施例中,共享存储器系统不信令各个处理部件起动初始化。例如,各处理部件可等待预定时段来开始初始化,这被认为足以确保完成启动逻辑和配置数据从闪存到随机存取存储器的复制。或者,各处理部件可轮询主存储器来确定共享存储器系统何时已将数据写入针对初始化逻辑的特殊已知最终地址。
在一些实施例中,共享存储器系统应处理部件的请求而非在初始化时从闪存复制数据。例如,各处理部件中的一个可能能够独立于系统的其余部分进行复位,诸如蜂窝电话中的介质处理器,以使该处理部件在设备已被初始化后请求从闪存中复制数据。作为另一示例,共享存储器系统可周期性地使一些处理部件断电以在不使用处理部件时省电。在这些情形中,主处理部件可提供请求处理部件以用来请求复制闪存中被该请求处理部件所用的区域的协议。
在一些实施例中,闪存部件中的初始化逻辑包含散列以验证其内容的完整性。例如,SHA散列或MD5散列可用来产生与各个处理部件的初始化逻辑一起存储的签名,该签名被各个处理部件用来验证该初始化逻辑的完整性。替换地或附加地,可对各处理部件中的一个或多个的初始化逻辑加密以防止用该初始化逻辑读取或篡改。各处理部件可包含用于在执行闪存的复制内容之前对该内容进行解密的公钥。或者,所指定的主处理单元可负责执行此类验证。
图4是示出一个实施例中初始化期间初始化逻辑的验证的流程图。在框410,处理部件识别其被复制到主存储器的初始化逻辑。在框420,该处理部件定位与该初始化逻辑相关联的签名。在框430,该处理部件执行初始化逻辑内容的散列。在框440,该处理部件将所确定的散列值和与该初始化逻辑相关联的签名作比较。在判定框450,如果这两个值匹配,则该部件在框470继续,否则该部件就在框460继续。在框460,在这两个值不匹配时,处理部件确定内容已被修改并采取适当的行动。例如,该处理部件可信令中断或中止进一步的处理。在框470,在初始化逻辑未被修改时,处理部件通过执行初始化逻辑来执行初始化。在步骤470之后,这些步骤终止。
从以上内容将可以理解,虽然在此出于例示目的已对共享存储器系统的各具体实施例进行了描述,但是可作各种修改而不背离本发明的精神和范围。例如,虽然已对随机存取存储器进行了描述,但是可使用任何适当的存储设备。类似地,虽然已对各处理部件进行了描述,但是通常从非易失性存储设备读取信息的任何部件,不管该非易失性存储设备是否包含要执行的指令,都可获益于所描述的共享存储器系统。因此,本发明只受所附权利要求限制。

Claims (40)

1.一种用于在各处理部件之间共享非易失性存储器的系统,包括:
易失性存储器,其被配置成在所述系统的运行期间存储数据;
第一处理部件,其被配置成从所述易失性存储器访问初始化逻辑;
第二处理部件,其被配置成从所述易失性存储器访问初始化逻辑;以及
非易失性存储器,其被配置成在所述系统的通电周期上存储针对所述第一处理部件和所述第二处理部件的初始化逻辑,
其中所述初始化逻辑在所述第一处理部件和所述第二处理部件开始初始化之前从所述非易失性存储器复制到所述易失性存储器。
2.如权利要求1所述的系统,其特征在于,进一步包括初始化部件,其被配置成将初始化逻辑从所述非易失性存储器复制到所述易失性存储器。
3.如权利要求1所述的系统,其特征在于,所述第一处理部件被进一步配置成将初始化逻辑从所述非易失性存储器复制到所述易失性存储器。
4.如权利要求1所述的系统,其特征在于,所述第一处理部件和所述第二处理部件被配置成基于各个处理部件的能力来确定哪个处理部件应当将初始化逻辑从所述非易失性存储器复制到所述易失性存储器。
5.如权利要求1所述的系统,其特征在于,所述第一处理部件与所述第二处理部件不是同一类型。
6.如权利要求1所述的系统,其特征在于,所述第一处理部件和所述第二处理部件被进一步配置成通过接收一信号来确定所述初始化逻辑的复制何时完成以开始访问所述初始化逻辑。
7.如权利要求1所述的系统,其特征在于,所述第一处理部件和所述第二处理部件被进一步配置成通过轮询所述易失性存储器确定所述初始化逻辑的复制何时完成以确定所述初始化逻辑何时可用。
8.如权利要求1所述的系统,其特征在于,所述第一处理部件和所述第二处理部件被进一步配置成通过等待预定时段来确定所述初始化逻辑的复制何时完成。
9.如权利要求1所述的系统,其特征在于,所述易失性存储器比所述非易失性存储器快。
10.如权利要求1所述的系统,其特征在于,所述第二处理部件被进一步配置成按需请求将所述初始化逻辑从所述非易失性存储器复制到所述易失性存储器。
11.如权利要求1所述的系统,其特征在于,所述系统在接收到已进行硬复位的指示后将初始化逻辑从所述非易失性存储器复制到所述易失性存储器。
12.如权利要求1所述的系统,其特征在于,存储于所述非易失性存储器中的所述初始化逻辑包含用于验证所述初始化逻辑的内容的签名。
13.如权利要求1所述的系统,其特征在于,存储于所述非易失性存储器中的所述初始化逻辑使用私钥加密,并且所述第一处理部件和所述第二处理部件使用公钥解密所述初始化逻辑。
14.一种计算机系统中的方法,所述方法使用存储于非易失性存储器中的信息来初始化所述系统中的各个处理部件,包括:
接收初始化所述系统的请求;
将初始化信息从所述非易失性存储器复制到可被所述系统的各处理部件中的至少一部分访问的易失性主存储器;
信令第一处理部件使用存储于所述易失性主存储器中的所述初始化信息的至少一部分来初始化其自身;
信令第二处理部件使用存储于所述易失性主存储器中的所述初始化信息的至少一部分来初始化其自身。
15.如权利要求14所述的方法,其特征在于,所述初始化信息被初始化部件从所述非易失性存储器复制到所述易失性存储器。
16.如权利要求14所述的方法,其特征在于,所述初始化信息被所述第一处理部件从所述非易失性存储器复制到所述易失性存储器。
17.如权利要求14所述的方法,其特征在于,所述第一处理部件与所述第二处理部件不是同一类型。
18.如权利要求14所述的方法,其特征在于,信令第一处理部件初始化其自身包括通过轮询所述易失性存储器确定所述初始化信息的复制何时完成以确定所述初始化信息何时可用。
19.如权利要求14所述的系统,其特征在于,信令第一处理部件初始化其自身包括通过等待预定时段确定所述初始化逻辑的复制何时完成。
20.如权利要求14所述的方法,其特征在于,所述易失性存储器比所述非易失性存储器快。
21.如权利要求14所述的方法,其特征在于,进一步包括基于来自所述处理部件中的一个的要求接收初始化所述系统的请求。
22.如权利要求14所述的方法,其特征在于,进一步包括在接收已进行硬复位的指示后再次将初始化信息从所述非易失性存储器复制到所述易失性存储器。
23.如权利要求14所述的方法,其特征在于,存储于所述非易失性存储器中的所述初始化信息包含用于验证所述初始化信息的内容的签名。
24.如权利要求14所述的方法,其特征在于,存储于所述非易失性存储器中的所述初始化信息使用私钥加密,并且所述第一处理部件和所述第二处理部件使用公钥解密所述初始化信息。
25.如权利要求14所述的方法,其特征在于,所述请求是通电信号。
26.如权利要求14所述的方法,其特征在于,所述请求是复位信号。
27.一种用指令编码的闪存部件,所述指令通过一种方法控制移动设备使用存储于非易失性存储器中的信息来初始化多个处理部件,所述方法包括:
接收初始化所述设备的请求;
将初始化信息从所述闪存部件复制到可被所述系统的各处理部件中的至少一部分访问的易失性存储器;
信令第一处理部件使用存储于所述易失性存储器中的所述初始化信息的至少一部分来初始化其自身;
信令第二处理部件使用存储于所述易失性存储器中的所述初始化信息的至少一部分来初始化其自身。
28.如权利要求27所述的闪存,其特征在于,所述初始化信息由初始化部件从所述非易失性存储器复制到所述易失性存储器。
29.如权利要求27所述的闪存,其特征在于,所述初始化信息由所述第一处理部件从所述非易失性存储器复制到所述易失性存储器。
30.如权利要求27所述的闪存,其特征在于,所述第一处理部件与所述第二处理部件不是同一类型。
31.如权利要求27所述的闪存,其特征在于,信令第一处理部件初始化其自身包括通过轮询所述易失性存储器确定所述初始化信息的复制何时完成以确定所述初始化信息何时可用。
32.如权利要求27所述的闪速寄存器,其特征在于,信令第一处理部件初始化其自身包括通过等待预定时段确定所述初始化信息的复制何时完成。
33.如权利要求27所述的闪存,其特征在于,所述易失性存储器比所述非易失性存储器快。
34.如权利要求27所述的闪存,其特征在于,进一步包括基于来自所述处理部件中的一个的要求接收另一初始化所述系统的请求。
35.如权利要求27所述的闪存,其特征在于,进一步包括在接收已进行硬复位的指示后再次将初始化信息从所述非易失性存储器复制到所述易失性存储器。
36.如权利要求27所述的闪存,其特征在于,存储于所述非易失性存储器中的所述初始化信息包含用于验证所述初始化信息的内容的签名。
37.如权利要求27所述的闪存,其特征在于,存储于所述非易失性存储器中的所述初始化信息使用私钥加密,并且所述第一处理部件和所述第二处理部件使用公钥解密所述初始化信息。
38.如权利要求27所述的闪速寄存器,其特征在于,所述请求是通电信号。
39.如权利要求27所述的闪速寄存器,其特征在于,所述请求是复位信号。
40.一种用于在各处理部件之间共享非易失性存储器的系统,包括:
易失性存储器,其被配置成在所述系统的运行期间存储数据;
非易失性存储器,其被配置成在所述系统的通电周期上存储初始化逻辑,
第一处理部件,其被配置成从所述非易失性存储器访问初始化逻辑;以及
第二处理部件,其被配置成从所述易失性存储器访问初始化逻辑,其中所述初始化逻辑在所述第二处理部件开始初始化之前从所述非易失性存储器复制到所述易失性存储器。
CN2007800160526A 2006-03-30 2007-03-30 共享非易失性存储器体系结构 Active CN101438242B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201310374264.9A CN103425623B (zh) 2006-03-30 2007-03-30 共享非易失性存储器体系结构

Applications Claiming Priority (5)

Application Number Priority Date Filing Date Title
US78840106P 2006-03-30 2006-03-30
US60/788,401 2006-03-30
US11/690,629 2007-03-23
US11/690,629 US7831778B2 (en) 2006-03-30 2007-03-23 Shared nonvolatile memory architecture
PCT/US2007/065727 WO2007115229A1 (en) 2006-03-30 2007-03-30 Shared nonvolatile memory architecture

Related Child Applications (1)

Application Number Title Priority Date Filing Date
CN201310374264.9A Division CN103425623B (zh) 2006-03-30 2007-03-30 共享非易失性存储器体系结构

Publications (2)

Publication Number Publication Date
CN101438242A true CN101438242A (zh) 2009-05-20
CN101438242B CN101438242B (zh) 2013-09-18

Family

ID=38421761

Family Applications (3)

Application Number Title Priority Date Filing Date
CN2007800160526A Active CN101438242B (zh) 2006-03-30 2007-03-30 共享非易失性存储器体系结构
CN2007800183833A Active CN101449262B (zh) 2006-03-30 2007-03-30 多端口存储器件中的端口间通信
CN2007800185044A Active CN101449334B (zh) 2006-03-30 2007-03-30 具有可变端口速度的多端口存储器件

Family Applications After (2)

Application Number Title Priority Date Filing Date
CN2007800183833A Active CN101449262B (zh) 2006-03-30 2007-03-30 多端口存储器件中的端口间通信
CN2007800185044A Active CN101449334B (zh) 2006-03-30 2007-03-30 具有可变端口速度的多端口存储器件

Country Status (7)

Country Link
US (2) US7639561B2 (zh)
EP (2) EP2008281B1 (zh)
JP (2) JP5188493B2 (zh)
KR (2) KR101341286B1 (zh)
CN (3) CN101438242B (zh)
TW (3) TWI353124B (zh)
WO (2) WO2007115227A2 (zh)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN104123241A (zh) * 2013-04-24 2014-10-29 华为技术有限公司 内存匿名页初始化方法、装置及系统
CN107624178A (zh) * 2015-06-26 2018-01-23 英特尔公司 快速归零的机柜式架构(rsa)和共享存储器控制器(smc)技术
CN111142955A (zh) * 2019-12-31 2020-05-12 联想(北京)有限公司 一种信息处理方法及装置

Families Citing this family (47)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8443134B2 (en) 2006-12-06 2013-05-14 Fusion-Io, Inc. Apparatus, system, and method for graceful cache device degradation
US9104599B2 (en) 2007-12-06 2015-08-11 Intelligent Intellectual Property Holdings 2 Llc Apparatus, system, and method for destaging cached data
US8489817B2 (en) 2007-12-06 2013-07-16 Fusion-Io, Inc. Apparatus, system, and method for caching data
WO2008070814A2 (en) 2006-12-06 2008-06-12 Fusion Multisystems, Inc. (Dba Fusion-Io) Apparatus, system, and method for a scalable, composite, reconfigurable backplane
US8706968B2 (en) 2007-12-06 2014-04-22 Fusion-Io, Inc. Apparatus, system, and method for redundant write caching
US7836226B2 (en) 2007-12-06 2010-11-16 Fusion-Io, Inc. Apparatus, system, and method for coordinating storage requests in a multi-processor/multi-thread environment
US9519540B2 (en) 2007-12-06 2016-12-13 Sandisk Technologies Llc Apparatus, system, and method for destaging cached data
DE102008011925B4 (de) * 2008-02-29 2018-03-15 Globalfoundries Inc. Sicheres Initialisieren von Computersystemen
US8230180B2 (en) * 2008-06-11 2012-07-24 Samsung Electronics Co., Ltd. Shared memory burst communications
KR20100085564A (ko) * 2009-01-21 2010-07-29 삼성전자주식회사 데이터 처리 시스템과 데이터 처리 방법
US8769213B2 (en) 2009-08-24 2014-07-01 Micron Technology, Inc. Multi-port memory and operation
JP2011058847A (ja) * 2009-09-07 2011-03-24 Renesas Electronics Corp 半導体集積回路装置
US9021158B2 (en) 2009-09-09 2015-04-28 SanDisk Technologies, Inc. Program suspend/resume for memory
US8289801B2 (en) * 2009-09-09 2012-10-16 Fusion-Io, Inc. Apparatus, system, and method for power reduction management in a storage device
US9223514B2 (en) 2009-09-09 2015-12-29 SanDisk Technologies, Inc. Erase suspend/resume for memory
US8458581B2 (en) * 2009-10-15 2013-06-04 Ansaldo Sts Usa, Inc. System and method to serially transmit vital data from two processors
US8190944B2 (en) * 2009-12-11 2012-05-29 Ati Technologies Ulc Device configured to switch a clock speed for multiple links running at different clock speeds and method for switching the clock speed
US8775856B1 (en) * 2010-03-10 2014-07-08 Smsc Holdings S.A.R.L. System and method for generating clock signal for a plurality of communication ports by selectively dividing a reference clock signal with a plurality of ratios
JP2011227834A (ja) * 2010-04-22 2011-11-10 Sony Corp 信号制御装置及び信号制御方法
US8984216B2 (en) 2010-09-09 2015-03-17 Fusion-Io, Llc Apparatus, system, and method for managing lifetime of a storage device
KR101796116B1 (ko) 2010-10-20 2017-11-10 삼성전자 주식회사 반도체 장치, 이를 포함하는 메모리 모듈, 메모리 시스템 및 그 동작방법
US9208071B2 (en) 2010-12-13 2015-12-08 SanDisk Technologies, Inc. Apparatus, system, and method for accessing memory
US9218278B2 (en) 2010-12-13 2015-12-22 SanDisk Technologies, Inc. Auto-commit memory
US10817421B2 (en) 2010-12-13 2020-10-27 Sandisk Technologies Llc Persistent data structures
US9047178B2 (en) 2010-12-13 2015-06-02 SanDisk Technologies, Inc. Auto-commit memory synchronization
US10817502B2 (en) 2010-12-13 2020-10-27 Sandisk Technologies Llc Persistent memory management
EP2652623B1 (en) 2010-12-13 2018-08-01 SanDisk Technologies LLC Apparatus, system, and method for auto-commit memory
US9092337B2 (en) 2011-01-31 2015-07-28 Intelligent Intellectual Property Holdings 2 Llc Apparatus, system, and method for managing eviction of data
WO2012109677A2 (en) 2011-02-11 2012-08-16 Fusion-Io, Inc. Apparatus, system, and method for managing operations for data storage media
WO2012112618A1 (en) * 2011-02-14 2012-08-23 The Regents Of The University Of California Multi-band interconnect for inter-chip and intra-chip communications
US9141527B2 (en) 2011-02-25 2015-09-22 Intelligent Intellectual Property Holdings 2 Llc Managing cache pools
CN102176138B (zh) * 2011-03-01 2013-04-03 上海维宏电子科技股份有限公司 数控系统中硬件端口的对象化管理控制方法
US8543774B2 (en) 2011-04-05 2013-09-24 Ansaldo Sts Usa, Inc. Programmable logic apparatus employing shared memory, vital processor and non-vital communications processor, and system including the same
US9767032B2 (en) 2012-01-12 2017-09-19 Sandisk Technologies Llc Systems and methods for cache endurance
US9251086B2 (en) 2012-01-24 2016-02-02 SanDisk Technologies, Inc. Apparatus, system, and method for managing a cache
US20140321471A1 (en) * 2013-04-26 2014-10-30 Mediatek Inc. Switching fabric of network device that uses multiple store units and multiple fetch units operated at reduced clock speeds and related method thereof
US8963587B2 (en) * 2013-05-14 2015-02-24 Apple Inc. Clock generation using fixed dividers and multiplex circuits
US9666244B2 (en) 2014-03-01 2017-05-30 Fusion-Io, Inc. Dividing a storage procedure
US9665432B2 (en) * 2014-08-07 2017-05-30 Microsoft Technology Licensing, Llc Safe data access following storage failure
US9847918B2 (en) 2014-08-12 2017-12-19 Microsoft Technology Licensing, Llc Distributed workload reassignment following communication failure
US9933950B2 (en) 2015-01-16 2018-04-03 Sandisk Technologies Llc Storage operation interrupt
US9690494B2 (en) * 2015-07-21 2017-06-27 Qualcomm Incorporated Managing concurrent access to multiple storage bank domains by multiple interfaces
US9996138B2 (en) * 2015-09-04 2018-06-12 Mediatek Inc. Electronic system and related clock managing method
CN105701026A (zh) * 2016-01-04 2016-06-22 上海斐讯数据通信技术有限公司 一种数据采集器及其利用系统冗余资源采集数据的方法
KR20180033368A (ko) * 2016-09-23 2018-04-03 삼성전자주식회사 케스-케이드 연결 구조로 레퍼런스 클록을 전달하는 스토리지 장치들을 포함하는 전자 장치
KR102438319B1 (ko) * 2018-02-07 2022-09-01 한국전자통신연구원 공통 메모리 인터페이스 장치 및 방법
US11567708B2 (en) * 2021-01-05 2023-01-31 Brother Kogyo Kabushiki Kaisha Image forming apparatus having one or more ports to which portable memory is attachable

Family Cites Families (44)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4344133A (en) * 1978-07-31 1982-08-10 Motorola, Inc. Method for synchronizing hardware and software
US4449183A (en) 1979-07-09 1984-05-15 Digital Equipment Corporation Arbitration scheme for a multiported shared functional device for use in multiprocessing systems
US4729091A (en) * 1984-11-13 1988-03-01 International Business Machines Corporation Directing storage requests prior to address comparator initialization with a reference address range
IT1184553B (it) * 1985-05-07 1987-10-28 Honeywell Inf Systems Architettura di sistema a piu' processori
US5142683A (en) * 1987-03-09 1992-08-25 Unisys Corporation Intercomputer communication control apparatus and method
JPH01501660A (ja) * 1987-06-18 1989-06-08 ユニシス・コーポレーシヨン コンピユータ間通信制御装置及びその方法
US5144314A (en) * 1987-10-23 1992-09-01 Allen-Bradley Company, Inc. Programmable object identification transponder system
US4987529A (en) * 1988-08-11 1991-01-22 Ast Research, Inc. Shared memory bus system for arbitrating access control among contending memory refresh circuits, peripheral controllers, and bus masters
US5197130A (en) * 1989-12-29 1993-03-23 Supercomputer Systems Limited Partnership Cluster architecture for a highly parallel scalar/vector multiprocessor system
US5175853A (en) * 1990-10-09 1992-12-29 Intel Corporation Transparent system interrupt
JPH04367963A (ja) 1991-06-15 1992-12-21 Hitachi Ltd 共有記憶通信方法
US5423008A (en) 1992-08-03 1995-06-06 Silicon Graphics, Inc. Apparatus and method for detecting the activities of a plurality of processors on a shared bus
JP3442128B2 (ja) * 1994-02-21 2003-09-02 松下電工株式会社 プロセッサ間通信方法および装置
JP3447404B2 (ja) * 1994-12-08 2003-09-16 日本電気株式会社 マルチプロセッサシステム
US5925099A (en) * 1995-06-15 1999-07-20 Intel Corporation Method and apparatus for transporting messages between processors in a multiple processor system
US6167487A (en) * 1997-03-07 2000-12-26 Mitsubishi Electronics America, Inc. Multi-port RAM having functionally identical ports
US5901309A (en) * 1997-10-07 1999-05-04 Telefonaktiebolaget Lm Ericsson (Publ) Method for improved interrupt handling within a microprocessor
US6118792A (en) * 1997-11-21 2000-09-12 Nortel Networks Corporation Method and apparatus for a flexible access rate common-memory packet switch
US6313766B1 (en) * 1998-07-01 2001-11-06 Intel Corporation Method and apparatus for accelerating software decode of variable length encoded information
US6263390B1 (en) * 1998-08-18 2001-07-17 Ati International Srl Two-port memory to connect a microprocessor bus to multiple peripherals
KR100284741B1 (ko) * 1998-12-18 2001-03-15 윤종용 로컬클럭 신호 발생회로 및 방법, 내부클럭신호 발생회로 및방법,이를 이용한 반도체 메모리 장치
US6002633A (en) * 1999-01-04 1999-12-14 International Business Machines Corporation Performance optimizing compiler for building a compiled SRAM
US6378051B1 (en) * 1999-06-14 2002-04-23 Maxtor Corporation Interrupt signal prioritized shared buffer memory access system and method
US6396324B1 (en) * 2000-05-08 2002-05-28 International Business Machines Corporation Clock system for an embedded semiconductor memory unit
US6845409B1 (en) * 2000-07-25 2005-01-18 Sun Microsystems, Inc. Data exchange methods for a switch which selectively forms a communication channel between a processing unit and multiple devices
GB2370667B (en) * 2000-09-05 2003-02-12 Samsung Electronics Co Ltd Semiconductor memory device having altered clock frequency for address and/or command signals, and memory module and system having the same
US6665795B1 (en) * 2000-10-06 2003-12-16 Intel Corporation Resetting a programmable processor
US6938164B1 (en) * 2000-11-22 2005-08-30 Microsoft Corporation Method and system for allowing code to be securely initialized in a computer
EP1358561A1 (en) * 2001-01-31 2003-11-05 International Business Machines Corporation Method and apparatus for transferring interrupts from a peripheral device to a host computer system
US6877071B2 (en) * 2001-08-20 2005-04-05 Technology Ip Holdings, Inc. Multi-ported memory
US6795360B2 (en) * 2001-08-23 2004-09-21 Integrated Device Technology, Inc. Fifo memory devices that support all four combinations of DDR or SDR write modes with DDR or SDR read modes
US7032106B2 (en) 2001-12-27 2006-04-18 Computer Network Technology Corporation Method and apparatus for booting a microprocessor
US7571287B2 (en) * 2003-03-13 2009-08-04 Marvell World Trade Ltd. Multiport memory architecture, devices and systems including the same, and methods of using the same
CN1275143C (zh) * 2003-06-11 2006-09-13 华为技术有限公司 数据处理系统及方法
KR100606242B1 (ko) * 2004-01-30 2006-07-31 삼성전자주식회사 불휘발성 메모리와 호스트간에 버퍼링 동작을 수행하는멀티 포트 휘발성 메모리 장치, 이를 이용한 멀티-칩패키지 반도체 장치 및 이를 이용한 데이터 처리장치
JP4346506B2 (ja) * 2004-06-07 2009-10-21 株式会社リコー 先入れ先出しメモリ及びそれを用いた記憶媒体制御装置
WO2006029094A2 (en) * 2004-09-02 2006-03-16 Xencor, Inc. Erythropoietin derivatives with altered immunogenicity
US20060072563A1 (en) 2004-10-05 2006-04-06 Regnier Greg J Packet processing
JP2006301894A (ja) * 2005-04-20 2006-11-02 Nec Electronics Corp マルチプロセッサシステム、及びマルチプロセッサシステムのメッセージ伝達方法
JP2006309512A (ja) * 2005-04-28 2006-11-09 Nec Electronics Corp マルチプロセッサシステム、及びマルチプロセッサシステムのメッセージ伝達方法
JP4425243B2 (ja) * 2005-10-17 2010-03-03 Okiセミコンダクタ株式会社 半導体記憶装置
US7433263B2 (en) * 2006-02-28 2008-10-07 Samsung Electronics Co., Ltd. Multi-port semiconductor device and method thereof
US7369453B2 (en) * 2006-02-28 2008-05-06 Samsung Electronics Co., Ltd. Multi-port memory device and method of controlling the same
KR100909805B1 (ko) * 2006-09-21 2009-07-29 주식회사 하이닉스반도체 멀티포트 메모리 장치

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN104123241A (zh) * 2013-04-24 2014-10-29 华为技术有限公司 内存匿名页初始化方法、装置及系统
CN104123241B (zh) * 2013-04-24 2017-08-29 华为技术有限公司 内存匿名页初始化方法、装置及系统
CN107624178A (zh) * 2015-06-26 2018-01-23 英特尔公司 快速归零的机柜式架构(rsa)和共享存储器控制器(smc)技术
CN107624178B (zh) * 2015-06-26 2021-05-11 英特尔公司 快速归零的机柜式架构(rsa)和共享存储器控制器(smc)技术
CN111142955A (zh) * 2019-12-31 2020-05-12 联想(北京)有限公司 一种信息处理方法及装置
CN111142955B (zh) * 2019-12-31 2021-07-16 联想(北京)有限公司 一种信息处理方法及装置

Also Published As

Publication number Publication date
WO2007115227A3 (en) 2007-11-29
EP2008164A2 (en) 2008-12-31
WO2007115226A2 (en) 2007-10-11
TWI353124B (en) 2011-11-21
EP2008281A2 (en) 2008-12-31
WO2007115226A3 (en) 2008-10-30
CN101449334B (zh) 2012-04-25
KR101323400B1 (ko) 2013-10-29
CN101438242B (zh) 2013-09-18
CN101449334A (zh) 2009-06-03
US20070234021A1 (en) 2007-10-04
WO2007115227A2 (en) 2007-10-11
JP5188493B2 (ja) 2013-04-24
TW200818734A (en) 2008-04-16
TWI386846B (zh) 2013-02-21
JP2009532782A (ja) 2009-09-10
CN101449262A (zh) 2009-06-03
JP2009532815A (ja) 2009-09-10
CN101449262B (zh) 2012-07-04
TW200802082A (en) 2008-01-01
US7639561B2 (en) 2009-12-29
TW200802403A (en) 2008-01-01
US20070245094A1 (en) 2007-10-18
US7949863B2 (en) 2011-05-24
KR20080104388A (ko) 2008-12-02
TWI340982B (en) 2011-04-21
KR101341286B1 (ko) 2013-12-12
JP5197571B2 (ja) 2013-05-15
EP2008281B1 (en) 2012-01-25
KR20090007378A (ko) 2009-01-16

Similar Documents

Publication Publication Date Title
CN101438242B (zh) 共享非易失性存储器体系结构
CN103425623A (zh) 共享非易失性存储器体系结构
US7882344B2 (en) Memory system having a communication channel between a first processor and a second processor and memory management method that uses the communication channel
TW518517B (en) Storing system-level mass storage configuration data in non-volatile memory on each mass storage device to allow for reboot/power-on reconfiguration of all installed mass storage devices to the same configuration as last use
US10515196B2 (en) Creating secure original equipment manufacturer (OEM) identification
TWI335536B (en) Information handling system (ihs) method and for updating a non-volatile memory (nvm) included in an information handling system
CN108763099A (zh) 系统的启动方法、装置、电子设备和存储介质
TWI241589B (en) Real time processing method of a flash memory
US4734855A (en) Apparatus and method for fast and stable data storage
CN104115230A (zh) 高效pcms刷新机制背景
US20220100498A1 (en) Implementation of object versioning and consistency at scale
CN106663471A (zh) 用于反向存储器备份的方法和装置
CN108604107A (zh) 用于基于指令类型调整最大时钟频率的处理器、方法和系统
US11487339B2 (en) Operating mode register
JP7332083B2 (ja) マルチモード保護メモリ
KR20180066601A (ko) 메모리 시스템의 구동 방법
US11726795B2 (en) Concurrent image measurement and execution
US20210326135A1 (en) Programmable Fabric-Based Instruction Set Architecture for a Processor
CN115176313A (zh) 内存启动和初始化系统和方法
CN106886495B (zh) 一种嵌入式系统及其控制方法
US20060085204A1 (en) Method and system for testing information handling system components
US7178009B2 (en) Different register data indicators for each of a plurality of central processing units
TW201007458A (en) Data processing system for integrating transmission interfaces and method thereof
US10936495B2 (en) Separate data registers and cache registers in memory
US20210232395A1 (en) Methods and devices for hardware characterization of computing devices

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
C14 Grant of patent or utility model
GR01 Patent grant
C41 Transfer of patent application or patent right or utility model
TR01 Transfer of patent right

Effective date of registration: 20151130

Address after: oregon

Patentee after: LATTICE SEMICONDUCTOR CORPORATION

Address before: American California

Patentee before: Silicon Image Inc. A. Delaware C.