Task definition for specifying resource requirements
First Claim
1. An integrated circuit comprising:
- processing nodes that are heterogeneous between each other and comprise processing resources that are different between each other, wherein the processing nodes comprise programmable processors;
a memory that stores corresponding task definitions for different tasks to be executed by the processing nodes, the task definitions specifying processing resources for the different tasks, wherein the different tasks comprise programs for the programmable processors and the processing resources specified by the task definitions comprise program resources for executing the programs; and
a plurality of hardware schedulers in at least a portion of the processing nodes, each of the plurality of hardware schedulers in a different processing node, the hardware schedulers assigning the different tasks to the processing nodes for execution by matching the processing resources specified in the task definitions with the processing resources of the processing nodes.
4 Assignments
0 Petitions
Accused Products
Abstract
Task definitions are used by a task scheduler and prioritizer to allocate task operation to a plurality of processing units. The task definition is an electronic record that specifies researching needed by, and other characteristics of, a task to be executed. Resources include types of processing nodes desired to execute the task, needed amount or rate of processing cycles, amount of memory capacity, number of registers, input/output ports, buffer sizes, etc. Characteristics of a task include maximum latency tome, frequency of execution of a task, communication ports, and other characteristics. An exemplary task definition language and syntax is described that uses constructs including other of attempted scheduling operations, percentage or amount of resources desired by different operations, handling of multiple executable images or modules, overlays, port aliases and other features.
596 Citations
44 Claims
-
1. An integrated circuit comprising:
-
processing nodes that are heterogeneous between each other and comprise processing resources that are different between each other, wherein the processing nodes comprise programmable processors; a memory that stores corresponding task definitions for different tasks to be executed by the processing nodes, the task definitions specifying processing resources for the different tasks, wherein the different tasks comprise programs for the programmable processors and the processing resources specified by the task definitions comprise program resources for executing the programs; and a plurality of hardware schedulers in at least a portion of the processing nodes, each of the plurality of hardware schedulers in a different processing node, the hardware schedulers assigning the different tasks to the processing nodes for execution by matching the processing resources specified in the task definitions with the processing resources of the processing nodes. - View Dependent Claims (2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23)
-
-
24. A method for scheduling tasks in an integrated circuit comprised of processing nodes that are heterogeneous between each other and comprise processing resources that are different between each other, the method comprising:
-
storing corresponding task definitions for different tasks to be executed by the processing nodes on the integrated circuit, the task definitions specifying processing resources for the different tasks, wherein the processing nodes comprise programmable processors, the different tasks comprise programs for the programmable processors, and the processing resources specified by the task definitions comprise program resources for executing the programs; and assigning the different tasks to the processing nodes for execution on the integrated circuit from the integrated circuit comprising matching the processing resources specified in the task definitions with the processing resources of the processing nodes, wherein the different tasks are assigned by a plurality of hardware schedulers, each of the plurality of hardware schedulers in a different one of the processing nodes. - View Dependent Claims (25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43)
-
-
44. An integrated circuit comprising:
-
processing nodes that are heterogeneous between each other and comprise processing resources that are different between each other, wherein the processing nodes comprise programmable processors, and wherein the processing nodes comprise configurable hardware; a memory that stores corresponding task definitions for different tasks to be executed by the processing nodes, the task definitions specifying processing resources for the different tasks, wherein the different tasks comprise programs for the programmable processors and the processing resources specified by the task definitions comprise program resources for executing the programs, and wherein the processing resources specified by the task definitions comprise configuration information for configuring the configurable hardware for the different tasks; and a plurality of hardware schedulers in at least a portion of the processing nodes, each of the plurality of hardware schedulers in a different processing node, the hardware schedulers assigning the different tasks to the processing nodes for execution by matching the processing resources specified in the task definitions with the processing resources of the processing nodes.
-
Specification