CN111273852A - 存储器区块大小判定方法 - Google Patents

存储器区块大小判定方法 Download PDF

Info

Publication number
CN111273852A
CN111273852A CN201811471565.2A CN201811471565A CN111273852A CN 111273852 A CN111273852 A CN 111273852A CN 201811471565 A CN201811471565 A CN 201811471565A CN 111273852 A CN111273852 A CN 111273852A
Authority
CN
China
Prior art keywords
memory
range
magic string
reading
found
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.)
Pending
Application number
CN201811471565.2A
Other languages
English (en)
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.)
Jmicron Tech Corp
Original Assignee
Jmicron Tech Corp
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 Jmicron Tech Corp filed Critical Jmicron Tech Corp
Priority to CN201811471565.2A priority Critical patent/CN111273852A/zh
Publication of CN111273852A publication Critical patent/CN111273852A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/0604Improving or facilitating administration, e.g. storage management
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0638Organizing or formatting or addressing of data
    • G06F3/064Management of blocks
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0668Interfaces specially adapted for storage systems adopting a particular infrastructure
    • G06F3/0671In-line storage system
    • G06F3/0673Single storage device
    • G06F3/0679Non-volatile semiconductor memory device, e.g. flash memory, one time programmable memory [OTP]

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Human Computer Interaction (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Read Only Memory (AREA)

Abstract

一种存储器区块大小判定方法,包含:将一魔术字串写入到一存储器的存储空间的起始位置;以第一范围对该存储器进行第一次读取,并于该第一次读取未找到该魔术字串的情况下,以第二范围对该存储器进行第二次读取,直到找出该魔术字串为止;以及当魔术字串是于第N次读取中被找到时,将对应于该第N次读取的第N范围判定为该存储器的区块大小,其中,N是大于或等于1的正整数。

Description

存储器区块大小判定方法
【技术领域】
本发明是关于存储器装置的领域,尤其关于一种存储器区块大小判定方法。
【背景技术】
串行外设接口(Serial Peripheral Interface,SPI)为在两个装置之间提供相对简单连接的通信接口,其用以作为主装置与一或多个附属装置进行通信的接口。数据经由SPI同时传输及接收,从而使其成为全双工协定(full duplexed protocol)。
由于市面上串行外设接口快闪存储器(flash memory)的种类繁多且每种快闪存储器的大小可能不一致,当烧入数据大于快闪存储器大小时可能造成不可预期的错误。因此,要如何妥善预防将过大的数据烧入串行外设接口快闪存储器是本领域人士必须解决的问题。
相关技术中提及通过将每颗快闪存储器的读取辨识码(RDID)以及将存储器大小记录于数据表(datasheet)中,之后要对快闪存储器进行读取的时候则通过查表的方式找出RDID以及对应的存储器大小。换言之,已知作法必须不断地查表,而这样的查表动作除了耗费时间,也影响到维护上的便利性,举例来说,每当使用新的快闪存储器时,开发者就必须去研究其规格,并且修改程序码以及数据表。
【发明内容】
有鉴于上述相关技术会遭遇的问题,本发明的目的在于提供一种存储器区块大小判定方法,以在不用事先记录所要读取的存储器的规格以及进行查表的情况下取得存储器大小,以利后续的各种操作。
本发明的至少一实施例提供了一种存储器区块大小判定方法,该方法包含以下步骤:将一魔术字串(magic string)写入到一存储器的存储空间的起始位置;以第一范围对该存储器进行第一次读取,并于该第一次读取未找到该魔术字串的情况下,以第二范围对该存储器进行第二次读取,直到找出该魔术字串为止;以及当魔术字串是于第N次读取中被找到时,将对应于该第N次读取的第N范围判定为该存储器的区块大小,其中,N是大于或等于1的正整数。
通过以上本发明的方法,可快速且确实地得知存储器的区块大小。另外,依据本发明的实施例来实施不需要额外设置硬件架构,亦即,亦即,并不会造成成本的增加。相较于相关技术,本发明能在没有副作用或较不可能带来副作用的状况下实现存储装置的读取。
【附图说明】
图1是串行外设接口快闪存储器的操作示意图。
图2是根据本发明实施例的存储器区块大小判定方法的示意图。
【符号说明】
202~222步骤
【具体实施方式】
在说明书及后续的申请专利范围当中使用了某些词汇来指称特定的元件。所属领域中具有通常知识者应可理解,硬件制造商可能会用不同的名词来称呼同样的元件。本说明书及后续的申请专利范围并不以名称的差异来作为区分元件的方式,而是以元件在功能上的差异来作为区分的准则。在通篇说明书及后续的权利要求当中所提及的「包含」是一开放式的用语,故应解释成「包含但不限定于」。
请参考图1,图1是串行外设接口(SPI)快闪存储器的操作示意图,如图1所示,共有两条控制线及两条数据线,控制线包含串行时脉(serial clock)线SCLK及芯片选择(chipselect)线CS#,其中,串行时脉线SCLK用以提供数字时脉信号,芯片选择线CS用以选取所要操作的装置。数据线包含信号输出线SO以及信号输入线SI,用以传递数据。
在本范例中,是使用长度为24bit的读取指令来读取SPI快闪存储器的内容,而该读取指令是通过信号输入线SI来传送,之后第一个存储器位置有三个(A23~A0)待读取。在本实施例中,只有最大有效比特AMSB(most significant bit)至A0会被解码,其余的比特(A23~AMSB)则被忽略。
有别于已知技术必须繁琐地于数据表中记录每颗快闪存储器的RDID和存储器大小,并且于之后读取时再搭配查表的方式来确认对应当下的快闪存储器的RDID以及存储器大小,取而代的地,本发明是即时(real-time)检测或运算出存储器大小,除了省时也省下不少的存储器空间,以下将对实施细节作详细的介绍。需注意的是,已知技术必须根据RDID来找出快闪存储器在查找表(look-up table)中的对应位置。
首先将一魔术字串(magic string)写入到一存储器的存储空间的起始位置,接着通过寻找该魔术字串来判定存储器大小,其中,该起始位置可为address 0。在计算机的用语中,魔术字串是指程序开发者认为不会来自于外部、且能够激活(activate)隐藏功能的一种输入。通常,使用者在设计输入的时候都会期望该多个输入能有预期的响应,然而,若使用者无意间使预先定义的输入引发内部的某些功能,这样的程序响应通常超出使用者的预期,因而有「魔术」之称。以上是偏重学术上的定义,简单来说,可以将魔术字串理解为一特定的字串,大小依使用者而定,但字串内容不重复于其他字串的内容。
首先,将一长度未定的魔术字串写入快闪存储器起始位置,并由位置64KB作为第一次读取长度。假设SPI快闪存储器的实际大小为64Kbyte(KB),A15~A0为可解析的比特,且A23~A16为无效比特,当读取位置64KB(0x010000)时,因A15~A0皆为0,读到的SPI快闪存储器位置相当于0x000000,因此第一次读到魔术字串的位置即为SPI快闪存储器大小。其中,上述24个比特中实际上只使用到16个比特,另外8个比特相当于预设比特。以上是探讨在第一次读取中就找到魔术字串的情况,若在第一次读取中即读到魔术字串,则将该第一次读取长度视为快闪存储器大小。
当第一次读取未能找到魔术字串的情况下,本发明会继续以第二范围对该存储器进行第二次读取,以此类推,直到找出魔术字串为止。当魔术字串是于第N次读取中被找到时,即判定对应于该第N次读取的第N范围判定为该存储器的区块大小,其中,N是大于或等于1的正整数。举例来说,在第二次读取时可采用第一次读取长度的两倍进行读取(即采用128KB),以此类推,第三次读取则采用256KB进行读取。换言之,本发明可采用以2的幂次方为倍数的范围成长速度来读取魔术字串长度,其中,若2X位置没有读到魔术字串但2X+1位置却有读取到魔术字串,则快闪存储器大小为64KB*2X+1,以此类推。
需注意的是,以上仅为举例的目的,并不用以限缩本发明的范畴,举例来说,本发明不受限于上述数值,起始的64KB区间以及24比特的读取指令皆可调整为其他数值,而在后续叠代中所使用的倍数亦不限定为必须呈现2的幂次方关系,而可以是其他数值的的幂次方关系。
请参考图2,图2是根据本发明实施例的存储器区块大小判定方法的示意图。请注意,假若可获得实质上相同的结果,则该多个步骤并不一定要完全遵照图2所示的执行次序来执行,且本流程亦不排除可插入其它相关步骤的可能性。图2所示的步骤可与以上所介绍的本发明概念结合,并可简单归纳如下:
步骤202:开始。
步骤204:将魔术字串写入到快闪存储器地址0x000000。
步骤206:将魔术字串的大小从地址0x010000读取到缓冲存储器。
步骤208:判断是否找到魔术字串(若魔术字串相同于缓冲存储器,则判定已找到),若是,则进入步骤210;若否,则进入步骤212。
步骤210:判定串行外设接口快闪存储器的大小为0x010000比特组(Byte)。
步骤212:将魔术字串的大小从地址0x020000读取到缓冲存储器。
步骤214:判断是否找到魔术字串(若魔术字串相同于缓冲存储器,则判定已找到),若是,则进入步骤216;若否,则进入步骤218。
步骤216:判定串行外设接口快闪存储器的大小为0x020000比特组。
步骤218:将魔术字串的大小从地址0x040000读取到缓冲存储器。
步骤220:判断是否找到魔术字串(若魔术字串相同于缓冲存储器,则判定已找到),若是,则进入步骤222;若否,则继续进入下一次叠代。
步骤222:判定串行外设接口快闪存储器的大小为0x040000比特组。
通过以上本发明的方法,可快速且确实地得知存储器的区块大小。另外,依据本发明的实施例来实施不需要额外设置硬件架构,亦即,亦即,并不会造成成本的增加。相较于相关技术,本发明能在没有副作用或较不可能带来副作用的状况下实现存储装置的读取。
以上所述仅为本发明的较佳实施例,凡依本发明申请专利范围所做的均等变化与修饰,皆应属本发明的涵盖范围。

Claims (6)

1.一种存储器区块大小判定方法,其特征在于,该方法包含以下步骤:
将一魔术字串写入到一存储器的存储空间的起始位置;
以第一范围对该存储器进行第一次读取,并于该第一次读取未找到该魔术字串的情况下,以第二范围对该存储器进行第二次读取,直到找出该魔术字串为止;以及
当魔术字串是于第N次读取中被找到时,将对应于该第N次读取的第N范围判定为该存储器的区块大小,其中,N是大于或等于1的正整数。
2.如权利要求1所述的存储器区块大小判别方法,其特征在于,该存储器是一串行外设接口快闪存储器。
3.如权利要求1所述的存储器区块大小判别方法,其特征在于,该第一范围为64K。
4.如权利要求1所述的存储器区块大小判别方法,其特征在于,该第二范围大于该第一范围。
5.如权利要求4所述的存储器区块大小判别方法,其特征在于,该第二范围与该第一范围呈倍数关系。
6.如权利要求5所述的存储器区块大小判别方法,其特征在于,该第二范围与该第一范围呈2的幂次方关系。
CN201811471565.2A 2018-12-04 2018-12-04 存储器区块大小判定方法 Pending CN111273852A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201811471565.2A CN111273852A (zh) 2018-12-04 2018-12-04 存储器区块大小判定方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201811471565.2A CN111273852A (zh) 2018-12-04 2018-12-04 存储器区块大小判定方法

Publications (1)

Publication Number Publication Date
CN111273852A true CN111273852A (zh) 2020-06-12

Family

ID=70996652

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201811471565.2A Pending CN111273852A (zh) 2018-12-04 2018-12-04 存储器区块大小判定方法

Country Status (1)

Country Link
CN (1) CN111273852A (zh)

Citations (16)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH09293014A (ja) * 1996-04-25 1997-11-11 Oki Electric Ind Co Ltd メモリの記憶容量の認識方法
JP2000122921A (ja) * 1998-10-14 2000-04-28 Oki Data Corp メモリサイズ自動判定方法及び判定装置
CN1564130A (zh) * 2004-04-06 2005-01-12 中兴通讯股份有限公司 一种判别嵌入式系统内存大小的方法
US20080133583A1 (en) * 2006-10-26 2008-06-05 Nabi Sertac Artan Generating a hierarchical data structure associated with a plurality of known arbitrary-length bit strings used for detecting whether an arbitrary-length bit string input matches one of a plurality of known arbitrary-length bit string
CN101321341A (zh) * 2008-07-11 2008-12-10 东信和平智能卡股份有限公司 智能卡断电保护方法
CN101477837A (zh) * 2009-01-21 2009-07-08 炬力集成电路设计有限公司 一种存储器容量检测方法和装置
CN101527172A (zh) * 2008-03-07 2009-09-09 佛山市顺德区顺达电脑厂有限公司 动态随机存储器容量检测系统及方法
CN101681301A (zh) * 2007-05-14 2010-03-24 高通股份有限公司 存储器页大小自动检测
CN102306503A (zh) * 2010-07-30 2012-01-04 深圳市江波龙电子有限公司 一种假容量存储器的检测方法及系统
CN102667743A (zh) * 2009-10-09 2012-09-12 高通股份有限公司 存取具有非均匀页大小的多通道存储器系统
CN102981974A (zh) * 2012-11-09 2013-03-20 深圳市共进电子股份有限公司 一种嵌入式系统中内存大小的自动识别方法
CN103116536A (zh) * 2013-02-25 2013-05-22 杭州华澜微科技有限公司 存储装置的容量检测方法
CN103777907A (zh) * 2014-02-25 2014-05-07 四川长虹空调有限公司 自动获取eeprom存储容量的方法
CN107833593A (zh) * 2017-11-15 2018-03-23 中京复电(上海)电子科技有限公司 一种无源uhf rfid芯片存储容量的测试方法
CN108021482A (zh) * 2017-12-28 2018-05-11 杭州迪普科技股份有限公司 一种Boot Loader下检测内存的方法及装置
CN110109785A (zh) * 2019-04-16 2019-08-09 晶晨半导体(上海)股份有限公司 内存容量获取方法、装置、计算机设备及可读存储介质

Patent Citations (16)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH09293014A (ja) * 1996-04-25 1997-11-11 Oki Electric Ind Co Ltd メモリの記憶容量の認識方法
JP2000122921A (ja) * 1998-10-14 2000-04-28 Oki Data Corp メモリサイズ自動判定方法及び判定装置
CN1564130A (zh) * 2004-04-06 2005-01-12 中兴通讯股份有限公司 一种判别嵌入式系统内存大小的方法
US20080133583A1 (en) * 2006-10-26 2008-06-05 Nabi Sertac Artan Generating a hierarchical data structure associated with a plurality of known arbitrary-length bit strings used for detecting whether an arbitrary-length bit string input matches one of a plurality of known arbitrary-length bit string
CN101681301A (zh) * 2007-05-14 2010-03-24 高通股份有限公司 存储器页大小自动检测
CN101527172A (zh) * 2008-03-07 2009-09-09 佛山市顺德区顺达电脑厂有限公司 动态随机存储器容量检测系统及方法
CN101321341A (zh) * 2008-07-11 2008-12-10 东信和平智能卡股份有限公司 智能卡断电保护方法
CN101477837A (zh) * 2009-01-21 2009-07-08 炬力集成电路设计有限公司 一种存储器容量检测方法和装置
CN102667743A (zh) * 2009-10-09 2012-09-12 高通股份有限公司 存取具有非均匀页大小的多通道存储器系统
CN102306503A (zh) * 2010-07-30 2012-01-04 深圳市江波龙电子有限公司 一种假容量存储器的检测方法及系统
CN102981974A (zh) * 2012-11-09 2013-03-20 深圳市共进电子股份有限公司 一种嵌入式系统中内存大小的自动识别方法
CN103116536A (zh) * 2013-02-25 2013-05-22 杭州华澜微科技有限公司 存储装置的容量检测方法
CN103777907A (zh) * 2014-02-25 2014-05-07 四川长虹空调有限公司 自动获取eeprom存储容量的方法
CN107833593A (zh) * 2017-11-15 2018-03-23 中京复电(上海)电子科技有限公司 一种无源uhf rfid芯片存储容量的测试方法
CN108021482A (zh) * 2017-12-28 2018-05-11 杭州迪普科技股份有限公司 一种Boot Loader下检测内存的方法及装置
CN110109785A (zh) * 2019-04-16 2019-08-09 晶晨半导体(上海)股份有限公司 内存容量获取方法、装置、计算机设备及可读存储介质

Similar Documents

Publication Publication Date Title
US6629172B1 (en) Multi-chip addressing for the I2C bus
US7047335B2 (en) Method for receiving user defined frame information structure (FIS) types in a serial-ATA (SATA) system
US20060195639A1 (en) System and method for dynamically allocating inter integrated circuits addresses to multiple slaves
US7900078B1 (en) Asynchronous conversion circuitry apparatus, systems, and methods
US9576627B2 (en) Semiconductor device, semiconductor system, and method for use in operating the same based on operation mode information
US10347347B1 (en) Link training mechanism by controlling delay in data path
CN105700732A (zh) 用于传输触摸传感器信息的装置、系统和方法
GB2542970A (en) Digital accessory interface calibration
US6617918B2 (en) Multi-level receiver circuit with digital output using a variable offset comparator
US9197394B2 (en) Clock for serial communication device
US20180254782A1 (en) Efficient silent code assignment to a set of logical codes
KR102457095B1 (ko) 딜레이 가변 소자를 포함하는 메모리 모듈 및 그것의 딜레이 설정 방법
KR100805836B1 (ko) 버스 폭 설정 장치, 디스플레이 장치 그리고 버스 폭 설정방법
CN107943727B (zh) 一种高效dma控制器
CN111273852A (zh) 存储器区块大小判定方法
US11106618B2 (en) Method for addressing an integrated circuit on a bus and corresponding device
US20180301196A1 (en) Method for Addressing a Non-Volatile Memory on I2C Bus and Corresponding Memory Device
US9747205B2 (en) Method for processing data and electronic device
US20160055272A1 (en) Method and compiling system for generating testbench for ic
TWI684915B (zh) 記憶體區塊大小判定方法
GB2538246A (en) Digital accessory interface calibration
KR20050116781A (ko) 아날로그 신호 처리 회로, 및 그 데이터 레지스터 재기록방법과 그 데이터 통신 방법
US20050249235A1 (en) Method of accessing a mac address for a nic device
WO2023231090A1 (zh) 一种终结阻抗参数的产生方法和测试系统
CN116775526B (zh) 一种扩展装置及电子设备

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