CN101042655A - 韧体执行装置与执行方法、韧体配置器与配置方法 - Google Patents

韧体执行装置与执行方法、韧体配置器与配置方法 Download PDF

Info

Publication number
CN101042655A
CN101042655A CNA2007100013637A CN200710001363A CN101042655A CN 101042655 A CN101042655 A CN 101042655A CN A2007100013637 A CNA2007100013637 A CN A2007100013637A CN 200710001363 A CN200710001363 A CN 200710001363A CN 101042655 A CN101042655 A CN 101042655A
Authority
CN
China
Prior art keywords
instruction
address
firmware
relative address
volume 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
CNA2007100013637A
Other languages
English (en)
Other versions
CN100445951C (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.)
MediaTek Wuhan Inc
Original Assignee
MediaTek 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
Application filed by MediaTek Inc filed Critical MediaTek Inc
Publication of CN101042655A publication Critical patent/CN101042655A/zh
Application granted granted Critical
Publication of CN100445951C publication Critical patent/CN100445951C/zh
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

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/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/3017Runtime instruction translation, e.g. macros
    • G06F9/30178Runtime instruction translation, e.g. macros of compressed or encrypted instructions

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Storage Device Security (AREA)
  • Executing Machine-Instructions (AREA)
  • Compression, Expansion, Code Conversion, And Decoders (AREA)
  • Stored Programmes (AREA)

Abstract

本发明提供韧体执行装置与执行方法、韧体配置器与配置方法。所述韧体执行装置包括:一第一存储器,储存一压缩韧体数据;一解压缩器,耦接所述第一存储器,将所述压缩韧体数据解压缩为一第一指令串流,包含至少一绝对地址指令;一后置过滤器,耦接所述解压缩器,使所述第一指令串流转换为一第二指令串流,其中所述绝对地址指令被转换为一相对地址指令;一第二存储器,耦接所述后置过滤器,储存所述第二指令串流;一处理器,耦接所述第二存储器,读取所述第二指令串流并执行其中的指令。本发明可以提升韧体实时执行效能。

Description

