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
Resolve the captcha to access the links!