Concurrent virtual storage management

US10372352B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-10372352-B2
Application numberUS-201715440556-A
CountryUS
Kind codeB2
Filing dateFeb 23, 2017
Priority dateSep 30, 2015
Publication dateAug 6, 2019
Grant dateAug 6, 2019

How to read this patent

A practical reading order for non-experts. Skip the full description unless you need deep technical detail.

  1. Title

    What the patent document calls the invention.

  2. Abstract

    A short plain-language summary of the technical disclosure.

  3. Assignees and inventors

    Who owns or filed the patent and who is credited as inventor.

  4. Key dates

    Filing, priority, publication, and grant dates set the timeline.

  5. First independent claim

    The legal scope of protection — read this for what is actually claimed.

  6. CPC / IPC classifications

    Technology tags used to group this patent with similar filings.

  7. Citations and related patents

    Prior art links and similar publications in this corpus.

Abstract

Official abstract text for this publication.

A memory system is configured for access by a plurality of computer processing units. An address lock bit is configured in a translation table of the memory system. The address lock supports both address lock shared and address lock exclusive functions. A storage manager of an operating system configured to obtain exclusive access to an entry in a DAT table either by obtaining an address space lock exclusive or obtaining an address space lock shared, and setting a lock bit in a DAT entry.

First claim

Opening claim text (preview).

