US20200409862A1 - Dynamically joining and splitting dynamic address translation (dat) tables based on operational context - Google Patents

Dynamically joining and splitting dynamic address translation (dat) tables based on operational context Download PDF

Info

Publication number
US20200409862A1
US20200409862A1 US16/456,075 US201916456075A US2020409862A1 US 20200409862 A1 US20200409862 A1 US 20200409862A1 US 201916456075 A US201916456075 A US 201916456075A US 2020409862 A1 US2020409862 A1 US 2020409862A1
Authority
US
United States
Prior art keywords
storage
dat
tables
changed
context
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
US16/456,075
Other versions
US10891238B1 (en
Inventor
Harris M. Morgenstern
Elpida Tzortzatos
Scott B. Compton
Steven M. Partlow
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.)
International Business Machines Corp
Original Assignee
International Business Machines 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 International Business Machines Corp filed Critical International Business Machines Corp
Priority to US16/456,075 priority Critical patent/US10891238B1/en
Assigned to INTERNATIONAL BUSINESS MACHINES CORPORATION reassignment INTERNATIONAL BUSINESS MACHINES CORPORATION ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: MORGENSTERN, HARRIS M., PARTLOW, STEVEN M., COMPTON, SCOTT B., TZORTZATOS, ELPIDA
Priority to US17/128,664 priority patent/US11321239B2/en
Publication of US20200409862A1 publication Critical patent/US20200409862A1/en
Application granted granted Critical
Publication of US10891238B1 publication Critical patent/US10891238B1/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/08Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
    • G06F12/10Address translation
    • G06F12/1009Address translation using page tables, e.g. page table structures
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/08Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/08Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
    • G06F12/10Address translation
    • G06F12/109Address translation for multiple virtual address spaces, e.g. segmentation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2212/00Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
    • G06F2212/10Providing a specific technical effect
    • G06F2212/1016Performance improvement
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2212/00Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
    • G06F2212/65Details of virtual memory and virtual address translation
    • G06F2212/657Virtual address space management

