9/23/20151 Energy Efficient Scheduling Techniques For Real-Time Embedded Systems Rabi Mahapatra.

Slides:



Advertisements
Similar presentations
Real Time Scheduling.
Advertisements

EE5900 Advanced Embedded System For Smart Infrastructure
Energy-efficient Task Scheduling in Heterogeneous Environment 2013/10/25.
1 EE5900 Advanced Embedded System For Smart Infrastructure Energy Efficient Scheduling.
1 “Scheduling with Dynamic Voltage/Speed Adjustment Using Slack Reclamation In Multi-processor Real-Time Systems” Dakai Zhu, Rami Melhem, and Bruce Childers.
Real- time Dynamic Voltage Scaling for Low- Power Embedded Operating Systems Written by P. Pillai and K.G. Shin Presented by Gaurav Saxena CSE 666 – Real.
Courseware Scheduling of Distributed Real-Time Systems Jan Madsen Informatics and Mathematical Modelling Technical University of Denmark Richard Petersens.
CSE 522 Real-Time Scheduling (4)
Mehdi Kargahi School of ECE University of Tehran
Power Aware Real-time Systems Rami Melhem A joint project with Daniel Mosse, Bruce Childers, Mootaz Elnozahy.
Tasks Periodic The period is the amount of time between each iteration of a regularly repeated task Time driven The task is automatically activated by.
Module 2 Priority Driven Scheduling of Periodic Task
Chapter 5 CPU Scheduling. CPU Scheduling Topics: Basic Concepts Scheduling Criteria Scheduling Algorithms Multiple-Processor Scheduling Real-Time Scheduling.
Senior Design Project: Parallel Task Scheduling in Heterogeneous Computing Environments Senior Design Students: Christopher Blandin and Dylan Machovec.
SIGMETRICS 2008: Introduction to Control Theory. Abdelzaher, Diao, Hellerstein, Lu, and Zhu. CPU Utilization Control in Distributed Real-Time Systems Chenyang.
High-level System Modeling and Power Management Techniques Jinfeng Liu Dept. of ECE, UC Irvine Sep
Chapter 6: CPU Scheduling. 5.2 Silberschatz, Galvin and Gagne ©2005 Operating System Concepts – 7 th Edition, Feb 2, 2005 Chapter 6: CPU Scheduling Basic.
1 of 30 June 14, 2000 Scheduling and Communication Synthesis for Distributed Real-Time Systems Paul Pop Department of Computer and Information Science.
EE 249, Fall Discussion: Scheduling Haibo Zeng Amit Mahajan.
Scheduling Algorithms for Multiprogramming in a Hard-Real-Time Environment Presented by Pete Perlegos C.L. Liu and James W. Layland.
By Group: Ghassan Abdo Rayyashi Anas to’meh Supervised by Dr. Lo’ai Tawalbeh.
Misconceptions About Real-time Computing : A Serious Problem for Next-generation Systems J. A. Stankovic, Misconceptions about Real-Time Computing: A Serious.
Real-Time Operating System Chapter – 8 Embedded System: An integrated approach.
Technische Universität Dortmund Classical scheduling algorithms for periodic systems Peter Marwedel TU Dortmund, Informatik 12 Germany 2007/12/14.
Distributed Real-Time systems 1 By: Mahdi Sadeghizadeh Website: Sadeghizadeh.ir Advanced Computer Networks.
Task Alloc. In Dist. Embed. Systems Murat Semerci A.Yasin Çitkaya CMPE 511 COMPUTER ARCHITECTURE.
Minimizing Response Time Implication in DVS Scheduling for Low Power Embedded Systems Sharvari Joshi Veronica Eyo.
VOLTAGE SCHEDULING HEURISTIC for REAL-TIME TASK GRAPHS D. Roychowdhury, I. Koren, C. M. Krishna University of Massachusetts, Amherst Y.-H. Lee Arizona.
MM Process Management Karrie Karahalios Spring 2007 (based off slides created by Brian Bailey)
Low-Power Wireless Sensor Networks
Computer Science Department University of Pittsburgh 1 Evaluating a DVS Scheme for Real-Time Embedded Systems Ruibin Xu, Daniel Mossé and Rami Melhem.
An Efficient Algorithm for Dual-Voltage Design Without Need for Level-Conversion SSST 2012 Mridula Allani Intel Corporation, Austin, TX (Formerly.
1 EE5900 Advanced Embedded System For Smart Infrastructure Energy Efficient Scheduling.
A S CHEDULABILITY A NALYSIS FOR W EAKLY H ARD R EAL - T IME T ASKS IN P ARTITIONING S CHEDULING ON M ULTIPROCESSOR S YSTEMS Energy Reduction in Weakly.
© Oxford University Press 2011 DISTRIBUTED COMPUTING Sunita Mahajan Sunita Mahajan, Principal, Institute of Computer Science, MET League of Colleges, Mumbai.
Scheduling policies for real- time embedded systems.
1 Distributed Energy-Efficient Scheduling for Data-Intensive Applications with Deadline Constraints on Data Grids Cong Liu and Xiao Qin Auburn University.
Power Management of Flash Memory for Portable Devices ELG 4135, Fall 2006 Faculty of Engineering, University of Ottawa November 1, 2006 Thayalan Selvam.
Company name KUAS HPDS A Realistic Variable Voltage Scheduling Model for Real-Time Applications ICCAD Proceedings of the 2002 IEEE/ACM international conference.
Real Time Scheduling Telvis Calhoun CSc Outline Introduction Real-Time Scheduling Overview Tasks, Jobs and Schedules Rate/Deadline Monotonic Deferrable.
CS Spring 2011 CS 414 – Multimedia Systems Design Lecture 31 – Multimedia OS (Part 1) Klara Nahrstedt Spring 2011.
Real-Time Scheduling CS4730 Fall 2010 Dr. José M. Garrido Department of Computer Science and Information Systems Kennesaw State University.
Prepare by : Ihab shahtout.  Overview  To give an overview of fixed priority schedule  Scheduling and Fixed Priority Scheduling.
Resource Mapping and Scheduling for Heterogeneous Network Processor Systems Liang Yang, Tushar Gohad, Pavel Ghosh, Devesh Sinha, Arunabha Sen and Andrea.
Object-Oriented Design and Implementation of the OE-Scheduler in Real-time Environments Ilhyun Lee Cherry K. Owen Haesun K. Lee The University of Texas.
Hard Real-Time Scheduling for Low- Energy Using Stochastic Data and DVS Processors Flavius Gruian Department of Computer Science, Lund University Box 118.
6. Application mapping 6.1 Problem definition
End-To-End Scheduling Angelo Corsaro & Venkita Subramonian Department of Computer Science Washington University Distributed Systems Seminar, Spring 2003.
CSCI1600: Embedded and Real Time Software Lecture 24: Real Time Scheduling II Steven Reiss, Fall 2015.
Introduction to Embedded Systems Rabie A. Ramadan 5.
Multimedia Computing and Networking Jan Reduced Energy Decoding of MPEG Streams Malena Mesarina, HP Labs/UCLA CS Dept Yoshio Turner, HP Labs.
Dynamic Priority Driven Scheduling of Periodic Task
Classical scheduling algorithms for periodic systems Peter Marwedel TU Dortmund, Informatik 12 Germany 2012 年 12 月 19 日 These slides use Microsoft clip.
CS Spring 2009 CS 414 – Multimedia Systems Design Lecture 31 – Process Management (Part 1) Klara Nahrstedt Spring 2009.
Introduction to Real-Time Systems
CprE 458/558: Real-Time Systems (G. Manimaran)1 Energy Aware Real Time Systems - Scheduling algorithms Acknowledgement: G. Sudha Anil Kumar Real Time Computing.
CprE 458/558: Real-Time Systems (G. Manimaran)1 CprE 458/558: Real-Time Systems Energy-aware QoS packet scheduling.
1 Hardware-Software Co-Synthesis of Low Power Real-Time Distributed Embedded Systems with Dynamically Reconfigurable FPGAs Li Shang and Niraj K.Jha Proceedings.
Determining Optimal Processor Speeds for Periodic Real-Time Tasks with Different Power Characteristics H. Aydın, R. Melhem, D. Mossé, P.M. Alvarez University.
CS Spring 2010 CS 414 – Multimedia Systems Design Lecture 32 – Multimedia OS Klara Nahrstedt Spring 2010.
Chapter 4 CPU Scheduling. 2 Basic Concepts Scheduling Criteria Scheduling Algorithms Multiple-Processor Scheduling Real-Time Scheduling Algorithm Evaluation.
Pradeep Konduri Static Process Scheduling:  Proceedance process model  Communication system model  Application  Dicussion.
Distributed Process Scheduling- Real Time Scheduling Csc8320(Fall 2013)
Real-Time Operating Systems RTOS For Embedded systems.
Embedded System Scheduling
Multiprocessor Real-Time Scheduling
Wayne Wolf Dept. of EE Princeton University
Flavius Gruian < >
Networked Real-Time Systems: Routing and Scheduling
Presentation transcript:

9/23/20151 Energy Efficient Scheduling Techniques For Real-Time Embedded Systems Rabi Mahapatra

9/23/20152 Outline Introduction Motivation Related Work Single Processor Systems Distributed Multiprocessor Systems Experiments & Results Summary

9/23/20153 Introduction PDA audio/video entertainment devices robotsHandheld computer Mobile Phone Network CameraWireless presentation GatewayCerfcube Sample Embedded Systems

9/23/20154 Application Specification for Embedded Systems Application Specification for Embedded Systems Periodic Task graphsPeriodic Task graphs Each task characterized by:Each task characterized by: PeriodPeriod Execution timeExecution time DeadlineDeadline Sporadic TasksSporadic Tasks Invoked at any timeInvoked at any time Hard deadlineHard deadline Soft AperiodicSoft Aperiodic Invoked at any timeInvoked at any time No deadlineNo deadline t1t1 t3t3 t2t2 t4t4 t5t5 Period =90, Deadline =90 Sporadic Task, Deadline =30 Typical Input Specification of Embedded Systems

9/23/20155 Why Low Power ?   High Power dissipation causes Chip failures   Expensive Cooling & Packaging overheads   High Manufacturing Costs   Portable Systems, User convenience limited by:   Battery Size   Recharging Interval

9/23/20156 Power Management  Processor power dissipation is a function of α. C l. V 2 dd. f  Various Low-Power Techniques System-Level System-Level Architecture-Level Architecture-Level Circuit-Level Circuit-Level  System-Level power reduction techniques: Dynamic Voltage Scaling Dynamic Voltage Scaling Dynamic Power Management Dynamic Power Management

9/23/20157 System Level Power Management Taxonomy SLPM DPM Fixed Tasks Single Processor Multiprocessors Variable Tasks Single processor Multiprocessors LPS (DVS) Fixed Task set Single Processor D≤P (contd..) No Restrictions Multiprocessors Tolerance DL Hard Realtime Variable Task set Single Processor Multiprocessors SLPM – System Level Power Management DPM – Dynamic Power Management LPS – Low power Scheduling

9/23/20158 System Level Power Management Taxonomy (contd …) D≤P Tolerance DL Hard Real time No Precedence Periodic Periodic + Sporadic With Precedence Periodic Periodic + Sporadic

9/23/20159 Our Objective Given Embedded system and its application task graphs with library functions (i.e. period, execution time, Deadline etc.), our goal is to Reduce the system wide power consumption while guaranteeing the deadlines

9/23/ Related Work Multi-Processor  J.Luo and N.K.Jha, 2001 “Battery-Aware static scheduling” “Battery-Aware static scheduling” Global shifting scheme & local schedule transformationsGlobal shifting scheme & local schedule transformations More suitable to small scale systemsMore suitable to small scale systems  R.Mishra, N.Rastogi, and D.Zhu, 2003 “Energy aware scheduling for distributed” “Energy aware scheduling for distributed” Greedy and gap-filling dynamic power management techniquesGreedy and gap-filling dynamic power management techniques Limited to task graphs with equal deadlineLimited to task graphs with equal deadline  D. Zhu, R. Melhem, and B. Childers, 2003 “Scheduling with Dynamic Voltage/Speed” “Scheduling with Dynamic Voltage/Speed” Slack sharing among processors, global queueSlack sharing among processors, global queue Limited homogenous systems with shared memoryLimited homogenous systems with shared memory Single Processor:  G.Quan, and X. HU, 2001 Minimum constant voltage for each interval Minimum constant voltage for each interval Assumes deadline less than or equal to period. Assumes deadline less than or equal to period.  V.Swaminathan, and K.Chakrabarty, 2000 Low-energy earliest deadline first heuristic Low-energy earliest deadline first heuristic No guarantee on required maximum processor speed No guarantee on required maximum processor speed

9/23/ Contributions   Provides a framework for single processor that consider tasks Whose response time is greater than the period. With Precedence constraints   Introduced chain of task set based execution approach to model low-power in distributed embedded systems.

9/23/ Energy Efficient Scheduling Techniques for Single Processor

9/23/ Proposed Approach “A 3-step approach to reduce power in single processor embedded systems with arbitrary response times and precedence constraints.”   Step1: Task priority assignment that guarantees precedence constraints.   Step 2: Determination of task speed that guarantees deadlines. reduces power consumption.   Step 3: Dynamic power management Idle Intervals. Run-time variations in task execution time.

9/23/ Task Modeling   Periodic task graphs Scheduled according to their priorities   Sporadic task Invoked at any time Hard deadline Execution slot is needed Let ‘  ’ be the worst-case execution time and ‘d’ be the deadline   Execution Slots are defined with   Period : d -    Deadline: d - 

9/23/ STEP 1 : Priority Assignment Remove the node with no Predecessor and least slack time END Arrange the task graphs & EX. Slots in increasing order Of their period Remove the task graph with smallest period Assign the node next highest priority If all nodes in the Graph are Assigned priorities no List is empty yes no

9/23/ STEP 2 : Task Speed Determination yes Find the task with largest speed, ‘s’. Mark the speed for this task and all other high priority tasks as ‘s’ Arrange tasks in decreasing order of priority For each task in the list, determine the speed at which the task and all high priority tasks in the list can be run Remove all these tasks from the list List is empty END no

9/23/ Task Schedulability   Let  = {T 1,T 2,…,T N } be the task set arranged in decreasing order of priorities.   Characteristics of T i : {P i, e i, D i }. A task set is feasible if the deadline of all tasks are always met.  Critical Instant Theorem (  Critical Instant Theorem ( Liu and Layland, 1973) “Scheduling algorithms for multiprogramming” if a task meets its deadline whenever the task is requested simultaneously with all the high priority tasks, then the deadline will always be met for all task phasing.

9/23/ In other words, the task set  = {T 1,T 2,…,T N } is schedulable if and only t i  D i  i =1,..n, where otherwise t i,j  D i,j  i =1,..n, and ‘j’ instances of t i, where t i,j = R(t i,j + (j-1)P i ) – (j-1)P i, where R(t i,j ) = + j*e i …………… (2) + e i  t i if P i  D i ………….. (1) Task Schedulability (Contd … )

9/23/ STEP 2 : Task Speed Determination yes Find the task with largest speed, ‘s’. Mark the speed for this task and all other high priority tasks as ‘s’ Arrange tasks in decreasing order of priority For each task in the list, determine the speed at which the task and all high priority tasks in the list can be run Remove all these tasks from the list List is empty END no

9/23/ Step 3: Dynamic Power Management  During System operation, idle intervals arise when: Actual task execution time is less than the worst-case execution time. (that is assumed at the time of fixed priority scheduling). Actual task execution time is less than the worst-case execution time. (that is assumed at the time of fixed priority scheduling). Since these Idle intervals can not be exploited by off-line methods.  An on-line method that adapts the clock speed to take advantage of idle intervals is needed.

9/23/ DPM (Contd..)  Schedule the tasks according to their pre- determined speeds in a preemptive manner.  If the current task has finished and the queue of ready tasks is empty, then: Determine the length of idle interval Determine the length of idle interval If feasible, put the processor in the power down mode. If feasible, put the processor in the power down mode.

9/23/ Experimental Setup  Event driven simulator  Intel Strong Arm SA-1100 Embedded Processor Specifications  Real-world test cases (CNC controller, INS, avionics,…)

9/23/201523Benchmarks Test cases# Periodic task graphs # sporadic tasks # tasks with D > P Utilization Synthetic I Synthetic II Synthetic III CNC [1] INS [2] Avionics [3] Characteristics of various test cases

9/23/ Various low power techniques % Energy savings Comparison of % Energy savings with various Low power techniques

9/23/ % Energy Savings with the proposed technique on various test cases

9/23/ Energy Efficient Scheduling Techniques for Multi-Processor Embedded Systems

9/23/ Overview  Preliminaries  System model  Slack distribution heuristic  Periodical determination of service rate  Experiments & Results

9/23/ Preliminaries  Command and control systems that comprise of hard real-time applications in a distributed environment.  An application comprises of: Chain(s) of tasks or Task sets Chain(s) of tasks or Task sets Hard deadlines Hard deadlines Exchange of messages during execution Exchange of messages during execution  Admitting task set (Connection establishment) : Key Issues Traffic descriptor [6] Traffic descriptor [6] Worst-case delay analysis Worst-case delay analysis  Power Reduction approaches slack distribution slack distribution Clock speed adaptation during system run-time Clock speed adaptation during system run-time

9/23/ System Model  A task set is described by a vector triplet where ≡ ≡ A distributed system with 3 nodes & 2 task sets PE1PE2 PE3 M 1 M 2

9/23/ Admission of Task Set  Task set admission: Key Phases Setting up task set Setting up task set Reply task set Reply task set  Setting up task set : Key Issues local worst-case delay < local deadline local worst-case delay < local deadline end-to-end worst-case delay < end-to-end deadline end-to-end worst-case delay < end-to-end deadline  Reply task set : Key Issues Slack distribution Slack distribution Service rate < 1 (periodic service rate determination) Service rate < 1 (periodic service rate determination)

9/23/ Observations   Processing of messages at a node can be extended up to their delay bounds.   This slack can be utilized to increase the worst-case delay tolerable at the computational nodes involved in processing the task set.   The actual processing time demanded by the messages of a task set during the run-time varies and is less than the worst-case specification.   A technique to adapt the clock speed periodically is introduced to take advantage of run-time variations

9/23/ Slack Distribution  The slack in a task set is the difference between the end- to-end deadline and the sum of the worst-case delays suffered at each node.  This slack can be distributed among the nodes serving task set to reduce the system energy consumption.  The slack is distributed among the nodes according to the service rate of the nodes.

9/23/ Service Rate Determination  Key Issues: Monitoring the traffic pattern Monitoring the traffic pattern Feedback incorporation while determining service rate. Feedback incorporation while determining service rate. Periodical service rate determination Periodical service rate determination guarantees processing of messages of outstanding intervals by their delay boundsguarantees processing of messages of outstanding intervals by their delay bounds guarantees processing of messages of upcoming interval by their delay boundsguarantees processing of messages of upcoming interval by their delay bounds Scheduling policies considered: FCFS & WRR Scheduling policies considered: FCFS & WRR

9/23/ FCFS Scheduling Policy and the corresponding queue is determined according to The service rate should be such that it must process the outstanding messages that arrived during the interval (t-j ,t-(j-1)  ) by their remaining delay bound. i.e., (d fcfs - j  ). The new service rate at the beginning of every interval is determined according to where k =

9/23/ WRR Scheduling Policy The new service rate at the beginning of every interval is determined according to and the corresponding queue is determined according to The service rate and the corresponding processing time demanded by the outstanding messages that arrived during the interval (t-j ,t-(j-1)  ) are given by

9/23/ Experimental Setup  Event driven simulator  Socket interface for communication  Intel PXA250 XScale Embedded Processor  Real-life test cases (DSP, Multimedia,..)

9/23/ Benchmarks Test Cases Number Of Nodes Number Of Connections Number Of Modes Synthetic I 3102 Synthetic II 5202 Synthetic III Multimedia443 DSP [4] Characteristics of various test cases

9/23/ Test Cases Mode 1 (nodes, connections) Mode 2 (nodes,connecti ons) Mode 3 (nodes,connectio ns) Synthetic (10,30) (9,20)(9,25)(10,30) Multimedia( 4,4) (3,2)(3,3)(4,4) Mode configurations for Multimedia and Synthetic test cases Benchmarks (Contd …)

9/23/ Energy Saving versus Slack distributation

9/23/ Energy Saving at different Modes

9/23/ Service rate at intervals

9/23/ Service rate vs MI

9/23/ Overhead due to number of task sets on service

9/23/ Summary  Energy Efficient Scheduling technique for Single Processor that: handles Sporadic and periodic task graphs with precedence constraints handles Sporadic and periodic task graphs with precedence constraints takes into account tasks with arbitrary response times takes into account tasks with arbitrary response times determines minimum speed for each task determines minimum speed for each task adapts clock speed to take advantage of idle intervals. adapts clock speed to take advantage of idle intervals.  A connection based task execution approach for distributed embedded systems that: effectively distributes the slack available in the connection to reduce system wide power consumption. effectively distributes the slack available in the connection to reduce system wide power consumption. periodically adjusts the clock speed to take advantage of run-time variations. periodically adjusts the clock speed to take advantage of run-time variations.  Experimental results indicate that the proposed techniques yield significant energy savings.

9/23/ References 1. 1.N. Kim, M. Ryu, S. Hong, M. Saksena, C. Choi, and H. Shin, “Visual assessment of a real time system design: A case study on a CNC controller,” in Proc. IEEE Real-Time Systems Symposium, December A. Burns, K. Tindell, and A. Wellings, “Effective analysis for engineering real-time fixed priority schedulers,” IEEE Trans. on Software Eng., vol. 21, no. 5, pp. 475–480, May C. Locke, D. Vogel, and T. Mesler, “Building a predictable avionics platform in Ada: A casestudy,” in Proc. IEEE Real-Time Systems Symposium, December C. M. Woodside and G. G. Monforton, “Fast allocation of processes in distributed and parallel systems,” Proc. IEEE Trans. Parallel & Distr. Systems., vol. 4, no. 2, pp , Feb

9/23/ References (Contd..) 5. G.Quan, and X.Hu, “Energy efficient fixed priority scheduling for real-time systems on variable voltage processors,” In Proc. Design Automation Conference, June A.Raha, N.Malcom, and W.Zhao, “Guaranteeing end-to-end deadlines in ATM networks,” In Proc. International conference on Distributed Computing Systems, May 1995.

9/23/ THANK YOU