# ECE 271 – Microcomputer Architecture and Applications Lecture 22

Vince Weaver http://web.eece.maine.edu/~vweaver

vincent.weaver@maine.edu

11 April 2019

#### Announcements

- Read Chapter 20
- Midterm Tuesday the 16th



### **Midterm Review**

• Shorter than last time.

There will be a take-home section (floating point)

- Interrupts
  - Vectored interrupts there is a table low in memory (the interrupt vector) which has a lookup table of pointers. When an interrupt happens, the CPU looks up the address from the appropriate pointer and jumps to it
  - Interrupt handlers on Cortex-M are just normal



functions (the CPU does "stacking", saving some registers on the stack automatically for you. A magic value is put in the Link register so the CPU knows you are returning from a handler).

Once an interrupt happens, you enter the handler.
 Often you will need to ACK (acknowledge) the interrupt so the CPU knows you are done handling it. How this happens can vary with what hardware you use (it's often clearing a bit, but somehow it happens automatically).

Enabling an interrupt is multiple steps. You have



to enable it in the device (For example, in the timer registers). Then you have to tell the NVIC (interrupt controller) to enable it. Then you have to enable it on the CPU globally with \_\_asm("CPIE i"). Finally you have to enable whatever hardware will be triggering the interrupt.

 Some devices (such as TIM4) can have multiple causes that trigger the same interrupt (i.e., overflow and capture). You can figure out which one was the cause by checking certain bits to see the source of the interrupt.



#### • Timers

- $\circ$  Lots of registers to set.
- $\circ$  Set what clock source to use system wide.
- You can then use the prescalar to divide the frequency down.
- You can set to count up (from 0 to the ARR register value), count down (from ARR to 0) or center count (count up and down).
- PWM
  - pulse width modulation: you set a CCR value that when the counter gets bigger it triggers an output to



go high. This way you can generate a regular pulse with an overall frequency based on ARR and a duty cycle based on CCR.

- Input Capture
  - $\circ$  You can use the Timer to measure the length of signals.
  - When the incoming signal has a transition (high to low or low to high) the timer will grab the current timer count and store it in a register. (optionally also an interrupt can be triggered).
  - By saving the previous value, and subtracting from the current value, you can calculate how many clock ticks



have happened

- If your signal is wider than the maximum value of the counter, an overflow can happen. In order to measure signals that long you can catch the overflows and count them, and then add that time in to the measured time.
- Fixed/Floating Point: there will be a take-home question where you will convert a decimal value to IEEE-574 floating point and back.



# **Analog/Digital Converters**

- Take an analog signal out, quantize it to a set of digital values
- Compared to a reference voltage
- Key terms:
  - Sampling rate (how many conversions per second).
    Can be millions or more.
  - Number of bits in ADC (resolution)
    Varies between 6 to 24 bits usually. 12 or 24 bits common.



This is how many steps (voltages) can be represented
 Power dissipation – how much power used for conversion.



# Many, Many types of converters (textbook)

- Sigma-delta (low-speed)
  - low-sampling rate but high resolution (100 k-samples 12-24 bits) which is fine for things like audio
- Successive-approximation (SAR) (low-power)
  Low-power and moderate sampling rate, 5 million samples/s
- Pipelined (high-speed)
  - oscilloscopes, HDTV, radar, needing grater than 5MSPS



# Many, Many types of converters (Wikipedia)

- Direct conversion
  - Parallel: Just an array of  $2^N$  comparators. Fast, but need a lot (256 for 8 bit)
  - $\circ$  Counter: count up and stop when gets to it
  - Servo-tracking: if too high, count down, if too low, count up, until it matches
- Integrating





• Apple II

#### RC circuit controls 555 timer. Count how long it takes for it to trigger.



# **Digital Quantization**

- Uses binary search
- $\bullet$  Internal DAC (opposite of ADC) set to 1/2 Vref, compares it with Vin
- If Vin is larger, sets MSB (high bit), otherwise 0
- Next it tries either 3/4Vref or 1/4 Vref, does comparison
- Repeats, for each N bits
- Tradeoff between resolution and time



# Sampling and Hold Amplifier (SHA)

- Uses a capacitor to grab the voltage and hold it while the ADC happens
- Capacitor takes a while to charge, need to wait  $V_C(t) = V_{in} \times (1 e^{-fractT_C})$
- Wait until the sampling time



### **ADC Sampling Error**

• Difference from ideal result



#### **STM32L Hardware implementation**

- STM32 board uses SAR with SHA
- Always uses HSI clock no matter the board is using (can use 1, 2, or 4 divider in SMP register)
- Time to convert is sample time + channel conversion time. For 12-bit ADC



#### **STM32L4 Hardware implementation**

- Three ADC modules: ADC1, ADC2, ADC3
- ADC1 and ADC2 can run in dual mode (both run at same time)
- Can be 12, 10, 8, or 6 bits
- 16 bits via "over-sampling"
- Provide Vref- and Vref+ externally, internal reference 3.0V
- Clock rate is independent of processor clock
- With 80MHz clock at 12 bits can get 5.33 million



samples/second

 Can have a watchdog AWD which watches and if voltage goes above or below certain value, trigger interrupt (why?)



# **ADC conversion modes**

- One input channel
  - Start conversion
  - ADC\_DR holds result
  - $\circ$  EOC end of conversion flag set
  - $\circ$  Optionally generate interrupt
  - o regular vs injected?
  - $\circ$  can be put into continuous mode
- Multiple input channels
  - Round robin switch between channels



#### **Data Alignment**

• Can be aligned in various ways



### **ADC Input Channels**

- Various GPIO pins can be hooked in
- Single-ended or differential (Single ended compare against ground, differential takes two pins and compares the difference)



# Triggering

- Can trigger with software ADSTART
- External trigger
  - Timer outputs
  - $\circ$  External pins
- Should set delay so doesn't retrigger so quickly



# Lab #10

- Potentiometer voltage divider
- 12-bit ADC, single ended
- $ADVResult = \frac{V_{input}}{V_{REF}} * 4096$
- $V_{input} = \frac{ADCResult}{4096} * V_{REF}$
- LED transmitter/receiver



### Other issues from lab not covered?

- Conversion sequence (switching between channels automatically)
- DMA
- Internal reference voltages
- Injected channels (you can have a setup where it regularly samples each channel in turn, but an injected one happens on demand and takes precedence.

