WO2014022431A1 - System and method for object deletion in persistent memory using bitmap windows - Google Patents

System and method for object deletion in persistent memory using bitmap windows Download PDF

Info

Publication number
WO2014022431A1
WO2014022431A1 PCT/US2013/052780 US2013052780W WO2014022431A1 WO 2014022431 A1 WO2014022431 A1 WO 2014022431A1 US 2013052780 W US2013052780 W US 2013052780W WO 2014022431 A1 WO2014022431 A1 WO 2014022431A1
Authority
WO
WIPO (PCT)
Prior art keywords
objects
windows
list
memory
window
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.)
Ceased
Application number
PCT/US2013/052780
Other languages
English (en)
French (fr)
Inventor
Saqib Ahmad
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.)
Oracle International Corp
Original Assignee
Oracle International 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 Oracle International Corp filed Critical Oracle International Corp
Priority to EP13748415.0A priority Critical patent/EP2880538B1/en
Priority to JP2015525522A priority patent/JP6163551B2/ja
Priority to KR1020157000473A priority patent/KR102065563B1/ko
Priority to CN201380030019.4A priority patent/CN104350478B/zh
Publication of WO2014022431A1 publication Critical patent/WO2014022431A1/en
Anticipated expiration legal-status Critical
Ceased legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/0223User address space allocation, e.g. contiguous or non contiguous base addressing
    • G06F12/023Free address space management
    • G06F12/0253Garbage collection, i.e. reclamation of unreferenced memory
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/0223User address space allocation, e.g. contiguous or non contiguous base addressing
    • G06F12/023Free address space management
    • G06F12/0238Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory
    • G06F12/0246Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory in block erasable memory, e.g. flash memory
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/0223User address space allocation, e.g. contiguous or non contiguous base addressing
    • G06F12/023Free address space management
    • G06F12/0253Garbage collection, i.e. reclamation of unreferenced memory
    • G06F12/0269Incremental or concurrent garbage collection, e.g. in real-time systems
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2212/00Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
    • G06F2212/17Embedded application
    • G06F2212/177Smart card
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2212/00Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
    • G06F2212/20Employing a main memory using a specific memory technology
    • G06F2212/202Non-volatile memory
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; 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]
    • GPHYSICS
    • G07CHECKING-DEVICES
    • G07FCOIN-FREED OR LIKE APPARATUS
    • G07F7/00Mechanisms actuated by objects other than coins to free or to actuate vending, hiring, coin or paper currency dispensing or refunding apparatus
    • G07F7/08Mechanisms actuated by objects other than coins to free or to actuate vending, hiring, coin or paper currency dispensing or refunding apparatus by coded identity card or credit card or other personal identification means
    • G07F7/10Mechanisms actuated by objects other than coins to free or to actuate vending, hiring, coin or paper currency dispensing or refunding apparatus by coded identity card or credit card or other personal identification means together with a coded signal, e.g. in the form of personal identification information, like personal identification number [PIN] or biometric data
    • G07F7/1008Active credit-cards provided with means to personalise their use, e.g. with PIN-introduction/comparison system

