AT91 Embedded Peripherals - PowerPoint PPT Presentation

About This Presentation
Title:

AT91 Embedded Peripherals

Description:

SYSTEM and USER PERIPHERALS Overview System Peripherals ... Typical Application Code download Packet Exchange ... another ARM based microcontroller ... – PowerPoint PPT presentation

Number of Views:93
Avg rating:3.0/5.0
Slides: 39
Provided by: allu198
Category:

less

Transcript and Presenter's Notes

Title: AT91 Embedded Peripherals


1
AT91 Embedded Peripherals
2
SYSTEM and USER PERIPHERALS Overview
  • System Peripherals
  • External Bus Interface
  • Advanced Interrupt Controller
  • Parallel I/O Controller
  • Watchdog
  • Peripheral Data Controller
  • System Timer
  • Power Management Controller
  • Real Time Clock
  • User Peripherals
  • USART
  • Serial Peripheral Interface
  • Timer Counter
  • Analog to Digital Converter
  • Digital to Analog Converter

3
PIO Controller Features
  • Up to 32 Programmable Input Output lines
  • I/O lines may be multiplexed with an on-chip
    peripheral signal to optimize the use of
    available package pins managed by the PIO
    controller
  • Input Change Detection Interrupt on each line
  • Available even in Peripheral mode
  • Multi Driver (Open-Drain)
  • Allows multiple devices to drive the PIO lines
  • Reset state all PIO configured as PIO in input
  • PIO Multiplexed with EBI signals do not respect
    this rule

4
PIO Controller Block Diagram
5
PIO Controller I/O Levels
  • Each pin can be configured to be driven high or
    low
  • The level is defined in four different ways,
    according to the following conditions
  • If a pin is controlled by the PIO Controller and
    is not defined as an output, the level is
    determined by the external circuit.
  • If a pin is controlled by the PIO Controller and
    is defined as an output, the level is programmed
    using the registers Set Output Data (PIO_SODR)
    and Clear Output Data (PIO_CODR).
  • If a pin is not controlled by the PIO Controller,
    the state of the pin is defined by the
    peripheral.
  • In all cases, the level on the pin can be read in
    the register PIO_PDSR (Pin Data Status).

6
AIC Features
  • 8-level Priority
  • Up to 32 Interrupt sources
  • Individually maskable
  • Hardware interrupt vectoring
  • Internal Interrupt sources
  • Level sensitive or edge triggered
  • External Interrupt sources
  • Low/High level sensitive or positive/negative
    edge triggered

7
AIC Block Diagram
8
WD Features
  • 16-bit Down Counter
  • Programmable Time-out Period
  • 4ms to 8s, with 33MHz system clock
  • 4 Clock sources
  • MCK/32, MCK/128, MCK/1024 and MCK/4096
  • 3 Independent Outputs
  • Internal Reset
  • Internal Interrupt
  • Low level on Watchdog overflow signal for a
    duration of 8 MCK cycles
  • Control access keys

9
WD Block Diagram
10
WD Software Checking
11
ST Features
  • One Period Interval Timer (PIT)
  • 16-bit programmable counter
  • periodic interrupt, useful for OS
  • One Watchdog Timer (WD)
  • 16-bit programmable counter
  • maximum watchdog period of 256s with a typical
    slow clock of 32.768kHz
  • One Real Time Timer (RTT)
  • 20-bit free-running counter
  • count elapsed seconds
  • 1s increment with a typical slow clock of
    32.768kHz
  • count up to 1048576s (12 days)
  • Alarm to generate an interrupt

12
ST Block Diagram
13
TC Features
  • Three 16-bit Timer/Counter channels
  • Wide range of functions
  • Frequency measurement
  • Event counting
  • Interval measurement
  • Pulse generation
  • Delay timing
  • Pulse Width Modulation
  • Clock inputs
  • 3 External and 5 Internal
  • Two configurable Input/Ouput signals
  • Internal interrupt signal

14
TC Block Diagram
15
TC Clock Selection
  • Internal clock signals MCK/2, MCK/8, MCK/32,
    MCK/128, MCK/1024
  • External clock signals XC0, XC1, XC2
  • Selected clock can be inverted
  • Burst Function

