Real-Time Embedded Systems Specialization

Real-Time Embedded Systems Specialization

English | MP4 | AVC 1280×720 | AAC 44KHz 2ch | 160 Lessons (42h 18m) | 7.75 GB

Boost your career with real-time systems expertise. Master real-time theory, methods of analysis and design, and put them into practice.

What you’ll learn

  • Rate Monotonic theory and policies
  • Methods of Rate Monontoic analysis
  • Real-time system design techniques
  • Engineering principles for allocating functionality and services to hardware, firmware or software implementation

Skills you’ll gain

  • Fault Tolerance
  • Rate Monotonic Analysis
  • Real-Time Operating System (RTOS)
  • Linux On Embedded Systems
  • Asymmetric Multi-core Processing

The Real-Time Embedded Systems specialization is a series of four course taking you from a beginning practitioner, to a more advanced real-time system analyst and designer. Knowledge and experience gained on hard to master topics such as predictable response services, when to allocate requirements to hardware or software, as well as mission critical design will enhance your engineering talent. You will gain experience building a simple, but real, system project with real-time challenges, that will boost your confidence.

The hands-on, at home, project hardware is affordable, widely available, and quick-time-to market methods leverage Linux real-time extensions, open source RTOS (Real-Time Operating System), as well as tried and true cyclic executives.

After you complete all four courses in the series, you can consider yourself an intermediate to more advanced real-time system practitioner. This knowledge is invaluable for medical, aerospace, transportation, energy, digital entertainment, telecommunications, and other exciting embedded career options.

The series stresses hands-on practice and assessment of your learning progress, not only based on knowledge acquisition, but by teaching you to put theory into practice and how to evaluate design options and make optimal choices. The unique final project allows you to see real-time challenges with your eyes, to debug interactively, and build a simple at-home detection, tracking and synchronization system.

Applied Learning Project
Project work includes a series of real-time processing and concurrency exercises along with analysis and design in the first two courses. The third course provides experience with mission critical components like error correction code memory, flash file systems, and redundant hardware. In the final course, you put all of the practice together into your own design to build a real-time system that you can test at home. The project covers topics including: concurrency, Linux kernel modules, machine vision, co-processors, and correct function with timing constraints. You will use specific real-time extensions to Linux and compare advantages and disadvantages of Linux to more traditional RTOS, cyclic executive, and FPGA options. The experience you gain can be used to launch additional exploration of hybrid FPGA systems (e.g. Altera and Xilinx), GP-GPU (e.g. NVIDIA), and multi-core scale-up (e.g. ARM A and R-Series) as well as MCU scale-down solutions (ARM M-Series microprocessors).

Table of Contents

real-time-embedded-systems-concepts-practices

exploration-of-rt-challenges-and-concepts

introduction
1 course-introduction
2 extra-help-home-lab-set-up_instructions
3 extra-help-code-walkthroughs-and-demonstrations_instructions
4 scan-and-question-rtes-terminology_instructions

real-time-challenges-and-concepts
5 predictable-response-software
6 simple-linux-real-time-services-compared-to-non-real-time-introduction
7 assignment-1-hello-world-simple-thread-creation_instructions
8 simple-linux-real-time-services-compared-to-non-real-time-conclusion

real-time-fundamentals-and-architecture-styles
9 extra-help-code-walkthroughs-and-demonstrations_instructions
10 introduction-to-scheduling-theory-for-real-time-systems
11 rm-optimal-priority-policy-and-service-request-and-response-timeline

comparison-of-linux-posix-real-time-threads-to-rtos-and-mfe-multi-frequency
12 extra-help-code-walkthroughs-and-demonstrations_instructions
13 timing-analysis-rate-monotonic-priority-assignment-policy-by-example
14 challenges-with-linux-user-and-kernel-space-real-time-applications
15 assignment-2-multiple-threads_instructions
16 basic-and-multi-threaded-code-review_peer_assignment_instructions

module-1-review-of-concepts-discussed
17 re-read-recite-and-review-rtes-terminology-we-used_instructions

quality-of-service-theory-from-best-effort-to-hard-real-time