Definitions

  • the present invention relates to a highly configurable memory architecture, and more specifically, to a highly configurable memory architecture for dynamically joining and splitting dynamic address translation (DAT) tables based on operational context.
  • DAT dynamic address translation
  • a computer-implemented method includes determining, via a processor, context attributes of a storage.
  • Data address translation (DAT) tables are created, via the processor, to map virtual addresses to real addresses within the storage.
  • DAT tables are updated based at least in part on the changed context attributes of the storage.
  • FIG. 1 illustrates a dynamic address translation (DAT) structure according to one or more embodiments of the present invention
  • FIG. 2 illustrates another DAT structure according to one or more embodiments of the present invention
  • FIG. 3 illustrates a flow diagram of a process according to one or more embodiments of the present invention
  • FIG. 4 illustrates another flow diagram of a process according to one or more embodiments of the present invention
  • FIG. 5 illustrates a computer system according to one or more embodiments of the present invention.
  • FIG. 6 illustrates another DAT structure according to one or more embodiments of the present invention.
  • One or more embodiments of the present invention are used to allow dynamically joining or splitting dynamic address translation (DAT) tables within virtual memory.
  • DAT dynamic address translation
  • a computer-implemented method includes the ability to manage two sets of radix tree based dynamic address translation (DAT) tables where one is used to facilitate access of all allocated storage in an address space, while the other permits access to a subset of the storage.
  • DAT dynamic address translation
  • address space provides a linear range of storage to an application program, isolating the application from other applications that run in other address spaces.
  • Operating systems create multiple address spaces to run multiple application programs concurrently in isolation where each application has the illusion of having control over the system. The illusion of a single address space in isolation is made possible by virtual memory.
  • DAT dynamic address translation
  • the operating system may need to create a data area within the address space. Such data may require privileged access, meaning that the application program should not be able to access it. It is also possible that different parts of the application run at different levels of trust and that the part of the application that is most trusted should have access to the entire address space while the part that less trusted only have access to a subset of the address space.
  • the subset of the address space used by non-trusted programs is referred to as the “partial space” while the entire spaces is referred to as the “full space”.
  • a joined page table is simply one that is used by both the full and partial spaces. In short, the memory mapped by a joined page table is accessible by an application running in either space.
  • a split page table is one that is not shared between the full and partial spaces because there are one or more pages visible in the full space that should not be visible in the partial space.
  • FIG. 1 depicts a joined DAT structure 100 according to one or more embodiments of the present invention includes a multi-level or radix-tree memory structure.
  • a DAT table consists of five levels: three region tables, a segment table and a page table, in order of highest to lowest. The region tables are not shown in any of diagrams as they are not relevant to the invention. All of the DAT structures down to the segment table are unique for both the full and partial spaces.
  • the joined DAT structure 100 includes a full segment table (SGT) 101 and a partial SGT 103 .
  • FIG. 1 also depicts a page table (PGT) 105 and a plurality of entries R 102 within the PGT ( 107 , 108 , 109 ) that contain the real addresses of frames in the computer's main (real) memory.
  • PGT page table
  • the split DAT structure 200 shown in FIG. 2 includes a multi-level (radix-tree) structure showing a full SGT 201 and a partial SGT 202 .
  • the split DAT structure 200 also includes a PGT full table 206 , a PGT partial table 208 , and a plurality of entries R 203 which contain the addresses of frames in real memory ( 210 , 211 , 212 ) or a bit indicating the entry is invalid. Both 210 and 212 are mapped into the full and partial spaces. However, 211 is only mapped into the full space; the invalid bit is set in the mapping in the partial space.
  • the full page table 206 and partial page table 208 are peer page tables in that they both provide a mapping of the same segment of storage where the latter maps a subset of the former. Pointer to peer tables, and indications of either partial, joined or not joinable are associated with both the PGT full table 206 and the PGT partial table 208 . This information may be maintained in an associated data structure, for example, the page frame table entries of the frames that back the page tables may contain this information. The page frame table entries may also record the relationship between peer tables, where the full table points to the partial and the partial points to the full.
  • DAT tables Some of the management of DAT tables is performed when the application or the operating system invokes an API to allocate a page of memory.
  • a joined Page Table is created to map the page.
  • the joined page table would be split into a full space PGT which would provide access to the privileged storage. The partial space will lose access to the segment and all the storage it makes visible until subsequent DAT faults.
  • a PGT will be created to provide a map for the full space ONLY and the PGT will be marked as “not-joinable” since non-privileged units of work are not eligible to access all the storage that it maps.
  • a memory allocation flow is generally depicted in accordance with one or more embodiments of the present invention.
  • the process begins at block 300 , and proceeds with assigning memory to be allocated at block 301 and determining if the full data should be visible for all contexts at block 303 . If it is determined at block 303 that the full data should be visible in both the full and partial spaces, then the data is allocated at block 305 . If the buffer being allocated should not be visible in the partial space, then the process determines if a page table (PGT) is currently joined at block 307 . If the page table is not joined, then the page table is marked not joinable at block 309 and the buffer is allocated at block 305 .
  • PTT page table
  • the page table is split by invalidating the segment table entry that points to the joined page table in the partial segment table.
  • the page table is marked as not joinable (block 311 ) and the memory allocation is performed using just the split page table.
  • the partial space has lost access to the segment of memory that has been split since there is no corresponding partial page table has been created.
  • the full space segment table entry maintains access to the segment.
  • Subsequent references to storage mapped by the invalidated segment will result in a segment fault ( FIG. 4 ).
  • An alternative design for splitting a page table is to make an exact copy of the page table before the memory request proceeds and use it to validate the segment in the partial space. Taking this approach will avoid subsequent segment faults for existing allocated memory mapped by the segment for units of work running in the partial space.
  • the PGT table is marked not joinable at block 309 and current allocation continues 305 .
  • a DAT fault is a hardware interrupt that is issued when an application references storage that is not valid (mapped) in real.
  • a segment fault is a type of DAT fault where the segment table exists, but the segment entry mapping the virtual address is invalid.
  • FIG. 4 a segment fault flow diagram is generally shown in accordance with one or more embodiments of the present invention. As described in FIG. 3 , when a split of a page table is performed, the partial space loses access to the data in the segment, a subset of which it should be able to access. The following describes how this is corrected during segment fault processing.
  • the segment fault flow process starts at block 400 when a segment fault occurs block 401 . It is possible that the reference is legal, meaning that the storage was previously allocated ( FIG.
  • Segment fault processing determines if the segment faulter was using the partial space block 403 . If the DAT faulter was not using the partial space of memory block 403 , the process performs the fault processing normally on the full DAT 405 . If the segment faulter was using the partial space of the memory block 403 , then if the partial space should not have access to the storage, the faulter is abended block 411 . Otherwise, if the page table mapping the full space segment is joinable, then the partial space segment is validated with the full space page table which will be marked as joined block 419 .
  • FIG. 3 and FIG. 4 could be changed to use Region 3 rd table and Segment Tables for example, as described in zSeries Architecture (see Principles of Operation), instead of Segment Tables and Page Tables. In this case, the Segment tables would be joined or split. Region 2nd/3rd and Region 2nd/Region 1 st could also be managed in a similar manner.
  • a computer system 500 for controlling DAT tables based on the context attributes of storage is generally shown in accordance with one or more embodiments of the present invention.
  • the methods described herein can be implemented in hardware, software (e.g., firmware), or a combination thereof.
  • the methods described herein are implemented in hardware as part of the microprocessor of a special or general-purpose digital computer, such as a personal computer, workstation, minicomputer, or mainframe computer.
  • the system 500 therefore may include general-purpose computer or mainframe 501 capable of running multiple instances of an O/S simultaneously.
  • the computer 501 includes one or more processors 505 , memory 510 coupled to a memory controller 515 , and one or more input and/or output (I/O) devices 540 , 545 (or peripherals) that are communicatively coupled via a local input/output controller 535 .
  • the input/output controller 535 can be, for example but not limited to, one or more buses or other wired or wireless connections, as is known in the art.
  • the input/output controller 535 may have additional elements, which are omitted for simplicity, such as controllers, buffers (caches), drivers, repeaters, and receivers, to enable communications.
  • the local interface may include address, control, and/or data connections to enable appropriate communications among the aforementioned components.
  • the input/output controller 535 may include a plurality of sub-channels configured to access the output devices 540 and 545 .
  • the sub-channels may include fiber-optic communications ports.
  • the processor 505 is a hardware device for executing software, particularly that stored in storage 520 , such as cache storage, or memory 510 .
  • the processor 505 can be any custom made or commercially available processor, a central processing unit (CPU), an auxiliary processor among several processors associated with the computer 501 , a semiconductor based microprocessor (in the form of a microchip or chip set), a macroprocessor, or generally any device for executing instructions.
  • the memory 510 can include any one or combination of volatile memory elements (e.g., random access memory (RAM, such as DRAM, SRAM, SDRAM, etc.)) and nonvolatile memory elements (e.g., ROM, erasable programmable read only memory (EPROM), electronically erasable programmable read only memory (EEPROM), programmable read only memory (PROM), tape, compact disc read only memory (CD-ROM), disk, diskette, cartridge, cassette or the like, etc.).
  • RAM random access memory
  • EPROM erasable programmable read only memory
  • EEPROM electronically erasable programmable read only memory
  • PROM programmable read only memory
  • tape compact disc read only memory
  • CD-ROM compact disc read only memory
  • disk diskette
  • cassette or the like etc.
  • the memory 510 may incorporate electronic, magnetic, optical, and/or other types of storage media. Note that the memory 510 can have a distributed architecture, where various components are situated remote from one another, but can be accessed by the processor
  • the instructions in memory 510 may include one or more separate programs, each of which comprises an ordered listing of executable instructions for implementing logical functions.
  • the instructions in the memory 510 a suitable operating system (OS) 511 .
  • the operating system 511 essentially controls the execution of other computer programs and provides scheduling, input-output control, file and data management, memory management, and communication control and related services.
  • the memory 510 may include multiple logical partitions (LPARs) 512 , each running an instance of an operating system.
  • the LPARs 512 may be managed by a hypervisor, which may be a program stored in memory 510 and executed by the processor 505 .
  • a conventional keyboard 550 and mouse 555 can be coupled to the input/output controller 535 .
  • Other output devices such as the I/O devices 540 , 545 may include input devices, for example but not limited to a printer, a scanner, microphone, and the like.
  • the I/O devices 540 , 545 may further include devices that communicate both inputs and outputs, for instance but not limited to, a network interface card (NIC) or modulator/demodulator (for accessing other files, devices, systems, or a network), a radio frequency (RF) or other transceiver, a telephonic interface, a bridge, a router, and the like.
  • the system 500 can further include a display controller 525 coupled to a display 530 .
  • the system 500 can further include a network interface 560 for coupling to a network 565 .
  • the network 565 can be an IP-based network for communication between the computer 501 and any external server, client and the like via a broadband connection.
  • the network 565 transmits and receives data between the computer 501 and external systems.
  • network 565 can be a managed IP network administered by a service provider.
  • the network 565 may be implemented in a wireless fashion, e.g., using wireless protocols and technologies, such as WiFi, WiMax, etc.
  • the network 565 can also be a packet-switched network such as a local area network, wide area network, metropolitan area network, Internet network, or other similar type of network environment.
  • the network 565 may be a fixed wireless network, a wireless local area network (LAN), a wireless wide area network (WAN) a personal area network (PAN), a virtual private network (VPN), intranet or other suitable network system and includes equipment for receiving and transmitting signals.
  • LAN wireless local area network
  • WAN wireless wide area network
  • PAN personal area network
  • VPN virtual private network
  • the instructions in the memory 510 may further include a basic input output system (BIOS) (omitted for simplicity).
  • BIOS is a set of essential software routines that initialize and test hardware at startup, start the OS 511 , and support the transfer of data among the hardware devices.
  • the BIOS is stored in ROM so that the BIOS can be executed when the computer 501 is activated.
  • the processor 505 is configured to execute instructions stored within the memory 510 , to communicate data to and from the memory 510 , and to generally control operations of the computer 501 pursuant to the instructions.
  • the split DAT structure 600 shown in FIG. 6 includes a multi-level (radix-tree) structure showing a full SGT 601 and a partial SGT 603 .
  • the DAT structure 600 also includes a PGT full table 605 , a joined PGT table 607 and a PGT full table 609 and PGT partial table 611 .
  • Information regarding the DAT structure 600 may be maintained in an associated data structure, for example, in page frame table entries (PFTE).
  • the PFTE 615 for the PGT full table 605 has the partial (P), joined (J), and not-joinable (NJ) bits all OFF (0).
  • the joined PGT table 607 has it's PFTE 617 indicating that it is joined by having the joined (J) bit ON (1) while the partial (P) and not-joinable (NJ) bits are OFF (0). Accordingly, the PGT full table 609 and PGT partial table 611 have their PFTE 619 as follows: the PFTE 619 for the full PFTE has the not joinable (NJ) bit ON (1), with the other bits OFF (0) and the partial PFT, which has the partial (P) bit ON (1) and the other bits OFF (0).
  • the present invention may be a system, a method, and/or a computer program product.
  • the computer program product may include a computer readable storage medium (or media) having computer readable program instructions thereon for causing a processor to carry out aspects of the present invention.
  • the computer readable storage medium can be a tangible device that can retain and store instructions for use by an instruction execution device.
  • the computer readable storage medium may be, for example, but is not limited to, an electronic storage device, a magnetic storage device, an optical storage device, an electromagnetic storage device, a semiconductor storage device, or any suitable combination of the foregoing.
  • a non-exhaustive list of more specific examples of the computer readable storage medium includes the following: a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), a static random access memory (SRAM), a portable compact disc read-only memory (CD-ROM), a digital versatile disk (DVD), a memory stick, a floppy disk, a mechanically encoded device such as punch-cards or raised structures in a groove having instructions recorded thereon, and any suitable combination of the foregoing.
  • RAM random access memory
  • ROM read-only memory
  • EPROM or Flash memory erasable programmable read-only memory
  • SRAM static random access memory
  • CD-ROM compact disc read-only memory
  • DVD digital versatile disk
  • memory stick a floppy disk
  • a mechanically encoded device such as punch-cards or raised structures in a groove having instructions recorded thereon
  • a computer readable storage medium is not to be construed as being transitory signals per se, such as radio waves or other freely propagating electromagnetic waves, electromagnetic waves propagating through a waveguide or other transmission media (e.g., light pulses passing through a fiber-optic cable), or electrical signals transmitted through a wire.
  • Computer readable program instructions described herein can be downloaded to respective computing/processing devices from a computer readable storage medium or to an external computer or external storage device via a network, for example, the Internet, a local area network, a wide area network and/or a wireless network.
  • the network may comprise copper transmission cables, optical transmission fibers, wireless transmission, routers, firewalls, switches, gateway computers and/or edge servers.
  • a network adapter card or network interface in each computing/processing device receives computer readable program instructions from the network and forwards the computer readable program instructions for storage in a computer readable storage medium within the respective computing/processing device.
  • Computer readable program instructions for carrying out operations of the present invention may be assembler instructions, instruction-set-architecture (ISA) instructions, machine instructions, machine dependent instructions, microcode, firmware instructions, state-setting data, or either source code or object code written in any combination of one or more programming languages, including an object oriented programming language such as Smalltalk, C++ or the like, and conventional procedural programming languages, such as the “C” programming language or similar programming languages.
  • the computer readable program instructions may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server.
  • the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).
  • electronic circuitry including, for example, programmable logic circuitry, field-programmable gate arrays (FPGA), or programmable logic arrays (PLA) may execute the computer readable program instructions by utilizing state information of the computer readable program instructions to personalize the electronic circuitry, in order to perform aspects of the present invention.
  • These computer readable program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
  • These computer readable program instructions may also be stored in a computer readable storage medium that can direct a computer, a programmable data processing apparatus, and/or other devices to function in a particular manner, such that the computer readable storage medium having instructions stored therein comprises an article of manufacture including instructions which implement aspects of the function/act specified in the flowchart and/or block diagram block or blocks.
  • the computer readable program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other device to cause a series of operational steps to be performed on the computer, other programmable apparatus or other device to produce a computer implemented process, such that the instructions which execute on the computer, other programmable apparatus, or other device implement the functions/acts specified in the flowchart and/or block diagram block or blocks.
  • each block in the flowchart or block diagrams may represent a module, segment, or portion of instructions, which comprises one or more executable instructions for implementing the specified logical function(s).
  • the functions noted in the block may occur out of the order noted in the figures.
  • two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved.