16
TC Clock Control
  • Counter clock can be enabled/disabled and
    started/stopped
  • Software Enabling Commands by Control Register
    CLKEN and CLKDIS
  • Loading RB in Capture Mode or RC Compare in
    Waveform Mode can stop or disable the counter
    clock

17
TC Operating Modes
  • Two different modes
  • Capture Mode allows measurement on signals,
  • Waveform Mode allows wave generation.
  • Timer Counter Mode programmed with the WAVE bit
    in the TC Mode Register.

18
TC Triggers
  • A trigger resets the counter and starts the
    counter clock.
  • The following triggers are common to both modes
  • Software Trigger
  • Each channel has a software trigger, available by
    setting SWTRG in TC_CCR.
  • SYNC
  • Each channel has a synchronization signal SYNC.
    When asserted, this signal has the same effect as
    a software trigger. The SYNC signals of all
    channels are asserted simultaneously by writing
    TC_BCR (Block Control) with SYNC set.
  • Compare RC Trigger
  • RC is implemented in each channel and can provide
    a trigger when the counter value matches the RC
    value if CPCTRG is set in TC_CMR.
  • External triggers
  • TIOA or TIOB in Capture Mode
  • TIOB, XC0,XCC1 or XC2 in Waveform Mode

19
TC Capture Mode (1/3)
Selected Clock
Capture Register A
Capture Register B
Register C
16-bit Counter
RC Compare
SYNC
SWTRG
CPCTRG
LDRA
LDRB
ABETRG
TIOB input
RB Loading Logic
RA Loading Logic
Edge Detector
ETRGEDG
TIOA input
  • TIOA and TIOB as input pins
  • RA Loading Logic can be loaded only after a
    trigger or if RB has been loaded
  • RB Loading Logic can be loaded only after a
    trigger and if RA has been loaded

20
TC Capture Mode (2/3)
  • Examples
  • Measure the phase between TIOB and TIOA and the
    duration of the TIOA pulse
  • TIOB rising edge resets and starts the counter
  • TIOA rising edge loads RA and a falling edge
    loads RB
  • RA contains the phase between TIOB and TIOA
  • (RB-RA) is the duration of the TIOA pulse

21
TC Capture Mode (3/3)
  • Measure the duration of a TIOA pulse or period
  • TIOA falling edge resets and starts the counter
    and loads RB if RA is already loaded
  • TIOA rising edge loads RA
  • RA contains the duration of a TIOA pulse (low
    level)
  • RB contains the duration of the TIOA period

22
TC Waveform Mode (1/2)
Register A
Register B
Register C
16-bit Counter
Selected Clock
RC Compare
RB Compare
RA Compare
ASWTRG
SYNC
TIOA output
AEEVT
SWTRG
CPCTRG
ACPC
ACPA
ENETRG
EEVT
BSWTRG
Edge Detector
XC0
BEEVT
TIOB output
XC1
XC2
BCPC
EEVTEDG
BCPB
TIOB input
  • TIOA is an output
  • TIOB can be input or output depending on EEVT
    programming ( default is input )
  • Output controllers can set, clear or toggle
    outputs in function of events

23
TC Waveform Mode (2/2)
  • Examples
  • Dual Pulse Width Modulation (PWM) generation
  • TIOA is toggled by RA and RC, TIOB by RB and RC
  • A trigger starts the counter and initializes TIOA
    and TIOB
  • The PWM frequency must be stored in the compare
    register RC
  • The duty cycles on TIOA and TIOB are defined by
    RA and RB respectively

24
USART Features
  • Programmable Baud Rate Generator with External or
    Internal Clock
  • Up to 1Mbits/s in Asynchronous Mode and up to
    16Mbits/s in Synchronous Mode at 32MHz
  • Parity, Framing and Overrun Error Detection
  • Line Break generation and detection
  • Automatic Echo, Local Loopback and Loopback
    Channel Modes
  • Multi Drop Mode Address Detection and
    Generation
  • Interrupt Generation
  • 2 Dedicated PDC Channels
  • 5,6,7,8 and 9-bit Character Length
  • Transmitter Time Guard

