CN109669729A - 一种处理器的启动引导方法 - Google Patents

一种处理器的启动引导方法 Download PDF

Info

Publication number
CN109669729A
CN109669729A CN201811603407.8A CN201811603407A CN109669729A CN 109669729 A CN109669729 A CN 109669729A CN 201811603407 A CN201811603407 A CN 201811603407A CN 109669729 A CN109669729 A CN 109669729A
Authority
CN
China
Prior art keywords
processor
spi
programmable logic
logic chip
data
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
CN201811603407.8A
Other languages
English (en)
Other versions
CN109669729B (zh
Inventor
陈宁
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.)
Hangzhou DPTech Technologies Co Ltd
Original Assignee
Hangzhou DPTech Technologies Co Ltd
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
Application filed by Hangzhou DPTech Technologies Co Ltd filed Critical Hangzhou DPTech Technologies Co Ltd
Priority to CN201811603407.8A priority Critical patent/CN109669729B/zh
Publication of CN109669729A publication Critical patent/CN109669729A/zh
Application granted granted Critical
Publication of CN109669729B publication Critical patent/CN109669729B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/4401Bootstrapping
    • 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/4063Device-to-bus coupling
    • G06F13/4068Electrical coupling

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Hardware Design (AREA)
  • Computer Security & Cryptography (AREA)
  • Stored Programmes (AREA)

Abstract

本说明书提供一种处理器的启动引导方法,所述处理器通过可编程逻辑芯片与具有SPI接口的非易失存储闪存连接;所述方法包括:所述可编程逻辑芯片通过SPI总线从所述非易失存储闪存中读取指定数据;所述可编程逻辑芯片接收所述处理器通过并行总线发送过来的数据读取指令后,对所述指定数据进行串并转换,然后发送给所述处理器。通过加入具有串并转换的可编程逻辑芯片,简单修改现存的处理器连接CFI NorFlash来引导启动的硬件方案,使得所述部分处理器能够支持以SPI NorFlash引导启动。这样,可避免设备厂家继续采购市面上价格较高且质量难以保证的CFI NorFlash,而采用主流供货的SPI NorFlash,在软硬件变化不大的情况下继续维持生产,且成本不受影响。

Description