real-time-utility-curves-and-practice-creating-srt-and-hrt-threads
18 code-demonstration-smp-compared-to-amp
19 code-walkthrough-starter-code-for-amp-using-thread-affinity
20 assignment-3-implementing-linux-real-time-threads_instructions
21 assignment-3-implementing-linux-real-time-threads_peer_assignment_instructions
22 real-time-scheduling-utility-curves

measuring-and-tracking-relative-and-absolute-time-on-rt-embedded-systems
23 code-walkthrough-rt-clock
24 review-of-absolute-time-and-date-standards-and-resources
25 cpu-core-affinity-and-rt-clock-code-review_peer_assignment_instructions

rate-monotonic-timing-analysis-of-feasibility-and-safety-margin
26 scan-and-question-original-paper-on-rate-monotonic-theory-liu-layland_instructions
27 optional-reading-on-linux-nptl-and-sched-deadline_instructions
28 rate-monotonic-scheduling-analysis-by-worst-case-inspection
29 rate-monotonic-scheduling-feasibility-vs-safety-and-exceeding-the-rm-lub

review-of-concepts-and-module-2-quiz

scheduling-and-concept-of-real-time-services

fixed-priority-rma-interference-preemption-and-scheduler-state-machine
30 priority-preemptive-scheduler-state-machine-for-linux-and-vxworks
31 service-code-structure-driven-by-interrupts
32 summary-of-key-points-and-liu-layland-rma-uses-and-limitations
33 more-details-on-liu-and-layland-rma-limitations-and-work-arounds

methods-of-sequencing-service-requests-by-example
34 code-walkthrough-posix-software-interval-timer-example
35 code-walkthrough-generic-sequencing-using-an-interval-timer
36 comparison-of-cyclic-executive-rtos-and-linux-rt-service-implementation
37 practice-using-generic-sequencer-to-create-scenario_peer_assignment_instructions

software-scheduling-and-real-time-policies-and-schedulers
38 introduction-to-worst-case-analysis-hand-diagramming-of-rm-schedules
39 worst-case-analysis-schedule-where-rm-fails-above-the-lub
40 example-where-rm-succeeds-above-the-lub-for-a-harmonic-service-set
41 example-of-scheduling-above-the-lub-at-100-utility-that-is-feasible
42 analysis-of-a-harmonic-service-schedule-by-hand-diagramming-for-rm-and-rr
43 introduction-to-cheddar-rma-tool
44 using-cheddar-to-check-hand-analysis-of-schedules_peer_assignment_instructions

module-3-quiz

overview-of-real-time-hardware-architectures-and-software-stacks

multi-core-processors-simple-microcontroller-real-time-and-advanced
45 space-shuttle-multi-frequency-executive-architecture_instructions
46 introduction-arm-m-series-r-series-and-a-series
47 overview-of-single-board-computers-used-for-real-time-education
48 real-time-architecture-and-configuration-for-applications_peer_assignment_instructions

rtos-options-open-or-proprietary-and-os-with-posix-real-time-extensions
49 using-linux-for-this-course-rationale-and-observations
50 assignment-4-pthreads-with-cpu-core-affinity-in-linux-to-emulate-amp_instructions
51 assignment-4-pthreads-with-cpu-core-affinity-in-linux-to-emulate-amp_peer_assignment_instructions

use-of-co-processors-in-real-time-systems
52 code-demonstration-thread-gridding-concepts-for-multi-core
53 using-multiple-cores-with-threads-to-speed-up-processing_peer_assignment_instructions

section-4-quiz

Resources

guidelines-for-code-quality-peer-reviews
54 resources

rt-terminology-guide-and-notes
55 resources

home-lab-required-for-this-course-and-series
56 Coursera-Raspberry-Pi-for-RTES-Series-Setup
57 resources

textbook-rtecs-with-linux-and-rtos
58 Real-Time_Embedded_Components_and_Systems_with_Linux_and_RTOS
59 Real_Time_Embedded_Components_and_System
60 resources

basic-makefile-skills-by-example
61 resources

posix-pthread-programming-resources
62 pthreads
63 resources

code-cu-boulder-linux-example-code-public
64 resources

recording-code-walk-throughs-for-peer-review
65 RTES_Raspberry-PI_3b___192.168.1.96_pi_2020-08-14_15-00-51
66 resources