韧体执行装置与执行方法、韧体配置器与配置方法
技术领域
本发明是有关于韧体的使用技术,尤其是有关于韧体的压缩和解压缩方法与装置,特别是有关韧体执行装置与执行方法、韧体配置器与配置方法。
背景技术
图1a是一已知的韧体执行架构。在典型使用韧体的嵌入式系统装置中,韧体通常是以压缩的形式储存在只读存储器104中。在制造过程中,厂商可能会使用一压缩器102来量产只读存储器104。最常被使用的压缩算法,例如LZ77和LZ78,又被称为字典式算法(dictionary base algorithms),可将具有重复性的字符串转换成简短的索引值,以节省占用的储存空间。因此对于字符串重复率越高的数据,便能得到越高的压缩率。在实际运作中,如图1a所示,解压缩器106可以实时的将韧体从只读存储器104中解压缩到存储器108中,使处理器110可以直接存取存储器108并执行其中的指令。
图1b是一指令架构图。韧体的结构就是一串连续的指令序列。每一指令可以是16或32位,其中若干位值代表指令代码,而某些位值则代表相对地址值。指令代码由处理器110解读,以进行对应的工作。而相对地址值可以用来指出一笔数据或另一笔指令相对于目前指令的相对地址。
图1c是指令分布于存储器中的状况。只读存储器104中储存的压缩韧体数据,被解压缩后储存于存储器108中,形成了该存储器分布。其中,一指令Ins1包含一相对地址值L1指向一指令Ins3。一Ins2也包含一相对地址值L2指向该指令Ins3。虽然指向同一个指令Ins3,但是相对地址值L1和相对地址值L2的值却不相同。该存储器分布中可能潜藏着大量的这种情形。为了实时解压缩并实时执行韧体指令,只读存储器104的容量和解压缩器106的效能都是很关键的资源。因此一种提升韧体实时执行效能的机制是有必要的。
发明内容
为解决上述现有技术中指出的缺陷,本发明提出一种韧体执行装置与执行方法以及韧体配置器与配置方法。
本发明的上述目的是通过如下技术方案来实现的:
一种韧体(firmware)执行装置,包括:一第一存储器,储存一压缩韧体数据;一解压缩器,耦接该第一存储器,将该压缩韧体数据解压缩为一第一指令串流,包含至少一绝对地址指令;一后置过滤器,耦接该解压缩器,使该第一指令串流转换为一第二指令串流,其中,该绝对地址指令被转换为一相对地址指令;一第二存储器,耦接该后置过滤器,储存该第二指令串流;一处理器,耦接该第二存储器,读取该第二指令串流并执行其中的指令。
在该后置过滤器中,一缓冲器收集一个或多个绝对地址指令,并从中重组出一地址字段,指向一绝对地址;一类型判断器耦接该缓冲器,判断该绝对地址指令的类型;一程序计数器产生地址索引,对应每一绝对地址指令;多个解码器耦接该缓冲器和该程序计数器,分别负责将不同类型的绝对地址指令,依据该程序计数器提供的地址索引,转换为对应的相对地址指令;一复用器耦接该缓冲器、该类型判断器和该多个解码器,根据该类型判断器的判断结果,选择该多个解码器其中之一的转换结果,当成该相对地址指令而输出。
该解压缩器是使用字典式解压缩算法对该压缩韧体数据进行解压缩。
当该类型判断器侦测出该绝对地址指令的类型后,对应该类型的一解码器将该地址字段中的绝对地址值,改写为一相对地址值。该相对地址值为该绝对地址值减去当时的地址索引值。
一种韧体配置器,耦接一只读存储器装置以置入一压缩韧体数据。包括:一前置过滤器,将一包含至少一相对地址指令的原始韧体数据转换为一转码韧体数据,该原始韧体数据中的相对地址指令,被转换为该转码韧体数据中的绝对地址指令;一压缩器耦接该前置过滤器,利用一字典式压缩算法,将该转码韧体数据压缩,产生一压缩韧体数据。该只读存储器装置耦接该压缩器,用以储存该压缩韧体数据。
在该前置过滤器中,一缓冲器收集一个或多个相对地址指令,并从中重组出一地址字段,指向一相对地址;一类型判断器耦接该缓冲器,判断该相对地址指令的类型;一程序计数器产生地址索引,对应每一相对地址指令;多个编码器耦接该缓冲器和该程序计数器,分别负责将不同类型的相对地址指令,依据该程序计数器提供的地址索引,转换为对应的绝对地址指令;一复用器耦接该缓冲器、该类型判断器和该多个编码器,根据该类型判断器的判断结果,选择该多个编码器其中之一的转换结果,当成该绝对地址指令而输出。
当该类型判断器侦测出该相对地址指令的类型后,对应该类型的一编码器将该地址字段中的相对地址值,改写为一绝对地址值;其中该绝对地址值为该相对地址值加上当时的地址索引值。
本发明另提供上述韧体执行装置和韧体配置器所实作的韧体执行方法和韧体配置方法。
一种韧体执行方法,包含下列步骤:提供一压缩韧体数据;将所述压缩韧体数据解压缩为一第一指令串流,包含至少一绝对地址指令;执行一过滤步骤,将所述第一指令串流转换为一第二指令串流,其中所述绝对地址指令被转换为一相对地址指令;读取所述第二指令串流并执行其中的指令。
其中,所述过滤步骤包含:收集一个或多个绝对地址指令,并从中重组出一地址字段,指向一绝对地址;产生地址索引,对应每一绝对地址指令;以及将所述多个绝对地址指令,依据程序计数器提供的地址索引,转换为对应的相对地址指令。
另外,所述过滤步骤进一步包含,将所述地址字段中的绝对地址值,改写为一相对地址值;其中该相对地址值为所述绝对地址值减去当时的地址索引值。
一种韧体配置方法,用以置入一压缩韧体数据于一只读存储器装置,包含下列步骤:对一包含至少一相对地址指令的原始韧体数据进行前置过滤,产生一转码韧体数据,其中该原始韧体数据中的相对地址指令被转换为绝对地址指令;以及使用一字典式压缩算法,将所述转码韧体数据压缩成所述压缩韧体数据。
其中,所述前置过滤步骤包含:收集一个或多个相对地址指令,并从中重组出一地址字段,指向一相对地址;产生地址索引,对应每一相对地址指令;以及将所述多个相对地址指令,依据程序计数器提供的地址索引,转换为对应的绝对地址指令。
另外,所述前置过滤步骤进一步包含,将所述地址字段中的相对地址值,改写为一绝对地址值;其中该绝对地址值为所述相对地址值加上当时的地址索引值。
本发明的有益效果是:可以提升韧体实时执行效能。
为让本发明的上述和其它目的、特征和优点能更明显易懂,下文特举出较佳实施例,并配合所附图式,作详细说明如下。
附图说明
图1a为一已知的韧体执行架构;
图1b为一指令架构图;
图1c为指令分布于存储器中的状况;
图2为韧体数据配置器210和韧体数据执行装置220的实施例;
图3a为图2中前置过滤器202的实施例;
图3b为绝对地址的计算实施例;
图4a为图2中后置过滤器204的实施例;
图4b为相对地址的计算实施例;以及
图5为本发明韧体配置方法和韧体执行方法的流程图。
主要组件符号说明:
102~压缩器;            104~只读存储器;
106~解压缩器;          108~存储器;
110~处理器;            202~前置过滤器;
204~后置过滤器;        210~韧体数据配置器;
220~韧体数据执行装置;  302~缓冲器;
304~类型判断器;        306a,306b~编码器;
308~程序计数器;        402~缓冲器;
404~类型判断器;        406a,406b~解码器;
408~程序计数器;        410~复用器。
具体实施方式
图2为韧体数据配置器210和韧体数据执行装置220的实施例。
该韧体数据配置器210提供一压缩韧体数据,而该韧体数据执行装置220将该压缩韧体数据解压缩并执行其中的指令。由于只读存储器104中的韧体数据是以字典式算法压缩,如果增加字符串的重复率可以提高压缩率。该韧体数据配置器210中包含一前置过滤器202和一压缩器102。该前置过滤器202将原始韧体数据转换为一转码韧体数据,该原始韧体数据包含如图1b所示的多个相对地址指令(至少一个),其中包含相对地址值指向如图1c所示的指令Ins3。该前置过滤器202将相对地址指令转换为绝对地址指令,使其中的指令Ins3的相对地址值改写为指令Ins3的绝对地址值。藉此,该转码韧体数据是一种最佳化的版本,比原始韧体数据提高了字符串的重复率。该压缩器102接着将该转码韧体数据压缩,并传送至只读存储器104储存起来。当韧体数据执行装置220开始运作之后,解压缩器106便开始从只读存储器104中读取压缩后的转码韧体数据并将之解压缩。其中,该解压缩器是使用字典式解压缩算法对该压缩韧体数据进行解压缩。接着一后置过滤器204对该转码韧体数据进行解码动作,使该转码韧体数据回复成原始的状态,而后存放于存储器108中。
图3a为图2中前置过滤器202的实施例。该原始韧体数据被传送至一缓冲器302。该原始韧体数据中包含许多具有相对地址值的指令,用以参照至其它地址的数据或指令。一个相对地址值可能是以一个指令来表示,也可能是以两个指令来表示。而缓冲器302具有足够的空间,收集一个或多个相对地址指令,重组出一地址字段,指向一相对地址值。一类型判断器304耦接该缓冲器302,用以判断该多个相对地址指令的类型。一程序计数器308同步地随着相对地址指令的输入累加一数字,又称为地址索引。该前置过滤器202中另包含多个编码器(306a,306b,......),各耦接至该缓冲器302和该程序计数器308,负责根据地址索引将不同类型的相对地址指令转换至绝对地址指令。当所述类型判断器侦测出所述相对地址指令的类型后,对应该类型的一编码器将所述地址字段中的相对地址值,改写为一绝对地址值;其中该绝对地址值为所述相对地址值加上当时的地址索引值。当一相对地址指令被暂存在该缓冲器302中,对应的编码器将随着类型判断器304的判断而激活,执行转换工作。
图3b为绝对地址的计算实施例。举例来说,如果一相对地址指令的地址索引是0xC084,且其中的相对地址值是0xCA,则编码器依照下列公式计算绝对地址:
0xC084+0x4+(0xCA<<2)=0xC3B0    (1)
0xC3B0>>2=0x30EC               (2)
符号“<<”和“>>”代表一种在处理器中平移位的动作。所求得的绝对地址值0x30EC接着写回原指令,取代原来的相对地址值。因为原始指令和转码后的指令的位数不变,所以只有0xCA被改写成0xEC。
在另一例子中,相对地址是由位于0xCC0C的两个连续的指令来表示。其中的地址值0x7AC和0x100根据下式重组,而产生完整的相对地址值:
[0x7AC<<12+0x100<1]            (3)
为了将相对地址转换为绝对地址,该程序计数器的地址索引值0xCC0C被加上去:
[0x7AC<<12+0x100<1]+(0xCC0C+0x4)=0x7B8E10    (4)
0x7B8E10>>1=0x3DC708=(0x7B8<<11)+0x708     (5)
相对地址值0x7AC和0x100,接着被由第(5)式得到的0x7B8和0x708取代,产生两个具有绝对地址值的转码后指令。
一复用器310耦接至缓冲器302,类型判断器304和编码器,用以选择最后的输出值。在原始韧体数据中不属于地址相关的指令,则直接通过该复用器310输出。而其它与地址相关的指令,则通过类型判断器304判断类型,并由对应的编码器转码后,再由复用器310输出。最后输出的结果被送去进行压缩程序。
图4a为图2中后置过滤器204的实施例。后置过滤器204进行的步骤恰好与前置过滤器202相反。在解压缩器106将该转码韧体数据从只读存储器104中读出来解压缩后,该后置过滤器204将其中的绝对地址指令转换为原始可执行的格式。在后置过滤器204中,一缓冲器402具有足够的空间,收集一个或多个绝对地址指令,重组出一地址字段,指向一绝对地址值。一类型判断器404耦接该缓冲器402,用以判断该多个绝对地址指令的类型。一程序计数器408同步地随着绝对地址指令的输入累加一数字,又称为地址索引。该后置过滤器204中另包含多个解码器(406a,406b,......),各耦接至该缓冲器402和该程序计数器408,负责根据地址索引将不同类型的绝对地址指令转换至相对地址指令。当所述类型判断器侦测出所述绝对地址指令的类型后,对应该类型的一解码器将所述地址字段中的绝对地址值,改写为一相对地址值;其中该相对地址值为所述绝对地址值减去当时的地址索引值。当一绝对地址指令被暂存在该缓冲器402中,对应的解码器将随着类型判断器404的判断而激活,执行转换工作。最后复用器410选择对应解码器的输出作为相对地址指令。
图4b为相对地址的计算实施例。举例来说,如果一绝对地址指令的地址索引是0xC084,且其中的绝对地址值是0xEC,则解码器依照下列公式计算相对地址:
(0xEC<<2)-(0xC084+0x4)=0xFFFF4328                (6)
0xFFFF4328>>2=0x3FFD0CA                          (7)
于是其中的0xCA覆写了原来的0xEC,形成相对地址指令。
在另一个例子中,0x7B8和0x708共同代表了绝对地址的值:
[0x7B8<<12+0x708<1]                              (8)
为了求出相对地址,程序计数器的地址索引0xCC0C被减除:
[0x7B8<<12+0x708<1]-(0xCC0C+0x4)=0x7AC200       (9)
0x7AC200>>1=0x3D6100=(0x7AC<<11)+0x100        (10)
藉此,相对地址值0x7AC和0x100取代了0x7B8和0x708,形成两个连续的相对地址指令。
图5为本发明韧体配置方法和韧体执行方法的流程图。在步骤502中,进行一前置过滤步骤,将原始韧体数据转换为一转码韧体数据。其中的相对地址指令被转换成绝对地址指令。在步骤504中,将该转码韧体数据压缩并储存在只读存储器104中。为了增进韧体数据执行装置220的效能,压缩算法可以采用LZ77或LZ78等字典式算法。步骤502和504是通过韧体数据配置器210,在厂商制造过程中执行。步骤512,当该韧体数据执行装置220启用时,解压缩器106将压缩韧体数据解压缩。步骤514,后置过滤器204接着将解压缩后的转码韧体数据解码,产生原始的相对地址指令。在步骤516中,将后置过滤器204的输出存放在存储器108中。步骤518,处理器110读取存储器108中的指令并执行。该韧体数据执行装置220可以是计算机,光驱或嵌入式系统。相对地址指令通常又称为程序计数器相关指令,遵循着例如ARM姆指编码等规格。
以上所述仅为说明本发明,而非用以限制其保护范围,任何根据本发明的精神所做的变化与修饰,都应包含于本发明的保护范围之内。