一种处理器的启动引导方法
技术领域
本说明书涉及处理器启动引导技术领域,尤其涉及一种处理器的启动引导方法。
背景技术
为了满足通信设备高性能、低成本的要求,NorFlash,作为当前两大非易失闪存技术之一,由于其可以在芯片内执行的特点,相对于NandFlash(当前两大非易失闪存技术中另一个)更适合作为启动程序的存储介质使用。而CFI:common flash interface,公共闪存接口,该接口相对于串口的SPI(serial peripheral interface,串行外围设备接口)来说,也被称为parallel接口,并行接口;NorFlash主要采用两种接口形式,分别为CFI并行接口和SPI串行接口;CFI接口为数据、地址信号分离的并行接口形式,非常适合CPU等芯片作为引导程序载体的接口形式使用;而SPI接口相对于CFI并行接口,极大减少了信号线的数量,外围设计简单,故很适合于手机、平板等智能产品中;也因为如此,现在CFI NorFlash在市场上的供应量出现断崖式下坠,旧型号停产,且并没有新型号接替。对于低端网络设备(低端交换机、防火墙、路由、网关等)来说,通常会长期使用某种相对较老的CPU芯片方案,这些老CPU芯片方案,因面世较早,对引导程序载体的接口一般都只支持CFI,只能使用CFINorFlash作为引导程序载体。虽然CPU芯片一般也具有SPI接口,但CPU芯片内部缺少相应的驱动支持,不能使用SPI NorFlash作为引导程序载体。
发明内容
为克服相关技术中存在的问题,本说明书提供了方法及装置。
根据本说明书实施例的第一方面,提供一种处理器的启动引导方法,所述处理器通过可编程逻辑芯片与具有SPI接口的非易失存储闪存连接;所述方法包括:
所述可编程逻辑芯片通过SPI总线从所述非易失存储闪存中读取指定数据;
所述可编程逻辑芯片接收所述处理器通过并行总线发送过来的数据读取指令后,对所述指定数据进行串并转换,然后发送给所述处理器;
根据本说明书实施例的第二方面,提供一种处理器的启动引导装置,所述处理器通过可编程逻辑芯片与具有SPI接口的非易失存储闪存连接;所述装置包括:
串行接口通信模块,用于通过SPI总线从所述非易失存储闪存中读取指定数据;
并行接口通信模块,用于接收处理器发送过来的数据读取指令,和用于将转换后的数据发送给所述处理器;
转换模块,用于根据所述数据读取指令,对所述指定数据进行串并转换,然后将转换后的数据发送给所述并行接口通信模块。
根据本说明书实施例的第三方面,提供一种电子设备,包括:处理器和可编程逻辑芯片,可编程逻辑芯片通过SPI总线与外部具有SPI接口的非易失存储闪存连接;所述可编程逻辑芯片包括存储器与执行器;
所述存储器用于存储可执行的计算机指令;
所述执行器用于执行所述计算机指令时实现如下步骤:
所述可编程逻辑芯片通过SPI总线从所述非易失存储闪存中读取指定数据;所述可编程逻辑芯片接收所述处理器通过并行总线发送过来的数据读取指令后,对所述指定数据进行串并转换,然后发送给所述处理器。
本说明书的实施例提供的技术方案可以包括以下有益效果:
本说明书实施例中,通过可编程逻辑芯片将处理器的并行接口与非易失存储闪存的SPI接口连接,通过串并转换,实现处理器通过并行接口读取所述具有SPI接口的非易失存储闪存中的引导程序数据,从而引导处理器启动。由于市面上部分处理器因面世较早,其内部只有与并行接口相对应的引导启动驱动支持,故该处理器只可接具有并行接口接口的CFI NorFlash作为引导程序载体。而通过加入具有串并转换的可编程逻辑芯片,简单修改现存的处理器连接CFI NorFlash来引导启动的硬件方案,使得所述部分处理器能够支持以SPI NorFlash引导启动。这样,可避免设备厂家继续采购市面上价格较高且质量难以保证的CFI NorFlash,而采用主流供货的SPI NorFlash,在软硬件变化不大的情况下继续维持生产,且成本不受影响。且通过只需要极短开发周期的具有串并转换的可编程逻辑芯片,延长了使用这些不支持SPI NorFLash引导的部分处理器的低端网络设备的生命周期。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本说明书。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本说明书的实施例,并与说明书一起用于解释本说明书的原理。
图1是本说明书根据一示例性实施例示出的一种处理器的启动引导方法的流程图。
图2是本说明书根据一示例性实施例示出的中央处理器启动时的启动引导示意图。
图3是本说明书根据一示例性实施例示出的中央处理器启动后的连接示意图。
图4是本说明书根据一示例性实施例示出的一种处理器的启动引导装置的组成框图。
图5是本说明书根据一示例性实施例示出的处理器启动后引导启动装置的连接框图。
图6是本说明书根据一示例性实施例示出的一种电子设备的硬件组成示意图。
具体实施方式
这里将详细地对示例性实施例进行说明,其示例表示在附图中。下面的描述涉及附图时,除非另有表示,不同附图中的相同数字表示相同或相似的要素。以下示例性实施例中所描述的实施方式并不代表与本说明书相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本说明书的一些方面相一致的装置和方法的例子。
在本说明书使用的术语是仅仅出于描述特定实施例的目的,而非旨在限制本说明书。在本说明书和所附权利要求书中所使用的单数形式的“一种”、“所述”和“该”也旨在包括多数形式,除非上下文清楚地表示其他含义。还应当理解,本文中使用的术语“和/或”是指并包含一个或多个相关联的列出项目的任何或所有可能组合。
应当理解,尽管在本说明书可能采用术语第一、第二、第三等来描述各种信息,但这些信息不应限于这些术语。这些术语仅用来将同一类型的信息彼此区分开。例如,在不脱离本说明书范围的情况下,第一信息也可以被称为第二信息,类似地,第二信息也可以被称为第一信息。取决于语境,如在此所使用的词语“如果”可以被解释成为“在……时”或“当……时”或“响应于确定”。
接下来对本说明书实施例进行详细说明。
如图1所示,图1是本说明书根据一示例性实施例示出的一种处理器的启动引导方法的流程图,包括以下步骤102-104:
步骤102、所述可编程逻辑芯片通过SPI总线从所述非易失存储闪存中读取指定数据;
步骤104、所述可编程逻辑芯片接收所述处理器通过并行总线发送过来的数据读取指令后,对所述指定数据进行串并转换,然后发送给所述处理器;
其中,所述可编程逻辑芯片通过并行总线连接至处理器的并行接口,还通过SPI总线连接至所述非易失存储闪存的SPI接口,即所述处理器通过可编程逻辑芯片与具有SPI接口的非易失存储闪存连接。
其中,所述串并转换包括:将原本在并行总线上传输的信号进行处理转换为可在串行总线上传输的信号和/或将原本在串行总线上传输的信号进行处理转换为可在并行总线上传输的信号。
在本实施例中,所述处理器可以是中央处理器即CPU,也可以是具有并行接口且需引导启动程序来引导启动的其他处理器;所述具有SPI接口的非易失存储闪存可以是SPINorFlash;所述可编程逻辑芯片可以是CPLD(Complex Programmable Logic Device),即用户根据各自需要而自行构造逻辑功能的数字集成电路,也可以是其他可编程的具有逻辑功能的芯片。
如图2所示,所述CPU201采用地址-数据复合并行总线202与所述CPLD203连接。比如:CPU的并行IO总线为32个地址信号A0~A31,16个数据信号D0~D15,D0~D15和低16位地址A0~A15是共用芯片管脚的,并通过一个额外的地址锁存信号ALE来显示目前发送的信号类型。CPU在发起读操作时地址-数据复合的这16路管脚先发出地址信号,此时ALE信号一直为低;待ALE信号转高并维持一段时间后,这些管脚变为输入数据信号,接收CPLD发送过来的数据。
在图2中,所述CPLD203通过SPI总线204与所述SPI NorFlash205的SPI接口连接,并通过该SPI接口读取所述SPI NorFlash内部的指定数据。
在一个实施例中,所述指定数据包括引导处理器启动的引导程序数据;即所述SPINorFlash内部存储有引导CPU启动的引导程序数据。
在一个实施例中,所述可编程逻辑芯片将读取到的指定数据缓存在所述可编程逻辑芯片内的缓存区中。以图2为例,所述CPLD根据设计时配置好的初始化命令,将读取到的所述指定数据存放在内部的缓存区中。
在本实施例中,所述处理器通过并行总线给可编程逻辑芯片发送数据读取指令,所述数据读取指令包括有:处理器发出的片选信号、地址信号以及输出使能信号;且该数据读取指令是根据所述非易失存储闪存的读时序设置的。具体来说:CPU201上电后,通过数据-地址复合的I/O并行总线发送数据读取指令给CPLD203。
在本实施例中,所述可编程逻辑芯片接收到所述数据读取指令后,根据默认配置,识别该数据读取指令中的地址信号,进而从缓存区中提取与所述地址信号对应的指定数据,将提取出的对应指定数据进行串并转换,转换成可通过并行总线传输给处理器的启动数据。具体而言,就是CPLD接收到数据读取指令后,识别出CPU在启动时需要接收数据对应的地址信息,该地址信息与所述引导程序数据在所述SPI NorFlash中的地址对应,并将该地址信息对应的引导程序数据从缓存区中顺序提取出来,再对该引导程序数据进行串并转换,即将原本通过SPI接口传输出来的该引导程序数据转换成可以由数据-地址复合的I/O并行总线传输、并行接口接收的启动数据。
本实施例中,在引导CPU启动阶段,采用CPLD进行并行IO总线到SPI总线的数据转换来使CPU使用并行IO总线读取SPI NorFlash的数据,实现CPU支持SPI NorFlash引导启动;这样使得不支持SPI NorFLash引导的老型号CPU也能使用SPI NorFlash作为引导程序载体,解决了CFI NorFlash采购难,成本高的问题,且进一步延长了使用老型号的CPU的低端网络设备的生命周期。本实施例中,采用SPI NorFlash来引导CPU启动,相对于现有技术中采用CFI NorFlash来引导,SPI NorFlash采用SPI串行接口相对于CFI接口极大减少了信号线的数量,外围设计简单,芯片管脚数量少,大大减轻了处理器程序加载接口的运行负担,节约了PCB电路板的使用面积。
在一个实施例中,所述缓存区采用堆栈结构,依据所述数据读取指令,所述可编程逻辑芯片从缓存区中提取所述指定数据并连续发送给所述处理器。
在一个实施例中,在从缓存区中提取出所述指定数据并连续发送给所述处理器的同时,所述可编程逻辑芯片连续读取所述指定数据并将其存储在缓存区中,根据所述缓存区的剩余缓存空间决定是否从所述非易失存储闪存中继续读取指定数据。
仍以图二为例,依据CPU启动时CPU默认从Flash 0地址连续读取指定数据来获取引导程序数据,在所述CPLD内设置了一个缓存区,当所述CPLD接收到CPU从Flash 0地址开始读取指定数据的读取操作后,根据CPU每次的读取动作,将所述缓存区中从Flash 0地址开始的所述指定数据连续发送至CPU。而CPLD也是从指定数据的起始地址开始连续读取所述SPINorFlash中的对应指定数据,并将其顺序存储在堆栈结构的缓存区中。CPU从CPLD的缓存区提取指定数据的速率大小由指导数据中的引导程序数据大小决定。CPLD根据缓存区的填充情况来决定是否继续读取所述指定数据还是挂起操作。根据对非易失存储闪存中的数据的访问特点,设计CPLD将指定数据的传输格式由地址-数据复合并行IO总线到SPI总线的转换,可以降低对CPLD性能的要求,也相对降低了CPLD代码设计的复杂度;进而降低了CPU启动时的功耗。
在一个实施例中,所述可编程逻辑芯片从所述非易失存储闪存中连续读取指定数据,并向处理器连续提供指定数据,且所述可编程逻辑芯片通过SPI总线读取指定数据的速率远大于所述处理器从缓存区中提取指定数据的速率,这样保证了缓存区内的缓存的数据不会出现被消耗完。这样所述可编程逻辑芯片不需要识别处理器的其他访问操作,且在启动时,处理器并不知道其读取的指定数据实际存储在所述非易失存储闪存中。
在一个实施例中,当处理器要发送数据写入所述非易失存储闪存中时,所述可编程逻辑芯片也可将原本通过并行接口发出、并口总线传输的所述发送数据转换成由串口总线传输、串口接口接收的写入数据。
在引导处理器(CPU)启动完成后,若依旧通过可编程逻辑器件对并行IO总线到SPI总线间的数据转换来支持处理器对所述非易失存储闪存进行读写操作,其对可编程逻辑器件的性能要求很高,且对低端网络设备的成本或有压力,且使得可编程逻辑器件的设计难度加大,需要长时间、高负载的验证测试保证功能的实现和稳定性。
在另一个实施例中,当所述处理器接收指定数据并启动后,处理器通过SPI总线与所述可编程逻辑芯片连接;通过所述可编程逻辑芯片的总线转接,所述处理器通过SPI总线访问所述非易失存储闪存。
在一个实施例中,所述通过SPI总线与所述可编程逻辑芯片连接,具体为:当处理器启动后,处理器内的运行程序接管处理器的SPI接口,将所述处理器的SPI接口与所述可编程逻辑芯片的SPI接口通过SPI总线连接。
如图3所示,所述CPU(处理器)301通过地址-数据并行复合总线接收来自CPLD303的指定数据(引导程序数据),完成CPU内部的内存控制器以及SPI接口的初始化进程,完成初始化后,该CPU向所述CPLD发送启动完成指令。接着CPLD接收到该启动完成指令后,将CPLD 303上与SPI NorFlash305连接的SPI接口的控制权限给到CPU 301,CPU 301通过SPI总线302与所述CPLD 301连接,如此,CPU 301对所述SPI NorFlash 305内的数据访问,全程都是通过SPI总线302以及SPI总线304传输,不用做不同总线传输间的数据转换,故这种情况下,CPLD只需要做总线转接就可以了。
也就是说处理器正常启动后,处理器通过自带的串行外设接口来实现对所述非易失存储闪存的正常读写操作,而不再用所述地址-数据并行复合总线来对该非易失存储闪存进行访问。
本实施例通过在启动时与启动后CPU对SPI NorFlash的访问接口的转换,避免了在CPU启动后依旧通过地址-数据复合并行IO总线连接到CPLD,再通过CPLD的串并转换来访问读取SPI NorFlash。由于启动后,CPU会对SPI Flash进行各式各样不同的读写操作,这将对CPLD的串并转换功能的稳定性以及准确性提出更大的挑战。故启动后将CPLD转换到CPU的SPI接口上,使得CPLD在CPU启动阶段与CPU启动后,其工作模式单纯,可行性高;如此,对CPLD的设计和后期验证测试都相对简单。
且启动后,通过用CPU的SPI接口连接SPI总线,来访问SPI NorFlash,提高了启动后CPU对SPI NorFlash中数据的读写速度,提升了处理器执行指令的响应速度。
与前述方法的实施例相对应,本说明书还提供了一种处理器的启动引导装置及其所应用的实施例。
在一个实施例中,提供了一种处理器的启动引导装置,处理器通过可编程逻辑芯片与具有SPI接口的非易失存储闪存连接;所述装置包括:
串行接口通信模块,用于通过SPI总线从所述非易失存储闪存中读取指定数据;
并行接口通信模块,用于接收处理器发送过来的数据读取指令,和用于将转换后的数据发送给所述处理器;
转换模块,用于根据所述数据读取指令,对所述指定数据进行串并转换,然后将转换后的数据发送给所述并行接口通信模块。
在一个实施例中,如图4所示,所述处理器401的启动引导装置包括可编程逻辑芯片403以及具有SPI接口的非易失存储闪存405;所述可编程逻辑芯片403包括并行接口通信模块4031、转换模块4032以及串行接口通信模块4033;所述并行接口通信模块4031通过转换模块4032与所述串行接口通信模块4033连接;处理器启动时,所述处理器401通过并行总线402与所述并行接口通信模块4031连接,所述非易失存储闪存405通过SPI总线404与所述串行接口通信模块4033连接;
所述串行接口通信模块4033通过SPI总线404从所述非易失存储闪存405中读取指定数据;所述并行接口通信模块4031接收处理器401发送过来的数据读取指令;所述转换模块4032根据所述数据读取指令,对所述指定数据进行串并转换,然后将转换后的数据通过并行接口通信模块4031发送给处理器401。
在一个实施例中,所述可编程逻辑芯片还包括:用于缓存所述指定数据的缓存区,根据所述缓存区的剩余缓存空间来决定是否从所述非易失存储闪存中继续读取指定数据。其中,缓存区可集成在所述转换模块内部,也可独立设置在所述可编程逻辑芯片内。
在一个实施例中,所述并行接口通信模块通过SPI总线读取指定数据的速率远大于所述处理器从缓存区中提取指定数据的速率。
在一个实施例中,如图5所示,当所述处理器501启动完成后,所述可编程逻辑芯片503的串行接口通信模块5033通过SPI总线502与所述处理器501连接。
在一个实施例中,所述并行接口通信模块5033通过SPI总线502与所述处理器501连接,具体为:当处理器启动后,处理器内的运行程序接管处理器的SPI接口,将所述处理器的SPI接口与所述并行接口通信模块5033通过SPI总线502连接。
具体而言,就是启动前,所述处理器通过并行总线与可编程逻辑芯片的并行接口通信模块5031连接;启动后,所述处理器的SPI接口被激活,此时,所述处理器将它的SPI接口与所述串行接口通信模块5033通过SPI总线502连接。如此,避免了启动后,若处理器501要读写所述非易失存储闪存505时,仍旧需要通过并行总线与并行接口通信模块5031通信,再通过转换模块5032对并行接口通信模块5031接收到的数据信号进行转换,转换成可通过串行接口通信模块5033发送、SPI总线504传输的数据信号;通过SPI总线502将处理器501与所述串行接口通信模块5033直接连接,进而实现了处理器读写所述非易失存储闪存时,不用所述转换模块5032处理,全程通过SPI总线进行传输。
本说明书文件中处理器的启动引导装置的实施例可以应用在计算机设备上,例如服务器或终端设备。该装置实施例可以通过软件实现,也可以通过硬件或者软硬件结合的方式实现。以软件实现为例,作为一个逻辑意义上的装置,是通过其所在文件处理的可编程逻辑芯片将非易失性存储器中对应的启动引导程序指令读取到内存中运行形成的。
上述装置中各个模块的功能和作用的实现过程具体详见上述方法中对应步骤的实现过程,在此不再赘述。
对于装置实施例而言,由于其基本对应于方法实施例,所以相关之处参见方法实施例的部分说明即可。以上所描述的装置实施例仅仅是示意性的,其中所述作为分离部件说明的模块可以是或者也可以不是物理上分开的,作为模块显示的部件可以是或者也可以不是物理模块,即可以位于一个地方,或者也可以分布到多个网络模块上。可以根据实际的需要选择其中的部分或者全部模块来实现本说明书方案的目的。本领域普通技术人员在不付出创造性劳动的情况下,即可以理解并实施。
本说明书还提供了一种电子设备,如图6所示,包括处理器601和可编程逻辑芯片602,可编程逻辑芯片通过SPI总线与外部具有SPI接口的非易失存储闪存603连接;所述可编程逻辑芯片602包括存储器605与执行器604;
所述存储器605用于存储可执行的计算机指令;
所述执行器604用于执行所述计算机指令时实现前述方法实施例对应的步骤:所述可编程逻辑芯片通过SPI总线从所述非易失存储闪存中读取指定数据;所述可编程逻辑芯片接收所述处理器通过并行总线发送过来的数据读取指令后,对所述指定数据进行串并转换,然后发送给所述处理器。
上述对本说明书特定实施例进行了描述。其它实施例在所附权利要求书的范围内。在一些情况下,在权利要求书中记载的动作或步骤可以按照不同于实施例中的顺序来执行并且仍然可以实现期望的结果。另外,在附图中描绘的过程不一定要求示出的特定顺序或者连续顺序才能实现期望的结果。在某些实施方式中,多任务处理和并行处理也是可以的或者可能是有利的。
本领域技术人员在考虑说明书及实践这里申请的发明后,将容易想到本说明书的其它实施方案。本说明书旨在涵盖本说明书的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本说明书的一般性原理并包括本说明书未申请的本技术领域中的公知常识或惯用技术手段。说明书和实施例仅被视为示例性的,本说明书的真正范围和精神由下面的权利要求指出。
应当理解的是,本说明书并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围进行各种修改和改变。本说明书的范围仅由所附的权利要求来限制。
以上所述仅为本说明书的较佳实施例而已,并不用以限制本说明书,凡在本说明书的精神和原则之内,所做的任何修改、等同替换、改进等,均应包含在本说明书保护的范围之内。

