340 likes | 367 Views
Explore time-memory scheduling and code generation of real-time embedded software, focusing on algorithmic solutions for efficient execution on constrained systems. Case studies and conclusions highlight practical implications.
 
                
                E N D
Time-Memory Scheduling and Code Generation ofReal-Time Embedded Software Chuen-Hau Gau and Pao-Ann Hsiung National Chung Cheng University Chiayi, Taiwan, R.O.C. 8th International Conference on Real-Time Computing Systems and Applications, March 18-20, 2002, Tokyo, Japan
Outline • Introduction • Previous Work • Real-Time Embedded Software Synthesis • ATM VPN Server Example • Conclusions National Chung Cheng University, Taiwan
Introduction • Embedded systems abound in human daily life • We interact with embedded systems in • our homes, • at offices, • at labs, • on transportations, • in communications, … • Due to this interaction with humans, most embedded systems are also REAL-TIME systems • And, software accounts for more than 70% functionalities in a real-time embedded system National Chung Cheng University, Taiwan
What is an embedded system? • Installed in a larger system • Dedicated task • Small Memory Space (200~400 KB) • Low Processing Power (100~200 MHz) • Unstable Environment (mobile, …) • Reactive • Real-Time National Chung Cheng University, Taiwan
Embedded System Examples research lab equipments space crafts factory automation office equipments home appliances medical instruments National Chung Cheng University, Taiwan
Embedded System Architecture National Chung Cheng University, Taiwan
Bounded Memory Execution • Real-Time Constraints Time Memory Scheduling (TMS) Code Generation Design Issues and Solution Proposed Solution National Chung Cheng University, Taiwan
Previous Work Formal Software Synthesis • Safe Petri-Nets (PN)  Quasi-Static Scheduling (QSS)[Lin: DATE’98, DAC’98] • Free-Choice PN  Net Decomposition + QSS[Sgroi: DAC’99] • Codesign FSM  POLIS[Balarin: ICCD’99] • Non-timed multi-rate PN Reachability graph[Cortadella et al: DAC’00] • Time Free-Choice PN  QSS + RTS or FIBS[Hsiung: CODES’01, FORTE’01] National Chung Cheng University, Taiwan
Real-Time Embedded Software (RTES) Model • Real-Time Embedded Software is specified as a set of Colored Time Petri Nets (CTPN) • Allows explicit modeling of • Timing Constraints • Memory Usages • No free-choice restriction! • Larger domain of real-time embedded applications! National Chung Cheng University, Taiwan
Colored Time Petri Nets National Chung Cheng University, Taiwan
Colored Time Petri Nets A CTPN is a 6-tuple (P,T, C, ,M0,) such that: • P is a finite set of places, • T is a finite set of transitions, P T  , P T = , • C is a set of colors associated with each token • : (P T )  (T P )  2NC, a set of weighted arcs such that each arc is associated with a set of integer-color pairs, • M0: P  2NC, the initial marking, • (t ) = (, ), t T, : Earliest Firing Time, : Latest Firing Time. National Chung Cheng University, Taiwan
CTPN Marking • A marking is a vector M = <NC1, NC2, …, NC|P|> where NCi is a set of integer-color pairs representing the non-negative number of colored tokens in place pi. • 2 attributes are associated with each M: • (1) a time-stamp(M) • (2) a memory-usage(M) National Chung Cheng University, Taiwan
Valid Firing (System Execution) • A transition t is said to be enabled at time  in a marking M with time-stamp (M) if: • (1) (pk, t)  NCk, (pk, t) , k {1, …,|P|}, • (2) (M)  (t) • The firing of a transition t at time  in a marking M with time-stamp (M) is called a valid firing if: • Transition Deadline: (t) (M) (t) • Memory Constraint: (M') max where M' is the marking obtained by firing t in M and max is the maximum amount of memory available. National Chung Cheng University, Taiwan
RTES Synthesis Problem Target Problem Real-Time Embedded Software Synthesis Given: • a set of CTPN S = {Ai | i = 1,2,…,n}, • an upper-bound maxon memory space, and • a set of real-time constraints: CTPN periods, deadlines software code is to be generated such that • it can be executed on a single processor, • it uses memory less than or equal to max, and • it satisfies all EFT, LFT, and real-time constraints. National Chung Cheng University, Taiwan
RTES Synthesis Algorithm • Choice Set: H = {t2, t3, t4} National Chung Cheng University, Taiwan
RTES Synthesis Algorithm • Exclusion Set H = {t2, t3, t4} Merging of all non-disjoint choice sets National Chung Cheng University, Taiwan
RTES Synthesis Algorithm Time-Memory Scheduling • A schedule (sequence of firing transitions) is valid if the following are satisfied: • Transition deadline • CTPN deadline • Memory bound • Incomplete exclusion sets are deleted (because corresponding code will be illegal) National Chung Cheng University, Taiwan
RTES Synthesis Algorithm • Transition Deadline Satisfaction Assume transition t: • enabled at marking M with time-stamp (M) • fired at marking M with time-stamp (M), then it must satisfy (M) - (M) + (t)  (t) token age transition execution time transition deadline National Chung Cheng University, Taiwan
RTES Synthesis Algorithm • CTPN Deadline Satisfaction Assume transition t: • fired at marking M (M) + (t)  d transition execution time CTPN deadline for current task National Chung Cheng University, Taiwan
RTES Synthesis Algorithm • Memory Bound Satisfaction Assume transition t: • fires and CTPN reaches marking M (M)  max memory usage memory bound National Chung Cheng University, Taiwan
RTES Synthesis Algorithm while( |Tree| != 0 ) { if( Entire Tree Marked ) CodeGen(); if( Current Node Is Spawned ) { Current Node :: Delete Incomplete Exsets if Current Node :: Has Marked Child Current Node :: Delete Other Child, Mark, Go Parent if(Child := SELECT() == null) Current Node :: Delete Current and Go Parent else Current Node :: Go Child } else { if(Current Node Is A CompleteSchedule) Current Node :: Mark and Go Parent else Current Node :: Spawn} } National Chung Cheng University, Taiwan
RTES Synthesis Algorithm Memory Estimation • Global Memory: G(R), R: tree • Local Memory: maxtM (L(t)), t: transition, M: marking • Buffer Memory: • Total Memory: National Chung Cheng University, Taiwan
Processi Task 1 Task 2 Task k … Code Generation • A real-time process for each independent task, i.e., each reachability tree • # tasks is minimal (= # independent tasks) Source Transitions in TFCPN Main Program National Chung Cheng University, Taiwan
Code Generation Algorithm Extract( CNode ) { if( CNode is leaf ) // no child { Code += getCode(CNode); Code += “return;”; } else if( CNode is branching ) // multi-child { Code += getBranchCode(CNode); for each child node CNode.ci Extract(CNode.ci); } else // one child { Code += getCode(CNode); Extract(CNode.child) } return(Code); } National Chung Cheng University, Taiwan
ATM VPN Server • ATM switching nodes interconnect LANs via an ATM backbone. • An ATM server: • temporarily stores input cells from VCCs (Virtual Channel Connections), and • forward VCC cells to the VPCs (Virtual Path Connections) by identifying cell headers. National Chung Cheng University, Taiwan
Functionalities of ATM VPN • Message Selective Discarding (MSD):A message discarding technique that avoids buffer overflow by discarding selected incoming cells • Weighted Fair Queuing (WFQ):A bandwidth control policy for outgoing flows Thus, there are TWO independent tasks! National Chung Cheng University, Taiwan
ATM VPN Server PUSH Message Selective Discarding VCC cell WFQ scheduling INSERT Counter Cell Extract TICK POP National Chung Cheng University, Taiwan
CTPN model of MSD in ATM National Chung Cheng University, Taiwan
CTPN models of WFQ, Extract LAST + BW > GLOBAL_TIME ? READ_LAST t14 p25 p27 Y p29 P30 p26 p28 N INSERT_CELL t13 *SCHEDULE_WFQ READ_BW t15 t17 POP t19 TICK t16 *SCHEDULE_WFQ p36 I=N? p33 Qlength=0? N N p31 p32 READ_SORTER N Y p35 p39 p37 p38 p34 I=I+1 Y Y I=0 CHECK_QLENGTH t18 COMPUTE_OUT_TIME CELL_OUT_TIME <= GLOBAL_TIME? National Chung Cheng University, Taiwan
Reachability Tree for MSD Schedule Results: • 49 markings • 14 schedules • 66 instructions • 12 Kbytes Memory National Chung Cheng University, Taiwan
Reachability Trees for WFQ and Extract Schedule Results: WFQ • 9 markings • 2 schedules Extract • 13 markings • 4 schedules National Chung Cheng University, Taiwan
Scheduling Results • Both MSD and Extract call WFQ (2 schedules) • MSD Task • # schedules = 14  2 = 28 • Extract Task • # schedules = 4 x 2 = 8 National Chung Cheng University, Taiwan
Conclusions • A synthesis method for real-time embedded software was presented • No free-choice restriction on model • Explicit time and data modeling • Both real-time constraints and memory constraints are considered for scheduling • Minimal number of tasks in generated code • Can be used for prototyping platforms National Chung Cheng University, Taiwan