paper-liu-layland-rate-monotonic-theory
67 resources

example-all-timing-diagrams-syslog-traces
68 download
69 resources

paper-space-shuttle-primary-avionic-software
70 resources

optional-paper-native-posix-threads-library
71 resources

optional-paper-linux-sched-deadline-policy
72 resources

optional-paper-exact-rm-feasibilty-analysis
73 resources

optional-paper-porting-vxworks-to-linux
74 resources

code-walkthough-basic-pthread-starter-code
75 L-C1-S02-Code-Walkthrough-1
76 resources

code-walkthrough-processes-vs-threads
77 L1-C1-S02-Code-Walkthrough-2
78 resources

code-walkthrough-vxworks-hard-coded-sequence
79 Untitled_Project
80 resources

code-walkthrough-posix-rt-threads
81 RT-Thread-Starter-Code-Walkthroughs
82 resources

code-walkthrough-posix-rt-thread-code
83 POSIX-RT-Starter-Code-Demonstration
84 resources

code-walkthrough-hard-coded-linux-sequencing
85 Linux-RT-Ex-0-Example-Schedule
86 resources

code-demonstration-generic-rt-sequencer
87 CW-7-1-C1-S03-Demonstration-of-Sequencer-Generic-using-POSIX-Clocks-and-Timer-Services
88 resources

code-walkthrough-linux-sequencer-generic
89 Untitled_Project
90 resources

code-demonstration-smp-compared-to-amp
91 CW-3-AMP-vs-SMP-Demonstration
92 resources

code-walk-through-starter-code-for-amp
93 Untitled_Project
94 resources

code-walkthrough-rt-clock-relative-time
95 CW-RT-Clock-code
96 resources

video-archive-at-cu-boulder
97 resources

all-rtes-series-notes-for-download
98 resources

real-time-embedded-theory-analysis

real-time-scheduling-and-rate-monotonic-least-upper-bound-derivation

introduction
99 course-assumed-real-time-knowledge-and-overview
100 extra-help-home-lab-set-up_instructions

real-time-scheduling-policies-overview-fixed-and-dynamic
101 code-walkthrough-syslog-for-tracing-and-autograded-assignments
102 rate-monotonic-fixed-priority-policy-and-optimality-review
103 rate-monotonic-scheduling-within-the-least-upper-bound
104 challenges-with-and-alternatives-to-fixed-priority-rm-policy
105 deadline-monotonic-extensions-to-rate-monotonic-policy
106 deadline-driven-scheduling-using-dynamic-priority-alternatives

real-time-fixed-priority-scheduling-feasibility-least-upper-bound
107 read-review-and-understand-derivations-in-original-rma-paper-liu-layland_instructions
108 rm-lub-derivation-introduction
109 two-cases-that-drive-the-rm-least-upper-bound
110 rm-least-upper-bound-intersection-point
111 rm-least-upper-bound-derivation-conclusion

rm-exact-fixed-priority-feasibility-analysis-with-worst-case-analysis
112 optional-rate-monotonic-exact-analysis_instructions
113 necessary-and-sufficient-feasibility-by-worst-case-analysis-exact-test
114 exact-feasibility-for-rate-monotonic-policy-with-scheduling-point
115 exact-feasibility-for-rate-monotonic-using-completion-test

service-design-feasibility-analysis-practice-and-methods-of-implementation

fixed-priority-timing-diagram-methods-practice-and-theory
116 comparison-of-rm-policy-to-round-robin
117 recall-method-for-rm-fixed-priority-scheduling-timing-diagram-creation
118 more-complex-rm-timing-diagrams
119 timing-diagram-with-a-harmonic-case
120 timing-diagram-with-a-full-utility-harmonic-case
121 timing-diagram-example-comparing-rm-and-edf

rt-service-design-and-implementation-patterns
122 rt-extensions-to-posix-1003-1-in-linux-qnx-solaris-freebsd-etc_instructions
123 optional-resources-for-posix-1003-1-rt-extensions_POSIX_4_Programmers_Guide
124 optional-resources-for-posix-1003-1-rt-extensions_instructions
125 optional-resources-for-posix-1003-1-rt-extensions_posix_faq
126 posix-rt-extension-support
127 general-design-pattern-part-1-amp-rt-functions-services-and-systems
128 general-design-pattern-part-2-mulit-core-multi-service-amp-systems
129 implementation-pattern-periodic-services-with-posix-rt-threads-interval-timers
130 message-queues-for-synchronization-and-data-sharing
131 code-walkthrough-posix-rt-feature-demonstration