Claims (10)

1.一种处理器的启动引导方法,其特征在于,所述处理器通过可编程逻辑芯片与具有SPI接口的非易失存储闪存连接;所述方法包括:
所述可编程逻辑芯片通过SPI总线从所述非易失存储闪存中读取指定数据;
所述可编程逻辑芯片接收所述处理器通过并行总线发送过来的数据读取指令后,对所述指定数据进行串并转换,然后发送给所述处理器。
2.根据权利要求1所述的一种处理器的启动引导方法,其特征在于,所述数据读取指令包括:根据所述非易失存储闪存的读时序,处理器发出的片选信号、地址信号以及输出使能信号。
3.根据权利要求1所述的一种处理器的启动引导方法,其特征在于,所述指定数据包括引导处理器启动的引导程序数据。
4.根据权利要求1所述的一种处理器的启动引导方法,其特征在于,所述方法还包括:存在用于缓存所述指定数据的缓存区,根据所述缓存区的剩余缓存空间来决定是否从所述非易失存储闪存中继续读取指定数据。
5.根据权利要求4所述的一种处理器的启动引导方法,其特征在于,所述可编程逻辑芯片通过SPI总线读取指定数据的速率远大于所述处理器从缓存区中提取指定数据的速率。
6.根据权利要求1所述的一种处理器的启动引导方法,其特征在于,所述方法还包括:所述处理器接收指定数据并启动后,通过SPI总线与所述可编程逻辑芯片连接。
7.根据权利要求6所述的一种处理器的启动引导方法,其特征在于,所述通过SPI总线与所述可编程逻辑芯片连接,具体为:当处理器启动后,处理器内的运行程序接管处理器的SPI接口,将所述处理器的SPI接口与所述可编程逻辑芯片的SPI接口通过SPI总线连接。
8.一种处理器的启动引导装置,其特征在于,处理器通过可编程逻辑芯片与具有SPI接口的非易失存储闪存连接;所述装置包括:
串行接口通信模块,用于通过SPI总线从所述非易失存储闪存中读取指定数据;
并行接口通信模块,用于接收处理器发送过来的数据读取指令,和用于将转换后的数据发送给所述处理器;
转换模块,用于根据所述数据读取指令,对所述指定数据进行串并转换,然后将转换后的数据发送给所述并行接口通信模块。
9.根据权利要求8所述的一种处理器的启动引导装置,其特征在于,所述串行接口通信模块,当所述处理器启动完成后,还用于通过SPI总线与所述处理器的SPI接口连接。
10.一种电子设备,其特征在于,包括:处理器和可编程逻辑芯片,可编程逻辑芯片通过SPI总线与外部具有SPI接口的非易失存储闪存连接;所述可编程逻辑芯片包括存储器与执行器;
所述存储器用于存储可执行的计算机指令;
所述执行器用于执行所述计算机指令时实现权利要求1至7任一所述方法的步骤。
CN201811603407.8A 2018-12-26 2018-12-26 一种处理器的启动引导方法 Active CN109669729B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201811603407.8A CN109669729B (zh) 2018-12-26 2018-12-26 一种处理器的启动引导方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201811603407.8A CN109669729B (zh) 2018-12-26 2018-12-26 一种处理器的启动引导方法

