Processing of multiple instruction streams in a parallel slice processor

US9672043B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-9672043-B2
Application numberUS-201414274942-A
CountryUS
Kind codeB2
Filing dateMay 12, 2014
Priority dateMay 12, 2014
Publication dateJun 6, 2017
Grant dateJun 6, 2017

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.

Techniques for managing instruction execution for multiple instruction streams using a processor core having multiple parallel instruction execution slices provide flexibility in execution of program instructions by a processor core. An event is detected indicating that either resource requirement or resource availability will not be met by the execution slice currently executing the instruction stream. In response to detecting the event, dispatch of at least a portion of the subsequent instruction is made to another instruction execution slice. The event may be a compiler-inserted directive, may be an event detected by logic in the processor core, or may be determined by a thread sequencer. The instruction execution slices may be dynamically reconfigured as between single-instruction-multiple-data (SIMD) instruction execution, ordinary instruction execution, wide instruction execution. When an instruction execution slice is busy processing a current instruction for one of the streams, another slice can be selected to proceed with execution.

First claim

Opening claim text (preview).

What is claimed is: 1. A computer system comprising: a processor for executing program instructions; and a memory for storing the program instructions coupled to the processor; wherein the program instructions are program instructions for analyzing and modifying instructions of multiple instruction streams for further execution by another processor core having a plurality of instruction execution slices, and wherein the program instructions comprise: program instructions for detecting, in a first one of the multiple instruction streams, an event indicating that a first instruction requires processing that changes resource availability for execution of a subsequent instruction of the first instruction stream or that the subsequent instruction has execution requirements such that a change in mapping between the instruction execution slices and corresponding ones of the multiple instruction streams is indicated, wherein the subsequent instruction is an instruction having a width greater than a width of each of the plurality of instruction execution slices, wherein the event is an SIMD instruction; and program instructions for, responsive to detecting the event, modifying the first one of the multiple instruction streams by inserting a directive in the first one of the multiple instruction streams, wherein the directive, when executed by the another processor core will cause the change in mapping so that at least a portion of the subsequent instruction is dispatched to a selected one of the instruction execution slices that was assigned to a second one of the multiple instruction streams during a previous execution cycle, wherein the program instructions for inserting a directive insert a directive that causes dispatch of a first portion of the subsequent instruction to the selected instruction execution slice and a second portion of the subsequent instruction to another instruction execution slice that executed an instruction previous to the first instruction for the first instruction stream, wherein the program instructions for inserting a directive insert a directive that causes dispatch of the subsequent instruction to the selected instruction execution slice and another instruction execution slice that executed an instruction previous to the first instruction for the first instruction stream, wherein the selected instruction execution slice and the another instruction execution slice process different data associated with the SIMD instruction. 2. The computer system of claim 1 , wherein the program instructions for detecting an event predict that another instruction execution slice that executed a second instruction previous to the first instruction for the first instruction stream will be unavailable due to the second instruction being a complex instruction or an instruction having completion dependent on an external event. 3. The computer system of claim 1 , wherein the program instructions are program instructions of a compiler that generates program code of the multiple instruction streams by inserting the directive in the program code to control the dispatching. 4. The computer system of claim 1 , wherein the program instructions are program instructions of a scheduler that pre-processes program code of the multiple instruction streams to allocate resources to hardware threads corresponding to the multiple instruction streams. 5. A computer program product comprising a computer-readable storage device that is not a signal or carrier wave, the storage device storing program instructions for analyzing and modifying instructions of multiple instruction streams for execution by a processor core having a plurality of instruction execution slices, wherein the program instructions comprise: program instructions for detecting, in a first one of the multiple instruction streams, an event indicating that a first instruction requires processing that changes resource availability or requirements for execution of a subsequent instruction of the first instruction stream such that a change in mapping between the instruction execution slices and corresponding ones of the multiple instruction streams is indicated, wherein the subsequent instruction is an instruction having a width greater than a width of each of the plurality of instruction execution slices; and program instructions for, responsive to detecting the event, modifying the first one of the multiple instruction streams by inserting a directive in the first one of the multiple instruction streams, wherein the directive, when executed by the processor core will cause dispatch of at least a portion of the subsequent instruction to a selected one of the instruction execution slices that was assigned to a second one of the multiple instruction streams during a previous execution cycle, wherein the program instructions for inserting a directive insert a directive that causes dispatch of a first portion of the subsequent instruction to the selected instruction execution slice and a second portion of the subsequent instruction to another instruction execution slice that executed an instruction previous to the first instruction for the first instruction stream, wherein the event is an SIMD instruction and wherein the program instructions for inserting a directive insert a directive that causes dispatch of the subsequent instruction to the selected instruction execution slice and another instruction execution slice that executed an instruction previous to the first instruction for the first instruction stream, wherein the selected instruction execution slice and the another instruction execution slice process different data associated with the SIMD instruction. 6. The computer program product of claim 5 , wherein the program instructions for detecting an event predict that another instruction execution slice that executed a second instruction previous to the first instruction for the first instruction stream will be unavailable due to the second instruction being a complex instruction or an instruction having completion dependent on an external event. 7. The computer program product of claim 5 , wherein the program instructions are program instructions of a compiler that generates program code of the multiple instruction streams by inserting the directive in the program code to control the dispatching. 8. The computer program product of claim 5 , wherein the program instructions are program instructions of a scheduler that pre-processes program code of the multiple instruction streams to allocate resources to hardware threads corresponding to the instruction streams.

Assignees

Inventors

Classifications

  • of variable length instructions · CPC title

  • using instruction pipelines · CPC title

  • G06F9/38Primary

    Concurrent instruction execution, e.g. pipeline or look ahead · CPC title

  • G06F9/3851Primary

    from multiple instruction streams, e.g. multistreaming · CPC title

  • controlled by a single instruction for multiple data lanes [SIMD] · 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 US9672043B2 cover?
Techniques for managing instruction execution for multiple instruction streams using a processor core having multiple parallel instruction execution slices provide flexibility in execution of program instructions by a processor core. An event is detected indicating that either resource requirement or resource availability will not be met by the execution slice currently executing the instructio…
Who is the assignee on this patent?
IBM
What technology area does this patent fall under?
Primary CPC classification G06F9/38. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Jun 06 2017 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 3 related publications on this page (citations in our corpus or others sharing the same primary CPC).