WO2012057813A1 - Method for non-volatile memory reallocation for information storage - Google Patents
Method for non-volatile memory reallocation for information storage Download PDFInfo
- Publication number
- WO2012057813A1 WO2012057813A1 PCT/US2011/000282 US2011000282W WO2012057813A1 WO 2012057813 A1 WO2012057813 A1 WO 2012057813A1 US 2011000282 W US2011000282 W US 2011000282W WO 2012057813 A1 WO2012057813 A1 WO 2012057813A1
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- received information
- application code
- primary
- memory
- code image
- Prior art date
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/60—Software deployment
- G06F8/65—Updates
Definitions
- This invention relates to a technique for reallocating non- volatile memory within an electronic device, and more particularly, a receiver, such as, but not limited to, a set-top box.
- Various content-receiving electronic devices such as, but not limited to, television sets and set-top boxes, often contain a flash chip or non-volatile storage mechanism that stores a combination of code and data used by the receiver for its normal operation.
- the code portion typically includes a boot loader and one or more application code images which provide control instructions and the like.
- the data portion contains parameters and other configuration information used by the receiver.
- the term "active image” refers to the currently running application code image. From time to time, a content service provider can replace the non-active application code images by various, well-known mechanisms (Open Cable Common Download, USB memory stick, etc.).
- the application code images have a maximum size based on the non-volatile memory allocation determined during receiver design.
- the boot loader contains fixed pointers to the application code images.
- the boot loader chooses the application code image to load based on one or more boot loader configuration parameters.
- the boot loader has minimal functionality. In this regard, the boot loader simply serves to load the current active application in a memory. The functionality for replacing a non-active code image resides in the current active code image.
- receiver manufacturers In response to customer demand, receiver manufacturers often add features to the receiver that would require the application code images to exceed the available allocation space in memory. Replacing the boot loader to point to different application code image locations in the non-volatile storage mechanism often does not prove practical or even desirable. Further, erasing all the code images during application code image replacement should never occur. If a power failure occurs during erasure of all of the code images (or the boot loader), the receiver could become non-functional.
- a method for storing received information in a memory commences by separating the incoming information into the first and second portions. Reallocation of the memory then occurs to establish a second information portion storage location for storing the second portion of the incoming information, whereas the first portion of the incoming information undergoes storage in the designated storage location in memory.
- FIGURE 1 depicts a block schematic diagram of a content receiving device for practicing the information storage technique of the present principles.
- FIGURE 2 depicts a block diagram of a non-volatile storage element within the content receiving device prior to re- allocation
- FIGURE 3 depicts a block diagram of the non- volatile storage element of FIG. 2 following reallocation in accordance with the present principles.
- FIGURE 1 depicts a block schematic diagram of a set-top box 10 which constitutes but one example of a content receiving device capable of practicing the memory allocation technique of the present principles.
- the set-top 10 includes an input signal receiver 12 for tuning a particular channel of a multi-channel content stream 14 provided by a content provider, such as cable television, satellite television, or telecommunication service provider (not shown).
- An input signal processor 16 under the control of a controller 18, processes the channel stream tuned by the input signal receiver 12. The processing performed by the input signal processor 16 will depend on the nature of the tuned channel stream. For example, the input signal processor 16 would need to perform decoding if the input stream tuned by the input signal stream receiver 12 were encoded.
- the input stream processor 16 splits the processed channel stream signal into an audio portion for receipt by an audio processor 20, and a video portion for receipt by a video processor 22, respectively.
- both the audio processor 20 and the video processor 22 operate under the control of the controller 18.
- An audio interface 24 receives and reproduces the audio portion of the processed channel stream produced by the audio processor 20.
- a video audio interface 26 receives and reproduces the video portion of the processed channel stream produced by the video processor 22.
- a non- volatile memory device 28 such as a flash memory, has links to the audio and video processors 20 and 22, respectively, as well as the controller 18 for supplying information thereto, and for storing information therefrom.
- the controller 18 also enjoys a link to a control memory 30 which can store program instructions for the controller.
- a user can enter commands to, and receive status information from the controller 18 via a user interface 32.
- FIGURE 2 depicts a typical allocation of the non- volatile memory 28 of FIG. 1.
- a first storage location 200 in the memory 28 stores a boot loader which functions to point to particular data structures stored elsewhere in the memory 28.
- the boot loader can point to one of a first and a second application code images stored in storage locations 202 and 204, respectively, sometimes referred to as "Bank 1" and "Bank 2" respectively.
- the operation of the boot loader stored in storage location 200 depends on the boat loader parameters stored in storage location 206 of the non-volatile memory 28.
- the non- volatile memory 28 of FIG. 1 can contain additional storage locations, as exemplified by the storage locations 212 and 214.
- the controller 18 can change the storage locations 200-210 as well as storage location 212, without intervention by the user or the service provider. , For some set-top boxes or for at least some of the data stored therein, the storage location 214 requires user or service provider intervention to change.
- the allocation of the memory 28 depicted in FIG. 2 does not offer any indication of which application code image is currently active. In some instances a multi-stage process will become necessary to obtain the final desired allocation of the memory 28. If service provider makes use of the Open Cable Common Download as the code upgrade path, the service provider will need to allocate bandwidth within the service delivery network for all of the stages of set-top box upgrades, as long as the set-top box model remain supported. Often, a service provider will store a quantity of set-top boxes in a warehouse for an extended period of time. Further, in some instances, a set-top box could remain powered off for an extended period in a subscriber's home.
- a first possible solution to allocate memory when the current application code image becomes to large would be to always store the current application code image in the same location in the non-volatile memory 28 of FIG. 2, for example storage area 204 ("Bank 2").
- storage area 204 always holds the currently active application code image.
- the contents of storage area 204 (Bank 2) will get replaced.
- the storage space within the non-volatile memory 28 of FIGS. 1 and 2 typically gets compacted toward high memory.
- the storage area 202 of FIG. 1 serves to hold a backup application code image that requires limited intelligence.
- the backup application code image need only possess enough intelligence to load an application code image into storage area 204 (Bank 2) should the application code image stored therein become corrupted.
- FIG. 3 depicts allocation of the non-volatile memory 28, in accordance with the present principles, which overcomes the disadvantages of the aforementioned possible allocation techniques. As discussed in greater detail hereinafter, the allocation of the memory 28 depicted in FIG. 3 affords compacted data storage, taking into consideration the following constraints:
- the original structure of the storage area contains configuration details that cannot undergo movement in the non-volatile memory 214 without either the home user or the service provider having to reconfigure the receiver for normal operation.
- the original structure of the storage area contains data in the non-volatile memory 212 that does not require intervention by either the subscriber or service provider before being recreated or reacquired.
- the allocation of memory 8 in accordance, which is depicted in FIG. 3, contains many similarities with the allocation technique of FIG. 2. To that end like reference numbers appear in FIG. 3 to refer to the same areas within the memory 28 of FIG. 2. In other words, the areas 200-210 in memory 28 of FIG. 3 store the same items (e.g., the boot loader, boot loader parameters, application code images and tags) as the areas 200-210 in FIG. 2.
- the boot loader boot loader parameters, application code images and tags
- the allocation of memory 28 depicted in FIG. 3 differs from the allocation of memory 28 of FIG. 2 in the following manner.
- the storage area 212 of FIG. 2 gets reallocated in FIG. 3 into sub-areas 216, 218 and 220.
- the sub-areas 216 and 218 bear the legends "Code Bank lb" and "Code Bank 2b" and each stores a portion of first and second application code images, respectively, as hereinafter described.
- the memory allocation of FIG. 3 makes use of the storage location 212 to store parts of application code images.
- the allocation of memory 28 depicted in FIG. 3 maintains the storage area 214 as before.
- an examination of the size of the application code image occurs to determine the capability of areas 202 and 204 to store that application code image. If the size of the received application code image permits storage in one of the storage areas 202 and 204 of FIG. 3, then storage occurs with no need for any further processing. However, if the received application code image exceeds the size of one of the storage areas 202 and 204 of FIG. 3, then the received application code image undergoes division into first and second portions, hereinafter referred to as primary and secondary parts, respectively.
- the division of the received application code image occurs in such a manner so that the primary part of the application code image can fit into the original application code image space (i.e., one of areas 202 and 204 of FIG. 3).
- the secondary part of the application code image gets stored into one of the two vacated data sections (areas 216 and 218 of FIG. 3) reallocated for this purpose.
- Loading of the primary part of the application code image into one of the areas 202 and 204 of FIG. 3 typically occurs through the legacy techniques.
- the primary part of the application code image has the capability of operating normally but with reduced functionality until execution of the secondary part loaded into one of the reallocated storage areas.
- the primary part of the application code image will contain a new feature to load the secondary part of the application code image in the reallocated storage area (e.g., one of storage areas 216 and 218).
- the application code images stored in the non- volatile memory 28 of FIGS. 2 and 3 have associated tags that identify the manufacturer and model of set-top box for which the application code image will operate.
- the secondary part of each application code image has a tag for this purpose.
- the re-allocated areas 216 and 218 include sub-areas 220 and 222, respectively, for storing the tags associated with the secondary application code image parts stored in the reallocated areas.
- a set-top box running an older application code image will only load the primary part of a newly received application code image. The newly loaded application code image will understand the new tags and load the secondary part in to the reallocated storage.
- the service provider In connection with the above-described allocation of memory 28 of FIG. 3, the service provider must make both the primary and secondary parts of the code image available to the set-top box 10. If the service provider decides to downgrade to an older code image that does not recognize the new reallocation of memory 28, the service provider will load an old code image into the non-activate application bank (e.g., one of storage areas 202 and 204 of FIG. 3) and then make the old application code image active. Upon loading, the old code image will detect that reallocation of the memory 28 has occurred and the memory as reallocated does not contain the data that the old application code image expects. Under such circumstances, the old application code image will initiate reloading of that data without user or service provider intervention.
- one of the newly vacated storage areas 216 and 218 get allocated to the secondary part of a newly received application code images.
- the primary part of each received application code images get allocated to one of the storage areas 202 and 204, respectively.
- the application code image whose primary part resides in storage area 202 (Bank 1), makes use of the reallocated storage area 216 (Banklb) for its secondary part.
- the application code image whose primary part resides in storage area 204 (Bank 2), makes use of the reallocated storage area 218 (Bank 2b) for its secondary part. If the two parts of a received application code image are inseparably linked together, the service provider must now change both the primary and secondary parts at the same time. If the primary and secondary parts of a received application code image are not inseparably linked, then the primary and secondary parts can undergo upgrading independently.
- problems can arise after loading a newly received application code image with new features. When such problems arise, a need then exists to revert to an older version of the application code image.
- the reallocation of memory 28 of FIG. 3 in accordance with the present principles does not prevent older versions of the application code from operating normally if reloaded into the set-top box 10.
- the memory allocation of the present principles allows for code upgrades to new application code images that make use the memory allocation. Further, the memory allocation of the present principles does not prevent code "downgrades" where an older application code image that does not understand the new allocation structure may still get loaded and function normally.
- a primary application code image part could make use of either of the application code image secondary parts.
- the application code image whose primary part resides in Bank 1 can make use of the secondary application code image parts stored in either Bank lb (storage area 216) or Bank 2b (storage area 218).
- the foregoing describes a technique for allocating a memory in a receiving device, such as, but not limited to, a set-top box.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Software Systems (AREA)
- Computer Security & Cryptography (AREA)
- Stored Programmes (AREA)
- Two-Way Televisions, Distribution Of Moving Picture Or The Like (AREA)
- Information Transfer Between Computers (AREA)
Abstract
Description
Claims
Priority Applications (5)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR1020137010898A KR20130142119A (en) | 2010-10-28 | 2011-02-16 | Method for non-volatile memory reallocation for information storage |
EP11711401.7A EP2633401A1 (en) | 2010-10-28 | 2011-02-16 | Method for non-volatile memory reallocation for information storage |
JP2013536592A JP2013546250A (en) | 2010-10-28 | 2011-02-16 | Method for non-volatile memory redistribution for information storage |
US13/877,840 US20130191608A1 (en) | 2010-10-28 | 2011-02-16 | Method for non-volatile memory reallocation for information storage |
CN2011800515604A CN103180828A (en) | 2010-10-28 | 2011-02-16 | Method for non-volatile memory reallocation for information storage |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US40765910P | 2010-10-28 | 2010-10-28 | |
US61/407,659 | 2010-10-28 |
Publications (1)
Publication Number | Publication Date |
---|---|
WO2012057813A1 true WO2012057813A1 (en) | 2012-05-03 |
Family
ID=44144868
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/US2011/000282 WO2012057813A1 (en) | 2010-10-28 | 2011-02-16 | Method for non-volatile memory reallocation for information storage |
Country Status (6)
Country | Link |
---|---|
US (1) | US20130191608A1 (en) |
EP (1) | EP2633401A1 (en) |
JP (1) | JP2013546250A (en) |
KR (1) | KR20130142119A (en) |
CN (1) | CN103180828A (en) |
WO (1) | WO2012057813A1 (en) |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6360364B1 (en) * | 1999-03-17 | 2002-03-19 | Microsoft Corporation | System and method for installing an application on a portable computer |
US20030051114A1 (en) * | 2001-09-07 | 2003-03-13 | Natu Mahesh S. | Executing large device firmware programs |
US20060136548A1 (en) * | 2002-09-10 | 2006-06-22 | Hideaki Nishio | Method for managing use of storage region by application |
US20060149894A1 (en) * | 2005-01-04 | 2006-07-06 | Samsung Electronics Co., Ltd. | Method of downloading main code to flash memory |
US20070089108A1 (en) * | 2000-11-17 | 2007-04-19 | Shao-Chun Chen | Initialization and update of software and/or firmware in electronic devices |
WO2009004266A1 (en) * | 2007-06-29 | 2009-01-08 | France Telecom | Storage method |
Family Cites Families (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP4084461B2 (en) * | 1997-06-05 | 2008-04-30 | 松下電器産業株式会社 | Terminal device capable of remote download, download method applied to a loader program provided in the terminal device, and recording medium recording the loader program |
JP2000293366A (en) * | 1999-04-06 | 2000-10-20 | Mitsubishi Electric Corp | Method for updating module for set top box |
ATE433149T1 (en) * | 2002-06-28 | 2009-06-15 | Koninkl Philips Electronics Nv | SOFTWARE DOWNLOAD TO A RECEIVER |
ATE543135T1 (en) * | 2003-04-11 | 2012-02-15 | Hewlett Packard Development Co | INITIALIZING AND UPDATING SOFTWARE AND/OR FIRMWARE IN ELECTRONIC DEVICES |
DE602004026822D1 (en) * | 2004-02-27 | 2010-06-10 | Ericsson Telefon Ab L M | Programming a flash memory |
JP2007328856A (en) * | 2006-06-07 | 2007-12-20 | Toshiba Corp | Magnetic disk drive and data recording method |
-
2011
- 2011-02-16 US US13/877,840 patent/US20130191608A1/en not_active Abandoned
- 2011-02-16 EP EP11711401.7A patent/EP2633401A1/en not_active Withdrawn
- 2011-02-16 KR KR1020137010898A patent/KR20130142119A/en not_active Application Discontinuation
- 2011-02-16 JP JP2013536592A patent/JP2013546250A/en active Pending
- 2011-02-16 CN CN2011800515604A patent/CN103180828A/en active Pending
- 2011-02-16 WO PCT/US2011/000282 patent/WO2012057813A1/en active Application Filing
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6360364B1 (en) * | 1999-03-17 | 2002-03-19 | Microsoft Corporation | System and method for installing an application on a portable computer |
US20070089108A1 (en) * | 2000-11-17 | 2007-04-19 | Shao-Chun Chen | Initialization and update of software and/or firmware in electronic devices |
US20030051114A1 (en) * | 2001-09-07 | 2003-03-13 | Natu Mahesh S. | Executing large device firmware programs |
US20060136548A1 (en) * | 2002-09-10 | 2006-06-22 | Hideaki Nishio | Method for managing use of storage region by application |
US20060149894A1 (en) * | 2005-01-04 | 2006-07-06 | Samsung Electronics Co., Ltd. | Method of downloading main code to flash memory |
WO2009004266A1 (en) * | 2007-06-29 | 2009-01-08 | France Telecom | Storage method |
Also Published As
Publication number | Publication date |
---|---|
EP2633401A1 (en) | 2013-09-04 |
CN103180828A (en) | 2013-06-26 |
KR20130142119A (en) | 2013-12-27 |
US20130191608A1 (en) | 2013-07-25 |
JP2013546250A (en) | 2013-12-26 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP1077407A1 (en) | Method of upgrading a program using associated configuration data | |
US7739490B2 (en) | Control apparatus, upgrade method and program product of the same | |
US20100235617A1 (en) | System recovery method and embedded system with automatic recovery function | |
US20110283274A1 (en) | Firmware image update and management | |
US20170308369A1 (en) | Data processing method and device of preset application after upgrading | |
US7793283B2 (en) | Communication terminal software updating method, communication terminal, and software updating method | |
US6269442B1 (en) | Apparatus and method for on-line replacement of a running program code and data using checkpoints | |
US7219261B2 (en) | Information processing apparatus and method | |
CN102023881B (en) | Method and device for upgrading software as well as embedded device | |
US8839227B2 (en) | Preventing overwrite of nonessential code during essential code update | |
US8924953B2 (en) | Information processing apparatus, and information processing method and program | |
EP3518097A2 (en) | Firmware updating method and electronic device using the same | |
KR20030032257A (en) | Method for upgrading program and apparatus therefor | |
CN1277214C (en) | Embedded system upgrading method | |
JP2004511833A (en) | System and method for a communication terminal that maintains memory for multiple applications and maintains the current application version | |
US11934680B2 (en) | Systems and methods for booting from NAND flash using squashfs to maximize memory | |
CN104915226A (en) | Network device software starting method, device and network device | |
US20020092011A1 (en) | Methods and arrangements for managing devices | |
EP2329368B1 (en) | Updating content without using a mini operating system | |
US20030093653A1 (en) | Method and apparatus for efficiently running an execution image using volatile and non-volatile memory | |
CN101872306A (en) | Embedded system for realizing software updating and software backup and implementation method thereof | |
US20020091720A1 (en) | Methods and arrangements for providing improved software version control in managed devices | |
CN109710297B (en) | Method for upgrading and backing equipment wholly or in modules | |
US20150089486A1 (en) | Method of Firmware Upgrade | |
US20130191608A1 (en) | Method for non-volatile memory reallocation for information storage |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
121 | Ep: the epo has been informed by wipo that ep was designated in this application |
Ref document number: 11711401 Country of ref document: EP Kind code of ref document: A1 |
|
WWE | Wipo information: entry into national phase |
Ref document number: 13877840 Country of ref document: US |
|
ENP | Entry into the national phase |
Ref document number: 2013536592 Country of ref document: JP Kind code of ref document: A |
|
ENP | Entry into the national phase |
Ref document number: 20137010898 Country of ref document: KR Kind code of ref document: A |
|
NENP | Non-entry into the national phase |
Ref country code: DE |
|
REEP | Request for entry into the european phase |
Ref document number: 2011711401 Country of ref document: EP |
|
WWE | Wipo information: entry into national phase |
Ref document number: 2011711401 Country of ref document: EP |