# APPLICATION DESIGN PROCESS USING PLATFORM 1 (RTC SCHEDULER WITH INTERRUPTS)

V1 9/17/2025

#### **NC STATE** UNIVERSITY

#### Where are we in the class?



### Extended Topic Map: Class 09



## **EXAMPLE APPLICATIONS: FIRST VERSIONS**WITH RTC SCHEDULER AND INTERRUPTS

## Applications: Functionality First, then Performance

|                         |             |                                          | Blinky Control<br>Panel    | Quad. Dec. w/Z<br>Limit Switch | Waveform<br>Generator         | LCD<br>Controller    | Touch screen         | Scope                                                  | Serial Comms.                                     | I <sup>2</sup> C Comms.                                                | μSD via SPI<br>Comms.                       | SMPS<br>Controller               |
|-------------------------|-------------|------------------------------------------|----------------------------|--------------------------------|-------------------------------|----------------------|----------------------|--------------------------------------------------------|---------------------------------------------------|------------------------------------------------------------------------|---------------------------------------------|----------------------------------|
| Providing Functionality | Interfacing | Simple Digital                           | In, Out                    | In                             |                               |                      | Out                  |                                                        |                                                   |                                                                        |                                             | PWM Out                          |
|                         |             | Complex Digital                          | PWM                        |                                |                               | Bus Out              |                      |                                                        | In, Out                                           | In, Out                                                                | In, Out                                     |                                  |
|                         |             | Analog                                   | ADC In, CMP In,<br>DAC Out |                                | Out                           |                      | ADC In               | ADC In,<br>Cmp In                                      |                                                   |                                                                        |                                             | ADC In with<br>Sync.<br>Sampling |
|                         | Async       | # Processes for async.<br>exec.          | 4                          | 1,2                            | 1,2                           | 0                    | 0, 1                 | 1,2                                                    | 2                                                 | 1                                                                      | 2                                           | 1                                |
|                         |             | Sync and Do: Coarse<br>Triggering        |                            | Digital Edge<br>Detection      | Periodic<br>Output<br>Updates |                      |                      | Ana. Edge Det.,<br>Periodic In. Smplg.,<br>Buffer mgt. | Tx Rdy, Rx Done<br>events. Producer<br>& Consumer | Data Producers &<br>Consumers. I2C Device<br>read response.            | Tx Rdy, Rx<br>Done events.<br>Prod. & Cons. | ADC In with<br>Sync.<br>Sampling |
|                         | Sync and .  | Internal, Fine Grain<br>Block/Sched/Trig | ADC conv. time             |                                |                               |                      | ADC<br>conv.<br>time |                                                        |                                                   | I2C message internal<br>events & timing reqts.<br>for conditions, data |                                             |                                  |
|                         | S           | Sync and Don't:<br>Sharing & Races       |                            |                                |                               |                      |                      | LCD Ctlr Sharing,<br>Data buffer mgt.                  | Tx, Rx byte<br>queues                             | Tx, Rx Msgs                                                            | Tx, Rx byte<br>queues                       |                                  |
|                         | IPC         | Inter-Process Comm.                      |                            | Shared Position<br>Variable    |                               |                      |                      | Data buffer                                            |                                                   |                                                                        |                                             |                                  |
| Meeting Perf.<br>Reats. |             | Timing Stability                         | 1                          |                                | 1                             |                      |                      | 2                                                      |                                                   |                                                                        |                                             | 1                                |
|                         |             | Responsiveness                           | 1                          |                                |                               |                      |                      | 1                                                      |                                                   |                                                                        | 1                                           | 1                                |
|                         | -           | Reducing SW<br>Overhead                  |                            |                                | 2                             | 1- Perf.<br>Optimiz. |                      | 2                                                      |                                                   | 1 – series of timed I/O<br>events per message.<br>FSM vs. RTOS         |                                             | 2                                |
| Σ̈́                     |             | Tolerating Timing<br>Mismatches          |                            |                                | 2                             |                      |                      | 2                                                      | 2                                                 |                                                                        | 2                                           |                                  |

