EFM8 Universal Bee Family
EFM8UB3 Reference Manual
The EFM8UB3, part of the Universal Bee family of MCUs, is a
multi-purpose line of 8-bit microcontrollers with USB feature set in
small packages.
These devices offer high value by integrating an innovative energy-smart USB peripheral
interface, charger detect circuit, 8 kV ESD protection, and enhanced high speed commuÂnication interfaces into small packages, making them ideal for space-constrained USB
applications. With an efficient 8051 core and precision analog, the EFM8UB3 family is
also optimal for embedded applications.
EFM8UB3 applications include the following:
• USB I/O controls
• Docking stations/USB hubs
• Dongles
Core / MemoryClock Management
CIP-51 8051 Core
(48 MHz)
Flash Memory
40 KB
RAM Memory
3328 bytes
• Consumer electronics
• USB Type-C converters
• USB Type-C billboard/alternate mode
External CMOS
Oscillator
Debug Interface
with C2
Low Frequency
RC Oscillator
High Frequency
48 MHz RC
Oscillator
High Frequency
24.5 MHz RC
Oscillator
KEY FEATURES
• Pipelined 8-bit C8051 core with 48 MHz
maximum operating frequency
• Up to 17 multifunction I/O pins
• Low Energy USB with full- and low-speed
support saves up to 90% of the USB
energy
• USB charger detect circuit (USB-BCS 1.2
compliant)
• One 12-bit ADC and two analog
comparators with internal voltage DAC as
reference input
• Six 16-bit timers
• UART and SMBus master/slave
• Priority crossbar for flexible pin mapping
Energy Management
Internal LDO
Regulator
Brown-Out
Detector
Power-On Reset
5 V-to 3.3 V LDO
Regulator
8-bit SFR bus
Serial InterfacesTimers and TriggersAnalog Interfaces
UART
SMBus
Lowest power mode with peripheral operational:
silabs.com | Building a more connected world.Rev. 0.2
USB
SPI
IdleNormalShutdownSuspendSnooze
External
Interrupts
General
Purpose I/O
Pin Reset
Pin Wakeup
Timers
0/1/2
Watchdog
Timer
4 x Configurable Logic Units
PCA/PWM
Timer 3/4/5
ADC
Internal Voltage
Reference
Charger Det
Comparator 1
Comparator 0
SecurityI/O Ports
16-bit CRC
Table of Contents
1. System Overview .............................13
silabs.com | Building a more connected world.Rev. 0.2 | 12
1. System Overview
1.1 Introduction
EFM8UB3 Reference Manual
System Overview
C2CK/RSTb
VDD
VREGIN
GND
D+
VBUS
CIP-51 8051 Controller
C2D
Programming
Power-On
Independent
Watchdog
Timer
Debug /
Hardware
Reset
Reset
Supply
Monitor
Core
40 KB ISP Flash
Program Memory
256 Byte SRAM
2048 Byte XRAM
SYSCLK
System Clock
Configuration
EXTCLK
Voltage
Regulators
Power
Net
Low Freq.
Oscillator
CMOS Oscillator
Input
48 MHz 1.5%
Oscillator
Clock
Recovery
24.5 MHz 2%
Oscillator
SFR
Bus
USB Peripheral
D-
Full / Low
Speed
Transceiver
1 KB RAMLow Power
Controller
Charge
Detection
Port I/O Configuration
Digital Peripherals
UART1
Timers 0,
1, 2, 3, 4, 5
3-ch PCA
I2C /
SMBus
SPI
CRC
Config.
Logic
Units (4)
Analog Peripherals
Internal
Reference
VREFVDD
12/10 bit
ADC
2 Comparators
Priority
Crossbar
Decoder
Crossbar
Control
AMUX
Sensor
+
+
-
-
VDD
Temp
Port 0
Drivers
Port 1
Drivers
Port 2
Drivers
P0.n
P1.n
P2.n
Figure 1.1. Detailed EFM8UB3 Block Diagram
This section describes the EFM8UB3 family at a high level.
For more information on the device packages and pinout, electrical specifications, and typical connection diagrams, see the EFM8UB3
Data Sheet. For more information on each module including register definitions, see the EFM8UB3 Reference Manual. For more inforÂmation on any errata, see the EFM8UB3 Errata.
silabs.com | Building a more connected world.Rev. 0.2 | 13
EFM8UB3 Reference Manual
System Overview
1.2 Power
Control over the device power consumption can be achieved by enabling/disabling individual peripherals as needed. Each analog peÂripheral can be disabled when not in use and placed in low power mode. Digital peripherals, such as timers and serial buses, have their
clocks gated off and draw little power when they are not in use.
Table 1.1. Power Modes
Power ModeDetailsMode EntryWake-Up Sources
NormalCore and all peripherals clocked and fully operational——
Idle• Core halted
• All peripherals clocked and fully operational
• Code resumes execution on wake event
Suspend• Core and peripheral clocks halted
• HFOSC0 and HFOSC1 oscillators stopped
• Regulators in normal bias mode for fast wake
• Timer 3 and 4 may clock from LFOSC0
• Code resumes execution on wake event
Stop• All internal power nets shut down
• 5V regulator remains active (if enabled)
• Internal 1.8 V LDO on
• Pins retain state
• Exit on any reset source
Snooze• Core and peripheral clocks halted
• HFOSC0 and HFOSC1 oscillators stopped
• Regulators in low bias current mode for energy savÂings
• Timer 3 and 4 may clock from LFOSC0
• Code resumes execution on wake event
Set IDLE bit in PCON0Any interrupt
1. Switch SYSCLK to
HFOSC0
2. Set SUSPEND bit in
PCON1
• USB0 Bus Activity
• Timer 4 Event
• SPI0 Activity
• Port Match Event
• Comparator 0 Falling
Edge
• CLUn Interrupt-Enabled
Event
1. Clear STOPCF bit in
Any reset source
REG0CN
2. Set STOP bit in
PCON0
1. Switch SYSCLK to
HFOSC0
2. Set SNOOZE bit in
PCON1
• USB0 Bus Activity
• Timer 4 Event
• SPI0 Activity
• Port Match Event
• Comparator 0 Falling
Edge
• CLUn Interrupt-Enabled
Event
Shutdown• All internal power nets shut down
• 5V regulator remains active (if enabled)
• Internal 1.8 V LDO off to save energy
• Pins retain state
1. Set STOPCF bit in
REG0CN
2. Set STOP bit in
PCON0
• RSTb pin reset
• Power-on reset
• Exit on pin or power-on reset
1.3 I/O
Digital and analog resources are externally available on the device’s multi-purpose I/O pins. Port pins P0.0-P1.6 can be defined as genÂeral-purpose I/O (GPIO), assigned to one of the internal digital resources through the crossbar or dedicated channels, or assigned to an
analog function. Port pins P2.0 and P2.1 can be used as GPIO. Additionally, the C2 Interface Data signal (C2D) is shared with P2.0.
The port control block offers the following features:
• Up to 17 multi-functions I/O pins, supporting digital and analog functions.
• Flexible priority crossbar decoder for digital peripheral assignment.
• Two drive strength settings for each port.
• Two direct-pin interrupt sources with dedicated interrupt vectors (INT0 and INT1).
• Up to 17 direct-pin interrupt sources with shared interrupt vector (Port Match).
silabs.com | Building a more connected world.Rev. 0.2 | 14
EFM8UB3 Reference Manual
System Overview
1.4 Clocking
The CPU core and peripheral subsystem may be clocked by both internal and external oscillator resources. By default, the system
clock comes up running from the 24.5 MHz oscillator divided by 8.
The clock control system offers the following features:
• Provides clock to core and peripherals.
• 24.5 MHz internal oscillator (HFOSC0), accurate to ±2% over supply and temperature corners.
• 48 MHz internal oscillator (HFOSC1), accurate to ±1.5% over supply and temperature corners.
• 80 kHz low-frequency oscillator (LFOSC0).
• External CMOS clock input (EXTCLK).
• Clock divider with eight settings for flexible clock scaling:
• Divide the selected clock source by 1, 2, 4, 8, 16, 32, 64, or 128.
• HFOSC0 and HFOSC1 include 1.5x pre-scalers for further flexibility.
1.5 Counters/Timers and PWM
Programmable Counter Array (PCA0)
The programmable counter array (PCA) provides multiple channels of enhanced timer and PWM functionality while requiring less CPU
intervention than standard counter/timers. The PCA consists of a dedicated 16-bit counter/timer and one 16-bit capture/compare modÂule for each channel. The counter/timer is driven by a programmable timebase that has flexible external and internal clocking options.
Each capture/compare module may be configured to operate independently in one of five modes: Edge-Triggered Capture, Software
Timer, High-Speed Output, Frequency Output, or Pulse-Width Modulated (PWM) Output. Each capture/compare module has its own
associated I/O line (CEXn) which is routed through the crossbar to port I/O when enabled.
• 16-bit time base
• Programmable clock divisor and clock source selection
• Up to three independently-configurable channels
• 8, 9, 10, 11 and 16-bit PWM modes (center or edge-aligned operation)
• Output polarity control
• Frequency output mode
• Capture on rising, falling or any edge
• Compare function for arbitrary waveform generation
• Software timer (internal compare) mode
• Can accept hardware “kill” signal from comparator 0 or comparator 1
silabs.com | Building a more connected world.Rev. 0.2 | 15
Several counter/timers are included in the device: two are 16-bit counter/timers compatible with those found in the standard 8051, and
the rest are 16-bit auto-reload timers for timing peripherals or for general purpose use. These timers can be used to measure time interÂvals, count external events and generate periodic interrupt requests. Timer 0 and Timer 1 are nearly identical and have four primary
modes of operation. The other timers offer both 16-bit and split 8-bit timer functionality with auto-reload and capture capabilities.
Timer 0 and Timer 1 include the following features:
• Standard 8051 timers, supporting backwards-compatibility with firmware and hardware.
• Clock sources include SYSCLK, SYSCLK divided by 12, 4, or 48, the External Clock divided by 8, or an external pin.
• 8-bit auto-reload counter/timer mode
• 13-bit counter/timer mode
• 16-bit counter/timer mode
• Dual 8-bit counter/timer mode (Timer 0)
Timer 2, Timer 3, Timer 4, and Timer 5 are 16-bit timers including the following features:
• Clock sources for all timers include SYSCLK, SYSCLK divided by 12, or the External Clock divided by 8
• LFOSC0 divided by 8 may be used to clock Timer 3 and Timer 4 in active or suspend/snooze power modes
• Timer 4 is a low-power wake source, and can be chained together with Timer 3
• 16-bit auto-reload timer mode
• Dual 8-bit auto-reload timer mode
• External pin capture
• LFOSC0 capture
• Comparator 0 capture
• USB Start-of-Frame (SOF) capture
• Configurable Logic output capture
Watchdog Timer (WDT0)
The device includes a programmable watchdog timer (WDT) running off the low-frequency oscillator. A WDT overflow forces the MCU
into the reset state. To prevent the reset, the WDT must be restarted by application software before overflow. If the system experiences
a software or hardware malfunction preventing the software from restarting the WDT, the WDT overflows and causes a reset. Following
a reset, the WDT is automatically enabled and running with the default maximum time interval. If needed, the WDT can be disabled by
system software or locked on to prevent accidental disabling. Once locked, the WDT cannot be disabled until the next system reset.
The state of the RST pin is unaffected by this reset.
The Watchdog Timer has the following features:
• Programmable timeout interval
• Runs from the low-frequency oscillator
• Lock-out feature to prevent any modification until a system reset
silabs.com | Building a more connected world.Rev. 0.2 | 16
EFM8UB3 Reference Manual
System Overview
1.6 Communications and Other Digital Peripherals
Universal Serial Bus (USB0)
The USB0 peripheral provides a full-speed USB 2.0 compliant device controller and PHY with additional Low Energy USB features. The
device supports both full-speed (12MBit/s) and low speed (1.5MBit/s) operation, and includes a dedicated USB oscillator with clock reÂcovery mechanism for crystal-free operation. No external components are required. The USB function controller (USB0) consists of a
Serial Interface Engine (SIE), USB transceiver (including matching resistors and configurable pull-up resistors), and 1 KB FIFO block.
The Low Energy Mode ensures the current consumption is optimized and enables USB communication on a strict power budget.
The USB0 module includes the following features:
• Full and Low Speed functionality.
• Implements 4 bidirectional endpoints.
• Low Energy Mode to reduce active supply current based on bus bandwidth.
• USB 2.0 compliant USB peripheral support (no host capability).
• Direct module access to 1 KB of RAM for FIFO memory.
• Clock recovery to meet USB clocking requirements with no external components.
• Charger detection circuitry with automatic detection of SDP, CDP, and DCP interfaces.
• D+ and D- can be routed to ADC input to support ACM and proprietary charger architectures.
UART1 is an asynchronous, full duplex serial port offering a variety of data formatting options. A dedicated baud rate generator with a
16-bit timer and selectable prescaler is included, which can generate a wide range of baud rates. A received data FIFO allows UART1
to receive multiple bytes before data is lost and an overflow occurs.
UART1 provides the following features:
• Asynchronous transmissions and receptions.
• Dedicated baud rate generator supports baud rates up to SYSCLK/2 (transmit) or SYSCLK/8 (receive).
• 5, 6, 7, 8, or 9 bit data.
• Automatic start and stop generation.
• Automatic parity generation and checking.
• Four byte FIFO on transmit and receive.
• Auto-baud detection.
• LIN break and sync field detection.
• CTS / RTS hardware flow control.
Serial Peripheral Interface (SPI0)
The serial peripheral interface (SPI) module provides access to a flexible, full-duplex synchronous serial bus. The SPI can operate as a
master or slave device in both 3-wire or 4-wire modes, and supports multiple masters and slaves on a single SPI bus. The slave-select
(NSS) signal can be configured as an input to select the SPI in slave mode, or to disable master mode operation in a multi-master
environment, avoiding contention on the SPI bus when more than one master attempts simultaneous data transfers. NSS can also be
configured as a firmware-controlled chip-select output in master mode, or disabled to reduce the number of pins required. Additional
general purpose port I/O pins can be used to select multiple slave devices in master mode.
• Supports 3- or 4-wire master or slave modes.
• Supports external clock frequencies up to 12 Mbps in master or slave mode.
• Support for all clock phase and polarity modes.
• 8-bit programmable clock rate (master).
• Programmable receive timeout (slave).
• Two byte FIFO on transmit and receive.
• Can operate in suspend or snooze modes and wake the CPU on reception of a byte.
• Support for multiple masters on the same data lines.
silabs.com | Building a more connected world.Rev. 0.2 | 17
EFM8UB3 Reference Manual
System Overview
System Management Bus / I2C (SMB0)
The SMBus I/O interface is a two-wire, bi-directional serial bus. The SMBus is compliant with the System Management Bus SpecificaÂtion, version 1.1, and compatible with the I2C serial bus.
The SMBus module includes the following features:
• Standard (up to 100 kbps), Fast (400 kbps), and Fast Mode Plus (1 Mbps) transfer speeds
• Support for master, slave, and multi-master modes
• Hardware synchronization and arbitration for multi-master mode
• Clock low extending (clock stretching) to interface with faster masters
• Hardware support for 7-bit slave and general call address recognition
• Firmware support for 10-bit slave address decoding
• Ability to inhibit all slave states
• Programmable data setup/hold times
• Transmit and receive FIFOs (two-byte) to help increase throughput in faster applications
16-bit CRC (CRC0)
The cyclic redundancy check (CRC) module performs a CRC using a 16-bit polynomial. CRC0 accepts a stream of 8-bit data and posts
the 16-bit result to an internal register. In addition to using the CRC block for data manipulation, hardware can automatically CRC the
flash contents of the device.
The CRC module is designed to provide hardware calculations for flash memory verification and communications protocols. The CRC
module supports the standard CCITT-16 16-bit polynomial (0x1021), and includes the following features:
• Support for CCITT-16 polynomial
• Byte-level bit reversal
• Automatic CRC of flash contents on one or more 256-byte blocks
• Initial seed selection of 0x0000 or 0xFFFF
Configurable Logic Units (CLU0, CLU1, CLU2, and CLU3)
The Configurable Logic block consists of multiple Configurable Logic Units (CLUs). CLUs are flexible logic functions which may be used
for a variety of digital functions, such as replacing system glue logic, aiding in the generation of special waveforms, or synchronizing
system event triggers.
• Four configurable logic units (CLUs), with direct-pin and internal logic connections
• Each unit supports 256 different combinatorial logic functions (AND, OR, XOR, muxing, etc.) and includes a clocked flip-flop for synÂchronous operations
• Units may be operated synchronously or asynchronously
• May be cascaded together to perform more complicated logic functions
• Can operate in conjunction with serial peripherals such as UART and SPI or timing peripherals such as timers and PCA channels
• Can be used to synchronize and trigger multiple on-chip resources (ADC, Timers, etc.)
• Asynchronous output may be used to wake from low-power states
silabs.com | Building a more connected world.Rev. 0.2 | 18
EFM8UB3 Reference Manual
System Overview
1.7 Analog
12-Bit Analog-to-Digital Converter (ADC0)
The ADC is a successive-approximation-register (SAR) ADC with 12-, 10-, and 8-bit modes, integrated track-and hold and a programÂmable window detector. The ADC is fully configurable under software control via several registers. The ADC may be configured to
measure different signals using the analog multiplexer. The voltage reference for the ADC is selectable between internal and external
reference sources.
• Up to 16 external inputs.
• Single-ended 12-bit and 10-bit modes.
• Supports an output update rate of 200 ksps samples per second in 12-bit mode or 800 ksps samples per second in 10-bit mode.
• Operation in low power modes at lower conversion speeds.
• Asynchronous hardware conversion trigger, selectable between software, external I/O, internal timer sources, and configurable logic
(CLU) sources.
• Output data window comparator allows automatic range checking.
• Support for burst mode, which produces one set of accumulated data per conversion-start trigger with programmable power-on setÂtling and tracking time.
• Conversion complete and window compare interrupts supported.
• Flexible output data formatting.
• Includes an internal fast-settling reference with two levels (1.65 V and 2.4 V) and support for external reference and signal ground.
• Integrated temperature sensor.
Low Current Comparators (CMP0, CMP1)
Analog comparators are used to compare the voltage of two analog inputs, with a digital output indicating which input voltage is higher.
External input connections to device I/O pins and internal connections are available through separate multiplexers on the positive and
negative inputs. Hysteresis, response time, and current consumption may be programmed to suit the specific needs of the application.
The comparator includes the following features:
• Up to 8 (CMP0) or 8 (CMP1) external positive inputs
• Up to 8 (CMP0) or 8 (CMP1) external negative inputs
• Additional input options:
• Internal connection to LDO output
• Direct connection to GND
• Direct connection to VDD
• Dedicated 6-bit reference DAC
• Synchronous and asynchronous outputs can be routed to pins via crossbar
• Programmable hysteresis between 0 and ±20 mV
• Programmable response time
• Interrupts generated on rising, falling, or both edges
• PWM output kill feature
silabs.com | Building a more connected world.Rev. 0.2 | 19
EFM8UB3 Reference Manual
System Overview
1.8 Reset Sources
Reset circuitry allows the controller to be easily placed in a predefined default condition. On entry to this reset state, the following occur:
• The core halts program execution.
• Module registers are initialized to their defined reset values unless the bits reset only with a power-on reset.
• External port pins are forced to a known state.
• Interrupts and timers are disabled.
All registers are reset to the predefined values noted in the register descriptions unless the bits only reset with a power-on reset. The
contents of RAM are unaffected during a reset; any previously stored data is preserved as long as power is not lost. The Port I/O latchÂes are reset to 1 in open-drain mode. Weak pullups are enabled during and after the reset. For Supply Monitor and power-on resets,
the RSTb pin is driven low until the device exits the reset state. On exit from the reset state, the program counter (PC) is reset, and the
system clock defaults to an internal oscillator. The Watchdog Timer is enabled, and program execution begins at location 0x0000.
Reset sources on the device include:
• Power-on reset
• External reset pin
• Comparator reset
• Software-triggered reset
• Supply monitor reset (monitors VDD supply)
• Watchdog timer reset
• Missing clock detector reset
• Flash error reset
• USB reset
1.9 Debugging
The EFM8UB3 devices include an on-chip Silicon Labs 2-Wire (C2) debug interface to allow flash programming and in-system debugÂging with the production part installed in the end application. The C2 interface uses a clock signal (C2CK) and a bi-directional C2 data
signal (C2D) to transfer information between the device and a host system. See the C2 Interface Specification for details on the C2
protocol.
silabs.com | Building a more connected world.Rev. 0.2 | 20
EFM8UB3 Reference Manual
System Overview
1.10 Bootloader
All devices come pre-programmed with a USB bootloader. This bootloader resides in the code security page and last pages of code
flash; it can be erased if it is not needed.
The byte before the Lock Byte is the Bootloader Signature Byte. Setting this byte to a value of 0xA5 indicates the presence of the bootÂloader in the system. Any other value in this location indicates that the bootloader is not present in flash.
When a bootloader is present, the device will jump to the bootloader vector after any reset, allowing the bootloader to run. The bootÂloader then determines if the device should stay in bootload mode or jump to the reset vector located at 0x0000. When the bootloader
is not present, the device will jump to the reset vector of 0x0000 after any reset.
More information about the bootloader protocol and usage can be found in AN945: EFM8 Factory Bootloader User Guide. Application
notes can be found on the Silicon Labs website (www.silabs.com/8bit-appnotes) or within Simplicity Studio in the [Documentation]
area.
0xFFFF
0xFFC0
0xFBFF
0xFBFE
0xFBFD
0xFA00
0x9DFF
0x9A00
Read-Only
64 Bytes
Reserved
Lock Byte
Bootloader Signature Byte
Security Page
512 Bytes
Reserved
Bootloader
Bootloader Vector
Bootloader
Memory Lock
Read-Only
64 Bytes
128-bit UUID
0xFFFF
0xFFFE
0xFFD0
0xFFCF
0xFFC0
40 KB Flash
(79 x 512 Byte pages)
0x0000
Figure 1.2. Flash Memory Map with Bootloader—40 KB Devices
Table 1.2. Summary of Pins for Bootloader Communication
BootloaderPins for Bootload Communication
USBVBUS
silabs.com | Building a more connected world.Rev. 0.2 | 21
Reset Vector
D+
D-
EFM8UB3 Reference Manual
Table 1.3. Summary of Pins for Bootload Mode Entry
Device PackagePin for Bootload Mode Entry
QFN24P2.0 / C2D
QSOP24P2.0 / C2D
QFN20P2.0 / C2D
System Overview
silabs.com | Building a more connected world.Rev. 0.2 | 22
EFM8UB3 Reference Manual
Memory
2. Memory
2.1 Memory Organization
The memory organization of the CIP-51 System Controller is similar to that of a standard 8051. There are two separate memory
spaces: program memory and data memory. Program and data memory share the same address space but are accessed via different
instruction types. Program memory consists of a non-volatile storage area that may be used for either program code or non-volatile
data storage. The data memory, consisting of "internal" and "external" data space, is implemented as RAM, and may be used only for
data storage. Program execution is not supported from the data memory space.
2.2 Program Memory
The CIP-51 core has a 64 KB program memory space. The product family implements some of this program memory space as in-sysÂtem, re-programmable flash memory. Flash security is implemented by a user-programmable location in the flash block and provides
read, write, and erase protection. All addresses not specified in the device memory map are reserved and may not be used for code or
data storage.
MOVX Instruction and Program Memory
The MOVX instruction in an 8051 device is typically used to access external data memory. On the devices, the MOVX instruction is
normally used to read and write on-chip XRAM, but can be re-configured to write and erase on-chip flash memory space. MOVC inÂstructions are always used to read flash memory, while MOVX write instructions are used to erase and write flash. This flash access
feature provides a mechanism for the product to update program code and use the program memory space for non-volatile data storÂage.
2.3 Data Memory
The RAM space on the chip includes both an "internal" RAM area which is accessed with MOV instructions, and an on-chip "external"
RAM area which is accessed using MOVX instructions. Total RAM varies, based on the specific device. The device memory map has
more details about the specific amount of RAM available in each area for the different device variants.
Internal RAM
There are 256 bytes of internal RAM mapped into the data memory space from 0x00 through 0xFF. The lower 128 bytes of data memoÂry are used for general purpose registers and scratch pad memory. Either direct or indirect addressing may be used to access the lower
128 bytes of data memory. Locations 0x00 through 0x1F are addressable as four banks of general purpose registers, each bank conÂsisting of eight byte-wide registers. The next 16 bytes, locations 0x20 through 0x2F, may either be addressed as bytes or as 128 bit
locations accessible with the direct addressing mode.
The upper 128 bytes of data memory are accessible only by indirect addressing. This region occupies the same address space as the
Special Function Registers (SFR) but is physically separate from the SFR space. The addressing mode used by an instruction when
accessing locations above 0x7F determines whether the CPU accesses the upper 128 bytes of data memory space or the SFRs. InÂstructions that use direct addressing will access the SFR space. Instructions using indirect addressing above 0x7F access the upper
128 bytes of data memory.
General Purpose Registers
The lower 32 bytes of data memory, locations 0x00 through 0x1F, may be addressed as four banks of general-purpose registers. Each
bank consists of eight byte-wide registers designated R0 through R7. Only one of these banks may be enabled at a time. Two bits in
the program status word (PSW) register, RS0 and RS1, select the active register bank. This allows fast context switching when entering
subroutines and interrupt service routines. Indirect addressing modes use registers R0 and R1 as index registers.
silabs.com | Building a more connected world.Rev. 0.2 | 23
EFM8UB3 Reference Manual
Memory
Bit Addressable Locations
In addition to direct access to data memory organized as bytes, the sixteen data memory locations at 0x20 through 0x2F are also acÂcessible as 128 individually addressable bits. Each bit has a bit address from 0x00 to 0x7F. Bit 0 of the byte at 0x20 has bit address
0x00 while bit 7 of the byte at 0x20 has bit address 0x07. Bit 7 of the byte at 0x2F has bit address 0x7F. A bit access is distinguished
from a full byte access by the type of instruction used (bit source or destination operands as opposed to a byte source or destination).
The MCS-51™ assembly language allows an alternate notation for bit addressing of the form XX.B where XX is the byte address and B
is the bit position within the byte. For example, the instruction:
Mov C, 22.3h
moves the Boolean value at 0x13 (bit 3 of the byte at location 0x22) into the Carry flag.
Stack
A programmer's stack can be located anywhere in the 256-byte data memory. The stack area is designated using the Stack Pointer
(SP) SFR. The SP will point to the last location used. The next value pushed on the stack is placed at SP+1 and then SP is incremenÂted. A reset initializes the stack pointer to location 0x07. Therefore, the first value pushed on the stack is placed at location 0x08, which
is also the first register (R0) of register bank 1. Thus, if more than one register bank is to be used, the SP should be initialized to a
location in the data memory not being used for data storage. The stack depth can extend up to 256 bytes.
External RAM
On devices with more than 256 bytes of on-chip RAM, the additional RAM is mapped into the external data memory space (XRAM).
Addresses in XRAM area accessed using the external move (MOVX) instructions.
Note: The 16-bit MOVX write instruction is also used for writing and erasing the flash memory. More details may be found in the flash
memory section.
silabs.com | Building a more connected world.Rev. 0.2 | 24
2.4 Memory Map
EFM8UB3 Reference Manual
Memory
0xFFFF
0xFFC0
0xFBFF
0xFBFE
0xFBFD
0xFA00
0x9DFF
0x9A00
Read-Only
64 Bytes
Reserved
Lock Byte
Bootloader Signature Byte
Security Page
512 Bytes
Reserved
Bootloader
Bootloader Vector
Bootloader
Memory Lock
Read-Only
64 Bytes
128-bit UUID
0xFFFF
0xFFFE
0xFFD0
0xFFCF
0xFFC0
0x0000
40 KB Flash
(79 x 512 Byte pages)
Reset Vector
Figure 2.1. Flash Memory Map — 40 KB Devices
silabs.com | Building a more connected world.Rev. 0.2 | 25
0xFF
EFM8UB3 Reference Manual
Memory
On-Chip RAM
Accessed with MOV Instructions as Indicated
Upper 128 Bytes
RAM
(Indirect Access)
0x80
0x7F
Lower 128 Bytes RAM
(Direct or Indirect Access)
0x30
0x2F
0x20
0x1F
0x00
Figure 2.2. Direct / Indirect RAM Memory
General-Purpose Register Banks
Bit-Addressable
On-Chip XRAM
Accessed with MOVX Instructions
Special Function
Registers
(Direct Access)
0xFFFF
0x0C00
0x0BFF
0x0800
0x07FF
0x0000
Shadow XRAM
Duplicates 0x0000-0x0BFF
On 3 KB boundaries
USB FIFO XRAM
1024 Bytes
(USBCLK Domain)
XRAM
2048 Bytes
(SYSCLK Domain)
Figure 2.3. XRAM Memory
silabs.com | Building a more connected world.Rev. 0.2 | 26
EFM8UB3 Reference Manual
2.5 XRAM Control Registers
2.5.1 EMI0CN: External Memory Interface Control
Bit76543210
NameReservedPGSEL
AccessRRW
Reset0x00x0
SFR Page = ALL; SFR Address: 0xE7
BitNameResetAccess Description
7:4ReservedMust write reset value.
3:0PGSEL0x0RWXRAM Page Select.
The XRAM Page Select field provides the high byte of the 16-bit data memory address when using 8-bit MOVX commands,
effectively selecting a 256-byte page of RAM. Since the upper (unused) bits of the register are always zero, the PGSEL
field determines which page of XRAM is accessed.
For example, if PGSEL = 0x01, addresses 0x0100 to 0x01FF will be accessed by 8-bit MOVX instructions.
Memory
silabs.com | Building a more connected world.Rev. 0.2 | 27
EFM8UB3 Reference Manual
Special Function Registers
3. Special Function Registers
3.1 Special Function Register Access
The direct-access data memory locations from 0x80 to 0xFF constitute the special function registers (SFRs). The SFRs provide control
and data exchange with the CIP-51's resources and peripherals. The CIP-51 duplicates the SFRs found in a typical 8051 implementaÂtion as well as implementing additional SFRs used to configure and access the sub-systems unique to the MCU. This allows the addi-
tion of new functionality while retaining compatibility with the MCS-51 ™ instruction set.
The SFR registers are accessed anytime the direct addressing mode is used to access memory locations from 0x80 to 0xFF. SFRs
with addresses ending in 0x0 or 0x8 (e.g., P0, TCON, SCON0, IE, etc.) are bit-addressable as well as byte-addressable. All other SFRs
are byte-addressable only. Unoccupied addresses in the SFR space are reserved for future use. Accessing these areas will have an
indeterminate effect and should be avoided.
SFR Paging
The CIP-51 features SFR paging, allowing the device to map many SFRs into the 0x80 to 0xFF memory address space. The SFR
memory space has 256 pages. In this way, each memory location from 0x80 to 0xFF can access up to 256 SFRs. The EFM8UB3
devices utilize multiple SFR pages. All of the common 8051 SFRs are available on all pages. Certain SFRs are only available on a
subset of pages. SFR pages are selected using the SFRPAGE register. The procedure for reading and writing an SFR is as follows:
1. Select the appropriate SFR page using the SFRPAGE register.
2. Use direct accessing mode to read or write the special function register (MOV instruction).
The SFRPAGE register only needs to be changed in the case that the SFR to be accessed does not exist on the currently-selected
page. See the SFR memory map for details on the locations of each SFR.
silabs.com | Building a more connected world.Rev. 0.2 | 28
EFM8UB3 Reference Manual
Special Function Registers
Interrupts and the SFR Page Stack
When an interrupt occurs, the current SFRPAGE is pushed onto an SFR page stack to preserve the current context of SFRPAGE.
Upon execution of the RETI instruction, the SFRPAGE register is automatically restored to the SFR page that was in use prior to the
interrupt. The stack is five elements deep to accomodate interrupts of different priority levels pre-empting lower priority interrupts. FirmÂware can read any element of the SFR page stack by setting the SFRPGIDX field in the SFRPGCN register and reading the
SFRSTACK register.
Table 3.1. SFR Page Stack Access
SFRPGIDX ValueSFRSTACK Contains
0Value of the first/top byte of the stack
1Value of the second byte of the stack
2Value of the third byte of the stack
3Value of the fourth byte of the stack
4Value of the fifth/bottom byte of the stack
Notes:
1. The top of the stack is the current SFRPAGE setting, and can also be directly accessed via the SFRPAGE register.
SFRPGEN
Interrupt
Logic
SFR Page
SFRPAGE
SFRPGIDX
000
001
010
SFRSTACK
Stack
011
100
Figure 3.1. SFR Page Stack Block Diagram
When an interrupt occurs, hardware performs the following operations:
1. The value (if any) in the SFRPGIDX = 011b location is pushed to the SFRPAGE = 100b location.
2. The value (if any) in the SFRPGIDX = 010b location is pushed to the SFRPAGE = 011b location.
3. The value (if any) in the SFRPGIDX = 001b location is pushed to the SFRPAGE = 010b location.
4. The current SFRPAGE value is pushed to the SFRPGIDX = 001b location in the stack.
5. SFRPAGE is set to the page associated with the flag that generated the interrupt.
On a return from interrupt, hardware performs the following operations:
1. The SFR page stack is popped to the SFRPAGE register. This restores the SFR page context prior to the interrupt, without softÂware intervention.
2. The value in the SFRPGIDX = 010b location of the stack is placed in the SFRPGIDX = 001b location.
3. The value in the SFRPGIDX = 011b location of the stack is placed in the SFRPGIDX = 010b location.
4. The value in the SFRPGIDX = 100b location of the stack is placed in the SFRPGIDX = 011b location.
Automatic hardware switching of the SFR page upon interrupt entries and exits may be enabled or disabled using the SFRPGEN locaÂted in SFRPGCN. Automatic SFR page switching is enabled after any reset.
silabs.com | Building a more connected world.Rev. 0.2 | 29
EFM8UB3 Reference Manual
Special Function Registers
3.2 Special Function Register Memory Map
Table 3.2. Special Function Registers by Address
AddressSFR PageAddressSFR Page
(*bit-addressÂable)
0x000x100x20(*bit-address-
able)
0x000x100x20
0x80*P00xC0*SMB0CN0TMR5CN0SMB0CN0
0x81SP0xC1SMB0CFPFE0CNSMB0CF
0x82DPL0xC2SMB0DAT-SMB0DAT
0x83DPH0xC3ADC0GTLSMB0FCN0
0x84-CLU0MX0xC4ADC0GTHSMB0FCN1
0x85IT01CFCLU1MX0xC5ADC0LTLSMB0RXLN
0x86CRC0CN1-CRC0CN10xC6ADC0LTHREG1CN
0x87PCON00xC7HFO0CALCLU3FN
0x88*TCON0xC8*TMR2CN0-
0x89TMOD0xC9REG0CN-REG0CN
0x8ATL00xCATMR2RLLCLU3CF
0x8BTL10xCBTMR2RLHCLEN0
0x8CTH00xCCTMR2L-
0x8DTH10xCDTMR2HCLIE0
0x8ECKCON00xCECRC0CN0EIE2CRC0CN0
0x8FPSCTL0xCFCRC0FLIPSFRPGCNCRC0FLIP
0x90*P10xD0*PSW
0x91TMR3CN0CLU2MX0xD1REF0CN-
0x92TMR3RLLCLU3MX0xD2CRC0STTMR5RLLCRC0ST
0x93TMR3RLHSMOD10xD3CRC0CNTTMR5RLHCRC0CNT
0x94TMR3LSBCON10xD4P0SKIPTMR5LP0SKIP
0x95TMR3HSBRLL10xD5P1SKIPTMR5HP1SKIP
0x96PCA0POLSBRLH10xD6SMB0ADMHFO1CALSMB0ADM
0x97WDTCN0xD7SMB0ADRSFRSTACKSMB0ADR
0x98*SCON1TMR4CN0SCON10xD8*PCA0CN0UART1FCN1
0x99SBUF1CMP0CN1SBUF10xD9PCA0MDCLOUT0
0x9A-SPI0FCN00xDAPCA0CPM0UART1PCF
0x9BCMP0CN0SPI0FCN10xDBPCA0CPM1-
0x9CPCA0CLR-0xDCPCA0CPM2-
0x9DCMP0MDUART1FCN00xDDCRC0IN-CRC0IN
0x9EPCA0CENTUART1LIN0xDECRC0DAT-CRC0DAT
0x9FCMP0MX-0xDFADC0PWRSPI0PCF
silabs.com | Building a more connected world.Rev. 0.2 | 30
Loading...
+ 332 hidden pages
You need points to download manuals.
1 point = 1 manual.
You can buy points or you can get point for every manual you upload.