linux-service-wcet-concepts-and-tracing-to-evaluate-jitter-and-drift
132 methods-to-determine-worst-case-execution-time-wcet
133 methods-for-wcet-speed-up-to-meet-deadlines
134 service-request-period-jitter-and-drift

dynamic-priority-earliest-deadline-first-and-least-laxity-first

using-edf-for-real-time-systems
135 rate-monotonic-vs-edf-judgement-day-paper_instructions
136 advantages-of-dynamic-priorities-and-when-to-use-edf
137 disadvantages-of-dynamic-priorities-and-when-edf-should-not-be-used

using-llf-for-real-time-systems
138 advantages-of-dynamic-adaptive-scheduling-when-to-use-llf
139 disadvantages-of-dynamic-adaptive-scheduling-when-llf-should-not-be-used
140 final-comparison-of-edf-and-llf-failure-modes-and-recovery

using-cheddar-to-analyze-fixed-and-dynamic-priority-schedules
141 cheddar-tool-introduction-and-overview

synchronization-and-bounded-vs-unbounded-blocking

bounded-and-unbounded-blocking-challenges
142 note-on-linux-methods-of-synchronization-compared-to-rtos
143 bounded-blocking-for-service-release
144 bounded-blocking-and-execution-efficiency-impact-on-rt-systems
145 definition-of-unbounded-blocking-and-examples-of-root-causes
146 code-walkthrough-circular-wait-deadlock-demonstration
147 code-walkthrough-can-you-think-of-a-simple-way-to-break-deadlock-after-a-timeout

unbounded-priority-inversion-due-to-blocking
148 priority-inversion-unbounded-and-priority-inheritance-protocol_instructions
149 review-of-semaphore-use-and-necessity-of-critical-section-c-s
150 code-walk-through-unbounded-priority-inversion-demonstration

solutions-to-unbounded-priority-inversion
151 priority-inheritance-priority-ceiling-and-priority-ceiling-emulation

mars-pathfinder-case-study
152 mars-pathfinder-problem-rolling-reset-3-days-prior-to-closest-approach-to-mars
153 mars-pathfinder-root-cause-analysis
154 mars-pathfinder-bug-localization-and-the-fix

Resources

home-lab-required-for-this-course-and-series
155 Coursera-Raspberry-Pi-for-RTES-Series-Setup
156 resources

code-cu-boulder-linux-example-code-public
157 resources

textbook-rtecs-with-linux-and-rtos
158 Real-Time_Embedded_Components_and_Systems_with_Linux_and_RTOS
159 Real_Time_Embedded_Components_and_System
160 resources

rt-terminology-guide-and-notes
161 resources

recording-code-walk-throughs-for-peer-review
162 RTES_Raspberry-PI_3b___192.168.1.96_pi_2020-08-14_15-00-51
163 resources

fundamentals-of-edf-book-and-key-papers
164 resources

reference-key-least-laxity-first-papers
165 resources

reference-priority-inheritance-protocols
166 resources

timing-analysis-examples-for-rm-edf-and-llf
167 resources

cheddar-3-2-tool-and-examples-updated
168 resources

paper-liu-layland-rate-monotonic-theory
169 resources

optional-the-evolution-of-real-time-linux
170 resources

video-archive-at-cu-boulder
171 resources

all-rtes-series-notes-for-download
172 resources

real-time-mission-critical-systems-design

device-i-o-interfaces-and-drivers-for-real-time-systems

introduction
173 course-goals-and-learning-objectives
174 detailed-overview-with-course-assumed-prior-knowledge
175 extra-help-home-lab-setup_Raspberry-Pi-Home-Lab-RTES-Setup
176 extra-help-home-lab-setup_instructions