Abstract

An aspect includes determining, via a processor, context attributes of a storage. Data address translation (DAT) tables are created, via the processor, to map virtual addresses to real addresses within the storage. When detecting, via the processor, that a context attribute of the storage has changed, and the DAT tables are updated based at least in part on the changed context attributes of the storage.

Description

    BACKGROUND
  • The present invention relates to a highly configurable memory architecture, and more specifically, to a highly configurable memory architecture for dynamically joining and splitting dynamic address translation (DAT) tables based on operational context.
  • SUMMARY
  • According to an embodiment of the present invention, a computer-implemented method includes determining, via a processor, context attributes of a storage. Data address translation (DAT) tables are created, via the processor, to map virtual addresses to real addresses within the storage. When detecting, via the processor, that a context attribute of the storage has changed, and the DAT tables are updated based at least in part on the changed context attributes of the storage.
  • Other embodiments of the present invention implement features of the above-described method in computer systems and computer program products.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • The subject matter which is regarded as the invention is particularly pointed out and distinctly claimed in the claims at the conclusion of the specification. The forgoing and other features, and advantages of the invention are apparent from the following detailed description taken in conjunction with the accompanying drawings in which:
  • FIG. 1 illustrates a dynamic address translation (DAT) structure according to one or more embodiments of the present invention;
  • FIG. 2 illustrates another DAT structure according to one or more embodiments of the present invention;
  • FIG. 3 illustrates a flow diagram of a process according to one or more embodiments of the present invention;
  • FIG. 4 illustrates another flow diagram of a process according to one or more embodiments of the present invention;
  • FIG. 5 illustrates a computer system according to one or more embodiments of the present invention; and
  • FIG. 6 illustrates another DAT structure according to one or more embodiments of the present invention.
  • DETAILED DESCRIPTION
  • One or more embodiments of the present invention are used to allow dynamically joining or splitting dynamic address translation (DAT) tables within virtual memory.
  • According to embodiments of the present invention, a computer-implemented method includes the ability to manage two sets of radix tree based dynamic address translation (DAT) tables where one is used to facilitate access of all allocated storage in an address space, while the other permits access to a subset of the storage. The former is referred to as the full space and the latter as the partial space.
  • All operating systems provide an abstraction called an address space. The address space provides a linear range of storage to an application program, isolating the application from other applications that run in other address spaces. Operating systems create multiple address spaces to run multiple application programs concurrently in isolation where each application has the illusion of having control over the system. The illusion of a single address space in isolation is made possible by virtual memory.
  • Virtual memory is implemented through a process called dynamic address translation (DAT). DAT is a function that takes as input a virtual address and returns a real address or a fault if the page associated with the virtual address is not backed in real memory. One possible implementation of virtual memory, the one that will be the focus of this disclosure involves the use and management of a radix-tree DAT table which is a hierarchical tree structure indexed by the input virtual address. The operating system's role is to create the DAT tables while the memory management function of the CPU is to use it to perform the actual translation of a virtual to a real address.
  • In the course of managing application programs, the operating system may need to create a data area within the address space. Such data may require privileged access, meaning that the application program should not be able to access it. It is also possible that different parts of the application run at different levels of trust and that the part of the application that is most trusted should have access to the entire address space while the part that less trusted only have access to a subset of the address space. The subset of the address space used by non-trusted programs is referred to as the “partial space” while the entire spaces is referred to as the “full space”. Thus, access to a virtual address that is mapped in the full space but not in the partial will result in a memory fault for an untrusted application whereas it will be translated to a real address for a trusted application or the operating system. Since the partial space is a subset of the full space, to minimize the amount of storage required for the DAT tables, some level DAT table sharing can occur. This invention describes how the radix-tree DAT tables are managed to maintain two different views of the same address space based on the privilege (operational context) of the current unit of work. The highest levels of the DAT tables for the full and partial spaces are unique, but the lowest level, the page table, may either be “joined” or “split”. A joined page table is simply one that is used by both the full and partial spaces. In short, the memory mapped by a joined page table is accessible by an application running in either space. A split page table is one that is not shared between the full and partial spaces because there are one or more pages visible in the full space that should not be visible in the partial space.
  • Turning now to a more detailed description of aspects of the invention, FIG. 1 depicts a joined DAT structure 100 according to one or more embodiments of the present invention includes a multi-level or radix-tree memory structure. In the z/Series IBM computer architecture such a DAT table consists of five levels: three region tables, a segment table and a page table, in order of highest to lowest. The region tables are not shown in any of diagrams as they are not relevant to the invention. All of the DAT structures down to the segment table are unique for both the full and partial spaces. The joined DAT structure 100 includes a full segment table (SGT) 101 and a partial SGT 103. FIG. 1 also depicts a page table (PGT) 105 and a plurality of entries R 102 within the PGT (107, 108, 109) that contain the real addresses of frames in the computer's main (real) memory.
  • Referring to FIG. 2, a split DAT structure 200 is shown according to one or more embodiments of the present invention. The split DAT structure 200 shown in FIG. 2 includes a multi-level (radix-tree) structure showing a full SGT 201 and a partial SGT 202. The split DAT structure 200 also includes a PGT full table 206, a PGT partial table 208, and a plurality of entries R 203 which contain the addresses of frames in real memory (210, 211, 212) or a bit indicating the entry is invalid. Both 210 and 212 are mapped into the full and partial spaces. However, 211 is only mapped into the full space; the invalid bit is set in the mapping in the partial space. The full page table 206 and partial page table 208 are peer page tables in that they both provide a mapping of the same segment of storage where the latter maps a subset of the former. Pointer to peer tables, and indications of either partial, joined or not joinable are associated with both the PGT full table 206 and the PGT partial table 208. This information may be maintained in an associated data structure, for example, the page frame table entries of the frames that back the page tables may contain this information. The page frame table entries may also record the relationship between peer tables, where the full table points to the partial and the partial points to the full.
  • Some of the management of DAT tables is performed when the application or the operating system invokes an API to allocate a page of memory. When the segment is not mapped (no page table exists) and the first request is for non-privileged storage, a joined Page Table is created to map the page. Subsequently, if the operating system were to request privileged storage in the same segment, the joined page table would be split into a full space PGT which would provide access to the privileged storage. The partial space will lose access to the segment and all the storage it makes visible until subsequent DAT faults. On the other hand, if the operating system were the first to allocate privileged storage in a segment, a PGT will be created to provide a map for the full space ONLY and the PGT will be marked as “not-joinable” since non-privileged units of work are not eligible to access all the storage that it maps.
  • Referring now to FIG. 3, a memory allocation flow is generally depicted in accordance with one or more embodiments of the present invention. The process begins at block 300, and proceeds with assigning memory to be allocated at block 301 and determining if the full data should be visible for all contexts at block 303. If it is determined at block 303 that the full data should be visible in both the full and partial spaces, then the data is allocated at block 305. If the buffer being allocated should not be visible in the partial space, then the process determines if a page table (PGT) is currently joined at block 307. If the page table is not joined, then the page table is marked not joinable at block 309 and the buffer is allocated at block 305. If it is determined at block 307 that the page table is joined, then the page table is split by invalidating the segment table entry that points to the joined page table in the partial segment table. The page table is marked as not joinable (block 311) and the memory allocation is performed using just the split page table. At this point, the partial space has lost access to the segment of memory that has been split since there is no corresponding partial page table has been created. The full space segment table entry maintains access to the segment. Subsequent references to storage mapped by the invalidated segment will result in a segment fault (FIG. 4). An alternative design for splitting a page table is to make an exact copy of the page table before the memory request proceeds and use it to validate the segment in the partial space. Taking this approach will avoid subsequent segment faults for existing allocated memory mapped by the segment for units of work running in the partial space. Then, the PGT table is marked not joinable at block 309 and current allocation continues 305.
  • A DAT fault is a hardware interrupt that is issued when an application references storage that is not valid (mapped) in real. A segment fault is a type of DAT fault where the segment table exists, but the segment entry mapping the virtual address is invalid. Referring to FIG. 4, a segment fault flow diagram is generally shown in accordance with one or more embodiments of the present invention. As described in FIG. 3, when a split of a page table is performed, the partial space loses access to the data in the segment, a subset of which it should be able to access. The following describes how this is corrected during segment fault processing. The segment fault flow process starts at block 400 when a segment fault occurs block 401. It is possible that the reference is legal, meaning that the storage was previously allocated (FIG. 3) and that the faulter has access to the storage. If the reference is invalid, then the faulter will be abnormally terminated (abended). Segment fault processing determines if the segment faulter was using the partial space block 403. If the DAT faulter was not using the partial space of memory block 403, the process performs the fault processing normally on the full DAT 405. If the segment faulter was using the partial space of the memory block 403, then if the partial space should not have access to the storage, the faulter is abended block 411. Otherwise, if the page table mapping the full space segment is joinable, then the partial space segment is validated with the full space page table which will be marked as joined block 419. Otherwise, if the full space page table is not joinable, then a new partial space page table is built to map the segment block 415 and is marked as “partial”. The fault process is then re-driven with the new DAT structures in place block 417. Making a page table joined instead of split, the operating system saves memory since there is only 1 joined page table instead of 1 for the full and another for the partial.
  • The process of managing segment tables and page tables in the above discussion is applicable to higher level DAT tables. Both FIG. 3 and FIG. 4 could be changed to use Region 3rd table and Segment Tables for example, as described in zSeries Architecture (see Principles of Operation), instead of Segment Tables and Page Tables. In this case, the Segment tables would be joined or split. Region 2nd/3rd and Region 2nd/Region 1st could also be managed in a similar manner.
  • Turning now to FIG. 5, a computer system 500 for controlling DAT tables based on the context attributes of storage is generally shown in accordance with one or more embodiments of the present invention. The methods described herein can be implemented in hardware, software (e.g., firmware), or a combination thereof. In an exemplary embodiment, the methods described herein are implemented in hardware as part of the microprocessor of a special or general-purpose digital computer, such as a personal computer, workstation, minicomputer, or mainframe computer. The system 500 therefore may include general-purpose computer or mainframe 501 capable of running multiple instances of an O/S simultaneously.
  • In an exemplary embodiment, in terms of hardware architecture, as shown in FIG. 5, the computer 501 includes one or more processors 505, memory 510 coupled to a memory controller 515, and one or more input and/or output (I/O) devices 540, 545 (or peripherals) that are communicatively coupled via a local input/output controller 535. The input/output controller 535 can be, for example but not limited to, one or more buses or other wired or wireless connections, as is known in the art. The input/output controller 535 may have additional elements, which are omitted for simplicity, such as controllers, buffers (caches), drivers, repeaters, and receivers, to enable communications. Further, the local interface may include address, control, and/or data connections to enable appropriate communications among the aforementioned components. The input/output controller 535 may include a plurality of sub-channels configured to access the output devices 540 and 545. The sub-channels may include fiber-optic communications ports.
  • The processor 505 is a hardware device for executing software, particularly that stored in storage 520, such as cache storage, or memory 510. The processor 505 can be any custom made or commercially available processor, a central processing unit (CPU), an auxiliary processor among several processors associated with the computer 501, a semiconductor based microprocessor (in the form of a microchip or chip set), a macroprocessor, or generally any device for executing instructions.
  • The memory 510 can include any one or combination of volatile memory elements (e.g., random access memory (RAM, such as DRAM, SRAM, SDRAM, etc.)) and nonvolatile memory elements (e.g., ROM, erasable programmable read only memory (EPROM), electronically erasable programmable read only memory (EEPROM), programmable read only memory (PROM), tape, compact disc read only memory (CD-ROM), disk, diskette, cartridge, cassette or the like, etc.). Moreover, the memory 510 may incorporate electronic, magnetic, optical, and/or other types of storage media. Note that the memory 510 can have a distributed architecture, where various components are situated remote from one another, but can be accessed by the processor 505.
  • The instructions in memory 510 may include one or more separate programs, each of which comprises an ordered listing of executable instructions for implementing logical functions. In the example of FIG. 5, the instructions in the memory 510 a suitable operating system (OS) 511. The operating system 511 essentially controls the execution of other computer programs and provides scheduling, input-output control, file and data management, memory management, and communication control and related services.
  • The memory 510 may include multiple logical partitions (LPARs) 512, each running an instance of an operating system. The LPARs 512 may be managed by a hypervisor, which may be a program stored in memory 510 and executed by the processor 505.
  • In an exemplary embodiment, a conventional keyboard 550 and mouse 555 can be coupled to the input/output controller 535. Other output devices such as the I/ O devices 540, 545 may include input devices, for example but not limited to a printer, a scanner, microphone, and the like. Finally, the I/ O devices 540, 545 may further include devices that communicate both inputs and outputs, for instance but not limited to, a network interface card (NIC) or modulator/demodulator (for accessing other files, devices, systems, or a network), a radio frequency (RF) or other transceiver, a telephonic interface, a bridge, a router, and the like. The system 500 can further include a display controller 525 coupled to a display 530. In an exemplary embodiment, the system 500 can further include a network interface 560 for coupling to a network 565. The network 565 can be an IP-based network for communication between the computer 501 and any external server, client and the like via a broadband connection. The network 565 transmits and receives data between the computer 501 and external systems. In an exemplary embodiment, network 565 can be a managed IP network administered by a service provider. The network 565 may be implemented in a wireless fashion, e.g., using wireless protocols and technologies, such as WiFi, WiMax, etc. The network 565 can also be a packet-switched network such as a local area network, wide area network, metropolitan area network, Internet network, or other similar type of network environment. The network 565 may be a fixed wireless network, a wireless local area network (LAN), a wireless wide area network (WAN) a personal area network (PAN), a virtual private network (VPN), intranet or other suitable network system and includes equipment for receiving and transmitting signals.
  • If the computer 501 is a PC, workstation, intelligent device or the like, the instructions in the memory 510 may further include a basic input output system (BIOS) (omitted for simplicity). The BIOS is a set of essential software routines that initialize and test hardware at startup, start the OS 511, and support the transfer of data among the hardware devices. The BIOS is stored in ROM so that the BIOS can be executed when the computer 501 is activated.
  • When the computer 501 is in operation, the processor 505 is configured to execute instructions stored within the memory 510, to communicate data to and from the memory 510, and to generally control operations of the computer 501 pursuant to the instructions.
  • Referring to FIG. 6, another DAT structure 600 is shown according to one or more embodiments of the present invention. The split DAT structure 600 shown in FIG. 6 includes a multi-level (radix-tree) structure showing a full SGT 601 and a partial SGT 603. The DAT structure 600 also includes a PGT full table 605, a joined PGT table 607 and a PGT full table 609 and PGT partial table 611. Information regarding the DAT structure 600 may be maintained in an associated data structure, for example, in page frame table entries (PFTE). The PFTE 615 for the PGT full table 605 has the partial (P), joined (J), and not-joinable (NJ) bits all OFF (0). The joined PGT table 607 has it's PFTE 617 indicating that it is joined by having the joined (J) bit ON (1) while the partial (P) and not-joinable (NJ) bits are OFF (0). Accordingly, the PGT full table 609 and PGT partial table 611 have their PFTE 619 as follows: the PFTE 619 for the full PFTE has the not joinable (NJ) bit ON (1), with the other bits OFF (0) and the partial PFT, which has the partial (P) bit ON (1) and the other bits OFF (0).
  • For the sake of brevity, conventional techniques related to making and using aspects of the invention may or may not be described in detail herein. In particular, various aspects of computing systems and specific computer programs to implement the various technical features described herein are well known. Accordingly, in the interest of brevity, many conventional implementation details are only mentioned briefly herein or are omitted entirely without providing the well-known system and/or process details.
  • Aspects of the invention are not limited in their application to the details of construction and the arrangement of the components set forth in the following description or illustrated in the drawings. The embodiments of the invention described herein are applicable to other embodiments or are capable of being practiced or carried out in various ways. The phraseology and terminology employed herein are for the purpose of description and should not be regarded as limiting. As will be appreciated by one skilled in the art, aspects of the present invention can be embodied as a system, method or computer program product.
  • The present invention may be a system, a method, and/or a computer program product. The computer program product may include a computer readable storage medium (or media) having computer readable program instructions thereon for causing a processor to carry out aspects of the present invention.
  • The computer readable storage medium can be a tangible device that can retain and store instructions for use by an instruction execution device. The computer readable storage medium may be, for example, but is not limited to, an electronic storage device, a magnetic storage device, an optical storage device, an electromagnetic storage device, a semiconductor storage device, or any suitable combination of the foregoing. A non-exhaustive list of more specific examples of the computer readable storage medium includes the following: a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), a static random access memory (SRAM), a portable compact disc read-only memory (CD-ROM), a digital versatile disk (DVD), a memory stick, a floppy disk, a mechanically encoded device such as punch-cards or raised structures in a groove having instructions recorded thereon, and any suitable combination of the foregoing. A computer readable storage medium, as used herein, is not to be construed as being transitory signals per se, such as radio waves or other freely propagating electromagnetic waves, electromagnetic waves propagating through a waveguide or other transmission media (e.g., light pulses passing through a fiber-optic cable), or electrical signals transmitted through a wire.
  • Computer readable program instructions described herein can be downloaded to respective computing/processing devices from a computer readable storage medium or to an external computer or external storage device via a network, for example, the Internet, a local area network, a wide area network and/or a wireless network. The network may comprise copper transmission cables, optical transmission fibers, wireless transmission, routers, firewalls, switches, gateway computers and/or edge servers. A network adapter card or network interface in each computing/processing device receives computer readable program instructions from the network and forwards the computer readable program instructions for storage in a computer readable storage medium within the respective computing/processing device.
  • Computer readable program instructions for carrying out operations of the present invention may be assembler instructions, instruction-set-architecture (ISA) instructions, machine instructions, machine dependent instructions, microcode, firmware instructions, state-setting data, or either source code or object code written in any combination of one or more programming languages, including an object oriented programming language such as Smalltalk, C++ or the like, and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The computer readable program instructions may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider). In some embodiments, electronic circuitry including, for example, programmable logic circuitry, field-programmable gate arrays (FPGA), or programmable logic arrays (PLA) may execute the computer readable program instructions by utilizing state information of the computer readable program instructions to personalize the electronic circuitry, in order to perform aspects of the present invention.
  • Aspects of the present invention are described herein with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems), and computer program products according to embodiments of the invention. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer readable program instructions.
  • These computer readable program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks. These computer readable program instructions may also be stored in a computer readable storage medium that can direct a computer, a programmable data processing apparatus, and/or other devices to function in a particular manner, such that the computer readable storage medium having instructions stored therein comprises an article of manufacture including instructions which implement aspects of the function/act specified in the flowchart and/or block diagram block or blocks.
  • The computer readable program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other device to cause a series of operational steps to be performed on the computer, other programmable apparatus or other device to produce a computer implemented process, such that the instructions which execute on the computer, other programmable apparatus, or other device implement the functions/acts specified in the flowchart and/or block diagram block or blocks.
  • The flowchart and block diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods, and computer program products according to various embodiments of the present invention. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of instructions, which comprises one or more executable instructions for implementing the specified logical function(s). In some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts or carry out combinations of special purpose hardware and computer instructions.
  • The corresponding structures, materials, acts, and equivalents of all means or step plus function elements in the claims below are intended to include any structure, material, or act for performing the function in combination with other claimed elements as specifically claimed. The description of the present invention has been presented for purposes of illustration and description, but is not intended to be exhaustive or limited to the invention in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope and spirit of the invention. The embodiments were chosen and described in order to best explain the principles of the invention and the practical application, and to enable others of ordinary skill in the art to understand the invention for various embodiments with various modifications as are suited to the particular use contemplated.
  • The descriptions of the various embodiments of the present invention have been presented for purposes of illustration, but are not intended to be exhaustive or limited to the embodiments disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope and spirit of the described embodiments. The terminology used herein was chosen to best explain the principles of the embodiments, the practical application or technical improvement over technologies found in the marketplace, or to enable others of ordinary skill in the art to understand the embodiments disclosed herein.