#### **Application Design Overview**

- Note: Provide just enough detail, but not too much.
   Later design stages and iteration will address details as needed.
- Identify system's inputs, outputs and processes, and their key connections
- Identify key hardware, software stages in each process
  - Initially consider only peripheral's fundamental features (examine enhancements later as needed)
- Analyze processes for synchronization and communication driven by I/O requirements
  - May be event-triggered or time-triggered
  - What triggers/releases/allows process (e.g. thread's work code) to start execution: event or time?
    - Do A once for every time E1 happens
    - Do B every 100 ms
  - Is there any internal synchronization (wait until)? Again, may be triggered by event or time
    - Do X, wait at least 3.2 ms but no more than 3.8 ms, do Y, Wait for event E, do Z.

- Analyze process interactions for sync. and comm.
  - Identify explicit sync. and comm. between processes
    - Triggering, shared data and resources (one-way data flows, other data flows)
  - Identify implicit sync. required by any communication
    - Notification of new data? Buffer old data? How much? how to manage buffer? How to handle overrun condition?
- Define architecture (high-level design)
  - Select how to implement most critical/difficult processing chain steps and interactions
  - Draw from toolbox of methods
    - Hardware: peripherals, DMA, programmable logic
    - Software: Program structure, algorithms
    - Both: Interrupts, task scheduler, support features from OS
- Continue with detailed design and implementation
  - Functionality first, then performance
  - Iterate design to improve performance

## **Identify System Fundamentals**

- Identify system's input and output devices and signals and processes, and their key connections
  - Information for key signals
    - Format: analog? digital? comm. protocol? bit width? ...
    - Challenging timing and performance requirements
  - Note: Feedback from output (motor) to some inputs
- Identify key hardware and software stages in each process
  - Initially consider only peripheral's fundamental features (later will examine enhancements as needed)



#### **NC STATE** UNIVERSITY

Synchronization Requirements for Inputs and Outputs

Set Foint

Potentioneter Analog

Voltage

Shaft

Position

ADC

Position

ATO

Determine

Position

Pos

- Analysis may drive early decisions: using interrupts, HW peripheral features, etc. Covered in Define Architecture soon.
- First synchronization: What triggers/releases/allows process (e.g. thread's work code) to start execution? Event or time?
  - Get Target Position: Time-triggered, periodic: run at least 5 times /second (at most every 200 ms)
  - Detect Position: Event-triggered: run on rising edge of A or rising edge of Z.
    - Could also be time-triggered if polled frequently enough
  - Control Motor: Time-triggered, periodic: run every 1 ms to set Speed to 1 (1 kHz PWM output signal) and update Direction
- Is there any more synchronization within the process after the first sync.? Event or time?
  - Control Motor: Time-triggered, delay. Clear Speed to 0 after 0 to 1 ms, depending on drive effort requested

#### Sync. and Comm. from Key Interactions between Processes



- Identify and describe synchronization and communication between processes
  - Additional triggering, shared data and resources (one-way data flows, other data flows, ...)
- Identify implicit sync. required within the communication.
  - Notification of new data? Handle over-run how? Buffer old data? How much? How to manage buffer? etc.

## Define Architecture (High-Level Design)

We have a high-level plan for what to do



- Next, refine that plan to decide how to do it
  - Decide **how** key stages in key processing chains will be performed
  - Pick from toolbox of methods
    - Hardware, software, scheduler, OS, and combinations
  - Note that a stage in the processing chain may contain another processing chain



#### **Example Applications and Subsystems**

- Blinky Control Panel
- Quadrature Decoder w/Limit Switch
- Waveform Generator
- LCD Controller
- Touch screen
- Scope
- Communications
  - Basic: Serial Comms., SPI
  - Higher protocol layers: I<sup>2</sup>C, Secure Digital via SPI
- SMPS Controller