Publications (2)

Publication Number Publication Date
CN109669729A true CN109669729A (zh) 2019-04-23
CN109669729B CN109669729B (zh) 2022-11-01

Family

ID=66146369

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201811603407.8A Active CN109669729B (zh) 2018-12-26 2018-12-26 一种处理器的启动引导方法

Country Status (1)

Country Link
CN (1) CN109669729B (zh)

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2021129304A1 (zh) * 2019-12-23 2021-07-01 华为技术有限公司 内存管理器、处理器内存子系统、处理器和电子设备
CN113326220A (zh) * 2021-06-09 2021-08-31 新华三技术有限公司 一种外设电子标签信息获取方法及设备
CN113535494A (zh) * 2021-07-28 2021-10-22 杭州迪普科技股份有限公司 一种设备调试的方法及电子设备
CN113609030A (zh) * 2021-07-09 2021-11-05 苏州浪潮智能科技有限公司 一种pfr闪存扩展装置及方法
CN114035853A (zh) * 2021-11-17 2022-02-11 珠海一微半导体股份有限公司 具备spi接口的mcu引导系统及芯片
CN114265799A (zh) * 2021-12-28 2022-04-01 南昌勤胜电子科技有限公司 基于cpld的spi读写系统及服务器
CN116719583A (zh) * 2023-08-08 2023-09-08 飞腾信息技术有限公司 一种启动方法、可编程逻辑器件、计算设备及存储介质