Definitions

  • Embodiments of the invention are generally related to persistent memory storage, and are particularly related to resource-constrained environments and other computing environments, and to systems and methods for deleting non-reachable objects from persistent memory, using bitmap windows representing memory chunks. Background:
  • a typical resource-constrained environment such as a smart card or similar execution environment or device, may have limited random access memory resources, and instead use persistent memory as a default location for creating and storing software objects.
  • Such environments have a need for reclaiming persistent memory which is in use by objects that have become garbage by virtue of being nonreachable from a defined set of roots.
  • Garbage collection algorithms which may be useful in other environments, such as Java SE, often rely on techniques such as moving or marking the objects directly.
  • these techniques are not as useful in a resource-constrained, smart card, or similar execution environment, since moving or marking objects in persistent memory is a time-consuming, and potentially damaging, operation given that only a limited number of data writes can be made to a persistent memory device before it wears out.
  • the system can generally be used with computing environments that use persistent memory, such as smart cards, Java Cards, and other resource-constrained environments.
  • the system comprises a processor or computational engine and a persistent memory for storage of software objects; and a data structure which can include one or more memory bitmap windows, each of which represents a chunk of addressable space in the persistent memory; wherein the system uses the one or more memory bitmap windows in deleting non-reachable objects from the persistent memory.
  • Figure 1 illustrates an example of a computing environment that uses persistent memory, such as a resource-constrained environment or smart card, in accordance with an embodiment.
  • Figure 2 illustrates the use of bitmap windows representing memory chunks, for object deletion in persistent memory, in accordance with an embodiment.
  • Figure 3 further illustrates the use of bitmap windows for object deletion in persistent memory, in accordance with an embodiment.
  • Figure 4 further illustrates the use of bitmap windows for object deletion in persistent memory, in accordance with an embodiment.
  • Figure 5 is a flowchart illustrating an algorithm or method of using bitmap windows for object deletion in persistent memory, in accordance with an embodiment.
  • Figure 6 is a flowchart further illustrating an algorithm or method of using bitmap windows for object deletion in persistent memory, in accordance with an embodiment.
  • Figure 7 is a flowchart further illustrating an algorithm or method of using bitmap windows for object deletion in persistent memory, in accordance with an embodiment. Detailed Description:
  • a typical resource-constrained environment such as a smart card or similar execution environment or device, may have limited random access memory resources, and instead use persistent memory as a default location for creating and storing software objects.
  • Such environments have a need for reclaiming persistent memory which is in use by objects that have become garbage by virtue of being nonreachable from a defined set of roots.
  • garbage collection algorithms which may be useful in other environments, but rely on techniques such as moving or marking the objects directly, are not as useful in a resource- constrained, smart card, or similar execution environment, since moving or marking objects in persistent memory is a time-consuming, and potentially damaging, operation given that only a limited number of data writes can be made to a persistent memory device before it wears out.
  • Some examples of the types of approach that can be used to address this include: use of a brute force algorithm to check each object to determine if it is referenced from any other object in the system; use of a reference counting algorithm which updates objects with a reference count such that a reference count of 0 indicates that the object is not referenced by another; or use of a RAM bitmap representing objects in memory.
  • a problem with the first two of these approaches is that they do not account for cyclical references for even simple cycles.
  • the first approach is also time-consuming since in a worst-case scenario potentially every object in the system will have to be checked for every other object in the system, to determine references from one object to another.
  • a problem with the third approach is that it relies on dereferencing objects, such that the system uses object references from an object table rather than actual address; however this slows the overall execution environment since many operations will require object addresses, and will have to go through the conversion process to get the address from a reference.
  • the system can generally be used with computing environments that use persistent memory, such as smart cards, Java Cards, and other resource-constrained environments.
  • the system comprises a processor or computational engine and a persistent memory for storage of software objects; and a data structure which can include one or more memory bitmap windows, each of which represents a chunk of addressable space in the persistent memory; wherein the system uses the one or more memory bitmap windows in deleting non-reachable objects from the persistent memory.
  • some advantages of the systems and methods described herein include that it can provide a fast version of mark-sweep garbage collection technique which addresses the cyclical referencing problem; that there is no need for dereferencing objects; that there is also no need to write to persistent memory until actual reclamation of memory; and that the approach is scaleable such that an increase in the overall target memory area does not increase resource requirements.
  • Figure 1 illustrates an example of a computing environment that uses persistent memory, such as a resource-constrained environment or smart card, in accordance with an embodiment.
  • a computing environment or device 100 such as a resource-constrained environment, smart card, or other environment, can be considered a miniature computing device, comprising a processor or computational engine 126, which can include circuitry for performing computational operations; and one or more memory, such as a random access memory (RAM) 120, electrically erasable programmable read-only memory (EEPROM) 122, and/or read-only memory (ROM) 124.
  • RAM random access memory
  • EEPROM electrically erasable programmable read-only memory
  • ROM read-only memory
  • the RAM can include a volatile random access memory
  • the EEPROM can include a writeable non-volatile memory
  • the ROM can include a read-only memory.
  • the RAM can be used to store data items and data structures, such as a system stack 121 .
  • the ROM can include a virtual machine 108, such as a Java virtual machine, which allows applications written in a platform-independent programming language, such as Java , to be executed by the smart card; and can also contain one or more applications 104, 105, which provide services for clients accessing the smart card.
  • applications 106 can also be located in EEPROM, or in both ROM and/or EEPROM.
  • the system can include a card manager 102, or a similar logic, which includes code for managing the execution of applications on the computing environment or device (including, for example, enabling communications between clients and applications); and deleting objects from memory.
  • the EEPROM can contain a plurality of objects 1 12, 1 13, 1 14, which are accessed by applications 104, 105 (more specifically, application 104 accesses object 1 12, application 105 accesses objects 1 13 and 1 14, and application 106 accesses object 1 14); while other objects 1 15, 1 16, that have become unlinked, are no longer referenced by any application. It is generally desirable to delete these unreferenced objects to free up memory space.
  • FIG. 1 The environment illustrated in Figure 1 is provided by way of illustration of one type of environment that can utilize the systems and methods described herein.
  • the invention is not limited to resource-constrained environments or smart cards, or to the particular environment or configuration described above, and can generally be used with other types of computing environment, device, or system that can store object in a writeable persistent or non-volatile memory.
  • a system and method for use of bitmap windows which represent a chunk of memory.
  • the technique uses an algorithm or method which can work with very limited resources, while mapping a large amount of addressable space.
  • the technique is also scaleable such that, for increased persistent memory size, even if the overall RAM size remains relatively unchanged, the algorithm or method will still work. Additionally, the algorithm or method does not reduce overall system performance as might be the case with brute- force, reference counting, and dereferencing techniques.
  • Figure 2 illustrates the use of bitmap windows representing memory chunks, for object deletion in persistent memory, in accordance with an embodiment.
  • the system can include a data structure 142, which can include one or more memory bitmap windows 144 (156, 158,160), which represent a chunk of addressable space 146, 148, 150 in persistent memory 140, for storage of objects.
  • a data structure 142 can include one or more memory bitmap windows 144 (156, 158,160), which represent a chunk of addressable space 146, 148, 150 in persistent memory 140, for storage of objects.
  • the data structure can further include a potential garbage list 162, which lists objects which are not referenced in windows that have already been processed; a dynamic roots list 164, which lists objects referenced from a previous window but not in the addressable space in the previous window, which become roots for a next window; a maximum recursion depth 166, which is a configurable value that limits the recursion depth for marking phase; and a deferred object list 168, which once the configured recursion depth is reached, includes the children objects which have not been processed yet.
  • a potential garbage list 162 which lists objects which are not referenced in windows that have already been processed
  • a dynamic roots list 164 which lists objects referenced from a previous window but not in the addressable space in the previous window, which become roots for a next window
  • a maximum recursion depth 166 which is a configurable value that limits the recursion depth for marking phase
  • a deferred object list 168 which once the configured recursion depth is reached, includes the children objects which have
  • Figure 3 and Figure 4 further illustrate the use of bitmap windows for object deletion in persistent memory, in accordance with an embodiment.
  • bitmap windows for object deletion in order to avoid unnecessary writes to
  • the system can maintain a bitmap in RAM.
  • RAM is a scarce resource; a typical amount might be 2k, which provides little space for bitmap storage.
  • a 512 byte bitmap contains 4k bits, and each bit can represent 4 bytes, so a bitmap of this size can be used to represent 16k of memory.
  • the system can perform a marking process, which "marks" all objects that are reachable in memory. This can be accomplished by following chains of references from "roots”, such as from applet tables and static variables, to find reachable objects. For example, an applet object can point to another object, which points to yet other objects, each of which also point to other objects. Similarly, static variables can point to objects, which point to yet other objects.
  • a marking phase starting from a window's root objects, its object children are marked. If a child object resides outside a window, and in a next window, then that object can be put into the dynamic roots list as a root for the next window. If a child object is within this window, then it can be marked, and the system can recurse on the children of that object. If a child object is in a previous window, then the system checks the potential garbage list and recurses on that object, and then removes it from the potential garbage list since it is addressable from this window. After the marking phase for a window, the system looks for objects that were not marked, and puts those in a potential garbage list. These objects may not actually be considered garbage yet, since they may be addressable from a next window. The system then processes the next windows. Ultimately, after completing the windows, the potential garbage list will contain those objects which are not referenced and can be considered garbage.
  • the memory space is divided into windows.
  • a bitmap is initialized for the windows, wherein a bit represents an address in memory. For example, if memory management is performed at 4-byte alignment, then a bit can represent the first byte in the 4-byte memory cell.
  • the bitmap windows are processed.
  • the root objects are marked, including marking applet objects 170 within the current window as indicated by an applet table 169; marking objects 174 that are referenced from static fields 176 which are in the window; and marking objects 178 from the dynamic roots table which are in the window.
  • children objects are then marked, including if a child object 171 , 172 is found within the current window, marking that object by marking 184 the corresponding bit in the bitmap. If a child object 180 is found outside the current window in the potential garbage list, then the object and its children are marked recursively in the current window and the potential garbage list. If a child object is found outside the current window and is not in the potential garbage list then, if the object is in an already processed area of the memory, it has already been marked as reachable, and therefore it can be ignored. If, instead, the child object is in an area of memory that still needs to be processed, then it is put in the dynamic roots list.
  • the process continues with the next window and with its root and child objects 185, 186, 187, 188.
  • the potential garbage list will only contain objects 189 which are not referenced, and are therefore garbage. In accordance with an embodiment, these objects can be deleted to reclaim the memory used.
  • Figure 5 is a flowchart illustrating an algorithm or method 190 of using bitmap windows for object deletion in persistent memory, in accordance with an embodiment.
  • step 192 the memory space is divided into windows.
  • a bitmap is initialized for the windows, wherein a bit represents an address in memory.
  • bitmap windows are processed.
  • root objects are marked, including marking applet objects within the current window, marking objects that are referenced from static fields which are in the window, and marking objects from the dynamic roots table which are in the window.
  • children objects are marked, subject to criteria as described in further detail below, and the bitmaps updated. Any unreferenced objects in the current window are put on the potential garbage list.
  • the potential garbage list will only contain objects which are not referenced, and are therefore garbage. In accordance with an embodiment, these objects can be deleted to reclaim the memory used.
  • Figure 6 is a flowchart further illustrating an algorithm or method 210 of using bitmap windows for object deletion in persistent memory, in accordance with an embodiment.
  • Figure 6 further illustrates how the marking of root and children objects can be performed, in accordance with an embodiment.
  • the root objects are marked, including marking applet objects within the current window, marking objects that are referenced from static fields which are in the window, and marking objects from the dynamic roots table which are in the window.
  • the children objects are marked, including if a child object is found within the current window, marking that object by marking the corresponding bit in the bitmap. If a child object is found outside the current window in the potential garbage list, then the object and its children are marked recursively in the current window and the potential garbage list. If a child object is found outside the current window and is not in the potential garbage list then, if the object is in an already processed area of the memory, it has already been marked as reachable, and therefore it can be ignored. If, instead, the child object is in an area of memory that still needs to be processed, then it is put in the dynamic roots list.
  • step 216 while marking child objects, if a maximum recursion depth is reached, then the next object in the hierarchy is put on the deferred object list, and will be processed at the end of processing the current hierarchy.
  • step 220 if the deferred object list is full, and the maximum recursion depth has been reached, then the marking process is started again in the current window, without resetting the bitmap, therefore increasing the number of roots in the second and subsequent cycles.
  • any unreferenced objects within the window are put on the potential garbage list.
  • the potential garbage list will only contain objects which are not referenced, and are therefore garbage. In accordance with an embodiment, these objects can be deleted to reclaim the memory used.
  • Figure 7 is a flowchart further illustrating an algorithm or method 230 of using bitmap windows for object deletion in persistent memory, in accordance with an embodiment.
  • Figure 7 illustrates the combination of each of the steps previously described at Figures 5 and 6, in accordance with an embodiment.
  • the invention relates to a system for object deletion in persistent memory using bitmap windows representing memory chunks, operating on one or more microprocessors, comprising:
  • a computing environment or device such as a resource- constrained environment, smart card, or other environment, including a processor or computational engine and a persistent memory for storage of software objects, a data structure which can include one or more memory bitmap windows, each of which represents a chunk of addressable space in the persistent memory;
  • Said system further comprising means for providing within the data structure one or more of:
  • Said system further comprising:
  • the potential garbage list includes objects which are not referenced in windows that have already been processed
  • the dynamic roots list includes objects referenced from a previous window but not in the addressable space in the previous window, which become roots a next window;
  • the maximum recursion depth is a configurable value that limits the recursion depth for a marking phase
  • the deferred object list once the configured recursion depth is reached, includes children objects which have not been processed yet.
  • Said system further comprising:
  • the present invention may be conveniently implemented using one or more conventional general purpose or specialized digital computer, computing device, machine, or microprocessor, including one or more processors, memory and/or computer readable storage media programmed according to the teachings of the present disclosure.
  • Appropriate software coding can readily be prepared by skilled programmers based on the teachings of the present disclosure, as will be apparent to those skilled in the software art.
  • the present invention includes a computer program product which is a non-transitory storage medium or computer readable medium (media) having instructions stored thereon/in which can be used to program a computer to perform any of the processes of the present invention.
  • the storage medium can include, but is not limited to, any type of disk including floppy disks, optical discs, DVD, CD-ROMs, microdrive, and magneto-optical disks, ROMs, RAMs, EPROMs, EEPROMs, DRAMs, VRAMs, flash memory devices, magnetic or optical cards, nanosystems (including molecular memory ICs), or any type of media or device suitable for storing instructions and/or data.

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
  • Memory System (AREA)
