# Signal Chain Benchmarking – ACI Motor Control Application

Ashwini Athalye Alex Tessarolo (Texas Instruments)

#### Signal Chain is the sample to output response



## Benchmark application representative of real sensorless AC Induction Motor Control application

No special HW needed, SW based solution (C Code)



Application executes 1024 iterations of the real-time loop (sensing + control code + actuation) and outputs min, max and average execution cycles.

#### Cache based systems introduce large variance

• Flash execution with **No cache** (with wide prefetch, lookahead prefetch)

| Device | CPU Clock<br>(MHz) | Cache | Benchmark – Min<br>(usec) | Benchmark – Max<br>(usec) | Variance<br>(usec) |
|--------|--------------------|-------|---------------------------|---------------------------|--------------------|
| C28    | 200                | No    | 2.84                      | 3.03                      | 0.19               |

Flash execution with L1 Instruction and Data Cache - Cold cache vs Hot cache

| Device | CPU Clock<br>(MHz) | Cache | Benchmark – Min<br>Warm cache (usec) | Benchmark – Max<br>Cold cache (usec) | Variance<br>(usec) |
|--------|--------------------|-------|--------------------------------------|--------------------------------------|--------------------|
| M7     | 480                | Yes   | 3.98                                 | 6.63                                 | 2.65               |

#### **ADC** architecture impacts real-time response

- Sequential scan Application has 2 ADC channels in a sequence
  - C28: Multiple ADC results registers: Results can be read directly from register bank
  - M7 : Single ADC results registers: Needs DMA to prevent overrun
- Interrupt response
  - C28: ADC early interrupt: after 1<sup>st</sup> channel sampling completes
  - M7 : DMA interrupt: DMA buffer half-full or full

| Device | CPU Clock<br>(MHz) | ADC Clock<br>(MHz) | CPU HW INT<br>(cycles) | ADC with DMA                                            | Benchmark ADC INT Response<br>[ADC sampling + CPU HW INT +<br>Compiler context save]<br>(cycles) |
|--------|--------------------|--------------------|------------------------|---------------------------------------------------------|--------------------------------------------------------------------------------------------------|
| C28    | 200                | 50                 | 14                     | No<br>(INT – 1 <sup>st</sup> chan<br>sampling complete) | <b>57</b> (10.6% of total cycles 537)                                                            |
| M7     | 480                | 50                 | 12                     | Yes<br>(INT – DMA half<br>full)                         | <b>198</b> (17.3% of total cycles 1143)                                                          |

#### Jitter fairly small for both devices

• Variance in ISR execution of 1024 iterations

| Device | Benchmark – Jitter<br>(cycles)                                           |  |
|--------|--------------------------------------------------------------------------|--|
| M7     | <ul><li>20 (Flash with cache)</li><li>10 (Tightly Coupled RAM)</li></ul> |  |
| C28    | <b>12</b> (Flash) <b>12</b> (RAM)                                        |  |

### Thank You.