Citations (33)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5784611A (en) * 1994-12-19 1998-07-21 Seagate Technology, Inc. Device and process for in-system programming electrically erasable and programmable non-volatile memory
US6292822B1 (en) * 1998-05-13 2001-09-18 Microsoft Corporation Dynamic load balancing among processors in a parallel computer
WO2002010921A1 (en) * 2000-07-31 2002-02-07 M-Systems Flash Disk Pioneers Ltd. System and method for enabling non-volatile memory to execute code while operating as a data storage/processing device
JP2005316676A (ja) * 2004-04-28 2005-11-10 Tatung Co フラッシュメモリチップの部分ブロックを保護できるハンドヘルド装置
US20050283598A1 (en) * 2004-06-22 2005-12-22 International Business Machines Corporation Method and system for loading processor boot code from serial flash memory
CN1991731A (zh) * 2005-12-26 2007-07-04 鸿富锦精密工业(深圳)有限公司 芯片烧录系统
US20080016260A1 (en) * 2006-07-11 2008-01-17 Pennock James D Serial communication input output interface engine
CN101169765A (zh) * 2007-11-28 2008-04-30 中兴通讯股份有限公司 一种处理器访问慢速存储器的控制方法
KR20080059973A (ko) * 2006-12-26 2008-07-01 삼성전자주식회사 통신시스템에서 에프피지에이 또는 디에스피 구성/부팅데이터 로딩 장치 및 방법
JP2008198000A (ja) * 2007-02-14 2008-08-28 Kyocera Mita Corp カスタム集積回路及びカスタム集積回路を備えた画像形成装置
US20090119481A1 (en) * 2005-11-29 2009-05-07 Xmtt Inc. Computer memory architecture for hybrid serial and parallel computing systems
CN101485913A (zh) * 2008-12-30 2009-07-22 深圳市普博科技有限公司 呼吸机板间通讯系统及方法
US20090240876A1 (en) * 2008-03-24 2009-09-24 Hitachi, Ltd. Information processing apparatus, information processing method and storage system
US20090300273A1 (en) * 2008-06-02 2009-12-03 Ming-Dar Chen Flash memory apparatus with automatic interface mode switching
US7822958B1 (en) * 2006-03-10 2010-10-26 Altera Corporation Booting mechanism for FPGA-based embedded system
US20110007795A1 (en) * 2009-07-13 2011-01-13 L3 Communications Intergrated Systems, L.P. Compressed sensing characterization system and method
CN102053937A (zh) * 2009-10-30 2011-05-11 上海研祥智能科技有限公司 在lpc总线中调用spi接口的闪存的方法及系统
CN102523145A (zh) * 2011-11-21 2012-06-27 天津中兴软件有限责任公司 一种本地总线桥接和数据传输的方法
CN102540937A (zh) * 2010-12-15 2012-07-04 贵州航天控制技术有限公司 信息处理器
CN103226719A (zh) * 2013-05-07 2013-07-31 中国工商银行股份有限公司 一种证件复印机、复印系统和复印方法
CN103235921A (zh) * 2013-04-24 2013-08-07 华为技术有限公司 一种计算机系统
US20130282945A1 (en) * 2012-04-19 2013-10-24 Lockheed Martin Corporation Apparatus and method emulating a parallel interface to effect parallel data transfer from serial flash memory
CN203433337U (zh) * 2013-07-26 2014-02-12 南京第五十五所技术开发有限公司 一种可复用spi控制总线的多通道扩展结构
KR20150039142A (ko) * 2015-02-16 2015-04-09 주식회사 이노와이어리스 시스템 성능 향상을 위한 제어 로직을 구비한 직렬 주변기기 인터페이스 및 그 구동 방법
CN204537117U (zh) * 2015-04-23 2015-08-05 绵阳灵通电讯设备有限公司 一种基于微处理器的fpga远程在线升级系统
US20160127615A1 (en) * 2014-10-31 2016-05-05 Panasonic Intellectual Property Management Co., Ltd. Signal transmitting device, signal transmitting/receiving device, and image display device
CN105607966A (zh) * 2015-11-06 2016-05-25 天津津航计算技术研究所 一种用于SiP芯片上电程序加载冗余备份方法
US20160147689A1 (en) * 2007-02-02 2016-05-26 PSIMAST, Inc Processor apparatus with programmable multi port serial communication interconnections
CN106293843A (zh) * 2016-08-15 2017-01-04 华为技术有限公司 一种数据加载系统
CN106527402A (zh) * 2016-12-02 2017-03-22 深圳市紫光同创电子有限公司 一种fpga调试转换设备、系统及方法
CN106843983A (zh) * 2017-02-09 2017-06-13 深圳市风云实业有限公司 远程升级现场可编程门阵列的系统及方法
CN107346298A (zh) * 2017-07-11 2017-11-14 郑州云海信息技术有限公司 一种并行总线与uart总线间协议转换的方法及系统
CN108228127A (zh) * 2018-01-09 2018-06-29 武汉精测电子集团股份有限公司 用于产生spi接口图形信号的装置及图形信号发生器