Claims (20)

1. A computer-implemented method comprising:
determining, via a processor, context attributes of a storage;
creating, via the processor, data address translation (DAT) tables to map virtual addresses to real addresses within the storage;
detecting, via the processor, that a context attribute of the storage has changed; and
updating, via the processor, the DAT tables based at least in part on the changed context attributes of the storage, wherein the DAT tables are dynamically separated based upon the changed context attributes of the storage.
2. (canceled)
3. The method according to claim 1, wherein the changed context attributes of the storage indicate that not all of the DAT tables are mapped in the same way.
4. The method according to claim 1, wherein the separated DAT tables have page frame table entries to indicate they have separated.
5. The method according to claim 1, wherein the DAT tables are dynamically joined based at least in part on the changed context attribute of the storage.
6. The method according to claim 5, wherein the context attribute is based on privilege of the storage.
7. The method according to claim 6, further comprising joining the DAT tables based at least in part on determining that the context attributes of the storage to create same real addresses.
8. A system comprising:
a memory having computer readable instructions; and one or more processors for executing the computer readable instructions, the computer readable instructions controlling the one or more processors to perform operations comprising;
determining context attributes of a storage;
creating data address translation (DAT) tables to map virtual addresses to real addresses within the storage;
detecting that a context attribute of the storage has changed; and
updating the DAT tables based at least in part on the changed context attributes of the storage, wherein the DAT tables are dynamically separated based upon the changed context attributes of the storage.
9. (canceled)
10. The system according to claim 8, wherein the changed context attributes of the storage indicate that not all of the DAT tables are mapped in the same way.
11. The system according to claim 8, wherein the separated DAT tables have page frame table entries to indicate they have separated.
12. The system according to claim 8, wherein the context attribute is based on privilege of the storage.
13. The system according to claim 8, wherein the DAT tables are dynamically joined based at least in part on the changed context attribute of the storage.
14. The system according to claim 13, further comprising joining the DAT tables based at least in part on determining that the context attributes of the storage to create same real addresses.
15. A computer program product comprising a computer readable non-transitory signal storage medium having program instructions embodied therewith, the program instructions executable by a processor to cause the processor to perform operations comprising:
a memory having computer readable instructions; and one or more processors for executing the computer readable instructions, the computer readable instructions controlling the one or more processors to perform operations comprising;
determining context attributes of a storage;
creating, via the processor, data address translation (DAT) tables to map virtual addresses to real addresses within the storage;
detecting that a context attribute of the storage has changed; and
updating the DAT tables based at least in part on the changed context attributes of the storage, wherein the DAT tables are dynamically separated based upon the changed context attributes of the storage.
16.
17. The computer program product according to claim 15, wherein the changed context attributes of the storage indicate that not all of the DAT tables are mapped in the same way.
18. The computer program product according to claim 15, wherein the context attribute is based on privilege of the storage.
19. The computer program product according to claim 15, wherein the separated DAT tables have page frame table entries to indicate they have separated.
20. The computer program product according to claim 15, wherein the DAT tables are dynamically joined based at least in part on the changed context attribute of the storage.
US16/456,075 2019-06-28 2019-06-28 Dynamically joining and splitting dynamic address translation (DAT) tables based on operational context Active US10891238B1 (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
US16/456,075 US10891238B1 (en) 2019-06-28 2019-06-28 Dynamically joining and splitting dynamic address translation (DAT) tables based on operational context
US17/128,664 US11321239B2 (en) 2019-06-28 2020-12-21 Dynamically joining and splitting dynamic address translation (DAT) tables based on operational context

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
US16/456,075 US10891238B1 (en) 2019-06-28 2019-06-28 Dynamically joining and splitting dynamic address translation (DAT) tables based on operational context

Related Child Applications (1)

Application Number Title Priority Date Filing Date
US17/128,664 Continuation US11321239B2 (en) 2019-06-28 2020-12-21 Dynamically joining and splitting dynamic address translation (DAT) tables based on operational context

Publications (2)

Publication Number Publication Date
US20200409862A1 true US20200409862A1 (en) 2020-12-31
US10891238B1 US10891238B1 (en) 2021-01-12

Family

ID=74044572

Family Applications (2)

Application Number Title Priority Date Filing Date
US16/456,075 Active US10891238B1 (en) 2019-06-28 2019-06-28 Dynamically joining and splitting dynamic address translation (DAT) tables based on operational context
US17/128,664 Active US11321239B2 (en) 2019-06-28 2020-12-21 Dynamically joining and splitting dynamic address translation (DAT) tables based on operational context

Family Applications After (1)

Application Number Title Priority Date Filing Date
US17/128,664 Active US11321239B2 (en) 2019-06-28 2020-12-21 Dynamically joining and splitting dynamic address translation (DAT) tables based on operational context

Country Status (1)

Country Link
US (2) US10891238B1 (en)

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11074195B2 (en) * 2019-06-28 2021-07-27 International Business Machines Corporation Access to dynamic address translation across multiple spaces for operational context subspaces
US11176056B2 (en) 2019-06-28 2021-11-16 International Business Machines Corporation Private space control within a common address space
US11321239B2 (en) 2019-06-28 2022-05-03 International Business Machines Corporation Dynamically joining and splitting dynamic address translation (DAT) tables based on operational context
US11321301B2 (en) * 2019-07-04 2022-05-03 Kabushiki Kaisha Toshiba Information processing apparatus, information processing method, and information processing system

Family Cites Families (39)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4945480A (en) 1988-02-10 1990-07-31 International Business Machines Corporation Data domain switching on program address space switching and return
US5220669A (en) 1988-02-10 1993-06-15 International Business Machines Corporation Linkage mechanism for program isolation
US5023773A (en) 1988-02-10 1991-06-11 International Business Machines Corporation Authorization for selective program access to data in multiple address spaces
JP2768503B2 (en) 1989-07-25 1998-06-25 富士通株式会社 Virtual memory address space access control method
US5361356A (en) 1992-03-06 1994-11-01 International Business Machines Corporation Storage isolation with subspace-group facility
JPH0713869A (en) 1993-06-28 1995-01-17 Fujitsu Ltd Data processing system with dynamic address converting function
US5745676A (en) 1995-12-04 1998-04-28 International Business Machines Corporation Authority reduction and restoration method providing system integrity for subspace groups and single address spaces during program linkage
US6286089B1 (en) 1999-08-24 2001-09-04 Amdahl Corporation Coupling facility using dynamic address translation
US6976255B1 (en) 2000-03-28 2005-12-13 International Business Machines Corporation Storage isolation employing secured subspace facility
DE60130836T2 (en) 2000-06-12 2008-07-17 Broadcom Corp., Irvine Architecture and method for context switching
JP2004512716A (en) 2000-10-02 2004-04-22 アルテラ・コーポレイション Programmable logic integrated circuit device including dedicated processor device
US6553477B1 (en) 2000-11-06 2003-04-22 Fujitsu Limited Microprocessor and address translation method for microprocessor
US7562179B2 (en) 2004-07-30 2009-07-14 Intel Corporation Maintaining processor resources during architectural events
US8219780B2 (en) 2005-09-16 2012-07-10 Hewlett-Packard Development Company, L.P. Mitigating context switch cache miss penalty
US7555628B2 (en) 2006-08-15 2009-06-30 Intel Corporation Synchronizing a translation lookaside buffer to an extended paging table
US8103851B2 (en) 2008-01-11 2012-01-24 International Business Machines Corporation Dynamic address translation with translation table entry format control for indentifying format of the translation table entry
US8176280B2 (en) 2008-02-25 2012-05-08 International Business Machines Corporation Use of test protection instruction in computing environments that support pageable guests
JP2010170266A (en) 2009-01-21 2010-08-05 Toshiba Corp Semiconductor integrated circuit and address translation method
US8312468B2 (en) 2009-06-09 2012-11-13 Open Kernel Labs Methods and apparatus for fast context switching in a virtualized system
JP5541036B2 (en) 2010-09-21 2014-07-09 富士通株式会社 Memory access control program, memory access control method, and information processing apparatus
US9317460B2 (en) 2012-06-15 2016-04-19 International Business Machines Corporation Program event recording within a transactional environment
US9424199B2 (en) * 2012-08-29 2016-08-23 Advanced Micro Devices, Inc. Virtual input/output memory management unit within a guest virtual machine
US10896127B2 (en) 2013-01-23 2021-01-19 Lucata Corporation Highly configurable memory architecture for partitioned global address space memory systems
US9378065B2 (en) 2013-03-15 2016-06-28 Advanced Elemental Technologies, Inc. Purposeful computing
US10075384B2 (en) 2013-03-15 2018-09-11 Advanced Elemental Technologies, Inc. Purposeful computing
US9645941B2 (en) 2013-09-26 2017-05-09 Cavium, Inc. Collapsed address translation with multiple page sizes
US9323692B2 (en) 2014-04-17 2016-04-26 International Business Machines Corporation Managing translation of a same address across multiple contexts using a same entry in a translation lookaside buffer
US9317443B2 (en) 2014-04-17 2016-04-19 International Business Machines Corporation Managing translations across multiple contexts using a TLB with entries directed to multiple privilege levels and to multiple types of address spaces
US9576031B1 (en) 2016-02-08 2017-02-21 International Business Machines Corporation Automated outlier detection
US10579421B2 (en) 2016-08-29 2020-03-03 TidalScale, Inc. Dynamic scheduling of virtual processors in a distributed system
US11310350B2 (en) * 2017-01-04 2022-04-19 Futurewei Technologies, Inc. Network bridge between different network communication protocols
US10579274B2 (en) 2017-06-27 2020-03-03 TidalScale, Inc. Hierarchical stalling strategies for handling stalling events in a virtualized environment
US11038887B2 (en) * 2017-09-29 2021-06-15 Fisher-Rosemount Systems, Inc. Enhanced smart process control switch port lockdown
US10387325B2 (en) 2017-11-28 2019-08-20 International Business Machines Corporation Dynamic address translation for a virtual machine
US20190205261A1 (en) 2017-12-29 2019-07-04 Intel Corporation Systems, methods, and apparatuses for patching pages
US11074195B2 (en) 2019-06-28 2021-07-27 International Business Machines Corporation Access to dynamic address translation across multiple spaces for operational context subspaces
US11176056B2 (en) 2019-06-28 2021-11-16 International Business Machines Corporation Private space control within a common address space
US10891238B1 (en) 2019-06-28 2021-01-12 International Business Machines Corporation Dynamically joining and splitting dynamic address translation (DAT) tables based on operational context
US10970224B2 (en) 2019-06-28 2021-04-06 International Business Machines Corporation Operational context subspaces

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11074195B2 (en) * 2019-06-28 2021-07-27 International Business Machines Corporation Access to dynamic address translation across multiple spaces for operational context subspaces
US11176056B2 (en) 2019-06-28 2021-11-16 International Business Machines Corporation Private space control within a common address space
US11321239B2 (en) 2019-06-28 2022-05-03 International Business Machines Corporation Dynamically joining and splitting dynamic address translation (DAT) tables based on operational context
US11321301B2 (en) * 2019-07-04 2022-05-03 Kabushiki Kaisha Toshiba Information processing apparatus, information processing method, and information processing system

Also Published As

Publication number Publication date
US20210109863A1 (en) 2021-04-15
US11321239B2 (en) 2022-05-03
US10891238B1 (en) 2021-01-12

Similar Documents

Publication Publication Date Title
US11321239B2 (en) Dynamically joining and splitting dynamic address translation (DAT) tables based on operational context
US9330023B2 (en) Managing translations across multiple contexts using a TLB with entries directed to multiple privilege levels and to multiple types of address spaces
US10248468B2 (en) Using hypervisor for PCI device memory mapping
US9323692B2 (en) Managing translation of a same address across multiple contexts using a same entry in a translation lookaside buffer
US9513832B2 (en) Accessing global data from accelerator devices
US9886398B2 (en) Implicit sharing in storage management
US10365825B2 (en) Invalidation of shared memory in a virtual environment
US11003585B2 (en) Determining affinity domain information based on virtual memory address
US9542100B2 (en) Management of memory pages
US10613774B2 (en) Partitioned memory with locally aggregated copy pools
AU2020234887B2 (en) Dispatch of a secure virtual machine
US10684959B2 (en) Shared memory in a virtual environment
JP2022522679A (en) Secure interface control communication interface
US9330037B2 (en) Dynamically resizing direct memory access (DMA) windows
US11176056B2 (en) Private space control within a common address space
US10228859B2 (en) Efficiency in active memory sharing
US11163680B2 (en) Dynamic write-back to non-volatile memory
US11726922B2 (en) Memory protection in hypervisor environments
US10705983B1 (en) Transparent conversion of common virtual storage
US20210019256A1 (en) Data realignment for hardware accelerated operations
US10528477B2 (en) Pseudo-invalidating dynamic address translation (DAT) tables of a DAT structure associated with a workload

Legal Events

Date Code Title Description
AS Assignment

Owner name: INTERNATIONAL BUSINESS MACHINES CORPORATION, NEW YORK

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:MORGENSTERN, HARRIS M.;TZORTZATOS, ELPIDA;COMPTON, SCOTT B.;AND OTHERS;SIGNING DATES FROM 20190626 TO 20190628;REEL/FRAME:049622/0450

FEPP Fee payment procedure

Free format text: ENTITY STATUS SET TO UNDISCOUNTED (ORIGINAL EVENT CODE: BIG.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

STCF Information on status: patent grant

Free format text: PATENTED CASE