25
USART Block Diagram
26
USART Baud Rate Generator
  • Asynchronous Mode
  • Baud rate MCK period / 16 / CD
  • Synchronous Mode
  • Baud Rate MCK period / CD

27
USART Reception
  • Asynchronous 8 bit 1 start and 1 stop
  • Synchronous 8 bit 1 start and 1 stop

28
USART Transmission
  • Asynchronous and Synchronous 8 bit, parity and
    1 stop

29
USART PDC Channels
  • PDC shares the ASB bus with the ARM Core
  • External or Internal Memories Access
  • ARM Core stopped during 3 cycles min.
  • Each PDC channel is dedicated to a peripheral and
    a transfer direction
  • PDC Registers mapped in User Interface
  • End of Transfer in the Status Register
  • Typical Application
  • Code download
  • Packet Exchange
  • Receiver Timeout Helps to Support Variable Length
    Packets
  • Transmitter Time Guard helps to Support Slow
    Remote Devices

PDC Channel
ARM Core
ASB Arbiter
RXRDY
PDC Receive Channel
USART
RXEND
Size Byte
TXRDY
PDC Transmit Channel
TXEND
Size Byte
30
SPI Features
  • Serial Interface between CPU and External
    Peripherals
  • Master or Slave Mode
  • Full duplex 3 wires synchronous transfer
  • MISO Master In Slave Out
  • MOSI Master Out Slave In
  • SPCK SPI Clock
  • Maximum SPI baud rate clock MCK/4
  • 4 External Slave chip selects
  • 8 to 16-bit Programmable Data Length
  • Mode Fault Detection in Master Mode
  • 2 Dedicated PDC Channels

31
SPI Block Diagram
32
SPI Bus Implementations
Up to 4 Peripherals
Up to 15 Peripherals with Decoding
AT91
AT91
SPI
SPI
4 to 16 Decoder
NPCS3
Q14
Serial Peripheral
NPCS2
Serial Peripheral
Q13
Serial Peripheral
NPCS1
Serial Peripheral
Q12
Serial Peripheral
NPCS0
Serial Peripheral
Q11
Serial Peripheral
Serial Peripheral
Q10
Serial Peripheral
Q1
Serial Peripheral
Q0
Serial Peripheral
  • 4 different protocols possible
  • First Bit set in NPCS field
  • 4 different protocols possible
  • 0-3, 4-7, 8-11, 12-14
  • Peripheral 15 is reserved for no selection

33
RTC Real Time Clock (1/2)
  • Available on the AT91M55800A only
  • Features
  • Low power consumption
  • Complete time of day clock
  • Programmable periodic interrupts
  • Alarm
  • Five programmable fields Month, Date, Sec, Min
    and Hour
  • Y2K compliant
  • BCD Format

34
RTC Real Time Clock (2/2)
  • Block Diagram

35
ADC Analog to Digital Converter (1/2)
  • Available on the AT91M55800A only
  • Features
  • Two identical 4-channel ADC
  • 10-bit resolution
  • Successive Approximation Register (SAR) approach
  • Settable analog input conversion range (dedicated
    VREF)
  • 11 ADC clock cycles conversion time including 1
    ADC clock cycle for sample and hold (e.g. 10µs
    for one channel at maximum clock rate)
  • 4 LSB Maximum Integral Non-linearity
  • Sleep mode (energy saving)
  • Starting modes
  • Software trigger
  • External input (A/D trigger)
  • Timers on-chip event signal
  • Dedicated analog power supply pins (VDDA and
    GNDA)
  • Improve noise rejection
  • End of conversion interrupt

36
ADC Analog to Digital Converter (2/2)
  • Block Diagram

37
DAC Digital to Analog Converter (1/2)
  • Available on the AT91M55800A only
  • Features
  • Two identical 1-channel DAC
  • 10-bit resolution
  • 6µs maximum settling time
  • Settable analog output range (dedicated VREF)
  • 4 LSB Maximum Integral Non-linearity
  • Starting modes
  • software trigger
  • Timers on-chip event signal
  • Dedicated analog power supply pins (VDDA and
    GNDA)
  • Improve noise rejection
  • Data ready interrupt

38
DAC Digital to Analog Converter (2/2)
  • Block Diagram
Write a Comment
User Comments (0)
About PowerShow.com