Patent Citations (33)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5784611A (en) * 1994-12-19 1998-07-21 Seagate Technology, Inc. Device and process for in-system programming electrically erasable and programmable non-volatile memory
US6292822B1 (en) * 1998-05-13 2001-09-18 Microsoft Corporation Dynamic load balancing among processors in a parallel computer
WO2002010921A1 (en) * 2000-07-31 2002-02-07 M-Systems Flash Disk Pioneers Ltd. System and method for enabling non-volatile memory to execute code while operating as a data storage/processing device
JP2005316676A (ja) * 2004-04-28 2005-11-10 Tatung Co フラッシュメモリチップの部分ブロックを保護できるハンドヘルド装置
US20050283598A1 (en) * 2004-06-22 2005-12-22 International Business Machines Corporation Method and system for loading processor boot code from serial flash memory
US20090119481A1 (en) * 2005-11-29 2009-05-07 Xmtt Inc. Computer memory architecture for hybrid serial and parallel computing systems
CN1991731A (zh) * 2005-12-26 2007-07-04 鸿富锦精密工业(深圳)有限公司 芯片烧录系统
US7822958B1 (en) * 2006-03-10 2010-10-26 Altera Corporation Booting mechanism for FPGA-based embedded system
US20080016260A1 (en) * 2006-07-11 2008-01-17 Pennock James D Serial communication input output interface engine
KR20080059973A (ko) * 2006-12-26 2008-07-01 삼성전자주식회사 통신시스템에서 에프피지에이 또는 디에스피 구성/부팅데이터 로딩 장치 및 방법
US20160147689A1 (en) * 2007-02-02 2016-05-26 PSIMAST, Inc Processor apparatus with programmable multi port serial communication interconnections
JP2008198000A (ja) * 2007-02-14 2008-08-28 Kyocera Mita Corp カスタム集積回路及びカスタム集積回路を備えた画像形成装置
CN101169765A (zh) * 2007-11-28 2008-04-30 中兴通讯股份有限公司 一种处理器访问慢速存储器的控制方法
US20090240876A1 (en) * 2008-03-24 2009-09-24 Hitachi, Ltd. Information processing apparatus, information processing method and storage system
US20090300273A1 (en) * 2008-06-02 2009-12-03 Ming-Dar Chen Flash memory apparatus with automatic interface mode switching
CN101485913A (zh) * 2008-12-30 2009-07-22 深圳市普博科技有限公司 呼吸机板间通讯系统及方法
US20110007795A1 (en) * 2009-07-13 2011-01-13 L3 Communications Intergrated Systems, L.P. Compressed sensing characterization system and method
CN102053937A (zh) * 2009-10-30 2011-05-11 上海研祥智能科技有限公司 在lpc总线中调用spi接口的闪存的方法及系统
CN102540937A (zh) * 2010-12-15 2012-07-04 贵州航天控制技术有限公司 信息处理器
CN102523145A (zh) * 2011-11-21 2012-06-27 天津中兴软件有限责任公司 一种本地总线桥接和数据传输的方法
US20130282945A1 (en) * 2012-04-19 2013-10-24 Lockheed Martin Corporation Apparatus and method emulating a parallel interface to effect parallel data transfer from serial flash memory
CN103235921A (zh) * 2013-04-24 2013-08-07 华为技术有限公司 一种计算机系统
CN103226719A (zh) * 2013-05-07 2013-07-31 中国工商银行股份有限公司 一种证件复印机、复印系统和复印方法
CN203433337U (zh) * 2013-07-26 2014-02-12 南京第五十五所技术开发有限公司 一种可复用spi控制总线的多通道扩展结构
US20160127615A1 (en) * 2014-10-31 2016-05-05 Panasonic Intellectual Property Management Co., Ltd. Signal transmitting device, signal transmitting/receiving device, and image display device
KR20150039142A (ko) * 2015-02-16 2015-04-09 주식회사 이노와이어리스 시스템 성능 향상을 위한 제어 로직을 구비한 직렬 주변기기 인터페이스 및 그 구동 방법
CN204537117U (zh) * 2015-04-23 2015-08-05 绵阳灵通电讯设备有限公司 一种基于微处理器的fpga远程在线升级系统
CN105607966A (zh) * 2015-11-06 2016-05-25 天津津航计算技术研究所 一种用于SiP芯片上电程序加载冗余备份方法
CN106293843A (zh) * 2016-08-15 2017-01-04 华为技术有限公司 一种数据加载系统
CN106527402A (zh) * 2016-12-02 2017-03-22 深圳市紫光同创电子有限公司 一种fpga调试转换设备、系统及方法
CN106843983A (zh) * 2017-02-09 2017-06-13 深圳市风云实业有限公司 远程升级现场可编程门阵列的系统及方法
CN107346298A (zh) * 2017-07-11 2017-11-14 郑州云海信息技术有限公司 一种并行总线与uart总线间协议转换的方法及系统
CN108228127A (zh) * 2018-01-09 2018-06-29 武汉精测电子集团股份有限公司 用于产生spi接口图形信号的装置及图形信号发生器

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
贾衡天 等: ""随钻垂直地震剖面测量装置"", 《石油机械》 *

