TO THE EXTENT PERMITTED BY APPLICABLE LAW, CYPRESS MAKES NO WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, WITH REGARD TO THIS DOCUMENT OR ANY SOFTWARE OR ACCOMPANYING HARDWARE, INCLUDING,
BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. To the extent permitted by applicable l aw, Cypress reserves the right to make changes to this document without further notice. Cypress does not assume any liability arising out of the application or use of any product or circuit described in
this document. Any information provided in this document, inclu ding any sample design info rmation o r progra mming co de, is
provided only for reference purposes. It is the responsibility of the user of this document to properly design, program, and test
the functionality and safety of any application made of this information and any resulting p roduct. Cypress products are not
designed, intended, or authorized for use as critical components in systems designed o r intended for the operation of we apons, weapons systems, nuclear installations, life-support devices or systems, other medical devices or systems (including
resuscitation equipment and surgical implants), pollution control or hazardous substances management, or other uses where
the failure of the device or system could cause personal injury, death, or property damage ("Unintended Uses"). A critical
component is any component of a device or system whose failure to perform can be reasonably expected to cause the failure
of the device or system, or to affect its safety or effectiveness. Cypress is not liable, in whole or in part, and you shall a nd
hereby do release Cypress from any claim, damage, or other liability arising from or related to all Unintended Uses of Cypress
products. You shall indemnify and hold Cypress harmless from and a gainst all claims, costs, damages, and other liabilities,
including claims for personal injury or death, arising from or related to any Unintended Uses of Cypress products.
Cypress, the Cypress logo, Spansion, the Spansion logo, and combinations thereof, WICED, PSoC, CapSense, EZ-USB,
F-RAM, and Traveo are trademarks or registered trademarks of Cypress in the U ni ted States and other countries. For a more
complete list of Cypress trademarks, visit cypress.com. Other names and brands may be claimed as property of their respective owners.
PSoC®4 is a programmable embedded system controller with an ARM® Cortex®-M0 CPU.CY8C4000 family is the smallest
member of the PSoC 4 family of devices and is upward-compatible with larger members of PSoC 4.
PSoC 4 devices have these characteristics:
■ High-performance, 32-bit single-cycle Cortex-M0 CPU core
■ Capacitive touch sensing (CapSense
■ Configurable Timer/Counter/PWM block
■ Configurable I
■ Low-power operating modes – Sleep and Deep-Sleep
This document describes each functional block of the PSoC 4000 device in detail. This information will help designers to create system-level designs.
2
C block with master, slave, and multi-master operating modes
1.1Top Level Architecture
Figure 1-1 shows the major components of the PSoC 4000 architecture.
■ 32-bit Cortex-M0 CPU with single-cycle multiply, deliver-
ing up to 14 DMIPS at 16 MHz
■ Up to 16 KB flash and 2 KB SRAM
■ A center-aligned pulse-width modulator (PWM) with
complementary, dead-band programmable outputs
■ I2C communication block with slave, master, and multi-
master operating modes
■ CapSense
■ Low-power operating modes: Sleep and Deep-Sleep
■ Programming and debugging system through serial wire
debug (SWD)
■ Two current sourcing/sinking DACs (IDACs)
■ Comparator with 1.2 V reference
■ Fully supported by PSoC Creator™ IDE tool
1.3CPU System
1.3.1Processor
The heart of the PSoC 4 is a 32-bit Cortex-M0 CPU core
running up to 16 MHz for PSoC 4000. It is optimized for lowpower operation with extensive clock gating. It uses 16-bit
instructions and executes a subset of the Thumb-2 instruction set. This instruction set enables fully compatible binary
upward migration of the code to higher performance processors such as Cortex M3 and M4.
The CPU has a hardware multiplier that provides a 32-bit
result in one cycle.
1.3.2Interrupt Controller
The CPU subsystem includes a nested vectored interrupt
controller (NVIC) with nine interrupt inputs and a wakeup
interrupt controller (WIC), which can wake the processor
from Deep-Sleep mode.
The PSoC 4 memory subsystem consists of a 16 KB flash
module with a flash accelerator, 2 KB SRAM, and 4 KB
supervisory ROM options. The flash accelerator improves
the average access times from the flash block delivering
85 percent of single-cycle SRAM access performance. A
powerful and flexible protection model allows you to selectively lock blocks of memory for read and write protection,
securing sensitive information. Additionally, all device interfaces can be permanently disabled for applications concerned about phishing attacks due to a maliciously
reprogrammed device or attempts to defeat security by
starting and interrupting flash programming sequences. The
supervisory ROM is used to store the boot and configuration
routines.
1.5System-Wide Resources
1.5.1Clocking System
The clocking system for the PSoC 4 device consists of the
internal main oscillator (IMO) and internal low-speed oscillator (ILO) as internal clocks and has provision for an external
clock.
The system clock (SYSCLK) required for the CPU system
and the high-frequency clock (HFCLK) required by the
peripherals can be as high as 16 MHz. These clocks are
generated from the IMO.
The IMO with an accuracy of ±2 percent is the primary
source of internal clocking in the device. The default IMO
frequency is 24 MHz and it can be adjusted between 3 MHz
and 48 MHz in steps of 1 MHz. The default IMO frequency is
24 MHz and can be adjusted between 24 MHz and 48 MHz
in steps of 4 MHz. Multiple clock derivatives are generated
from the main clock frequency to meet various application
needs.
The ILO is a low-power, less accurate oscillator and is used
to generate clocks for peripheral operation in Deep-Sleep
mode. Its clock frequency is 32 kHz with ±60 percent accuracy.
An external clock source ranging from MHz to 16 MHz can
be used to generate the clock derivatives for the functiona l
blocks instead of the IMO.
frequency clock is ON and the low-frequency peripherals
are in operation.
Multiple internal regulators are available in the system to
support power supply schemes in different power modes.
1.5.3GPIO
Every GPIO in PSoC 4 has the following characteristics:
■ Eight drive strength modes
■ Individual control of input and output disables
■ Hold mode for latching previous state
■ Selectable slew rates
■ Interrupt generation – edge triggered
The PSoC 4 also supports CapSense capability on 17 out of
20 GPIOs. The pins are organized in a port that is 8-bit wide.
A high-speed I/O matrix is used to multiplex between various signals that may connect to an I/O pin. Pin locations for
fixed-function peripherals are also fixed.
1.6Fixed-Function Digital
1.6.1Timer/Counter/PWM Block
The Timer/Counter/PWM block consists of a 16-bit counter
with user-programmable period length. The TCPWM block
has a capture register, period register, and compare register .
The block supports complementary, dead-band programmable outputs. It also has a kill input to force outputs to a predetermined state. Other features of the block include centeraligned PWM, clock prescaling, pseudo random PWM, and
quadrature decoding.
1.6.2Serial Communication BlocksI2C
Block
The PSoC 4 has a fixed-function I2C interface. The I2C
interface can be used for general-purpose I2C communication and for tuning the CapSense component fo r optimized
operation.
The features of the I2C block include:
■ Standard I
■ EZ function mode support with 32-byte buffer
2
C multi-master and slave function
1.5.2Power System
The PSoC 4 operates with a single external supply in the
range 1.71 V to 5.5 V.
PSoC 4 has two low-power modes – Sleep and Deep-Sleep
– in addition to the default Active mode. In Active mode, the
CPU runs with all the logic powered. In Sleep mode, the
CPU is powered off with all other peripherals functional. In
Deep-Sleep mode, the CPU, SRAM, and high-speed logic
are in retention; the main system clock is OFF while the low-
PSoC 4 devices have the CapSense feature, which allows
you to use the capacitive properties of your fingers to toggle
buttons and sliders. CapSense functionality is su pported on
all but three GPIO pins in PSoC 4 through a CapSense
Sigma-Delta (CSD) block. The CSD also provides waterproofing capability.
Introduction
1.7.1.1IDACs and Comparator
The CapSense block has two IDACs and a comparator with
a 12-V reference, which can be used for general purposes, if
CapSense is not used.
1.8Program and Debug
PSoC 4 devices support programming and debugging features of the device via the on-chip SWD interface. The PSoC
Creator IDE provides fully integrated programming and
debugging support. The SWD interface is also fully compatible with industry standard third-party tools.
Free support for PSoC®4 products is available online at www.cypress.com/psoc4. Resources include training seminars,
discussion forums, application notes, PSoC consultants, CRM technical support email, knowledge base, and application
support engineers.
For application assistance, visit www.cypress.com/support/ or call 1-800-541-4736.
2.2Product Upgrades
Cypress provides scheduled upgrades and version enhancements for PSoC C reator free of charge. Upgrades a re available
from your distributor on DVD-ROM; you can also download them directly from www.cypress.com/psoccreator. Critical updates
to system documentation are also provided in the Documentation section.
2.3Development Kits
The Cypress Online Store contains development kits, C compilers, and the accessories you need to successfully develop
PSoC projects. Visit the Cypress Online Store website at www.cypress.com/cypress-store. Under Products, click Program-mable System-on-Chip to view a list of available items. Development kits are also available from Digi-Key, Avnet, Arrow, and
Future.
2.4Application Notes
Refer to application note AN79953 - Getting Started with PSoC 4 for additional information on PSoC 4 device capabilities and
to quickly create a simple PSoC application using PSoC Creator and PSoC 4 development kits.
■ Section D: System Resources Subsystem (SRSS) on page 43
■ Section E: Digital System on page 81
■ Section F: Analog System on page 125
■ Section G: Program and Debug on page 137
3.1Major Sections
For ease of use, information is organized into sections and chapters that are divided according to device functionality.
■ Section – Presents the top-level architecture, how to get started, and conventions and overview information of the prod-
uct.
■ Chapter – Presents the chapters specific to an individual aspect of the section topic. These are the detailed implementa-
tion and use information for some aspect of the integrated circuit.
■ Glossary – Defines the specialized terminology used in this technical reference manual (TRM). Glossary terms are pre-
sented in bold, italic font throughout.
■ Registers Technical Reference Manual – Supplies all device register details summarized in the technical reference man-
ual. This is an additional document.
3.2Documentation Conventions
This document uses only four distinguishing font types, besides those found in the headings.
■ The first is the use of italics when referencing a document title or file name.
■ The second is the use of bold italics when referencing a term described in the Glossary of this document.
■ The third is the use of Times New Roman font, distinguishing equation examples.
■ The fourth is the use of Courier New font, distinguishing code examples.
3.2.1Register Conventions
Register conventions are detailed in the PSoC 4000 Family: PSoC 4 Registers TRM.
3.2.2Numeric Naming
Hexadecimal numbers are represented with all letters in u ppercase with an appended lowercase ‘h’ (for example, ‘14h’ or
‘3Ah’) and hexadecimal numbers may also be represented by a ‘0x’ prefix, the C coding convention. Binary numbers have an
appended lowercase ‘b’ (for example, 01010100b’ or ‘01000011b’). Numbers not indicated by an ‘h’ or ‘b’ are decimal.
pFpicofarads
pppeak-to-peak
ppmparts per million
SPSsamples per second
sigma: one standard deviation
Vvolts
3.2.4Acronyms
This table lists the acronyms used in this document
Table 3-2. Acronyms
AcronymDefinition
ABUSanalog output bus
ACalternating current
ADCanalog-to-digital converter
AHB
APIapplication programming interface
AMBA (advanced microcontroller bus architecture)
high-performance bus, an ARM data transfer bus
Table 3-2. Acronyms (continued)
AcronymDefinition
APORanalog power-on reset
BCbroadcast clock
BODbrownout detect
BOMbill of materials
BRbit rate
BRAbus request acknowledge
BRQbus request
CANcontroller area network
CIcarry in
CMPcompare
COcarry out
CPUcentral processing unit
CRCcyclic redundancy check
CSDCapSense sigma delta
CTcontinuous time
CTBcontinuous time block
CTBmcontinuous time block mini
DACdigital-to-analog converter
DAPdebug access port
DCdirect current
DIdigital or data input
DMAdirect memory access
DNLdifferential nonlinearity
DOdigital or data output
DSIdigital signal interface
DSMdeep-sleep mode
DWdata wire
ECOexternal crystal oscillator
EEPROM
EMIFexternal memory interface
FBfeedback
FIFOfirst in first out
FSRfull scale range
GPIOgeneral purpose I/O
HCIhost-controller interface
HFCLKhigh-frequency clock
HSIOMhigh-speed I/O matrix
I2C
IDEintegrated development environment
ILOinternal low-speed oscillator
ITOindium tin oxide
IMOinternal main oscillator
INLintegral nonlinearity
I/Oinput/output
IORI/O read
IOWI/O write
electrically erasable programmable read only
memory
The PSoC® 4 ARM Cortex-M0 core is a 32-bit CPU optimized for low-power operation. It has an efficient three-stage pipeline,
a fixed 4-GB memory map, and supports the ARMv6-M Thumb instruction set. The Cortex-M0 also features a single-cycle 32bit multiply instruction and low-latency interrupt handling. Other subsystems tightly linked to the CPU core include a nested
vectored interrupt controller (NVIC), a SYSTICK timer, and debug.
This section gives an overview of the Cortex-M0 processor. For more details, see the ARM Cortex-M0 user guide or technical
reference manual, both available at www.arm.com.
4.1Features
The PSoC 4 Cortex-M0 has the following features:
■ Easy to use, program, and debug, ensuring easier migration from 8- and 16-bit processors
■ Operates at up to 0.9 DMIPS/MHz; this helps to increase execution speed or reduce power
■ Supports the Thumb instruction set for improved code density, ensuring efficient use of memory
■ NVIC unit to support interrupts and exceptions for rapid and deterministic interrupt response
■ Extensive debug support including:
❐ SWD port
❐ Breakpoints
❐ Watchpoints
The Cortex-M0 is a 32-bit processor with a 32-bit data path, 32-bit registers, and a 32-bit memory interf ace. It supports most
16-bit instructions in the Thumb instruction set and some 32-bit instructions in the Thumb-2 instruction set.
The processor supports two operating modes (see “Operating Modes” on page 28). It has a single-cycle 32-bit multiplication
instruction.
4.4Address Map
The ARM Cortex-M0 has a fixed address map allowing access t o memory and peripherals using simple memory access
instructions. The 32-bit (4 GB) address space is divided into the regions show n in Table 4-1. Note that code can be executed
from the code and SRAM regions.
Table 4-1. Cortex-M0 Address Map
Address RangeNameUse
0x00000000 - 0x1FFFFFFFCode
0x20000000 - 0x3FFFFFFFSRAMData region. You can also execute code from this region.
0x40000000 - 0x5FFFFFFFPeripheralAll peripheral registers. You cannot execute code from this region.
0x60000000 - 0xDFFFFFFFNot used.
0xE0000000 - 0xE00FFFFFPPBPeripheral registers within the CPU core.
0xE0100000 - 0xFFFFFFFFDevicePSoC 4 implementation-specific.
Program code region. You can also place data here. Includes the exception vector table,
which starts at address 0.
The Cortex-M0 has 16 32-bit registers, as Table 4-2 shows:
■ R0 to R12 – General-purpose registers. R0 to R7 can be accessed by all instructions; the other registers can be accessed
by a subset of the instructions.
■ R13 – Stack pointer (SP). There are two stack pointers, with only one available at a t i me. In th re ad mode, the CONTROL
register indicates the stack pointer to use, Main Stack Pointer (MSP) or Process Stack Pointer (PSP).
■ R14 – Link register. Stores the return program counter during function calls.
■ R15 – Program count er. This register can be written to contro l program flow.
Table 4-2. Cortex-M0 Registers
Name
R0-R12RWUndefinedR0-R12 are 32-bit general-purpose registers for data operations.
MSP (R13)
PSP (R13)
LR (R14)RWUndefined
PC (R15)RW[0x00000004]
PSRRWUndefined
APSRRWUndefined
EPSRRO[0x00000004].0 On reset, EPSR is loaded with the value bit[0] of the register [0x00000004].
IPSRRO0The IPSR contains the exception number of the current ISR.
PRIMASKRW0The PRIMASK register prevents activation of all exceptions with configurable priority.
CONTROLRW0The CONTROL register controls the stack used when the processor is in thread mode.
a. Describes access type during program execution in thread mode and handler mode. Debug access can differ.
a
Type
RW[0x00000000]
Reset ValueDescription
The stack pointer (SP) is register R13. In thread mode, bit[1] of the CONTROL register
indicates which stack pointer to use:
0 = Main stack pointer (MSP). This is the reset value.
1 = Process stack pointer (PSP).
On reset, the processor loads the MSP with the value from address 0x00000000.
The link register (LR) is register R14. It stores the return information for subroutines,
function calls, and exceptions.
The program counter (PC) is register R15. It contains the current program address. On
reset, the processor loads the PC with the value from address 0x00000004. Bit[0] of the
value is loaded into the EPSR T-bit at reset and must be 1.
The program status register (PSR) combines:
Application Program Status Register (APSR).
Execution Program Status Register (EPSR).
Interrupt Program Status Register (IPSR).
The APSR contains the current state of the condition flags from previous instruction
executions.
Table 4-3 shows how the PSR bits are assigned.
Table 4-3. Cortex-M0 PSR Bit Assignments
BitPSR RegisterNameUsage
31APSRNNegative flag
30APSRZZero flag
29APSRCCarry or borrow flag
28APSRVOverflow flag
Use the MSR or CPS instruction to set or clear bit 0 of th e PRIM ASK regi ster. If the bit is 0, exceptions are enabled. If the bit
is 1, all exceptions with configurable priority, that is, all exceptions except HardFault, NMI, and Reset, are disabled. See th e
Interrupts chapter on page 31 for a list of exceptions.
4.6Operating Modes
The Cortex-M0 processor supports two operating modes:
■ Thread Mode – used by all normal applications. In this mode, the MSP or PSP can be used. The CONTROL register bit 1
determines which stack pointer is used:
❐ 0 = MSP is the current stack pointer
❐ 1 = PSP is the current stack pointer
■ Handler Mode – used to execute exception handlers. The MSP is always used.
In thread mode, use the MSR instruction to set the stack pointer bit in the CONTROL register. When changing the stack
pointer, use an ISB instruction immediately after the MSR instruction. This ensures that instructions after the ISB execute
using the new stack pointer.
In handler mode, explicit writes to the CONTROL register are ignored, because the MSP is always used. The exception entry
and return mechanisms automatically update the CONTROL register.
4.7Instruction Set
The Cortex-M0 implements a version of the Thumb instruction set, as Table4-4 shows. For details, see the Cortex-M0
Generic User Guide.
An instruction operand can be an ARM register, a constant, or another instruction-specific parameter. Instructions act on the
operands and often store the result in a destinat ion register. Many instructions a re unable to use, or have restrictions on
using, the PC or SP for the operands or destination register.
ADD{S}
ADRPC-relative address to register
ANDSBit wise AND
ASRSArithmetic shift right
B{cc}Branch {conditionally}
BICSBit clear
BKPTBreakpoint
BLBranch with link
BLXBranch indirect with link
BXBranch indirect
CMNCompare negative
CMPCompare
CPSIDChange processor state, disable interrupts
CPSIEChange processor state, enable interrupts
DMBData memory barrier
DSBData synchronization barrier
EORSExclusive OR
ISBInstruction synchronization barrier
LDMLoad multiple registers, increment after
LDRLoad register from PC-relative address
LDRBLoad register with word
LDRHLoad register with half-word
LDRSBLoad register with signed byte
LDRSHLoad register with signed half-word
LSLSLogical shift left
LSRSLogical shift right
a
MOV{S}
MRSMove to general register from special register
MSRMove to special register from general register
MULSMultiply, 32-bit result
MVNSBit wise NOT
NOPNo operation
ORRSLogical OR
POPPop registers from stack
PUSHPush registers onto stack
REVByte-reverse word
REV16Byte-reverse packed half-words
REVSHByte-reverse signed half-word
RORSRotate right
RSBSReverse subtract
SBCSSubtract with carry
Add
Move
Table 4-4. Thumb Instruction Set
MnemonicBrief Description
SEVSend event
STMStore multiple registers, increment after
STRStore register as word
STRBStore register as byte
STRHStore register as half-word
a
SUB{S}
SVCSupervisor call
SXTBSign extend byte
SXTHSign extend half-word
TSTLogical AND-based test
UXTBZero extend a byte
UXTHZero extend a half-word
WFEWait for event
WFIWait for interrupt
a. The ‘S’ qualifier causes the ADD, SUB, or MOV instructions to update
APSR condition flags.
Subtract
4.7.1Address Alignment
An aligned access is an operation where a word-aligned
address is used for a word or multiple word access, or
where a half-word-aligned address is used for a half-word
access. Byte accesses are always aligned.
No support is provided for unaligned accesses on the Cortex-M0 processor. Any attempt to perform an unaligned
memory access operation results in a HardFault exception.
4.7.2Memory Endianness
The PSoC 4 Cortex-M0 uses the little-endian forma t, where
the least-significant byte of a word is stored at the lowest
address and the most significant byte is stored at the hi ghest address.
4.8Systick Timer
The Systick timer is integrated with the NVIC and ge nerates
the SYSTICK interrupt. This interrupt can be used for task
management in a real-time system. The timer has a reload
register with 24 bits available to use as a countdown value.
The Systick timer uses the Cortex-M0 internal clock as a
source.
4.9Debug
PSoC 4 contains a debug interface based on SWD; it features four breakpoint (address) comparators and two watchpoint (data) comparators.