PCT/US2013/052780 2012-07-30 2013-07-30 System and method for object deletion in persistent memory using bitmap windows Ceased WO2014022431A1 (en)

Priority Applications (4)

Application Number Priority Date Filing Date Title
EP13748415.0A EP2880538B1 (en) 2012-07-30 2013-07-30 System and method for object deletion in persistent memory using bitmap windows
JP2015525522A JP6163551B2 (ja) 2012-07-30 2013-07-30 ビットマップウインドウを用いて永続メモリにおけるオブジェクトを削除するためのシステムおよび方法
KR1020157000473A KR102065563B1 (ko) 2012-07-30 2013-07-30 비트맵 윈도우들을 이용한 지속 메모리 내의 객체 삭제 시스템 및 방법
CN201380030019.4A CN104350478B (zh) 2012-07-30 2013-07-30 用于使用位图窗口的持久性存储器中对象删除的系统和方法

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
US201261677390P 2012-07-30 2012-07-30
US61/677,390 2012-07-30
US13/782,433 US9141539B2 (en) 2002-05-24 2013-03-01 System and method for object deletion in persistent memory using bitmap windows
US13/782,433 2013-03-01

Publications (1)

Publication Number Publication Date
WO2014022431A1 true WO2014022431A1 (en) 2014-02-06

