## Path-Based Edge Activation for Dynamic Run-Time Scheduling

Vincent J. Mooney III

Assistant Professor Electrical and Computer Engineering Georgia Institute of Technology Atlanta, GA USA

### Outline

Motivation Previous Work Path-Based Edge Activation **Example** Synthesis Flow Experimental Results **Future Work** 

#### Motivation

Dynamic Hard-Real-Time Systems
Previous work by author limited to DAGs
Application examples have control flow
Extend run-time system to handle CDFG

## Robotics Example: Concurrent Control Laws



#### Previous Work

 "Scheduling of Conditional Process Graphs for the Synthesis of Embedded Systems," Eles, et. al., DATE, 1998.

- "Hardware/Software Co-Design of Run-Time Systems," Ph.D. thesis, Stanford, 1998.
- "Hardware/Software Co-Design of Run-Time Schedulers for Real-Time Systems," to appear in Design Automation of Embedded Systems.



#### **Conditional Process Graphs**

- Conditionals (e.g., D, C, K) are broadcast to all processing elements
- Activation times (start times) for tasks fixed based on values of conditionals (or subset of conditionals)
- Focus on handling late arriving conditionals
   In case where all conditionals are ready at the beginning, *schedule merging* may result in known suboptimal solution



#### Task Control

Associate *start* and *done* event with each task Control of hardware tasks ◆ *start* signal (bit) ♦ done signal (bit) Control of software tasks ◆ *start* vector encapsulates all sw *start* events ◆ *done* vector encapsulates all sw *done* events

#### **R**un Time Scheduler Implementation

Start with control flow of hw- and sw-tasks
Hardware implementation:

- put FSM corresponding to the control flow
  - cycle based semantics
  - can predictably satisfy hard real-time constraints

Software implementation:

preemptive static priority scheduler
 can execute different threads
 keeps track of which threads are suspended

In the direct execution of software tasks by ISR

all sw tasks run to completion (no suspension)

Mixed implementation can leverage advantage of hardware and software

|                                 |                                     | struct<br>DAG                                                          | tive H           | Ieuris                                   | otic                          |
|---------------------------------|-------------------------------------|------------------------------------------------------------------------|------------------|------------------------------------------|-------------------------------|
| fkoh1cjdnvm2nvm1nvm3nvm1nvm4snk | t <sub>3</sub><br>oh0<br>oh1<br>cjd | $f_{3}(t_{3}, x_{3k})$ oh1,snk 24,020<br>$\infty$ 35,012<br>= {(oh0,o) | ∞<br>43,812<br>∞ | 24,020<br>43,812<br>35,012<br>(oh1,cjd,s | oh1,snk<br>cjd,snk<br>oh1,snk |



# Constructive Heuristic Scheduling Algorithm: Result

Final Result:

oh0 -- priority 1 cjd -- priority 2 oh1 -- priority 3

WCET: 39,012

#### Path-Based Edge Activation

Extend scheduling to handle CDFG, not just DAG
 Conditional edges

 active only if a particular path chosen
 a path is defined by a set of values of conditional choices in the CDFG

 For each path, insert conditional edges to minimize WCET

 assumption: conditional values evaluated early enough for all conditional edge insertions



## Example

task hw/sw wcet(cycles) 11,000 hw CQ oh0 2,554 SW oh1 20,581 SW fk hw 11,500 14,878 cjd SW 4,400 hw mvm

#### NEVER = {oh0, oh1, cjd}

No static order can achieve better than a WCET of 49,013

#### **Centralized Control**

Done signals arrive to hardware run-time scheduler (no broadcast)

- Dynamic ordering of software tasks must be done by hardware run-time scheduler
- Use hardware-driven software execution

ISR executes a software task

♦ adv.: fast

♦ disadv.: software tasks not interruptable

Scheduling Assumptions **A** CDFG represents the set of tasks limited number of paths One rate constraint for the graph A NEVER set specifies mutually exclusive sw-tasks Each sw-task, once started, runs to completion ♦ limits solution space Hw-sw communication accounted for ♦ in task WCET ♦ as a separate task Interrupts come only from the hw run-time sched.









## Algorithm

#### Solve\_order(CDFG,NEVER)

beginmodule

**foreach** *path* determined by a unique set of conditional values **begin** 

DAG = subset of CDFG determined by *path* Schedule DAG using *constructive heuristic scheduling* Add conditional edges to enforce DAG schedule end endmodule





#### **Example and Experimental Results**

| Software    | # Line s  | # Line s | WCET  |  |
|-------------|-----------|----------|-------|--|
| Task        | ofC       | Asmbly   |       |  |
| cjd         | 286       | 1177     | 14878 |  |
| oh0         | 90        | 237      | 2554  |  |
| oh1         | 693       | 3263     | 20581 |  |
| int-ser-rtn | N/A       | 26       | 20    |  |
|             |           |          |       |  |
| Hw-ta s k   | # Lines V | / Are a  | WCET  |  |
| mvm         | 629       | 33645    | 4400  |  |
| fk          | 2362      | 42168    | 11500 |  |
| cg          | 2897      | 59587    | 11000 |  |
| rtsched-hw  | 484       | 413      | 99701 |  |

Hw-tasks written in Verilog for BC, use LSI 10K library Verilog model of MIPS core with interrupts 19% decrease in WCET: 39859 (49013) Used VCS<sup>TM</sup> to verify result

#### Future Work

Extend to handle late arriving conditionalsExtend to allow interruptable software tasks