device-interfaces-for-embedded-i-o
177 scalable-embedded-i-o-bus-architectures
178 demonstration-i-o-cpu-or-memory-bound
179 drivers-and-device-interfaces
180 using-linux-uvc-driver-to-acquire-video-frames-with-opencv-and-v4l2

rtos-example-device-interface-for-vxworks-compared-to-linux
181 digging-deeper-into-v4l2-api-and-uvc-driver-camorama-v4l2-ctl-etc
182 code-walkthrough-bt878-vxworks-rtos-device-interface
183 key-differences-between-linux-and-rtos-drivers

layered-network-and-communication-drivers-for-distributed-rtes-amp
184 rt-services-communication-and-synchronization
185 using-point-to-point-serial-and-tcp-ip-for-embedded-systems

fault-tolerant-memory-and-storage-for-mission-critical-systems

memory-and-mission-critical-systems-concepts
186 why-we-need-ecc-single-event-upset-fault-tolerance
187 secded-approach-to-memory-protection
188 hamming-secded-formulation-walk-through

models-and-emulators-for-hamming-code-for-secded
189 analysis-secded-ecc-using-a-model-excel
190 secded-ecc-software-emulator

wear-leveling-for-rtes-nand-flash-filesystems-and-databases
191 flash-memory-hardware-device-overview
192 flash-file-systems-sector-erase-wear-leveling-introduction
193 flash-wear-leveling-example-conclusion

stored-data-protection-for-embedded-systems
194 raid-for-rt-embedded-systems-mission-critical-data
195 code-demonstration-xor-raid-for-data-loss-fault-tolerance
196 code-walkthrough-file-based-raid-5-for-rtes

solving-performance-and-reliability-defects-in-real-time-systems

code-optimization-to-meet-deadlines
197 optimizing-single-threaded-code-with-the-compiler
198 optimizing-code-thread-level-sequential-and-parallel

tracing-and-profiling-analysis-for-deadlines-using-software-in-circuit-swic
199 tracing-and-profiling-tools-overview
200 tracing-and-profiling-application-code-gcov-syslog-and-gprof
201 profiling-and-tracing-your-platform-and-application-with-sysprof-and-kernelshark
202 tracing-linux-kernel-and-network-stack-events

top-rtes-coding-errors-recommendations-and-code-improvement
203 overview-of-top-linux-programming-errors
204 note-on-linux-methods-of-synchronization
205 best-practices-for-rtes-programming

difference-between-high-availability-and-high-reliability-for-hard-and-soft-real

high-availability-definition
206 fdir-fault-detection-isolation-and-recovery-theory
207 high-availability-definition-in-terms-of-5-9-s-uptime-or-better

reliability-and-availability-rasm-design-principles
208 system-integration-testing-hardware-firmware-and-software
209 making-software-reliable-with-sqa

infamous-system-failures-and-learning-root-cause-analysis
210 infamous-mission-critical-system-failures-root-cause-analysis

Resources

home-lab-required-for-this-course
211 Raspberry-Pi-Home-Lab-RTES-Setup
212 resources

rt-terminology-guide-and-notes
213 resources

textbook-rtecs-with-linux-and-rtos
214 Real-Time_Embedded_Components_and_Systems_with_Linux_and_RTOS
215 Real_Time_Embedded_Components_and_System
216 resources

code-cu-boulder-linux-example-code-public
217 resources

recording-code-walk-throughs-for-peer-review
218 Video-on-Xbox-Gamebar-and-Mac-Video-Capture-for-a-Code-Walkthrough-or-Demo
219 resources

starter-code-from-u-of-colorado-boulder
220 resources

basic-makefile-skills-with-examples
221 resources

top-30-linux-and-rtes-mistakes-how-to-fix
222 resources

example-linux-drivers-from-jerry-cooperstein
223 resources

video-for-linux-2-v4l2-api-uvc-driver
224 resources
225 uvcvideo
226 v4l2

raspberry-pi-linux-driver-help
227 resources

advanced-unix-linux-and-network-programming
228 resources

error-correction-code-hamming-examples
229 resources

example-file-raid-srs-software-req-ts-spec
230 resources

infamous-mission-critical-systems-failures
231 resources

cu-boulder-course-video-archive
232 resources

all-rtes-series-notes-for-download
233 resources

real-time-project-embedded-systems