Family

ID=49996077

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2013/052780 Ceased WO2014022431A1 (en) 2012-07-30 2013-07-30 System and method for object deletion in persistent memory using bitmap windows

Country Status (6)

Country Link
US (1) US9141539B2 (https=)
EP (1) EP2880538B1 (https=)
JP (1) JP6163551B2 (https=)
KR (1) KR102065563B1 (https=)
CN (1) CN104350478B (https=)
WO (1) WO2014022431A1 (https=)

Families Citing this family (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9268807B2 (en) * 2013-07-17 2016-02-23 Sybase, Inc. In-memory bitmap for column store operations
US9367449B2 (en) * 2013-09-11 2016-06-14 Owtware Holdings Limited, BVI Hierarchical garbage collection in an object relational database system
US10372676B2 (en) * 2015-07-30 2019-08-06 Netapp Inc. Stale data detection
US10019456B2 (en) * 2016-06-29 2018-07-10 Microsoft Technology Licensing, Llc Recovering free space in nonvolatile storage with a computer storage system supporting shared objects
FR3064773B1 (fr) * 2017-04-04 2022-07-15 Safran Identity & Security Procede de ramassage de miettes dans une memoire d'un dispositif a plusieurs profils d'utilisateur
US11294805B2 (en) * 2019-04-11 2022-04-05 EMC IP Holding Company LLC Fast and safe storage space reclamation for a data storage system
CN111061508B (zh) * 2019-12-12 2022-05-20 恒宝股份有限公司 一种Java卡及其性能优化方法
US11422932B2 (en) * 2019-12-20 2022-08-23 Microsoft Technology Licensing, Llc Integrated reference and secondary marking
US11392427B2 (en) 2020-01-06 2022-07-19 Microsoft Technology Licensing, Llc Lock-free reading of unitary value sets
US11416390B2 (en) * 2020-09-09 2022-08-16 International Business Machines Corporation Tri-color bitmap array for garbage collection
US11687449B2 (en) * 2020-09-10 2023-06-27 International Business Machines Corporation Concurrent marking garbage collection
CN112947856B (zh) * 2021-02-05 2024-05-03 彩讯科技股份有限公司 一种内存数据的管理方法、装置、计算机设备及存储介质
US11809839B2 (en) 2022-01-18 2023-11-07 Robert Lyden Computer language and code for application development and electronic and optical communication

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6453403B1 (en) * 2000-05-19 2002-09-17 Sun Microsystems, Inc. System and method for memory management using contiguous fixed-size blocks
US20030221047A1 (en) * 2002-05-24 2003-11-27 Ahmed Saqib J. Method and apparatus for deleting objects from memory within a smart card
US20070174369A1 (en) * 2006-01-12 2007-07-26 Sun Microsystems, Inc. Method and apparatus for limiting the size and facilitating maintenance of remembered sets in a space incremental garbage collector
US20090248766A1 (en) * 2005-03-28 2009-10-01 Sun Microsystems, Inc. Method and apparatus for improving parallel marking garbage collectors that use external bitmaps

Family Cites Families (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5933847A (en) * 1995-09-28 1999-08-03 Canon Kabushiki Kaisha Selecting erase method based on type of power supply for flash EEPROM
US6480935B1 (en) * 1999-01-15 2002-11-12 Todd Carper Smart card memory management system and method
KR100528973B1 (ko) * 2003-11-05 2005-11-16 한국전자통신연구원 가비지 콜렉션 방법 및 그 장치
US7849110B2 (en) * 2006-12-30 2010-12-07 Sap Ag Database garbage collector
US7987215B2 (en) * 2008-04-22 2011-07-26 Microsoft Corporation Efficiently marking objects with large reference sets
US7937419B2 (en) * 2008-06-26 2011-05-03 Tatu Ylonen Oy Garbage collection via multiobjects
US8312219B2 (en) * 2009-03-02 2012-11-13 International Business Machines Corporation Hybrid caching techniques and garbage collection using hybrid caching techniques
JP2012128900A (ja) * 2010-12-14 2012-07-05 Samsung Yokohama Research Institute Co Ltd 半導体記憶装置、及び記憶媒体

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6453403B1 (en) * 2000-05-19 2002-09-17 Sun Microsystems, Inc. System and method for memory management using contiguous fixed-size blocks
US20030221047A1 (en) * 2002-05-24 2003-11-27 Ahmed Saqib J. Method and apparatus for deleting objects from memory within a smart card
US20090248766A1 (en) * 2005-03-28 2009-10-01 Sun Microsystems, Inc. Method and apparatus for improving parallel marking garbage collectors that use external bitmaps
US20070174369A1 (en) * 2006-01-12 2007-07-26 Sun Microsystems, Inc. Method and apparatus for limiting the size and facilitating maintenance of remembered sets in a space incremental garbage collector

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
CHANG J M ET AL: "Active memory processor: a hardware garbage collector for real-time java embedded devices", IEEE TRANSACTIONS ON MOBILE COMPUTING, IEEE SERVICE CENTER, LOS ALAMITOS, CA, US, vol. 2, no. 2, 1 April 2003 (2003-04-01), pages 89 - 101, XP011099365, ISSN: 1536-1233, DOI: 10.1109/TMC.2003.1217230 *

Also Published As

Publication number Publication date
US20140032841A1 (en) 2014-01-30
JP6163551B2 (ja) 2017-07-12
KR102065563B1 (ko) 2020-02-11
JP2015524593A (ja) 2015-08-24
CN104350478A (zh) 2015-02-11
CN104350478B (zh) 2017-06-16
US9141539B2 (en) 2015-09-22
EP2880538A1 (en) 2015-06-10
EP2880538B1 (en) 2022-04-20
KR20150039742A (ko) 2015-04-13

Similar Documents

Publication Publication Date Title
US9141539B2 (en) System and method for object deletion in persistent memory using bitmap windows
US11392314B2 (en) Sequentially writing metadata into a solid state disk by redirect-on-write
US9575976B2 (en) Methods and apparatuses to optimize updates in a file system based on birth time
US8694562B2 (en) Generational garbage collection for a pool-based heap
US6499095B1 (en) Machine-independent memory management system within a run-time environment
KR102440128B1 (ko) 통합된 객체 인터페이스를 위한 메모리 관리 장치, 시스템 및 그 방법
EP2281233B1 (en) Efficiently marking objects with large reference sets
EP2153317B1 (en) Managing object lifetime for native/managed peers
US8943290B2 (en) Automatic management of heterogeneous memory resources
CN107665095B (zh) 存储器空间管理的设备、方法及可读存储介质
US7882159B2 (en) Associative references in a garbage collected programming environment
WO2022126470A1 (zh) Flash数据掉电保护方法及设备
CN104079613A (zh) 用于多租户间共享应用程序对象的方法和系统
US20230367638A1 (en) Computation and Storage of Object Identity Hash Values
US20210303462A1 (en) Deep object graph traversal
EP3620912B1 (en) Deserialization method, apparatus, and computing device
US7269705B1 (en) Memory space management for object-based memory system
JP6173031B2 (ja) コンピュータにおいてオブジェクトを管理するための方法、プログラム及びシステム
US6408305B1 (en) Access frontier for demand loading pages in object-oriented databases
US9753850B1 (en) On-heap huge slab allocator
US12505037B2 (en) Garbage collection method and apparatus
US20250217285A1 (en) Concurrent Lazy Reference Counting In An Old Garbage Collection Generation
WO2000048056A2 (en) Address calculation of invariant references within a run-time environment

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: 13748415

Country of ref document: EP

Kind code of ref document: A1

ENP Entry into the national phase

Ref document number: 20157000473

Country of ref document: KR

Kind code of ref document: A

ENP Entry into the national phase

Ref document number: 2015525522

Country of ref document: JP

Kind code of ref document: A

WWE Wipo information: entry into national phase

Ref document number: 2013748415

Country of ref document: EP

NENP Non-entry into the national phase

Ref country code: DE