Real-Time Systems and Programming Languages © Alan Burns and Andy Wellings Chapter 9: Real-Time Facilities.

Slides:



Advertisements
Similar presentations
Introduction to Embedded Systems Resource Management - III Lecture 19.
Advertisements

Concurrency Important and difficult (Ada slides copied from Ed Schonberg)
Timed Automata.
Chapter 7 User-Defined Methods. Chapter Objectives  Understand how methods are used in Java programming  Learn about standard (predefined) methods and.
© Andy Wellings, 2004 Roadmap  Introduction  Concurrent Programming  Communication and Synchronization  Completing the Java Model  Overview of the.
© Alan Burns and Andy Wellings, 2001 Characteristics of a RTS n Large and complex n Concurrent control of separate system components n Facilities to interact.
© Andy Wellings, 2004 Roadmap  Introduction  Concurrent Programming  Communication and Synchronization  Completing the Java Model  Overview of the.
Basic Real Time Concepts Systems Concepts Real-Time Definitions Events and Determinism CPU Utilization Real-Time System Design Issues Example Real-Time.
Scheduling Theory ITV Real-Time Systems Anders P. Ravn Aalborg University March 2007.
Programming R-T Abstractions TSW November 2009 Anders P. Ravn Aalborg University.
© Andy Wellings, 2004 Roadmap  Introduction  Concurrent Programming  Communication and Synchronization  Completing the Java Model  Overview of the.
Real-Time Systems Specification and Analysis ITV Mutiprogramming and Real-Time Programs Anders P. Ravn Aalborg University May 2009.
Java Programming, 3e Concepts and Techniques Chapter 5 Arrays, Loops, and Layout Managers Using External Classes.
1 Chapter 4 Language Fundamentals. 2 Identifiers Program parts such as packages, classes, and class members have names, which are formally known as identifiers.
Teaching material based on Distributed Systems: Concepts and Design, Edition 3, Addison-Wesley Copyright © George Coulouris, Jean Dollimore, Tim.
Concurrency in Ada Programming Languages 1 Robert Dewar.
Exceptions (Large parts of these copied from Ed Schonberg’s slides)
Concurrency in Ada What concurrency is all about Relation to operating systems Language facilities vs library packages POSIX threads Ada concurrency Real.
© Alan Burns and Andy Wellings, 2001 Programming in the Small n Aim: to remind you how to read/write programs in Ada 95, Java and ANSI C n Practicals will.
Chapter 11 Exception Handling and Event Handling.
© Andy Wellings, 2004 Roadmap  Introduction  Concurrent Programming  Communication and Synchronization  Completing the Java Model  Overview of the.
Real-Time Systems Specification and Analysis ITV Real-Time Systems Anders P. Ravn Aalborg University February 2006.
© Andy Wellings, 2004 Roadmap  Introduction  Concurrent Programming  Communication and Synchronization  Completing the Java Model  Overview of the.
Real-Time Systems and Programming Languages
1 Organization of Programming Languages-Cheng (Fall 2004) Concurrency u A PROCESS or THREAD:is a potentially-active execution context. Classic von Neumann.
CprE 458/558: Real-Time Systems
Real-Time Systems Specification and Analysis ITV Real-Time Systems Anders P. Ravn Aalborg University February 2009.
Concurrency - 1 Tasking Concurrent Programming Declaration, creation, activation, termination Synchronization and communication Time and delays conditional.
The Real-Time Java Profile ITV Real-Time Systems Anders P. Ravn Aalborg University February 2006.
© Andy Wellings, 2004 Roadmap  Introduction  Concurrent Programming  Communication and Synchronization  Completing the Java Model  Overview of the.
Chair of Software Engineering ATOT - Lecture 21, 16 June 2003 Advanced Topics in Object Technology Bertrand Meyer.
© Andy Wellings, 2004 Roadmap  Introduction  Concurrent Programming  Communication and Synchronization  Completing the Java Model  Overview of the.
1 Exception and Event Handling (Based on:Concepts of Programming Languages, 8 th edition, by Robert W. Sebesta, 2007)
Fundamentals of Python: From First Programs Through Data Structures
1 Physical Clocks need for time in distributed systems physical clocks and their problems synchronizing physical clocks u coordinated universal time (UTC)
Real-Time Software Design Yonsei University 2 nd Semester, 2014 Sanghyun Park.
REAL-TIME SOFTWARE SYSTEMS DEVELOPMENT Instructor: Dr. Hany H. Ammar Dept. of Computer Science and Electrical Engineering, WVU.
© The McGraw-Hill Companies, 2006 Chapter 4 Implementing methods.
- 1 - Embedded Systems - SDL Some general properties of languages 1. Synchronous vs. asynchronous languages Description of several processes in many languages.
Instructore: Tasneem Darwish1 University of Palestine Faculty of Applied Engineering and Urban Planning Software Engineering Department Concurrent and.
Reference: Ian Sommerville, Chap 15  Systems which monitor and control their environment.  Sometimes associated with hardware devices ◦ Sensors: Collect.
1 Concurrency Architecture Types Tasks Synchronization –Semaphores –Monitors –Message Passing Concurrency in Ada Java Threads.
REAL-TIME SOFTWARE SYSTEMS DEVELOPMENT Instructor: Dr. Hany H. Ammar Dept. of Computer Science and Electrical Engineering, WVU.
CSC321 Concurrent Programming: §5 Monitors 1 Section 5 Monitors.
11 G53SRP: Clocks and Times in RTSJ Chris Greenhalgh School of Computer Science.
Global Time in Distributed Real-Time Systems Dr. Konstantinos Tatas.
EEL The Real-Time Specification for Java (1)
ICS 313: Programming Language Theory Chapter 13: Concurrency.
Concurrency in Java Brad Vander Zanden. Processes and Threads Process: A self-contained execution environment Thread: Exists within a process and shares.
Real Time Programming Language. Intro A programming language represents the nexus of design and structure. But misuse of the programming language can.
1 G53SRP: Clocks and Time in Java Chris Greenhalgh School of Computer Science.
State Modeling. Introduction A state model describes the sequences of operations that occur in response to external stimuli. As opposed to what the operations.
CE Operating Systems Lecture 2 Low level hardware support for operating systems.
CE Operating Systems Lecture 2 Low level hardware support for operating systems.
Multithreaded programming  Java provides built-in support for multithreaded programming. A multithreaded program contains two or more parts that can run.
 In the java programming language, a keyword is one of 50 reserved words which have a predefined meaning in the language; because of this,