Claims (14)

1.一韧体执行装置,其特征在于包含:
一第一存储器,用以储存一压缩韧体数据;
一解压缩器,耦接所述第一存储器,将所述压缩韧体数据解压缩为一第一指令串流,包含至少一绝对地址指令;
一后置过滤器,耦接所述解压缩器,使所述第一指令串流转换为一第二指令串流,其中所述绝对地址指令被转换为一相对地址指令;
一第二存储器,耦接所述后置过滤器,周以储存所述第二指令串流;以及
一处理器,耦接所述第二存储器,读取所述第二指令串流并执行其中的指令。
2.如权利要求1所述的韧体执行装置,其特征在于,所述后置过滤器包含:
一缓冲器,用以收集一个或多个绝对地址指令,并从中重组出一地址字段,指向一绝对地址;
一类型判断器,耦接所述缓冲器,用以判断所述绝对地址指令的类型;
一程序计数器,用以产生地址索引,对应每一绝对地址指令;
多个解码器,耦接所述缓冲器和所述程序计数器,分别负责将不同类型的绝对地址指令,依据所述程序计数器提供的地址索引,转换为对应的相对地址指令;以及
一复用器,耦接所述缓冲器、所述类型判断器和所述多个解码器,根据所述类型判断器的判断结果,选择所述多个解码器其中之一的转换结果,当成所述相对地址指令而输出。
3.如权利要求1所述的韧体执行装置,其特征在于,所述解压缩器是使用字典式解压缩算法对所述压缩韧体数据进行解压缩。
4.如权利要求2所述的韧体执行装置,其特征在于,当所述类型判断器侦测出所述绝对地址指令的类型后,对应该类型的一解码器将所述地址字段中的绝对地址值,改写为一相对地址值;其中该相对地址值为所述绝对地址值减去当时的地址索引值。
5.一韧体配置器,耦接一只读存储器装置,以置入一压缩韧体数据,其特征在于包含:
一前置过滤器,将一包含至少一相对地址指令的原始韧体数据,转换为一转码韧体数据;其中该原始韧体数据中的相对地址指令,被转换为该转码韧体数据中的绝对地址指令;以及
一压缩器,耦接所述前置过滤器,利用一字典式压缩算法,将所述转码韧体数据压缩,产生一压缩韧体数据;
其中所述只读存储器装置耦接所述压缩器,用以储存所述压缩韧体数据。
6.如权利要求5所述的韧体配置器,其特征在于,所述前置过滤器包含:
一缓冲器,用以收集一个或多个相对地址指令,并从中重组出一地址字段,指向一相对地址;
一类型判断器,耦接所述缓冲器,用以判断所述相对地址指令的类型;
一程序计数器,用以产生地址索引,对应每一相对地址指令;
多个编码器,耦接所述缓冲器和所述程序计数器,分别负责将不同类型的相对地址指令,依据所述程序计数器提供的地址索引,转换为对应的绝对地址指令;以及
一复用器,耦接所述缓冲器、所述类型判断器和所述多个编码器,根据所述类型判断器的判断结果,选择所述多个编码器其中之一的转换结果,当成所述绝对地址指令而输出。
7.如权利要求6所述的韧体配置器,其特征在于,当所述类型判断器侦测出所述相对地址指令的类型后,对应该类型的一编码器将所述地址字段中的相对地址值,改写为一绝对地址值;其中该绝对地址值为所述相对地址值加上当时的地址索引值。
8.一种韧体执行方法,其特征在于包含:
提供一压缩韧体数据;
将所述压缩韧体数据解压缩为一第一指令串流,包含至少一绝对地址指令;
执行一过滤步骤,将所述第一指令串流转换为一第二指令串流,其中所述绝对地址指令被转换为一相对地址指令;
读取所述第二指令串流并执行其中的指令。
9.如权利要求8所述的韧体执行方法,其特征在于,所述过滤步骤包含:
收集一个或多个绝对地址指令,并从中重组出一地址字段,指向一绝对地址;
产生地址索引,对应每一绝对地址指令;以及
将所述多个绝对地址指令,依据程序计数器提供的地址索引,转换为对应的相对地址指令。
10.如权利要求8所述的韧体执行方法,其特征在于,所述压缩韧体数据是使用字典式解压缩算法进行解压缩。
11.如权利要求9所述的韧体执行方法,其特征在于,所述过滤步骤进一步包含,将所述地址字段中的绝对地址值,改写为一相对地址值;其中该相对地址值为所述绝对地址值减去当时的地址索引值。
12.一种韧体配置方法,用以置入一压缩韧体数据于一只读存储器装置,其特征在于包含:
对一包含至少一相对地址指令的原始韧体数据进行前置过滤,产生一转码韧体数据,其中该原始韧体数据中的相对地址指令被转换为绝对地址指令;以及
使用一字典式压缩算法,将所述转码韧体数据压缩成所述压缩韧体数据。
13.如权利要求12所述的韧体配置方法,其特征在于,所述前置过滤步骤包含:
收集一个或多个相对地址指令,并从中重组出一地址字段,指向一相对地址;
产生地址索引,对应每一相对地址指令;以及
将所述多个相对地址指令,依据程序计数器提供的地址索引,转换为对应的绝对地址指令。
14.如权利要求13所述的韧体配置方法,其特征在于,所述前置过滤步骤进一步包含,将所述地址字段中的相对地址值,改写为一绝对地址值;其中该绝对地址值为所述相对地址值加上当时的地址索引值。
CNB2007100013637A 2006-03-24 2007-01-11 韧体执行装置与执行方法、韧体配置器与配置方法 Expired - Fee Related CN100445951C (zh)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US11/388,691 US20070226724A1 (en) 2006-03-24 2006-03-24 Method and apparatus for firmware execution and provision
US11/388,691 2006-03-24