rtes-project-goals-and-objectives

introduction
234 course-goals-and-learning-objectives
235 course-detailed-overview-with-assumed-prior-knowledge
236 extra-help-home-lab-setup-for-rtes-project_Home-Lab-Setup-Video
237 extra-help-home-lab-setup-for-rtes-project_instructions

standard-project-description
238 background-concepts-used-for-rtes-project
239 detecting-external-clock-tick-with-machine-vision
240 final-peer-review-assessment-of-rtes-project

standard-project-goals-and-objectives
241 verifying-frame-synchronization-to-external-clock-on-every-frame
242 rtes-project-demonstration-of-1-hz-solution
243 rtes-project-demonstration-of-10-hz-solution
244 design-notations-used-for-software-services
245 more-software-design-methods-and-notations_instructions

tools-and-methods
246 code-walkthrough-v4l2-video-for-linux-2-camera-interface-demonstration
247 code-demonstration-frame-difference-interactive-opencv-example
248 use-of-cheddar-for-timing-analysis
249 general-methods-for-tracing-and-profiling-rt-embedded-systems
250 linux-syslog-gnu-profiling-and-htop-for-rtes-project

completion-of-rtes-project-and-preliminary-functional-testing

external-clock-synchronization-with-machine-vision-architecture
251 request-for-proposal-goals-and-objectives-for-the-project_instructions
252 simple-design-that-does-not-work-and-why
253 better-design-example-but-not-fault-tolerant
254 better-design-somewhat-fault-tolerant
255 best-practice-design-example

rtes-project-starter-code-tick-detection-frame-capture-and-sequencing
256 download-rtes-project-starter-code-and-build-and-review_instructions
257 external-clock-tick-detection-starter-code-walk-through
258 simple-frame-capture-of-1800-frames-in-one-process
259 sequencing-rt-services-using-a-software-interval-timer

timing-analysis-comparison-of-actual-to-predicted-service-time-events

running-and-analyzing-first-rtes-project-complete-implementation
260 coding-tips-and-debugging
261 analysis-methods-of-multi-service-timing-verification

common-issues-with-rtes-project
262 most-common-rtes-project-errors-a-list-to-consider_instructions
263 review-of-common-mistakes

methods-for-system-verification-and-validation-of-rtes-project

methods-of-rtes-project-system-profiling
264 using-sysprof-and-kernel-shark-on-linux
265 wireshark-network-transport-tracing-with-linux

plotting-and-analyzing-trace-data
266 code-walk-through-demonstration-of-syslog-for-timing-analysis

final-project-review-and-presentation

final-rtes-project-peer-inspection
267 example-peer-review-design-demonstration-v4l-example
268 example-peer-review-design-walk-through-opencv-example

final-rtes-project-and-overall-course-summary
269 take-away-and-final-notes-for-course

Resources

home-lab-setup-required
270 Home-Lab-Setup-Video
271 resources

textbook-rtecs-with-linux-and-rtos
272 Real-Time_Embedded_Components_and_Systems_with_Linux_and_RTOS
273 Real_Time_Embedded_Components_and_System
274 resources

rt-terminology-guide-and-notes
275 resources

code-cu-boulder-linux-example-code-public
276 resources

cheddar-3-2-tools-and-examples-updated
277 resources

standard-rtes-project-starter-code
278 resources

making-a-peer-review-video-for-upload
279 Video-on-Xbox-Gamebar-and-Mac-Video-Capture-for-a-Code-Walkthrough-or-Demo
280 resources

example-rtes-project-demonstration-v4l2
281 RTES-Demo-Full-Final-Cut
282 resources

example-rtes-project-demonstration-opencv
283 RTES-OpenCV-Demo-Full-Final-Cut
284 resources

printable-rtes-project-peer-review-rubric
285 resources

notes-on-clocks-to-use-for-rtes-project
286 resources

a-few-important-notes-on-jetson-nano
287 resources

run-with-sudo-and-or-check-file-permissions
288 resources

using-a-linux-ram-disk-and-or-software-raid
289 resources

more-creative-rtes-project-examples
290 resources

cu-boulder-course-video-archive
291 resources

all-rtes-series-notes-for-download
292 resources

Homepage