Data Design and Implementation. Definitions Atomic or primitive type A data type whose elements are single, non-decomposable data items Composite type.
For a good summary, visit:
Time Management.  Time management is concerned with OS facilities and services which measure real time.  These services include:  Keeping track of.
© Andy Wellings, 2004 Thread Priorities I  Although priorities can be given to Java threads, they are only used as a guide to the underlying scheduler.
1 G53SRP: Introduction to Real Time Scheduling Chris Greenhalgh School of Computer Science.
“Time” in the NSI Protocol Two notions of “Time” are important to NSI Connection Service – Absolute time Globally Coordinated Time and Date, “UTC” time.
Embedded Real-Time Systems Processing interrupts Lecturer Department University.
9.1 CLASS (STATIC) VARIABLES AND METHODS Defining classes is only one aspect of object-oriented programming. The real power of object-oriented programming.
State Modeling. Introduction A state model describes the sequences of operations that occur in response to external stimuli. As opposed to what the operations.
G53SRP: Real Time Threads in RTSJ (part I)
Specification and Validation of Real-Time Programs ©A. Mok 2009
Java Programming Language
Multithreaded Programming
CSE 153 Design of Operating Systems Winter 19
Presentation transcript:

Real-Time Systems and Programming Languages © Alan Burns and Andy Wellings Chapter 9: Real-Time Facilities

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 2 of 55 Aims To understand the role that time has in the design and implementation of real-time systems To introduce the real-time systems notion of time To illustrate how clocks are handled in Ada, Real- Time Java and POSIX To illustrate how delays and timeouts are handled in Ada, Real-Time Java and POSIX To consider how timing requirements can be specified using temporal scopes

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 3 of 55 Requirements Interfacing with time  accessing clocks so that the passage of time can be measured  delaying processes until some future time  programming timeouts so that the non-occurrence of some event can be recognized and dealt with Representing timing requirements — see next lecture  specifying rates of execution  specifying deadlines Satisfying timing requirements — covered later

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 4 of 55 A Notion of Time Transitivity: Linearity: Irreflexivity: Density:

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 5 of 55 Standard Time

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 6 of 55 Maximum difference between UT2 (which is based on astrological measurement) and IAT (which is based upon atomic measurements) is kept to below 0.5 seconds UT2 correction to UTO because of polar motion UT1 Correction of UT1 because of variation in the speed of rotation of the earth Duration of 9_192_631_770 periods of the radiation corresponding to the transition between two hyperfine levels of the ground state of the Caesium atom Seconds(3) International Atomic Time (IAT) Based upon Caesium atomic clock Coordinated Universal Time (UTC) An IAT clock synchronized to UT2 by the addition of occasional leap ticks Accuracy of current Caesium atomic clocks deemed to be one part of 10^13 (that is, one clock error per 300,000 years)

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 7 of 55 Access to a Clock by having direct access to the environment's time frame (e.g. GPS also provides a UTC service) by using an internal hardware clock that gives an adequate approximation to the passage of time in the environment

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 8 of 55 package Ada.Calendar is type Time is private; Calendar subtype Year_Number is Integer range ; subtype Month_Number is Integer range 1..12; subtype Day_Number is Integer range 1..31; subtype Day_Duration is Duration range _400.0; function Clock return Time;

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 9 of 55 Calendar II function Year(Date:Time) return Year_Number; function Month(Date:Time) return Month_Number; function Day(Date:Time) return Day_Number; function Seconds(Date:Time) return Day_Duration; procedure Split(Date:in Time; Year:out Year_Number; Month:out Month_Number; Day:out Day_Number; Seconds:out Day_Duration); function Time_Of(Year:Year_Number; Month:Month_Number; Day:Day _ Number; Seconds:Day _ Duration := 0.0) return Time;

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 10 of 55 function "+"(Left:Time; Right:Duration) return Time; function "+"(Left:Duration; Right:Time) return Time; function "-"(Left:Time; Right:Duration) return Time; function "-"(Left:Time; Right:Time) return Duration; function "<"(Left,Right:Time) return Boolean; // similarly for " “, ">=" Calendar III Time_Error:exception; -- Time_Error may be raised by Time_Of, -- Split, Year, "+" and "-" private implementation-dependent end Ada.Calendar;

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 11 of 55 Calendar IV A value of the private type Time is a combination of the date and the time of day The time of day is given in seconds from midnight Seconds are described in terms of a subtype Day_Duration Which is, in turn, defined by means of Duration Time base is implementation-defined No requirement to be synchronized with UTC

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 12 of 55 Duration This fixed point type Duration is one of the predefined scalar types and has a range which, although implementation dependent, must be at least -86_ _400.0 The value 86_400 is the number of seconds in a day The accuracy of Duration is also implementation dependent but the smallest representable value Duration'Small must not be greater than 20 milliseconds It is recommended in the ARM that it is no greater than 100 microseconds

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 13 of 55 Example Use The other language clock is provided by the optional package Real_Time This has a similar form to Calendar but is intended to give a finer granularity declare Old_Time, New_Time : Time; Interval : Duration; begin Old_Time := Clock; -- other computations New_Time := Clock; Interval := New_Time - Old_Time; end;

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 14 of 55 Real-Time Clock package Ada.Real_Time is type Time is private; Time_First: constant Time; Time_Last: constant Time; Time_Unit: constant := implementation_defined_real_number; type Time_Span is private; Time_Span_First: constant Time_Span; Time_Span_Last: constant Time_Span; Time_Span_Zero: constant Time_Span; Time_Span_Unit: constant Time_Span; Tick: constant Time_Span; function Clock return Time;

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 15 of 55 Real-Time Clock II function "+" (Left: Time; Right: Time_Span) return Time; function "+" (Left: Time_Span; Right: Time) return Time; -- similarly for "-", "<",etc function To_Duration(TS: Time_Span) return Duration; function To_Time_Span(D: Duration) return Time_Span;

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 16 of 55 Real-Time Clock III function Nanoseconds (NS: Integer) return Time_Span; function Microseconds(US: Integer) return Time_Span; function Milliseconds(MS: Integer) return Time_Span; type Seconds_Count is range implementation-defined; procedure Split(T : in Time; SC: out Seconds_Count; TS : out Time_Span); function Time_Of(SC: Seconds_Count; TS: Time_Span) return Time; private -- not specified by the language end Ada.Real_Time;

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 17 of 55 Metrics Time_Unit is the smallest amount of real time representable by the Time type The value of Tick must be no greater than 1 millisecond The range of Time (from the epoch that represents the program's start-up) must be at least 50 years Other important features of this time abstraction are described in the Real-Time Annex

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 18 of 55 declare use Ada.Real_Time; Start, Finish : Time; Interval : Time_Span := To_Time_Span(1.7); begin Start := Clock; -- sequence of statements Finish := Clock; if Finish - Start > Interval then raise Time_Error; -- a user-defined exception end if; end; Example: Timing a Sequence

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 19 of 55 Clocks in Real-Time Java Similar to those in Ada java.lang. System.currentTimeMillis returns the number of milliseconds since 1/1/1970 GMT and is used by used by java.util.Date Real-time Java adds real-time clocks with high resolution time types

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 20 of 55 RT Java Time Types public abstract class HighResolutionTime implements java.lang.Comparable { public abstract AbsoluteTime absolute(Clock clock, AbsoluteTime destination);... public boolean equals(HighResolutionTime time); public final long getMilliseconds(); public final int getNanoseconds(); public void set(HighResolutionTime time); public void set(long millis); public void set(long millis, int nanos); }

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 21 of 55 public class AbsoluteTime extends HighResolutionTime { // various constructor methods including public AbsoluteTime(AbsoluteTime T); public AbsoluteTime(long millis, int nanos); public AbsoluteTime absolute(Clock clock, AbsoluteTime dest); public AbsoluteTime add(long millis, int nanos); public final AbsoluteTime add(RelativeTime time);... public final RelativeTime subtract(AbsoluteTime time); public final AbsoluteTime subtract(RelativeTime time); }

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 22 of 55 public class RelativeTime extends HighResolutionTime { // various constructor methods including public RelativeTime(long millis, int nanos); public RelativeTime(RelativeTime time); public RelativeTime add(long millis, int nanos); public final RelativeTime add(RelativeTime time); public final RelativeTime subtract(RelativeTime time);... }

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 23 of 55 RT Java: Clock Class public abstract class Clock { public Clock(); public static Clock getRealtimeClock(); public abstract RelativeTime getResolution(); public AbsoluteTime getTime(); public abstract void getTime(AbsoluteTime time); public abstract void setResolution(RelativeTime resolution); }

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 24 of 55 RT Java: Measuring Time { AbsoluteTime oldTime, newTime; RelativeTime interval; Clock clock = Clock.getRealtimeClock(); oldTime = clock.getTime(); // other computations newTime = clock.getTime(); interval = newTime.subtract(oldTime); }

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 25 of 55 Clocks in C and POSIX ANSI C has a standard library for interfacing to “ calendar ” time This defines a basic time type time_t and several routines for manipulating objects of type time Real-time POSIX requires at least one clock of minimum resolution 50 Hz (20ms)

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 26 of 55 Delaying a Process In addition to clock access, processes must also be able to delay their execution either for a relative period of time or until some time in the future Relative delays Start := Clock; -- from calendar loop exit when (Clock - Start) > 10.0; end loop;

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 27 of 55 Delaying a Process To eliminate the need for these busy-waits, most languages and operating systems provide some form of delay primitive In Ada, this is a delay statement delay 10.0; Java: sleep; RT Java provides a high resolution sleep

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 28 of 55 Delays Time specified by program Granularity difference between clock and delay Interrupts disabled Process runnable here but not executing Process executing Time

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 29 of 55 Absolute Delays -- Ada START := Clock; FIRST_ACTION; delay (Clock - START); SECOND_ACTION; Unfortunately, this might not achieve the desired result START := Clock; FIRST_ACTION; delay until START ; SECOND_ACTION;

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 30 of 55 Absolute Delays As with delay, delay until is accurate only in its lower bound RT Java - sleep can be relative or absolute POSIX requires use of an absolute timer and signals

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 31 of 55 Drift The time over-run associated with both relative and absolute delays is called the local drift and it it cannot be eliminated It is possible, however, to eliminate the cumulative drift that could arise if local drifts were allowed to superimpose

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 32 of 55 Regular Activity task T; task body T is begin loop Action; delay 7.0; end loop; end T; Cannot delay for less than 7 seconds local and cumulative drift

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 33 of 55 Periodic Activity task body T is Interval : constant Duration := 7.0; Next_Time : Time; begin Next_Time := Clock + Interval; loop Action; delay until Next_Time; Next_Time := Next_Time + Interval; end loop; end T; Will run on average every 7 seconds local drift only If Action takes 8 seconds, the delay statement will have no effect

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 34 of 55 Programming Timeouts Timeouts can be added to any condition synchronisation primitive:  Semaphores  CCRs  Condition variables in monitors  Entries in protected objects Also on message passing

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 35 of 55 Message-Passing task Controller is entry Call(T : Temperature); end Controller; task body Controller is -- declarations, including New_Temp : Temperature; begin loop accept Call(T : Temperature) do New_Temp := T; end Call; -- other actions end loop; end Controller;

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 36 of 55 Message-Passing task Controller is entry Call(T : Temperature); end Controller; task body Controller is -- declarations begin loop select accept Call(T : Temperature) do New_Temp := T; end Call; or delay 10.0; -- action for timeout end select; -- other actions end loop; end Controller;

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 37 of 55 Timeout on Message Send loop -- get new temperature T Controller.Call(T); end loop; loop -- get new temperature T select Controller.Call(T); or delay 0.5; null; end select; end loop; select T.E -- entry E in task T else -- other actions end select; The null is not strictly needed but shows that again the delay can have arbitrary statements following, that are executed if the delay expires before the entry call is accepted

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 38 of 55 Timeouts and Entries The above examples have used timeouts on inter- task communication; it is also possible, within Ada, to do timed (and conditional) entry call on protected objects select P.E ; -- E is an entry in PO P or delay 0.5; end select;

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 39 of 55 Timeouts on Actions select delay 0.1; then abort -- action end select; If the action takes too long, the triggering event will be taken and the action will be aborted This is clearly an effective way of catching run-away code

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 40 of 55 Imprecise Computation: Ada declare Precise_Result : Boolean; begin Completion_Time := compulsory part Results.Write(...); -- call to procedure in -- external protected object select delay until Completion_Time; Precise_Result := False; then abort while Can_Be_Improved loop -- improve result Results.Write(...); end loop; Precise_Result := True; end select; end;

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 41 of 55 Real-Time Java With Real-Time Java, timeouts on actions are provided by a subclass of AsynchronouslyInterrupted-Exception called Timed public class Timed extends AsynchronouslyInterruptedException implements java.io.Serializable { public Timed(HighResolutionTime time) throws IllegalArgumentException; public boolean doInterruptible(Interruptible logic); public void resetTime(HighResolutionTime time); }

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 42 of 55 Imprecise Computation public class PreciseResult { public resultType value; // the result public boolean preciseResult; // indicates if it is imprecise } public class ImpreciseComputation { private HighResolutionTime CompletionTime; private PreciseResult result = new PreciseResult(); public ImpreciseComputation(HighResolutionTime T) { CompletionTime = T; //can be absolute or relative } private resultType compulsoryPart() { // function which computes the compulsory part }

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 43 of 55 public PreciseResult Service() // public service { Interruptible I = new Interruptible() { public void run(AsynchronouslyInterruptedException exception) throws AsynchronouslyInterruptedException { // this is the optional function which improves on the // compulsory part boolean canBeImproved = true; while(canBeImproved) { // improve result synchronized(this) { // write result -- // the synchronized statement ensures // atomicity of the write operation } result.preciseResult = true; }

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 44 of 55 public void interruptAction( AsynchronouslyInterruptedException exception) { result.preciseResult = false; } }; Timed t = new Timed(CompletionTime); result.value = compulsoryPart(); // compute the compulsory part if(t.doInterruptible(I)) { // execute the optional part with the timer return result; } else {... }; }

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 45 of 55 Timing Requirements Work on a more rigorous approach to this aspect of real- time systems has followed two largely distinct paths:  The use of formally defined language semantics and timing requirements, together with notations and logics that enable temporal properties to be represented and analysed  A focus on the performance of real-time systems in terms of the feasibility of scheduling the required work load on the available resources (processors and so on)

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 46 of 55 Timing Verification The verification of a real-time system can thus be interpreted as requiring a two stage process:  verifying requirements — given an infinitely fast reliable computer, are the temporal requirements coherent and consistent, that is, have they the potential to be satisfied?  verifying the implementation — with a finite set of (possible unreliable) hardware resources, can the temporal requirements be satisfied?

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 47 of 55 Temporal Scopes deadline — the time by which the execution of a TS must be finished minimum delay — the minimum amount of time that must elapse before the start of execution of a TS maximum execution time — of a TS maximum elapse time — of a TS Temporal scopes with combinations of these attributes are also possible

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 48 of 55 Now Deadline a b c Minimum delay Maximum elapse time Units of execution Maximum execution time = a + b +c

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 49 of 55 Temporal Scopes Can be  Periodic  Sporadic  Aperiodic Deadlines can be: l Hard l Soft l Firm l Interactive — performance issue

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 50 of 55 Specifying Tasks and TS process periodic_P;... begin loop IDLE start of temporal scope... end of temporal scope end; The time constraints take the form of maximum and/or minimum times for IDLE and the requirement that the end of the temporal scope be by some deadline

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 51 of 55 Deadline The deadline can itself be expressed in terms of either absolute time execution time since the start of the temporal scope, or elapsed time since the start of the temporal scope

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 52 of 55 Aperiodic Processes process aperiodic_P;... begin loop wait for interrupt start of temporal scope... end of temporal scope end;

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 53 of 55 Summary To interact with the environment, need:  access to a clock  the ability to delay  ability to recognise timeouts Both relative and absolute delay mechanisms are needed Absolute delays allows cumulated drifts to be avoided

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 54 of 55 Summary Ada directly supports two clocks.  Calendar time - wall-based clock, no requirement to be synchronized with UTC.  Real-time - based on a monotonically non-decreasing clock whose epoch is system start-up. Real-time Java is similar except:  the wall clock is defined to be millisecond since a defined epoch (1/1/1970 UTC).  the real-time clock - monotonic, milliseconds and nanoseconds since 1/1/1970 UTC.

Real-Time Systems and Programming Languages: © Alan Burns and Andy Wellings 55 of 55 Summary The degree of importance of timing requirements is a useful way of characterising real-time systems Constraints that must be met are termed hard; those that can be missed occasionally, or by a small amount, are called soft; firm can be missed, but not value in being late It is useful to introduce the notion of a temporal scope  deadline for completion of execution  minimum delay before start of execution  maximum execution time  maximum elapse time