Publications (2)

Publication Number Publication Date
CN101042655A true CN101042655A (zh) 2007-09-26
CN100445951C CN100445951C (zh) 2008-12-24

Family

ID=38535143

Family Applications (1)

Application Number Title Priority Date Filing Date
CNB2007100013637A Expired - Fee Related CN100445951C (zh) 2006-03-24 2007-01-11 韧体执行装置与执行方法、韧体配置器与配置方法

Country Status (4)

Country Link
US (1) US20070226724A1 (zh)
CN (1) CN100445951C (zh)
TW (1) TW200736991A (zh)
WO (1) WO2007109946A1 (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102262547A (zh) * 2010-05-31 2011-11-30 中兴通讯股份有限公司 场可编程门阵列加载方法和装置

Families Citing this family (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9348593B2 (en) * 2012-08-28 2016-05-24 Avago Technologies General Ip (Singapore) Pte. Ltd. Instruction address encoding and decoding based on program construct groups
US20220318015A1 (en) * 2021-03-31 2022-10-06 Advanced Micro Devices, Inc. Enforcing data placement requirements via address bit swapping

Family Cites Families (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5710639A (en) * 1996-01-25 1998-01-20 Kuznicki; William Joseph Scan line compressed facsimile communication system
US5745058A (en) * 1996-10-21 1998-04-28 International Business Machines Corporation Method and system for compressing microcode to be executed within a data processing system
US6243798B1 (en) * 1997-10-28 2001-06-05 Microchip Technology Incorporated Computer system for allowing a two word jump instruction to be executed in the same number of cycles as a single word jump instruction
US6078541A (en) * 1998-04-28 2000-06-20 Mitsumi Electronics Co., Ltd. Device controller having volatile and non-volatile memory for storage of decompressed and compressed data
US6145069A (en) * 1999-01-29 2000-11-07 Interactive Silicon, Inc. Parallel decompression and compression system and method for improving storage density and access speed for non-volatile memory and embedded memory devices
JP3556556B2 (ja) * 2000-02-08 2004-08-18 株式会社東芝 命令コード変換装置及び情報処理システム
US6789157B1 (en) * 2000-06-30 2004-09-07 Intel Corporation Plug-in equipped updateable firmware
US6892292B2 (en) * 2002-01-09 2005-05-10 Nec Corporation Apparatus for one-cycle decompression of compressed data and methods of operation thereof
US6907598B2 (en) * 2002-06-05 2005-06-14 Microsoft Corporation Method and system for compressing program code and interpreting compressed program code
CN1200347C (zh) * 2002-07-08 2005-05-04 华为技术有限公司 一种动态加载单板芯片firmware程序的实现方法
US20050010811A1 (en) * 2003-06-16 2005-01-13 Zimmer Vincent J. Method and system to support network port authentication from out-of-band firmware
US6903668B1 (en) * 2003-11-18 2005-06-07 M-Systems Flash Disk Pioneers Ltd. Decompression accelerator for flash memory

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102262547A (zh) * 2010-05-31 2011-11-30 中兴通讯股份有限公司 场可编程门阵列加载方法和装置

Also Published As

Publication number Publication date
TW200736991A (en) 2007-10-01
US20070226724A1 (en) 2007-09-27
WO2007109946A1 (fr) 2007-10-04
CN100445951C (zh) 2008-12-24

Similar Documents

Publication Publication Date Title
CN1145264C (zh) 与串搜索交错进行即时字典更新的数据压缩和解压缩系统
CN1183683C (zh) 使用前缀预测的位自适应编码方法
CN1178134C (zh) 执行于板上系统内的中间对象代码程序的数据压缩方法
CN1612252A (zh) 实时数据在线压缩与解压缩方法
US20200294629A1 (en) Gene sequencing data compression method and decompression method, system and computer-readable medium
EP4030628A1 (en) Near-storage acceleration of dictionary decoding
US10303402B2 (en) Data compression using partial statistics
CN101042655A (zh) 韧体执行装置与执行方法、韧体配置器与配置方法
CN1601519A (zh) 文档变换系统
CN101060337A (zh) 一种优化的霍夫曼解码方法和装置
CN1200354C (zh) 自动压缩/解压缩文件系统
US20160226516A1 (en) Non-transitory computer-readable recording medium, compression method, decompression method, compression device, and decompression device
CN1269034C (zh) 一种嵌入式系统中可执行文件的压缩及其加载方法
CN1335958A (zh) 变指令长度处理
CN103198127B (zh) 大文件排序方法及系统
CN1737791A (zh) 一种对数据进行有限穷举优化的压缩方法
CN1653698A (zh) 包含cpu处理器接口的可编程变长解码器
CN1914807A (zh) 编码解码装置
CN1299198C (zh) 由可改变的指令格式而提高程序码密集度的微控制器结构
CN109698704B (zh) 比对型基因测序数据解压方法、系统及计算机可读介质
US11431995B2 (en) Memory system
JP7562451B2 (ja) 圧縮装置および制御方法
CN1186987A (zh) 信息压缩方法及其装置
US7334113B2 (en) Method and system for processing an instruction set
CN1293394A (zh) 处理器系统

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
ASS Succession or assignment of patent right

Owner name: MEDIATEK SOFTWARE (WUHAN) CO., LTD.

Free format text: FORMER OWNER: LIANFA SCIENCE AND TECHNOLOGY CO., LTD.

Effective date: 20150807

C41 Transfer of patent application or patent right or utility model
TR01 Transfer of patent right

Effective date of registration: 20150807

Address after: 430000, Hubei Wuhan East Lake Development Zone Finance Port Phase A4, building 7, -8 layer

Patentee after: MediaTek software (Wuhan) Co., Ltd.

Address before: Hsinchu Science Park, Taiwan, China

Patentee before: MediaTek.Inc

CF01 Termination of patent right due to non-payment of annual fee
CF01 Termination of patent right due to non-payment of annual fee

Granted publication date: 20081224

Termination date: 20200111