What is claimed is: 1. A system, comprising: a memory system configured for access by a plurality of computer processing units; a lock bit configured in a dynamic address translation (DAT) table of the memory system, the lock bit supporting a first function comprising obtaining an address lock shared on a DAT structure represented in the DAT table and a second function comprising obtaining an address lock exclusive on the DAT structure, wherein the memory system is organized according to a multi-level hierarchy, and wherein a region table corresponds to a higher level in the multi-level hierarchy than a segment table and the segment table corresponds to a higher level in the multi-level hierarchy than a page table; and a storage manager of an operating system, the storage manager configured to: determine that the DAT structure is a particular segment table in the memory system, determine that the particular segment table is the lowest valid level in the DAT table mapping a virtual address based at least in part on determining that the particular segment table does not point to a page table, initiate the address lock shared on the particular segment table at least in part by serializing, via a serialization instruction issued by a storage management function, the lowest valid level in the DAT table mapping the virtual address by attempting to set the lock bit, wherein a segment table entry in the DAT table comprises the lock bit, the segment table entry corresponding to the particular segment table, determine that setting the lock bit failed, determine that the particular segment table is already locked based at least in part on determining that setting the lock bit failed, drop the address space lock shared on the particular segment table, and obtain the address space lock exclusive on the particular segment table prior to performing a corresponding task by a computer processing unit. 2. The system of claim 1 , wherein the storage manager is further configured to release the address space lock exclusive subsequent to the corresponding task being performed by the computer processing unit. 3. The system of claim 2 , wherein the corresponding task is a first task, and wherein the storage manager is further configured to: obtain the address space lock shared on the particular segment table subsequent to release of the address space lock exclusive at least in part by setting the lock bit, and release the address space lock shared to unlock the particular segment table subsequent to a second task being performed by the computer processing unit. 4. The system of claim 1 , wherein the corresponding task is a segment fault. 5. A method, comprising: configuring a lock bit in a dynamic address translation (DAT) table of a memory system to support a first function comprising obtaining an address lock shared on a DAT structure represented in the DAT table and a second function comprising obtaining an address lock exclusive on the DAT structure, wherein the memory system is configured for access by a plurality of computer processing units, and wherein the memory system is organized according to a multi-level hierarchy, and wherein a region table corresponds to a higher level in the multi-level hierarchy than a segment table and the segment table corresponds to a higher level in the multi-level hierarchy than a page table, and by a storage manager of an operating system executing on the memory system: determining that the DAT structure is a particular segment table in the memory system, determining, by the storage manager, that the particular segment table is the lowest valid level in the DAT table mapping a virtual address based at least in part on determining that the particular segment table does not point to a page table, initiating, by the storage manager the address space lock shared on the particular segment table at least in part by serializing, via a serialization instruction issued by a storage management function, the lowest valid level in the DAT table mapping the virtual address by attempting to set the lock bit, wherein a segment table entry in the DAT table comprises the lock bit, the segment table entry corresponding to the particular segment table, determining that setting the lock bit failed, determining that the particular segment table is already locked based at least in part on determining that setting the lock bit failed, dropping the address space lock shared on the particular segment table, and obtaining the address space lock exclusive on the particular segment table prior to performing a corresponding task by a computer processing unit. 6. The method of claim 5 , further comprising releasing, by the storage manager, the address space lock exclusive subsequent to the corresponding task being performed by the computer processing unit. 7. The method of claim 5 , wherein the task is a first task, the method further comprising by the storage manager: obtain the address space lock shared on the particular segment table subsequent to release of the address space lock exclusive at least in part by setting the lock bit, and releasing the address space lock shared to unlock the particular segment table subsequent to a second task being performed by the computer processing unit. 8. The method of claim 5 , wherein the corresponding task is a segment fault. 9. A computer program product comprising a computer readable storage medium having program instructions embodied therewith, the program instructions executable by a processor to cause the processor to perform: configuring a lock bit in a dynamic address translation (DAT) table of a memory system to support a first function comprising obtaining an address lock shared on a DAT structure represented in the DAT table and a second function comprising obtaining an address lock exclusive on the DAT structure, wherein the memory system is configured for access by a plurality of computer processing units, and wherein the memory system is organized according to a multi-level hierarchy, and wherein a region table corresponds to a higher level in the multi-level hierarchy than a segment table and the segment table corresponds to a higher level in the multi-level hierarchy than a page table, and by a storage manager of an operating system executing on the memory system: determining that the DAT structure is a particular segment table in the memory system, determining, by the storage manager, that the particular segment table is the lowest valid level in the DAT table mapping a virtual address based at least in part on determining that the particular segment table does not point to a page table, initiating, by the storage manager the address space lock shared on the particular segment table at least in part by serializing, via a serialization instruction issued by a storage management function, the lowest valid level in the DAT table mapping the virtual address by attempting to set the lock bit, wherein a segment table entry in the DAT table comprises the lock bit, the segment table entry corresponding to the particular segment table, determining that setting the lock bit failed, determining that the particular segment table is already locked based at least in part on determining that setting the lock bit failed, dropping the address space lock shared on the particular segment table, and obtaining the address space lock exclusive on the particular segment table prior to performing a corresponding task by a computer processing unit. 10. The computer program product of claim 9 , further comprising releasing, by the storage manager, the address space lock exclusive subsequent to the corresponding task being performed by the computer processing un

Assignees

Inventors

Classifications

  • Virtual address space management · CPC title

  • with multilevel cache hierarchies · CPC title

  • using associative or pseudo-associative address translation means, e.g. translation look-aside buffer [TLB] · CPC title

  • Security improvement · CPC title

  • Hybrid storage combining heterogeneous device types, e.g. hierarchical storage, hybrid arrays · CPC title

Patent family

Related publications grouped by family.

External sources

Frequently asked questions

Answers are generated from the same data shown on this page.

What does patent US10372352B2 cover?
A memory system is configured for access by a plurality of computer processing units. An address lock bit is configured in a translation table of the memory system. The address lock supports both address lock shared and address lock exclusive functions. A storage manager of an operating system configured to obtain exclusive access to an entry in a DAT table either by obtaining an address space …
Who is the assignee on this patent?
IBM
What technology area does this patent fall under?
Primary CPC classification G06F3/0619. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Aug 06 2019 00:00:00 GMT+0000 (Coordinated Universal Time) (B2). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 8 related publications on this page (citations in our corpus or others sharing the same primary CPC).