Download presentation
Presentation is loading. Please wait.
1
Embedded Systems Design: A Unified Hardware/Software Introduction 1 Chapter 4 Standard Single Purpose Processors: Peripherals
2
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 2 Introduction Single-purpose processors –Performs specific computation task –Custom single-purpose processors Designed by us for a unique task –Standard single-purpose processors “Off-the-shelf” -- pre-designed for a common task a.k.a., peripherals serial transmission analog/digital conversions
3
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 3 Timers, counters, watchdog timers Timer: measures time intervals –To generate timed output events e.g., hold traffic light green for 10 s –To measure input events e.g., measure a car’s speed Based on counting clock pulses E.g., let Clk period be 10 ns And we count 20,000 Clk pulses Then 200 microseconds have passed 16-bit counter would count up to 65,535*10 ns = 655.35 microsec., resolution = 10 ns Top: indicates top count reached, wrap-around 16-bit up counter Clk Cnt Basic timer Top Reset 16
4
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 4 Timer Range –Maximum time interval. Equals to 2 N input intervals. Resolution –Minimum input time interval, or the input clock period. Range = n * t –Where: 0 < n < 2 N, t = clock period or timer resolution.
5
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 5 Counters Counter: like a timer, but counts pulses on a general input signal rather than clock –e.g., count cars passing over a sensor –Can often configure device as either a timer or counter 16-bit up counter Clk 16 Cnt_in 2x1 mux Mode Timer/counter Top Reset Cnt
6
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 6 Timers – Examples A PIC 16F84 clock runs at 4.194304 MHz, with an 8-bit timer, what frequencies can be obtained with TOP (overflow) interrupts? f int =f/2 N f int =4.194304 4/2 8 f int =4.096 KHz A 16-bit counter, using auto- reload, with f=1.2 MHz is used to generate an interrupt at every 500 s. What should the reload value be? T int =(2 N – R)/T 500 s = (2 N – R)/f R = (2 16 – 1.2*10 6 *500*10 -6 ) R = 65536 – 600 R = 64936
7
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 7 Other timer structures Top2 Time with prescaler 16-bit up counter Clk Prescaler Mode Interval timer –Indicates when desired time interval has passed –We set terminal count to desired interval Number of clock cycles = Desired time interval / Clock period Cascaded counters Prescaler –Divides clock –Increases range, decreases resolution 16-bit up counter Clk 16 Terminal count = Top Reset Timer with a terminal count Cnt 16-bit up counter Clk 16-bit up counter 16 Cnt2 Top1 16/32-bit timer Cnt1 16
8
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 8 Input Capture Timer When an external signal is asserted, the timer’s values is recorded.
9
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 9 Example: Reaction Timer indicator light reaction button time: 100 ms LCD /* main.c */ #define MS_INIT 63535 void main(void){ int count_milliseconds = 0; configure timer mode set Cnt to MS_INIT wait a random amount of time turn on indicator light start timer while (user has not pushed reaction button){ if(Top) { stop timer set Cnt to MS_INIT start timer reset Top count_milliseconds++; } turn light off printf(“time: %i ms“, count_milliseconds); } Measure time between turning light on and user pushing button –16-bit timer, clk period is 83.33 ns, counter increments every 6 cycles –Resolution = 6*83.33=0.5 microsec. –Range = 65535*0.5 microseconds = 32.77 milliseconds –Want program to count millisec., so initialize counter to 65535 – 1000/0.5 = 63535
10
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 10 Watchdog timer scalereg checkreg timereg to system reset or interrupt oscclk prescaler overflow /* main.c */ main(){ wait until card inserted call watchdog_reset_routine while(transaction in progress){ if(button pressed){ perform corresponding action call watchdog_reset_routine } /* if watchdog_reset_routine not called every < 2 minutes, interrupt_service_routine is called */ } watchdog_reset_routine(){ /* checkreg is set so we can load value into timereg. Zero is loaded into scalereg and 11070 is loaded into timereg */ checkreg = 1 scalereg = 0 timereg = 11070 } void interrupt_service_routine(){ eject card reset screen } Must reset timer every X time unit, else timer generates a signal Common use: detect failure, self-reset Another use: timeouts –e.g., ATM machine –16-bit timer, 2 microsec. resolution –timereg value = 2*(2 16 - 1)–X = 131070–X –For 2 min., X = 120,000 microsec.
11
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 11 WDT
12
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 12 WDT
13
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 13 WDT
14
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 14 Contador de RPM Um MCU tem 2 C/T de 16 bits, prescaler com divisões de 2, 4 ou 8, e recebem um clock estável entre 500 kHz e 8 MHz. Medir a rotação do eixo de um motor que varia entre 100 rpm e 1000 rpm. Um sensor está ligado ao eixo e produz 60 pulsos por ciclo. –Cada rotação do motor produz entre 100 Hz e 1000 Hz 60 cpr * 100 rpm = 6000 cpm / 60 spm = 100 cps –Contar os pulsos do sensor em cada segundo! Um C/T como temporizador gerando o período de 1 segundo Um C/T como contador de pulsos do sensor dentro de cada segundo –Geração de períodos de 1 segundo 1/2 16 = 15,259 s ou 65,536 kHz (usando o sinal overflow) Usando o prescaler de 8 8 * 65,536 = 524,288 kHz
15
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 15 Serial Transmission Using UARTs embedded device 1 0 0 1 1 0 1 1 Sending UART 10011011 Receiving UART 10011011 start bit data end bit UART: Universal Asynchronous Receiver Transmitter –Takes parallel data and transmits serially –Receives serial data and converts to parallel Parity: extra bit for simple error checking Start bit, stop bit Baud rate –signal changes per second –bit rate usually higher
16
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 16 UART Sync
17
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 17 I2C
18
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 18 I2C – PCF8574
19
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 19 I2C – PCF8574
20
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 20 SPI Serial Paralel Interface
21
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 21 SPI Timing
22
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 22 LED Must use resistor to limit current. Lei de Ohm: –R = V/I LED = diodo –V F e I F –V F determinado pela cor –I F determina a intensidade Resistor limita I F
23
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 23 Displays 7 Segments Dot Dot Matrix
24
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 24 7-Segments
25
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 25 7-Segments – Multiplexed
26
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 26 LCD Nematic type
27
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 27 LCD Polarizing
28
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 28 LCD Types
29
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 29 LCD Color
30
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 30 Pulse width modulator clk pwm_o 25% duty cycle – average pwm_o is 1.25V clk pwm_o 50% duty cycle – average pwm_o is 2.5V. clk pwm_o 75% duty cycle – average pwm_o is 3.75V. Generates pulses with specific high/low times Duty cycle: % time high –Square wave: 50% duty cycle Common use: control average voltage to electric device –Simpler than DC-DC converter or digital-analog converter –DC motor speed, dimmer lights Another use: encode commands, receiver uses timer to decode
31
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 31 Controlling a DC motor with a PWM void main(void){ /* controls period */ PWMP = 0xff; /* controls duty cycle */ PWM1 = 0x7f; while(1){}; } The PWM alone cannot drive the DC motor, a possible way to implement a driver is shown below using an MJE3055T NPN transistor. Internal Structure of PWM clk_div cycle_high counter ( 0 – 254) 8-bit comparator controls how fast the counter increments counter < cycle_high, pwm_o = 1 counter >= cycle_high, pwm_o = 0 pwm_o clk Relationship between applied voltage and speed of the DC Motor DC MOTOR 5V From processor
32
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 32 LCD controller E R/W RS DB7–DB0 LCD controller communications bus microcontroller 8 void WriteChar(char c){ RS = 1; /* indicate data being sent */ DATA_BUS = c; /* send data to LCD */ EnableLCD(45); /* toggle the LCD with appropriate delay */ }
33
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 33 Keypad controller
34
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 34 KBD Key bouncing
35
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 35 Key Debouncing RC Network/LP Filter
36
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 36 Latch
37
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 37 Software –Scan column –Scan line –Filter closed key Time-out interruption
38
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 38 Stepper motor controller Red A White A’ Yellow B Black B’ MC3479P 1 5 4 3 2 7 8 6 16 15 14 13 12 11 10 9 Vd A’ A GND Bias’/Set Clk O|C Vm B B’ GND Phase A’ CW’/CCW Full’/Half Step Stepper motor: rotates fixed number of degrees when given a “step” signal –In contrast, DC motor just rotates when power applied, coasts to stop Rotation achieved by applying specific voltage sequence to coils Controller greatly simplifies this
39
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 39 Stepper motor with controller (driver) 2 A’ 3 A 10 7 B 15 B’ 14 MC3479P Stepper Motor Driver 8051 P1.0 P1.1 Stepper Motor CLK CW’/CCW The output pins on the stepper motor driver do not provide enough current to drive the stepper motor. To amplify the current, a buffer is needed. One possible implementation of the buffers is pictured to the left. Q1 is an MJE3055T NPN transistor and Q2 is an MJE2955T PNP transistor. A is connected to the 8051 microcontroller and B is connected to the stepper motor. void main(void){ */turn the motor forward */ cw=0; /* set direction */ clk=0; /* pulse clock */ delay(); clk=1; /*turn the motor backwards */ cw=1; /* set direction */ clk=0; /* pulse clock */ delay(); clk=1; } /* main.c */ sbit clk=P1^1; sbit cw=P1^0; void delay(void){ int i, j; for (i=0; i<1000; i++) for ( j=0; j<50; j++) i = i + 0; }
40
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 40 Stepper motor without controller (driver) Stepper Motor 8051 GND/ +VP2.4 P2.3 P2.2 P2.1 P2.0 A possible way to implement the buffers is located below. The 8051 alone cannot drive the stepper motor, so several transistors were added to increase the current going to the stepper motor. Q1 are MJE3055T NPN transistors and Q3 is an MJE2955T PNP transistor. A is connected to the 8051 microcontroller and B is connected to the stepper motor. Q2 +V 1K Q1 1K +V A B 330 /*main.c*/ sbit notA=P2^0; sbit isA=P2^1; sbit notB=P2^2; sbit isB=P2^3; sbit dir=P2^4; void delay(){ int a, b; for(a=0; a<5000; a++) for(b=0; b<10000; b++) a=a+0; } void move(int dir, int steps) { int y, z; /* clockwise movement */ if(dir == 1){ for(y=0; y<=steps; y++){ for(z=0; z<=19; z+4){ isA=lookup[z]; isB=lookup[z+1]; notA=lookup[z+2]; notB=lookup[z+3]; delay(); } /* counter clockwise movement */ if(dir==0){ for(y=0; y<=step; y++){ for(z=19; z>=0; z - 4){ isA=lookup[z]; isB=lookup[z-1]; notA=lookup[z -2]; notB=lookup[z-3]; delay( ); } void main( ){ int z; int lookup[20] = { 1, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0 }; while(1){ /*move forward, 15 degrees (2 steps) */ move(1, 2); /* move backwards, 7.5 degrees (1step)*/ move(0, 1); }
41
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 41 Analog-to-digital converters proportionality V max = 7.5V 0V 1111 1110 0000 0010 0100 0110 1000 1010 1100 0001 0011 0101 0111 1001 1011 1101 0.5V 1.0V 1.5V 2.0V 2.5V 3.0V 3.5V 4.0V 4.5V 5.0V 5.5V 6.0V 6.5V 7.0V analog to digital 4 3 2 1 t1t2t3 t4 0100100001100101 time analog input (V) Digital output digital to analog 4 3 2 1 0100100001100101 t1t2t3 t4 time analog output (V) Digital input
42
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 42 Given an analog input signal whose voltage should range from 0 to 15 volts, and an 8-bit digital encoding, calculate the correct encoding for 5 volts. Then trace the successive-approximation approach to find the correct encoding. 5/15 = d/(28-1) d= 85 Successive-approximation method Digital-to-analog conversion using successive approximation 01000000 Encoding: 01010101 ½(V max – V min ) = 7.5 volts V max = 7.5 volts. ½(7.5 + 0) = 3.75 volts V min = 3.75 volts. 0000000001000000 ½(7.5 + 3.75) = 5.63 volts V max = 5.63 volts ½(5.63 + 3.75) = 4.69 volts V min = 4.69 volts. 01010000 ½(5.63 + 4.69) = 5.16 volts V max = 5.16 volts. 01010000 ½(5.16 + 4.69) = 4.93 volts V min = 4.93 volts. 01010100 ½(5.16 + 4.93) = 5.05 volts V max = 5.05 volts. 01010100 ½(5.05 + 4.93) = 4.99 volts 01010101
43
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 43 R2R Ladder DAC
44
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 44 Digital-to-analog conversion Use resistor tree: R 2R 4R 8R bnbn b n-1 b n-2 b n-3 V out
45
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 45 Flash A/D conversion N-bit result requires 2 n comparators: encoder V in...
46
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 46 RAMP ADC
47
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 47 Dual-slope conversion Use counter to time required to charge/discharge capacitor. Charging, then discharging eliminates non-linearities. V in timer
48
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 48 SAR ADC Algorithm 1.The successive approximation Analog to digital converter circuit typically consists of four chief subcircuits: 2.A sample and hold circuit to acquire the input voltage (Vin). 3.An analog voltage comparator that compares Vin to the output of the internal DAC and outputs the result of the comparison to the successive approximation register (SAR). 4.A successive approximation register subcircuit designed to supply an approximate digital code of Vin to the internal DAC. 5.An internal reference DAC that supplies the comparator with an analog voltage equivalent of the digital code output of the SAR for comparison with Vin.
49
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 49 SAR ADC
50
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 50 Distributed-charge SAR ADC The DAC conversion is performed in four basic steps: 1.First, the capacitor array is completely discharged to the offset voltage of the comparator, VOS. This step provides automatic offset cancellation. 2.Next, all of the capacitors within the array are switched to the input signal, vIN. The capacitors now have a charge equal to their respective capacitance times the offset voltage minus the input voltage upon each of them. 3.In the third step, the capacitors are then switched so that this charge is applied across the comparator's input, creating a comparator input voltage equal to -vIN. 4.Finally, the actual conversion process proceeds. First, the MSB capacitor is switched to VREF, which corresponds to the full-scale range of the ADC. Due to the binary-weighting of the array the MSB capacitor forms a 1:1 divided between it and the rest of the array. Thus, the input voltage to the comparator is now -vIN plus VREF/2. Subsequently, if vIN is greater than VREF/2 then the comparator outputs a digital 1 as the MSB, otherwise it outputs a digital 0 as the MSB. Each capacitor is tested in the same manner until the comparator input voltage converges to the offset voltage, or at least as close as possible given the resolution of the DAC.
51
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 51 Sample-and-hold Required in any A/D: converter V in
52
Embedded Systems Design: A Unified Hardware/Software Introduction, (c) 2000 Vahid/Givargis 52 Understanding analog to digital converter specifications, By Len Staller. Embedded Systems Design, 02/24/05. –http://www.embedded.com/showArticle.jhtml?articleID=604 03334
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.