Transcript Lecture 10

Computing Machinery
Chapter 10: Microcontrollers
Microprocessors vs. Microcontrollers
The primary difference between a microprocessor and a microcontroller is that the
microcontroller includes more supporting functions such as on-board memory and I/O
than the microprocessor.
Until recently, microcontroller units (MCU's) were considered less powerful than
microprocessors, however, continued development has lead to MCU's that meet or
exceed the throughput (number of equivalent instructions per second) of high-end
microprocessors.
Microcontroller
The power of some modern
microcontrollers is equal to highend CPU's but more specific in
their designs and applications than
general-purpose microprocessors.
Microcontrollers offer many
application specific features such
as
I2C
and
CAN
bus
communications
and
video
controllers.
Embedded Systems
An embedded system is a device or module designed for a specific purpose and based on
some computational (software modifiable) element. One of the key features of an
embedded system is real-time operation.
http://www.ece.cmu.edu/~koopman/iccd96/iccd96.html
Harvard Architecture
The Harvard Architecture separates the data and instructions into separate memory
units each with their own bus. Besides speeding up the data transfer rate, separating
the data from the instructions permits us to implement different bus widths and word
sizes for program and data memory space.
Digital Signal Processors
Digital Signal Processors (DSP's) are types of microcontrollers that are more specialized
for a particular application. DSP represent around 20% of the total MCU market.
DSP's are particularly well suited to real-time operations in which a data stream, video,
audio, etc. is modified in someway as it is passed along to another device or
component.
Most DSP's are based on the Harvard Architecture. DSP's commonly include analog-todigital (A/D) conversion for their inputs and digital-to-analog (D/A) conversion of their
outputs.
Pulse Width Modulation
Pulse Width Modulation (PWM) - Many MCU are designed to generate variable width
squarewave signals as shown below. A pulse width modulated (PWM) signal is a
squarewave with a varying ratio of high and low logic levels, called the duty cycle.
The PWM signal is defined by two parameters, the frequency and the duty cycle.
A 10% duty cycle signal is at a logical high 10% of the time and low 90% of the
time. The average rate at which the signal oscillates between logic levels is given
by the frequency in cycles per second (Hertz).
Digital to Analog Conversion
A PWM signal can be filtered using passive electronic components (e.g. an RC
[resistor-capacitor] network) to generate a smoothed average voltage level. A
controlled voltage level or power level can be delivered using PWM signals.
Serial I/O Interface (UART)
The Universal Asnychronous Receiver/Transmitter (UART) is a popular form of serial
communication between digital devices.
A number of bits are presented to the UART in parallel and are then serialized,
transmitted to another UART where they are converted back into a binary vector.
The UART specification does not include details of the communication details.
In fact, there are several interface standards in common use (e.g. RS232, RS422 and
RS485). For embedded systems the RS232 standard is the most popular.
The Serial Peripheral Interface (SPI)
This is a communications protocol used on most MCU's as an inexpensive
alternative to multiple pin parallel communications. SPI is used for many
applications in MCU including memory data block transfers. The SPI interface
include a clock line, a data-in, a data-out and a chip enable line, named as,
SCLK
MISO
MOSI
CS
-
serial clock
master input, slave output
master output, slave input
chip select (optional, usually inverted polarity)
Basic-X35 Schematic
AT25256
I2C Communications
The Inter-Integrated Circuit (I2C) computer bus is used to interface many different
types of peripherals to MCU's or other embedded systems when a high data throughput
is not required.
The I2C uses bidirectional data and clock lines with open-collector logic. The standard
data rate for the I2C is 100 kilobits/second. It also support a low-speed 10 Kbits/s or
lower.
The I2C protocol is ideal for sending control signals to remote devices, collecting A/D
signals from sensors and accessing slow-speed non-volatile RAM.
One of the most valuable features is that periperals can be connected and removed from
the I2C bus while powered up. This is possible because of the open-collector logic in
which a bus line is either set to ground or no-connection.
In open-collector circuits, a logical high is achieved by placing pull-up resistor on each
open-collector line.
Controller Area Nework (CAN) Bus
This is a multicast shared serial
bus standard. The CAN bus was
designed to operate in high noise
conditions, which makes it a
preferred communications standard
for
applications
involving
electrical motors and internal
combustion engines.
The CAN protocol uses errorcorrecting codes to automatically
detect and recover bit errors in data
words. The the full data transfer
rate of 1Mbit/s the total length of
the CAN network is limited to less
than 50 meters.
Analog-to-Digital (ADC)
Many of the devices and sensors interfaced to a MCU produce varying voltage levels
(analog signals) rather than binary vectors (digital signals). For this reason most modern
MCU's include built-in analog-to-digital (A/D) conversion circuits. These circuits accept
a voltage level on an input line and generate an internal binary encoded value that
corresponds to the magnitude of the voltage.
Aliasing
When we choose a sampling rate, we are setting a limit on the maximum frequency (or
time rate of change) of the signal that we will be able to measure.
Shown below are two signals of different frequencies. The lower frequency signal is
being sampled at a rate of 12 samples per cycle of the signal. If we replace this signal
with one with a frequency that is 11 times higher we will be sampling this signal a little
more that once per cycle. As shown the sampled voltage levels will match those of the
lower frequency signal. This effect is called aliasing.
To prevent aliasing we need to sample at a rate at least twice as high (in samples per
second) at the highest frequency signal we want to measure (in cycles/second).
Digital to Analog (D/A)
This is the process of converting a digital (binary encoded) value into an analog voltage
level. This operation is much less common on an MCU, but can be implemented using a
varying duty-cycle signal and some passive electronics for filtering (see Pulse Width
Modulation above). A much better aproach is to use a linear amplifier as a summing
circuit, as shown in Figure 10-6. This is an example of a digital to analog (D/A) circuit
called an R2R ladder network.
http://www.play-hookey.com/analog/d2a_converter.html
Prescalar
A prescaler is a circuit that divides an incoming clock signal by a predetermined
amount. An N level prescaler is sometimes called a divide-by-N counter.
AVR A/D
The AVR MCU includes 8 A/D input circuits. These cicuits can operate in two different
modes, either single conversion and free run.
When in single conversion mode, each conversion must be prompted by the running
programming.
In free-run mode the A/D conversion is started and will run continuously with updated
values being placed in the ADC data register.
BasicX Microcontrollers
The BasicX system is the MCU and the software development environment for a PCcompatible desktop computer running the Microsoft Windows operating system.
BASIC programs are written and compiled on the PC and downloaded onto the
BasicX MCU through a serial interface to an EEPROM or a parallel USB interface
(which needs some additional circuitry).
As with the AVR and PIC18, the BasicX is in-circuit/FLASH programmable. The
BX-24 and BX-35 IC's are depicted in Figure 10-22. The BX-35 is also available as a
surface mount IC.
BasicX-35
BasicX-24
The BasicX MCU's offer the following features:
25 I/O Lines BX-35 (16 I/O Lines BX-24)
- (17 TTL I/O BX-35) (8 TTL I/O BX-24)
- 8 Channel Analog-to-Digital Converters (10-bit) or TTL
32 KB EEPROM (external for BX-35) for program and data storage
On-chip RAM 400 bytes
Program execution speed 60 microseconds per 16 bit integer add/subtract
Serial I/O speed 2400 baud to 460.8 Kbaud on Com1
300 baud to 19 200 baud on any I/O pin (Com3)
Operating voltage range - 4.0 VDC to 6.0 VDC
I/O internal pull-up resistors 120 kΩ maximum
Floating point math
On-chip multitasking
On-chip clock/calendar
Built-in SPI interface
Parallel or serial FLASH Programmable