Cited By (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2021129304A1 (zh) * 2019-12-23 2021-07-01 华为技术有限公司 内存管理器、处理器内存子系统、处理器和电子设备
CN113326220A (zh) * 2021-06-09 2021-08-31 新华三技术有限公司 一种外设电子标签信息获取方法及设备
CN113609030A (zh) * 2021-07-09 2021-11-05 苏州浪潮智能科技有限公司 一种pfr闪存扩展装置及方法
CN113609030B (zh) * 2021-07-09 2023-07-18 苏州浪潮智能科技有限公司 一种pfr闪存扩展装置及方法
CN113535494A (zh) * 2021-07-28 2021-10-22 杭州迪普科技股份有限公司 一种设备调试的方法及电子设备
CN113535494B (zh) * 2021-07-28 2024-02-27 杭州迪普科技股份有限公司 一种设备调试的方法及电子设备
CN114035853A (zh) * 2021-11-17 2022-02-11 珠海一微半导体股份有限公司 具备spi接口的mcu引导系统及芯片
CN114035853B (zh) * 2021-11-17 2023-07-07 珠海一微半导体股份有限公司 具备spi接口的mcu引导系统及芯片
CN114265799A (zh) * 2021-12-28 2022-04-01 南昌勤胜电子科技有限公司 基于cpld的spi读写系统及服务器
CN114265799B (zh) * 2021-12-28 2024-03-26 南昌勤胜电子科技有限公司 基于cpld的spi读写系统及服务器
CN116719583A (zh) * 2023-08-08 2023-09-08 飞腾信息技术有限公司 一种启动方法、可编程逻辑器件、计算设备及存储介质
CN116719583B (zh) * 2023-08-08 2023-11-10 飞腾信息技术有限公司 一种启动方法、可编程逻辑器件、计算设备及存储介质

Also Published As

Publication number Publication date
CN109669729B (zh) 2022-11-01

Similar Documents

Publication Publication Date Title
CN109669729A (zh) 一种处理器的启动引导方法
US7506087B2 (en) Method for configuring a Peripheral Component Interconnect Express (PCIE)
US20090198770A1 (en) System and method of updating codes in controller
CN107704285B (zh) 现场可编程门阵列多版本配置芯片、系统和方法
JPH0764770A (ja) 遠隔的に書込み可能なepromを有するマイクロコントローラ装置及び書込み方法
CN109542478A (zh) 一种更新SPI Flash内FPGA程序的系统及方法
CN106843918A (zh) 对包括arm芯片、dsp芯片和fpga芯片的嵌入式系统进行程序更新的方法
US20160011886A1 (en) Adaptive device driver method and system
CN108664264A (zh) 一种基于cpu通过jtag方式远程更新fpga的装置和方法
CN102520961A (zh) 片外在线可编程的soc系统及其控制方法
CN111931442A (zh) Fpga内嵌flash控制器及电子装置
US10496422B2 (en) Serial device emulator using two memory levels with dynamic and configurable response
US20140215123A1 (en) Controller-Opaque Communication with Non-Volatile Memory Devices
CN103793263A (zh) 一种基于PowerPC处理器的DMA事务级建模方法
US20070250740A1 (en) System and method for conducting BIST operations
TW201344444A (zh) 主機板及應用於該主機板的資料處理方法
CN100568159C (zh) 存储卡用输入输出装置及其控制方法
CN109426511A (zh) 软核更新方法和系统
CN102193860A (zh) 微控制器在线调试电路及方法、微控制器
CN116560688A (zh) 用于域控制器的软件更新方法
CN106980513A (zh) 一种双引导文件的切换方法及装置
JP2907808B1 (ja) フラッシュメモリエミュレーション装置及びそれを用いたデバッグシステム
CN112885403B (zh) 一种Flash控制器的功能测试方法、装置及设备
EP3891594B1 (en) Memory control system with a sequence processing unit
CN114328342A (zh) 一种用于PCIe异构加速卡的新型程控配置方法

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant