NXP Semiconductors
Data sheet: Technical data
Document Number: MC33PT2000
Rev. 13, 5/2022
Programmable solenoid controller
PT2000
The PT2000 is a SMARTMOS programmable gate driver IC for precision solenoid
control applications, which makes the component very flexible and relieves the
main microcontroller from the heavy task of the actuator control. The chip
integrates six microcores used to control, seven external MOSFET high-side predrivers, eight external MOSFET low-side pre-drivers (two of them with higher
switching frequency can be used for DC/DC converters), an integrated end of
injection detection, six current measurements, and diagnostics for both the highside and low-side.
PT2000 includes two internal regulators with overvoltage and undervoltage
monitoring and protection, VCCP fed from the battery line supplying the pre-driver
section and VCC2P5 fed from an external 5.0 V generating supply for the digital
block.
Interface with the MCU is achieved via serial peripheral interface (SPI) and 16
configurable I/O signals. I/O are supplied by an external 3.3 V or 5.0 V regulator
connected to VCCIO.
PROGRAMMABLE SOLENOID
CONTROLLER
AF SUFFIX
98ASA00505D
80 LQFP
These features along with cost effective packaging, make the PT2000 ideal for
power train engine control applications.
Features
Applications
•
•
•
•
•
•
•
•
•
• Automotive (12 V), truck and industrial (24 V) power
train
• Diesel and gasoline direct injection (three banks)
• Transmission
• Valve control
Battery voltage range, 5.0 V < VBATT < 72 V
Battery and boost voltage monitoring
Pre-drive operating voltage up to 72 V
Seven high-side/ eight low-side pre-drive PWM capability up to 100 kHz-30 nC
All pre-drivers have four selectable slew rates
Eight selectable, pre-defined VDS monitoring thresholds
Measurement function for end of injection detection
Encryption for microcode protection
Integrated 1.0 MHz back-up clock
VBAT
VBAT/VBOOST
5.0 V
VBOOST
x3 Bank
VSENSEPx
VSENSENx
VBOOST
VBAT
VSENSEPx
VSENSENx
Figure 1. PT2000 simplified application diagram
© NXP B.V. 2022
Table of Contents
1
2
3
4
5
6
Orderable parts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4
1.1 Cipher key . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4
Internal block diagram . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5
Pin connections . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6
Functional description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10
4.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10
4.2 Features . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10
Electrical characteristics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
5.1 Maximum ratings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
5.2 Power supply electrical characteristics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
5.3 High-side pre-driver electrical characteristics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16
5.4 Low-side (LS1-LS6) pre-driver electrical characteristics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
5.5 Low-side high-speed (LS7-LS8) pre-driver electrical characteristics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19
5.6 High-side VDS VSRC monitoring electrical characteristics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
5.7 Low-side VDS VSRC monitoring electrical characteristics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22
5.8 Load bias electrical characteristics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23
5.9 Current measurement electrical characteristics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24
5.9.1 Current measurement for positive current . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24
5.9.2 Current measurement for negative currents . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
5.10 Analog output (OAx) electrical characteristics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
5.11 Clock / PLL electrical characteristics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
5.12 Digital input/output electrical characteristics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30
5.13 Serial peripheral interface electrical characteristics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32
Functional block description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34
6.1 Power supplies . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34
6.1.1 VCC5 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34
6.1.2 VCCIO . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34
6.1.3 VCC2P5 regulator . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34
6.1.3 VCC2P5 regulator . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34
6.1.4 VCCP regulator . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
6.1.5 Battery voltage monitor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
6.1.6 Boost voltage monitor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
6.1.7 Charge pump . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38
6.2 Clock subsystem . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38
6.3 High-side pre-driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39
6.3.1 High-side pre-driver slew rate control . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40
6.3.2 Safe state of high-side pre-driver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40
6.4 High-side VDS and VSRC monitor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42
6.4.1 HS1, 3, 5, 7 VDS monitoring . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42
6.4.2 HS2, 4, 6 VDS monitoring . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
6.5 Low-side pre-driver (LS1-6) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44
6.5.1 Low-side pre-driver slew rate control . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
6.5.2 LS1 - LS6 VDS monitor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46
6.6 Low-side pre-driver for DC/DC converter (LS7 and LS8) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47
6.6.1 Low-side pre-driver slew rate control (LS7 and LS8) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48
6.6.2 Low-side VDS monitor D_ls7/D_ls8 for DC/DC . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48
PT2000
NXP Semiconductors
2
6.7
Current measurement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49
6.7.1 General purpose current measurement block . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49
6.7.2 Current measurement for DC/DC . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52
6.8 OA_x output pins, multiplexer and T & H . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
6.8.1 General features . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
6.8.2 OA_2 Pin digital I/O function . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55
6.8.3 OAx output offset and offset error . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56
7 Functional device operation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57
7.1 Power-up/down sequence . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57
7.1.1 Power-up sequence of VCC5, VCC2P5, and reset . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57
7.1.2 Power-up sequence VCCP and bootstrap capacitors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58
7.2 DC/DC converter control (LS7/8) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61
7.2.1 General description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61
7.3 Device clock manager and PLL init . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63
7.4 SW initialization flow . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63
7.4.1 Power supply, reset, and clock . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63
7.4.2 SPI configuration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64
7.4.3 Clock monitor, flash enable, and DrvEn . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64
7.5 BIST . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64
7.5.1 MBIST . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65
7.5.2 LBIST . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65
7.6 Reset sources . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65
7.7 Cipher unit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66
7.8 Ground connections . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66
7.9 Shutoff path via the DrvEn pin . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66
8 Digital core . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 68
8.1 Logic channels description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 68
8.1.1 Microcores . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69
8.1.2 Dual microcore arbiter . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 70
8.1.3 Signature unit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72
8.1.4 SPI backdoor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72
8.1.5 CRAM . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 73
8.1.6 DRAM . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 73
8.2 Serial peripheral interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 74
8.2.1 SPI read access . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 75
8.2.2 SPI write access . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 76
8.2.3 SPI protocol . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 77
8.3 SPI address map . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 79
8.3.1 Selection register (3FFh) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 89
8.3.2 Configuration register . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 90
8.3.3 IO configuration registers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 100
8.3.4 Main configuration registers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 117
8.3.5 Diagnostics configuration registers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 132
9 Typical applications . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 139
9.1 Application diagram: 3 bank, 6 cylinder with DC/DC . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 139
9.2 Application diagram: 3 bank, 3 cylinder (full overlap) with DC/DC . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 140
10 Packaging . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 141
10.1 Package mechanical dimensions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 141
11 Reference section . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 145
12 Revision history . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 146
PT2000
3
NXP Semiconductors
1
Orderable parts
Table 1. Orderable part variations
Part number
MC33PT2000AF
(1)
Temperature (TA)
-40 °C to 125 °C
Package
80-pin LQFP with exposed pad
Notes
1.
To order parts in tape and reel, add the R2 suffix to the part number.
1.1
Cipher key
Contact a NXP sales representative to obtain devices with a specific encryption key and the associated code encryptor.
PT2000
NXP Semiconductors
4
2
Internal block diagram
B_HS1
Logic
Control
CLK
RESETB
Controls
IRQB
HS Pre-driver 1
VDS Monitor 1
Logic
Channel 1
G_HS1
S_HS1
B_HS2
HS Pre-driver 2
VDS Monitor 2
Digital
Microcore
(Uc0Ch1)
G_HS2
S_HS2
B_HS3
HS Pre-driver 3
VDS Monitor 3
G_HS3
S_HS3
MISO
MOSI
SPI
Interface
Digital
Microcore
(Uc1Ch1)
B_HS4
HS Pre-driver 4
VDS Monitor 4
G_HS4
S_HS4
SCLK
B_HS5
HS Pre-driver 5
VDS Monitor 5
Code RAM
CSB
G_HS5
S_HS5
B_HS6
HS Pre-driver 6
VDS Monitor 6
Data RAM
DBG
G_HS6
S_HS6
FLAG0
B_HS7
Debug
Interface
FLAG1
HS Pre-driver 7
VDS Monitor 7
G_HS7
S_HS7
FLAG2
START1
Logic
Channel 2
LS Pre-driver 1
VDS Monitor 1
D_LS1
Digital
Microcore
(Uc0Ch2)
LS Pre-driver 2
VDS Monitor 2
D_LS2
LS Pre-driver 3
VDS Monitor 3
D_LS3
LS Pre-driver 4
VDS Monitor 4
D_LS4
LS Pre-driver 5
VDS Monitor 5
D_LS5
LS Pre-driver 6
VDS Monitor 6
D_LS6
LS Pre-driver 7
VDS Monitor 7
D_LS7 (DC/DC)
LS Pre-driver 8
VDS Monitor 8
D_LS8 (DC/DC)
START2
Digital
Microcore
(Uc1Ch2)
START3
START4
START5
START6
Code RAM
START7
START8
Data RAM
Supplies
VBOOST
BOOST
Monitor
Current
Measure 1
Charge
Pump
BAT
Monitor
VBATT
VCCP
LDO
UV Monitor
VCCP
VCC5
Monitor
VCC5
VCC2P5
Regulator
VCC2P5
IO Buffers
Supply
VCCIO
Crossbar Switch
FLAG3
Logic
Channel 3
Digital
Microcore
(Uc0Ch3)
Digital
Microcore
(Uc1Ch3)
Code RAM
OA Mux Out 1
Current
Measure 3
Current
Measure 2
OA Mux Out 2
Current
Measure 4
OA Mux Out 3
Current
Measure 5
Data RAM
Current
Measure 6
G_LS1
G_LS2
G_LS3
G_LS4
G_LS5
G_LS6
G_LS7 (DC/DC)
G_LS8 (DC/DC)
VSENSEP1
VSENSEN1
OA_1
VSENSEP3
VSENSEN3
VSENSEP2
VSENSEN2
OA_2
VSENSEP4
VSENSEN4
OA_3
VSENSEP5 (DC/DC)
VSENSEN5 (DC/DC)
VSENSEP6 (DC/DC)
VSENSEN6 (DC/DC)
DRVEN
DGND
AGND
PGND (Exposed Pad)
Figure 2. PT2000 simplified internal block diagram
PT2000
5
NXP Semiconductors
Pin connections
CLK
IRQB
S_HS1
G_HS1
B_HS1
S_HS2
G_HS2
B_HS2
S_HS3
G_HS3
B_HS3
S_HS4
G_HS4
B_HS4
S_HS5
G_HS5
B_HS5
S_HS6
G_HS6
B_HS6
3
Transparent
top view
80 79 78 77 76 75 74 73 72 71 70 69 68 67 66 65 64 63 62 61
DRVEN
RESETB
START1
START2
START3
START4
START5
START6
START7
FLAG0
FLAG1
FLAG2
FLAG3
CSB
MOSI
MISO
SCLK
VCCIO
DBG
DGND
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
60
59
58
57
56
55
54
53
52
51
50
49
48
47
46
45
44
43
42
41
S_HS7
G_HS7
B_HS7
VBOOST
G_LS1
G_LS2
G_LS3
G_LS4
G_LS5
G_LS6
G_LS7
G_LS8
VCCP
VBATT
D_LS1
D_LS2
D_LS3
D_LS4
D_LS5
D_LS6
VCC2P5
VCC5
AGND
VSENSEN4
VSENSEP4
VSENSEN1
VSENSEP1
VSENSEN2
VSENSEP2
VSENSEN3
VSENSEP3
VSENSEN5
VSENSEP5
VSENSEN6
VSENSEP6
OA_1
OA_2
OA_3
D_LS8
D_LS7
21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40
Figure 3. PT2000 pin connections
Functional descriptions of many of these pins can be found in the Functional block description section beginning on page 34.
Table 2. PT2000 pin definitions (2), (3), (4)
Pin
Pin name
Pin function
Pull
configuration
1
DRVEN
Input
Weak PD
Driver enable input
2
RESETB
Input
Weak PU
Reset pin
3
START1
Input/output
PU/PD
Configurable
Trigger pin actuator 1 / Flag_bus(5)
4
START2
Input/output
PU/PD
Configurable
Trigger pin actuator 2 / Flag_bus(6)
5
START3
Input/output
PU/PD
Configurable
Trigger pin actuator 3 / Flag_bus(7)
6
START4
Input/output
PU/PD
Configurable
Trigger pin actuator 4 / Flag_bus(8)
7
START5
Input/output
PU/PD
Configurable
Trigger pin actuator 5 / Flag_bus(9)
Definition
PT2000
NXP Semiconductors
6
Table 2. PT2000 pin definitions (2), (3), (4)(continued)
Pin
Pin name
Pin function
Pull
configuration
8
START6
Input/output
PU/PD
Configurable
Trigger pin actuator 6 / Flag_bus(10)
9
START7
Input/output
PU/PD
Configurable
Trigger pin actuator 7 / Flag_bus(11)
10
FLAG 0
Input/output
Weak PD
Flag_bus(0) (general purpose I/O)/command for external free-wheeling MOSFTET
pre-driver 1
11
FLAG 1
Input/output
Weak PD
Flag_bus(1) (general purpose I/O)/command for external free-wheeling MOSFTET
pre-driver 2
12
FLAG 2
Input/output
Weak PD
Flag_bus(2) (general purpose I/O)/command for external free-wheeling MOSFTET
pre-driver 3
13
FLAG 3
Input/output
Weak PD
Flag_bus(3) (general purpose I/O)/command for external free-wheeling MOSFTET
pre-driver 4
14
CSB
Input
PU
SPI chip select
15
MOSI
Input
Weak PU
SPI slave input
16
MISO
Output
—
17
SCLK
Input
Weak PU
18
VCCIO
Input
—
19
DBG
Input/output
Weak PU
20
DGND
Ground
—
Digital ground
21
VCC2P5
Output
—
Internal 2.5 V voltage regulator decoupling
22
VCC5
Input
—
Power supply 5.0 V (supplied externally)
23
AGND
Ground
—
Analog ground
24
VSENSEN4
Input/output
PU/PD
Configurable
25
VSENSEP4
Input/output
Weak PD
26
VSENSEN1
Input
—
Current sense input comparator 1 -
27
VSENSEP1
Input
—
Current sense input comparator 1 +
28
VSENSEN2
Input
—
Current sense input comparator 2 -
29
VSENSEP2
Input
—
Current sense input comparator 2 +
30
VSENSEN3
Input
—
Current sense input comparator 3 -
31
VSENSEP3
Input
—
Current sense input comparator 3 +
32
VSENSEN5
Input
—
DC-DC current sense input comparator -
33
VSENSEP5
Input
—
DC-DC current sense input comparator +
34
VSENSEN6
Input
—
DC-DC current sense input comparator -
35
VSENSEP6
Input
—
DC-DC current sense input comparator +
36
OA_1
Output
—
Analog output 1
37
OA_2
Input/output
Weak PD
38
OA_3
Output
—
Analog output 3
39
D_LS8
Input
—
Drain pin low-side MOSFET for DC/DC converter
40
D_LS7
Input
—
Drain pin low-side MOSFET for DC/DC converter
41
D_LS6
Input
—
Drain pin low-side MOSFET actuator 6
42
D_LS5
Input
—
Drain pin low-side MOSFET actuator 5
Definition
SPI slave output
SPI clock
Digital I/O voltage supply 3.3 V or 5.0 V (supplied externally)
Debug port / Flag_bus (15)
Current sense input comparator - / Start8 / Flag(12)
Current sense input comparator + /Flag(4) (general purpose I/O)
Analog output 2/Flag_bus (14)
PT2000
7
NXP Semiconductors
Table 2. PT2000 pin definitions (2), (3), (4)(continued)
Pin
Pin name
Pin function
Pull
configuration
43
D_LS4
Input
—
Drain pin low-side MOSFET actuator 4
44
D_LS3
Input
—
Drain pin low-side MOSFET actuator 3
45
D_LS2
Input
—
Drain pin low-side MOSFET actuator 2
46
D_LS1
Input
—
Drain pin low-side MOSFET actuator 1
47
VBATT
Input
—
Battery voltage input
48
VCCP
Input/output
—
Output: Internal 7.0 V voltage regulator
Input: External 7.0 V voltage regulator (supplied externally)
49
G_LS8
Output
—
Gate pin low-side high speed MOSFET can be used for DC/DC converter
50
G_LS7
Output
—
Gate pin low-side high speed MOSFET can be used for DC/DC converter
51
G_LS6
Output
—
Gate pin low-side MOSFET actuator 6
52
G_LS5
Output
—
Gate pin low-side MOSFET actuator 5
53
G_LS4
Output
—
Gate pin low-side MOSFET actuator 4
54
G_LS3
Output
—
Gate pin low-side MOSFET actuator 3
55
G_LS2
Output
—
Gate pin low-side MOSFET actuator 2
56
G_LS1
Output
—
Gate pin low-side MOSFET actuator 1
57
VBOOST
Input
—
Boost voltage and drain pin for boost pre-drivers
58
B_HS7
-
—
Bootstrap pin high-side MOSFET 7
59
G_HS7
Output
—
Gate pin high-side MOSFET 7
60
S_HS7
Input
—
Source pin high side MOSFET 7
61
B_HS6
-
—
Bootstrap pin Boost MOSFET 6
62
G_HS6
Output
—
Gate pin Boost MOSFET 6
63
S_HS6
Input
—
Source pin Boost MOSFET 6
64
B_HS5
-
—
Bootstrap pin high-side MOSFET 5
65
G_HS5
Output
—
Gate pin high-side MOSFET 5
66
S_HS5
Input
—
Source pin high side MOSFET 5
67
B_HS4
-
—
Bootstrap pin boost MOSFET 4
68
G_HS4
Output
—
Gate pin boost MOSFET 4
69
S_HS4
Input
—
Source pin boost MOSFET 4
70
B_HS3
-
—
Bootstrap pin high-side MOSFET 3
71
G_HS3
Output
—
Gate pin high-side MOSFET 3
72
S_HS3
Input
—
Source pin high-side MOSFET 3
73
B_HS2
-
—
Bootstrap pin boost MOSFET 2
74
G_HS2
Output
—
Gate pin boost MOSFET 2
75
S_HS2
Input
—
Source pin boost MOSFET 2
76
B_HS1
-
—
Bootstrap pin high-side MOSFET 1
77
G_HS1
Output
—
Gate pin high-side MOSFET 1
78
S_HS1
Input
—
Source pin high-side MOSFET 1
79
IRQB
Input/output
Weak PD
Interrupt output/Flag_bus (13)
80
CLK
Input
Weak PU
Clock pin (low-frequency reference for internal PLL)
Definition
PT2000
NXP Semiconductors
8
Table 2. PT2000 pin definitions (2), (3), (4)(continued)
Pin
Pin name
Pin function
Pull
configuration
ePAD
PGND
Ground
—
Definition
Power ground (to be soldered on GND PCB)
Notes
2.
External 7.0 V is required in case the typical battery voltage is 24 V (See External VCCP (vccp_ext_en='1') on page 35).
3.
Except for supply and ground, it is guaranteed by design unused pins can be kept open without any impact on the device.
4.
Unused VSENSEPx and VSENSENx pins can both be connected to GND.
Table 3. Resistor types
Pin type
Description
PU
Pull-up to VCCIO (nominal value: 120 k
Weak PU
Weak pull-up to VCCIO (nominal value: 480 k
PD
Pull-down to AGND (nominal value: 120 k
Weak PD
Weak pull-down to AGND (nominal value: 480 k
PT2000
9
NXP Semiconductors
4
Functional description
4.1
Introduction
The PT2000 is a mixed signal IC for engine injector and electrical valve control, which provides a cost effective, flexible, and smart, highside and low-side MOSFET gate driver. The device includes both individual charge pump outputs for each high-side pre-driver and highvoltage DC/DC converter pre-driver. Gate drive, diagnostics, and protection against external faults, are managed through six independent
and concurrent digital microcores. Each of the three logic channels including two microcores and their own code RAM and data RAM. The
internal microcode is protected against theft via encryption and corruption via check sums. Those microcores are optimized to control
power MOSFET with a small latency time. The PT2000 can control three banks of two injectors each or three banks with one injector per
bank for full overlap,
4.2
Features
High-side and low-side pre-drivers
• Seven high-side pre-drivers for logic level N-channel MOSFETs using four programmable slew rates
• Six low-side pre-drivers for logic level N-channel MOSFETs using four programmable slew rates
• Integrated bootstrap circuitry for each high-side pre-driver
• Integrated charge pump circuitry for each high-side pre-driver with 100% duty cycle capability
• Configurable automatic freewheeling capability between high-side and low-side
DC/DC converter
• Two low-side pre-driver, for a logic level N-channel MOSFET, can be optionally dedicated to providing a boost DC-DC converter with
four programmable slew rates
• Three different control modes to reduce power dissipation (manual, hysteretic, resonant)
Current measurement
• Four independent current measurement blocks
• Two current measurements (channel 5 and 6) are optionally configurable to support DC/DC converters
Diagnostics and monitoring
• VDS and VSRC monitoring (programmable values) for fault protection and diagnostics
• VBOOST monitoring
• VBAT monitoring
• Temperature monitoring
Integrated end of injection detection
• Accurate detection of end of injection for each high-side source and low-side drain without any external component needed.
Power supplies
• Integrated 7.0 V linear regulator (VCCP) for the HS/LS gate power supply (2)
• Integrated 2.5 V linear regulator (VCC2P5) for the digital core supply based on the VCC5 input supply
• External 5.0 V supply (VCC5)
• Selectable VCCIO external supply (5.0 V or 3.3 V) for digital I/O
Digital block
• Six digital microcores, each with their own ALU, and full access to the system crossbar switch
• Three memory banks: 1024 x 16-bit of code RAM with built-in error detection and 64 x 16-bit of data RAM
• Memory BIST and Logic BIST activated by the SPI, with pass/fail status
Control interface
• 16-bit slave SPI up to 10 MHz - two protocols - programmable slew rate
• 16 general purpose digital IOs able to sustain up to 36 V
• Independent direct pre-driver inhibition input for safety purposes
PT2000
NXP Semiconductors
10
5
Electrical characteristics
5.1
Maximum ratings
Table 4. Maximum ratings
All voltages are with respect to ground unless otherwise noted. Exceeding these ratings may cause a malfunction or permanent damage
to the device.
Symbol
Ratings
Min.
Max.
Unit
0
72
V
Notes
Electrical ratings
VBOOSTMAX
DC voltage at VBOOST
VBATT
DC voltage at VBATT
-0.3
72
V
VCC5
DC voltage at VCC5
-0.3
36
V
VCCIO
DC voltage at VCCIO
-0.3
36
V
VCC2P5
DC voltage at VCC2P5
-0.3
3.0
V
DC voltage at CLK, MISO, MOSI, SCLK, CSB, IRQB, RESETB
-0.3
36
V
VDRV_EN
DC voltage at DRVEN
-0.3
36
V
VSTARTX
DC voltage at STARTx
-0.3
36
V
VFLAGX
DC voltage at FLAGx
-0.3
36
V
VSTART8_VSENSE
Start8 voltage of pins multiplexed with VSENSEN4
-1.0
-1.0
18
36
V
(5)
VFLAG4_VSENSE
Flag4 voltage of pins multiplexed with VSENSEP4
-2.5
-2.5
18
36
V
(5)
DC voltage at DBG
-0.3
36
V
DC voltage at OA_1, OA_2, OA_3
-0.3
36
V
VDGND
DC voltage at DGND
-0.3
0.3
V
VAGND
DC voltage at AGND
-0.3
0.3
V
VCCP
DC voltage at VCCP
-0.3
9.0
V
S_HSx
• DC voltage
• Transients t 36 V, the VBAT
monitoring feature will not work but device will be 100 % functional until VBAT = 72 V.
PT2000
15
NXP Semiconductors
5.3
High-side pre-driver electrical characteristics
Table 6. High-side pre-driver electrical characteristics
Characteristics noted under conditions -40 ºC < TA < +125 ºC, referenced to ground, unless otherwise noted. Typical values noted reflect
the approximate parameter means at TA = 25 °C under nominal conditions, unless otherwise noted.
Symbol
Characteristic
Min.
Typ.
Max.
Unit
Notes
High-side pre-driver
VS_HSX
S_HSx pin operating voltage
Transients t 4.75 V
• VBATT < 8.0 V, VCC5 > 4.75 V
RBIAS_LS
Equivalent resistance of LS current source
• VD_LSx < 1.0 V
Load biasing structures
IBIAS_HS
IBIAS_HS_STRONG
3.8
(VBATT/2)
-200 mV
(VBATT/2)
VCC5
(VBATT/2)
200 mV
0.5
—
1.5
—
V
k
Notes
33.
Current source can be connected to maximum two D_LSx
34.
Current source can be connected to maximum three D_LSx
35.
Current source can be connected to maximum five D_LSx
PT2000
23
NXP Semiconductors
5.9
Current measurement electrical characteristics
5.9.1
Current measurement for positive current
This section is applicable for all current measurement paths for positive currents:
• Current measurement channel 1- 4
• Differential amplifier 1- 4
• DAC 1- 4
• Comparator 1- 4
• Current measurement channel 5 - 6
• Differential amplifier 5 - 6
• DAC 5 - 6H and DAC 5 - 6L
• Comparator 5 - 6H and 5 - 6L
Table 12. Current measurement for positive currents
Symbol
CS
Statistically
evaluated
Characteristic
Overall current sense error including gain errors and offsets at DAC range of 75% 100%, after analog offset compensation
• at GDA_diff (00) = 5.8
• at GDA_diff (01) = 8.7
• at GDA_diff (10) = 12.6
• at GDA_diff (11) = 19.3
±3.5
±3.5
±3.5
±3.5
At DAC range of 25% to 75%, after analog offset compensation
• at GDA_diff (00) = 5.8
• at GDA_diff (01) = 8.7
• at GDA_diff (10) = 12.6
• at GDA_diff (11) = 19.3
±5.3
±5.3
±5.3
±5.3
Unit
Notes
%
(36) (37)
%
(36), (37)
,
Notes
36.
Guaranteed by design.
37.
The tolerance of the 10 m shunt resistor is assumed as ±2.0% (at 4.5 ). All other input tolerances from the device specification are assumed
at 6 .
Table 13. Differential amplifier 1, 2, 3, 4, 5, and 6
Characteristics noted under conditions -40 ºC < TA < +125 ºC, referenced to ground, unless otherwise noted. Typical values noted reflect
the approximate parameter means at TA = 25 °C under nominal conditions, unless otherwise noted.
Symbol
Characteristic
Min.
Typ.
Max.
Unit
VVSENSENX_DA
Differential amplifier x functional range VSENSENx (x = 1…6)
-1.0
—
1.0
V
VVSENSEPX_DA
Differential amplifier x functional range VSENSEPx (x = 1…6)
-1.0
—
1.5
V
VDA_DIFF_IN (00)
Differential input voltage range (00)
• GDA_DIFF(00) = 5.8
-25.9
—
387
mV
VDA_DIFF_IN (01)
Differential input voltage range (01)
• GDA_DIFF(01) = 8.7
-17.3
—
258
mV
VDA_DIFF_IN (10)
Differential input voltage range (10)
• GDA_DIFF(10) = 12.6
-12
—
179
mV
VDA_DIFF_IN (11)
Differential input voltage range (11)
• GDA_DIFF(11) = 19.3
-7.8
—
116
mV
GDA_DIFF (00)
Differential voltage gain (00)
5.71
5.79
5.87
GDA_DIFF (01)
Differential voltage gain (01)
8.55
8.68
8.81
GDA_DIFF (10)
Differential voltage gain (10)
12.32
12.53
12.74
Notes
PT2000
NXP Semiconductors
24
Table 13. Differential amplifier 1, 2, 3, 4, 5, and 6 (continued)
Characteristics noted under conditions -40 ºC < TA < +125 ºC, referenced to ground, unless otherwise noted. Typical values noted reflect
the approximate parameter means at TA = 25 °C under nominal conditions, unless otherwise noted.
Symbol
Characteristic
GDA_DIFF (11)
Differential voltage gain (11)
tDA_GAIN_SW
Gain switching settling time
Min.
Typ.
Max.
Unit
Notes
18.92
19.25
19.58
—
2.0
s
(38)
RVSENSENX_IN
Input impedance VSENSENx (x = 1…4)
• 1.0 V common mode voltage
10
—
26
k
RVSENSEPX_IN
Input impedance VSENSEPx (x = 1…4)
• 1.0 V common mode voltage
10
—
26
k
CVSENSE
Differential amplifier EMI filter C. It is recommended to place a filter C
between VSENSEN and P close to the IC for EMI.
—
330
—
pF
VDA_BIAS
Output bias voltage
240
250
265
mV
Maximum output offset voltage error at maximum gain
-140
—
220
mV
0.1
—
2.7
V
DAC LSB
—
9.77
—
mV
VDAC_OUT_MIN
DAC minimum output voltage
• DAC code = 0h
—
0.0
—
V
VDAC_OUT_MAX
DAC maximum output voltage
• DAC code = FFh
—
2.49
—
V
DAC_DNL
DAC differential linearity error
-0.5
—
0.5
LSB
DAC_INL
DAC integral linearity error
-1.0
—
1.0
LSB
DAC maximum output offset
0.0
—
10
mV
DAC settling time
—
—
0.9
s
Comparator input voltage
0.0
—
2.7
V
Comparator input offset voltage
-25
—
10
mV
500
ns
VDA_OUT_OFF
VDA_OUT
Differential amplifier x output voltage range
DAC 1, 2, 3, 4, 5L, 5H, 6H, and 6L (8-bit)
VDAC_LSB
VDAC_OUT_OFF
tDAC
Voltage comparator 1, 2, 3, 4, 5H, 5L, 6H, and 6L
VCOMP_IN
VCOMP_IN_OFF
Current measurement channel 1, 2, 3, 4, 5, and 6 detection delays
tD_CS
Detection delay coming from differential amplifier and comparator at
GDA_DIFF(00) = 5.8
20
(38)
Notes
38.
Guaranteed by design.
PT2000
25
NXP Semiconductors
Table 13. Differential amplifier 1, 2, 3, 4, 5, and 6 (continued)
Characteristics noted under conditions -40 ºC < TA < +125 ºC, referenced to ground, unless otherwise noted. Typical values noted reflect
the approximate parameter means at TA = 25 °C under nominal conditions, unless otherwise noted.
Symbol
Characteristic
Min.
Typ.
Max.
150
-310
—
—
310
-150
Unit
Notes
mV
(40)
Differential amplifier 1, 2, 3, 4, 5L, 5H, 6L and 6H analog offset compensation
VOFFDAC_OUT_MAX
_POS
VOFFDAC_OUT_MAX
_NEG
Offset compensation voltage range referred to amplifier output offset
at maximum gain
• Offset DAC value = +31
• Offset DAC value = -31
VOFFDAC_LSB
Offset compensation step size referred to amplifier output offset at
maximum gain
5.0
—
10
mV
VCS_OFF_TEMP
Differential amplifier output offset temperature drift
-5.0
-50
—
—
5.0
50
LSB
mV
(39)
Residual offset after offset compensation at diff amplifier output for
path shunt comparator output
-0.61
-6.1
—
—
0.39
3.9
LSB
mV
(41)
Offset compensation minimum step time
—
—
2.0
s
(40)
Offset compensation runtime to finish compensation
—
—
2.0*31 = 62
s
(40)(42)
VCS_OFF_GD
tOFFCOMP_STEP
tOFFCOMP
Notes
39.
Guaranteed by design.
40.
Gain set to GDA_DIFF(11) = 19.3
41.
The offset compensation algorithm is implemented so the compensation always stops when the comparator output signal is low, assuming a zero
DAC gain error and INL.
42.
Assuming the start from an offset compensation DAC value of 0 is worst case, it has to go to one extreme value (-31 or 31).
5.9.2
Current measurement for negative currents
This section is applicable for all current measurement paths for negative currents:
• Current measurement channel 5 and 6
• Differential amplifier 5 and 6 negative
• DAC 5 and 6 negative
• Comparator 5 and 6 negative
Table 14. PT2000 static electrical characteristics
Characteristics noted under conditions -40 ºC < TA < +125 ºC, referenced to ground, unless otherwise noted. Typical values noted reflect
the approximate parameter means at TA = 25 °C under nominal conditions, unless otherwise noted.
Symbol
Characteristic
Min.
Typ.
Max.
Unit
Notes
—
—
—
—
4.4
8.9
%
(43), (44)
Differential amplifier 5 and 6 negative (negative currents) functional
range VSENSE N5/6
-3.0
—
1.0
V
(43)
Differential amplifier 5 and 6 negative (negative currents) functional
range VSENSE P5/6
-4.2
—
1.0
V
(43)
Differential input voltage range
• GDANEG_DIFF = -2.0
-1.125
—
0.0
V
(43)
Differential voltage gain
-1.966
-2.0
-2.034
6.0
—
14
Overall current sense performance for negative
CSNEG
Overall current sense error including gain errors and offsets
• at DAC range of 75% to 100% at GDANEG_DIFF = -2.0
• at DAC range of 25% to 75% at GDANEG_DIFF = -2.0
Differential amplifier 5, 6 negative
VVSENSEN5/
6_DANEG
VVSENSEP5/
6_DANEG
VDANEG_DIFF_IN
GDANEG_DIFF
RVSENSEN5/6_IN
Input impedance VSENSE N5/6
• 1.0 V common mode voltage
k
PT2000
NXP Semiconductors
26
Table 14. PT2000 static electrical characteristics (continued)
Characteristics noted under conditions -40 ºC < TA < +125 ºC, referenced to ground, unless otherwise noted. Typical values noted reflect
the approximate parameter means at TA = 25 °C under nominal conditions, unless otherwise noted.
Symbol
Characteristic
Min.
Typ.
Max.
Unit
Notes
Differential amplifier 5, 6 negative (continued)
RVSENSEP5/6_IN
Input impedance VSENSE P5/6
• 1.0 V common mode voltage
6.0
—
14
k
VDANEG_IN_OFF
Differential amplifier maximum input offset voltage
-20
—
20
mV
Output bias voltage
240
250
265
mV
Maximum output offset voltage error, including amplifier input offset
and bias voltage offset.
-60
—
60
mV
Differential amplifier x output voltage range
0.0
—
2.7
V
DAC LSB
—
156.3
—
mV
VDACNEG_OUT_MIN
DAC minimum output voltage
• DAC code = 0h
—
0.0
—
V
VDACNEG_OUT_MAX
DAC maximum output voltage
• DAC code = Fh
—
2.344
—
V
-1.0
—
1.0
%
VDANEG_BIAS
VDANEG_OUT_OFF
VDANEG_OUT
DAC 5 Neg and 6 Neg (4 Bit)
VDACNEG_LSB
DACNEG_GAIN
DAC maximum gain error
• Error of bandgap reference voltage
DACNEG_DNL
DAC differential linearity error
-0.063
—
0.063
LSB
DAC integral linearity error
-0.063
—
0.063
LSB
DAC maximum output offset
0.0
—
10
mV
DAC settling time
—
—
0.9
s
Comparator input voltage
0.0
—
2.7
V
Comparator input offset voltage
-25
—
10
mV
20
—
500
ns
DACNEG_INL
VDACNEG_OUT_OFF
tDACNEG
Voltage comparator 5 Neg and 6 Neg
VCOMP_IN
VCOMP_IN_OFF
Current measurement channel 5 Neg and 6 Neg detection delays
tD_CSNEG
Detection delay coming from differential amplifier and comparator
• GDANEG_DIFF = -2.0
(45)
Notes
43.
Guaranteed by design.
44.
The tolerance of the 10 m shunt resistor is assumed as ±2.0% (at 4.5 ). All other input tolerances from the device specification are assumed at
6
45.
Guaranteed by design.
PT2000
27
NXP Semiconductors
5.10
Analog output (OAx) electrical characteristics
Table 15. Analog output static electrical characteristics
Characteristics noted under conditions -40 ºC < TA < +125 ºC, referenced to ground, unless otherwise noted. Typical values noted reflect
the approximate parameter means at TA = 25 °C under nominal conditions, unless otherwise noted.
Symbol
Characteristic
Min.
Typ.
Max.
Unit
Notes
OAx output voltage range
0.0
—
VCC5
V
OAx output bandwidth
100
—
—
kHz
OAx permissible capacitive load
• without series resistor, for digital function
• RMIN = 200
• RMIN = 100
• RMIN = 75
• RMIN = 50
—
1.0
5.0
15
50
—
—
—
—
—
50
5.0
15
50
100
pF
nF
nF
nF
nF
PSRROAX
OAx power supply rejection
—
—
103
dB
(46)
GOAX(00)
OAx output gain (00)
1.303
1.33
1.357
GOAX(01)
OAx output gain (01)
1.940
2.0
2.060
GOAX(10)
OAx output gain (10)
2.91
3.0
3.090
GOAX(11)
OAx output gain (11)
5.17
5.33
5.49
GOAX(ADC)
OAx output gain (ADC)
0.98
1.0
1.02
tOAX_GAIN
OAx output gain switching time
—
—
2.0
s
(46)
OAx output offset voltage from OAx amplifier
• GOAx = 1.0
• GOAx = 1.33
• GOAx = 2.0
• GOAx = 3.0
• GOAx = 5.33
-14
-18
-28
-30
-53
—
—
—
—
—
14
18
28
30
53
—
—
8000
k
350
—
500
k
OAx output PiNS, multiplexer and T&H
VOAX
BWOAX
COAX
VOAX_OFFSET
ROA1/3_EN0
OA1/3 input impedance when OaENx = 0
• 2.0 V, impedance to GND
(46)
mV
ROA2_EN0
OA2 input impedance when OaENx = 0
• 2.0 V, impedance to GND
tOAX_MUX
OAx multiplexer switching time
—
—
10
s
OAx output voltage drift of T&H in ADC mode over time
• at VOAx = 1.5 V and after 20 s
-50
—
50
mV
VOAX_DRIFT_ADC
(46)
(46)
Notes
46.
Guaranteed by design.
PT2000
NXP Semiconductors
28
5.11
Clock / PLL electrical characteristics
Table 16. Clock / PLL electrical characteristics
Characteristics noted under conditions -40 ºC < TA < +125 ºC, referenced to ground, unless otherwise noted. Typical values noted reflect
the approximate parameter means at TA = 25 °C under nominal conditions, unless otherwise noted.
Symbol
Characteristic
Min.
Typ.
Max.
Unit
Notes
Backup clock
fCLK
CLK pin input frequency
0.94
1.0
1.06
MHz
DCCLK
CLK pin input duty cycle
45
50
55
%
CLK pin voltage
0.0
—
VCCIO
V
VIH_CLK
CLK pin high input voltage threshold
1.5
—
2.2
V
VIL_CLK
CLK pin low input voltage threshold
1.0
—
1.65
V
VHYST_CLK
CLK pin hysteresis
0.3
—
—
V
tCLK_JITTER
CLK pin clock edge jitter
-25
—
25
ns
fCLK_BACK
Backup oscillator clock frequency
0.95
1.0
1.05
MHz
DCCLK_BACK
Backup oscillator clock duty cycle
48
50
52
%
fCLK_BACK
*24.5
MHz
VCLK
(47)
PLL
fCKSYS24
fCKSYS_MOD
Cksys output clock frequency 24 MHz
fCLK_BACK fCLK_BACK
*23.5
*24
(48)
Cksys modulation frequency
—
25
—
kHz
tPLL _LOCK
PLL lock time
—
25
40
s
tCKSYS_T1
Cksys rising edge to cksys_cram rising edge T1 CRAM address setup
phase
8.75
—
12.32
ns
(49)
tCKSYS_T2
Cksys rising edge to cksys_c/dram rising edge T2 CRAM/DRAM
address setup phase
19.44
—
—
ns
(49)
tCKSYS_T3
Cksys_c/dram rising edge to cksys rising edge T3 CRAM/DRAM
access time
19.44
—
—
ns
(49)
Notes
47.
Guaranteed by design.
48.
Divider value is changed every 10 μs
49.
The following values take into account an input clock at 0.95 MHz to 1.05 MHz, a PLL multiplication factor of 47 to 49, and an output duty cycle of
45% to 55%.
Figure 4. PLL, DRAM/CRAM system clock
PT2000
29
NXP Semiconductors
5.12
Digital input/output electrical characteristics
Table 17. PT2000 static electrical characteristics
Characteristics noted under conditions -40 ºC < TA < +125 ºC, referenced to ground, unless otherwise noted. Typical values noted reflect
the approximate parameter means at TA = 25 °C under nominal conditions, unless otherwise noted.
Symbol
Characteristic
Min.
Typ.
Max.
Unit
VIOVCCIO
Digital pins voltage (IRQB, MISO, MOSI, SCLK, CSB, Startx, Flagx,
DBG, OAx)
0.0
—
VCCIO
V
VIOVCC5
Digital pins voltage (RESETB, DRVEN)
0.0
—
VCC5
V
tDIGIOREADY
Digital output ready time after POResetB deactivation
—
—
100
s
tFILT_RESETB
RESETB filter time
0.2
—
2.0
s
VIH_IO
Digital pins high input voltage threshold (RESETB, IRQB, MOSI,
SCLK, CSB, DRVEN, Startx, Flagx, DBG, OAx)
1.5
—
2.2
V
VIL_IO
Digital pins low input voltage threshold (RESETB, IRQB, MOSI, SCLK,
CSB, DRVEN, STARTx, FLAGx, DBG, OAx)
1.0
—
1.65
V
VHYST_IO
Digital pins hysteresis (RESETB, IRQB, MOSI, SCLK, CSB, DRVEN,
STARTx, FLAGx, DBG, OAx)
0.3
—
—
V
VOH_IO
Digital pins high output voltage (IRQB, MISO, START1-7, FLAG0-3,
DBG)
• IOUT > -1.0 mA, no higher current at other I/Os
VCCIO -0.3
—
—
V
VOL_IO
Digital pins low output voltage (IRQB, MISO, START1-7, FLAG0-3,
DBG)
• IOUT < 1.0 mA, no higher current at other I/Os
—
—
0.3
V
Notes
Digital I/OS
VOH_ START8/FLAG4
Digital pins high output voltage (Start8, Flag4)
• IOUT > -200 A
VCC0 -0.6
—
—
V
VOL_ START8/FLAG4
Digital pins low output voltage (Start8, Flag4)
• IOUT > -200 A
—
—
0.6
V
2.8
VCC5 -0.6
—
—
—
—
V
VOH_OA2
Digital pins high output voltage (OA2)
• GOAx = 1.33, IOUT > -1.0 mA
• GOAx = 2.0, IOUT > -1.0 mA
VOL_OA2
Digital pins low output voltage (OA2), IOUT < 0.5 mA
—
—
0.3
V
tR_XXX
Digital pins output rise time (IRQB, START1-7, FLAG0-3, DBG)
• CLOAD = 30 pF, 10%-90% of out voltage
3.0
—
12
ns
tF_XXX
Digital pins output fall time (IRQB, START1-7, FLAG0-3, DBG)
• CLOAD = 30 pF, 90%-10% of out voltage
3.0
—
12
ns
tD_XXX
Digital pins output delay (IRQB, START1-7, FLAG0-3, DBG)
• CLOAD = 30 pF, 10% of out voltage
2.0
—
10
ns
PT2000
NXP Semiconductors
30
Table 17. PT2000 static electrical characteristics (continued)
Characteristics noted under conditions -40 ºC < TA < +125 ºC, referenced to ground, unless otherwise noted. Typical values noted reflect
the approximate parameter means at TA = 25 °C under nominal conditions, unless otherwise noted.
Symbol
Characteristic
Min.
Typ.
Max.
Unit
Notes
Digital I/OS (continued)
tR_OA2
Digital pins output rise time (OA2), 10%-90% of out voltage
• CLOAD = 30 pF with VCCIO = 3.3 V
• CLOAD = 30 pF with VCCIO = 5.0 V
—
—
—
—
1.4
2.0
s
(50)
tF_OA2
Digital pins output fall time (OA2), 90%-10% of out voltage
• CLOAD = 30 pF with VCCIO = 3.3 V
• CLOAD = 30 pF with VCCIO = 5.0 V
—
—
—
—
1.4
3.2
s
(50)
tD_OA2
Digital pins output delay (OA2), 10% of out voltage
• CLOAD = 30 pF with VCCIO = 3.3 V
• CLOAD = 30 pF with VCCIO = 5.0 V
—
—
—
—
2.7
3.0
s
(50)
tR_START8/FLAG4
Digital pins output rise time (START8, FLAG4)
• CLOAD = 30 pF, 10%-90% of out voltage
60
—
200
ns
(50)
tF_START8/FLAG4
Digital pins output fall time (START8, FLAG4)
• CLOAD = 30 pF, 90%-10% of out voltage
60
—
200
ns
(50)
tD_START8/FLAG4
Digital pins output delay (START8, FLAG4)
• CLOAD = 30 pF, 10% of out voltage
5.0
—
20
ns
(50)
CPIN_XXX
Digital pins equivalent pin capacitance (IRQB, STARTx, FLAGx, DBG)
—
—
10
pF
(50)
CPIN_MISO
Digital pin equivalent pin capacitance (MISO)
—
—
10
pF
(50)
CPIN_MOSI
Digital pin equivalent pin capacitance (MOSI)
—
—
10
pF
(50)
Weak pull-up/down resistor
200
480
800
k
Pull-up/down resistor
50
120
200
k
Pull-up/down resistors
RW_PU/PD
RPU/PD
Notes
50.
Guaranteed by design.
PT2000
31
NXP Semiconductors
5.13
Serial peripheral interface electrical characteristics
Figure 5. SPI timing
Table 18. SPI electrical characteristics
Characteristics noted under conditions -40 ºC < TA < +125 ºC, referenced to ground, unless otherwise noted. Typical values noted reflect
the approximate parameter means at TA = 25 °C under nominal conditions, unless otherwise noted.
Symbol
Characteristic
Min.
Typ.
Max.
Unit
Notes
SPI
fSCLK
SCLK pin input frequency - (1)
—
—
12.5
MHz
(51)
tCSBF_SCLKR
CSB fall to first SCLK rise - (2)
1/fSCLK
—
—
ns
(51)
tSCLKF_CSBR
Last SCLK fall to CSB rise - (3)
1/fSCLK
—
—
ns
(51)
tMISO_VAL
MISO valid time - (4)
—
—
10 +
tR_MISO
ns
(51)
tMOSI_SET
MOSI setup time - (5)
10
—
—
ns
(51)
tMOSI_HOLD
MOSI hold time - (6)
12.5
—
—
ns
(51)
tCSBR_MISOT
CSB rise to MISO tri-state - (7)
—
—
15
ns
(51)
tSCLKF_CSBF
SCLK fall (other device) to CSB fall - (8)
13
—
—
ns
(51)
tCSBR_CLKR
CSB rise to SCLK rise (other device) - (9)
15
—
—
ns
(51)
SPI setup time after first RESETB rising edge
100
—
—
s
(51)
SPI setup time after each following RESETB rising edge
30
—
—
s
(51)
tSPI_RESETB_t0
tSPI_RESETB
Notes
51.
See Figure 5
PT2000
NXP Semiconductors
32
Table 18. SPI electrical characteristics
Characteristics noted under conditions -40 ºC < TA < +125 ºC, referenced to ground, unless otherwise noted. Typical values noted reflect
the approximate parameter means at TA = 25 °C under nominal conditions, unless otherwise noted.
Symbol
Characteristic
Min.
Typ.
Max.
tR_MISO_S3.3
MISO rise time slow setting:
• CL = 30 pF
• CL = 75 pF
• CL = 150 pF
10
20
40
—
—
—
30
50
90
tF_MISO_S3.3
MISO fall time slow setting:
• CL = 30 pF
• CL = 75 pF
• CL = 150 pF
10
20
40
—
—
—
30
50
90
tR_MISO_F3.3
MISO rise time fast setting:
• CL = 30 pF
• CL = 75 pF
• CL = 150 pF
1.5
2.7
4.4
—
—
—
13.4
17.1
23.9
tF_MISO_F3.3
MISO fall time fast setting:
• CL = 30 pF
• CL = 75 pF
• CL = 150 pF
1.5
2.7
4.4
—
—
—
13.4
17.1
23.9
tR_MISO_S5.0
MISO rise time slow setting:
• CL = 30 pF
• CL = 75 pF
• CL = 150 pF
9.0
20
35
—
—
—
25
47
77
tF_MISO_S5.0
MISO fall time slow setting:
• CL = 30 pF
• CL = 75 pF
• CL = 150 pF
9.0
20
35
—
—
—
25
47
77
tR_MISO_F5.0
MISO rise time fast setting:
• CL = 30 pF
• CL = 75 pF
• CL = 150 pF
1.1
2.1
3.6
—
—
—
9.6
12.5
17.8
tF_MISO_F5.0
MISO fall time fast setting:
• CL = 30 pF
• CL = 75 pF
• CL = 150 pF
1.1
2.1
3.6
—
—
—
9.6
12.5
17.8
Unit
Notes
SPI MISO driver with VCCIO = 3.3 V
ns
ns
ns
ns
SPI MISO driver with VCCIO = 5.0 V
ns
ns
ns
ns
PT2000
33
NXP Semiconductors
6
Functional block description
6.1
Power supplies
6.1.1
VCC5
The PT2000 works with an external supply voltage of 5.0 V connected to the VCC5 pin. This voltage is used for the VCC2P5 regulator,
the load biasing, and to supply the analog blocks. The VCC5 overvoltage monitor is used to disconnect the device from the VCC5 supply
in any overvoltage condition at this pin. This is done to guarantee 36 V robustness of the VCC5 pin.
The VCC5 undervoltage monitor is used to disable all the pre-drivers, as long as the supply voltage at the VCC5 pin is not high enough
to guarantee full functionality of the analog modules of the device. An interrupt request (in case it is enabled) is issued to the
microcontroller as soon as uv_vcc5 is asserted.
6.1.2
VCCIO
The interfaces toward the ECU microcontroller uses the VCCIO voltage for the output drivers and receives the same levels on its inputs.
The voltage level of the I/O pins interfacing the device with the microcontroller (STARTx, FLAGx, RESETB, DBG, SPI pins, CLK, IRQB,
DRVEN, and OA_x, when used as digital I/O) can be selected between 3.3 V and 5.0 V by supplying the device with the desired voltage
at the VCCIO pin. This does not change the possible output voltage range of the analog outputs OA_x when used as analog outputs
because they are supplied by VCC5
Note that the DRVEN and RESETB input pins can operate with an input level of 5.0 V, even when VCCIO is 3.3 V.
6.1.3
VCC2P5 regulator
An integrated voltage regulator, fed by the VCC5 supply pin, provides 2.5 V to supply the logic core of the device. An external buffer
capacitor (1.0 F recommended) needs to be connected at the VCC2P5 pin. The regulator, as well as the buffer capacitor, is referenced
to digital ground (DGND pin).
If the VCC2P5 voltage is below the undervoltage threshold (VPORESETB- for a minimum duration of tPORESETB), the power on reset
signal (VCC2P5) is asserted to the logic core after a delay of tD_PORESETB and resets the logic core and all device internal modules.
Figure 6. PORESETB
PT2000
NXP Semiconductors
34
6.1.4
VCCP regulator
6.1.4.1
Internal VCCP (vccp_ext_en='0')
The voltage source at the VBATT input pin provides power for the VCCP regulator. This integrated linear regulator provides typically 7.0 V
at the VCCP pin, to supply the pre-driver section of the device. The regulator uses low drop out features to extend the system's operating
range when VBATT temporarily falls below its normal operating range, for example during engine crank conditions. This avoids problems
caused by insufficient gate voltage, such as slow MOSFET switching and increased on-state losses. A capacitor (4.7 F recommended)
is required at the VCCP pin to provide the high peak currents required when charging a MOSFET gate.
At low VCC5, the regulator may be active, but with an increased dropout voltage. The low dropout mode of the regulator is active only when
the voltage at VCC5 is above the VCC5 undervoltage threshold VUVVCC5+.
If VCC5 is not present or low, POResetB is active and disables the VCCP regulator.
VCCP during bootstrap initialization:
1. If the DBG pin is not used as a digital I/O, the DBG pin logic level is ‘1’ during reset due to the device internal weak pull-up resistor.
As result, the internal VCCP regulator is switched on during the HS pre-driver bootstrap initialization phase. (refer to See Power-up
sequence VCCP and bootstrap capacitors on page 58).
2. If the DBG pin is used as a digital I/O. This means the DBG pin logic level is undefined during reset and may be '0'. As result, the
internal VCCP regulator's On status during HS pre-driver bootstrap init phase can only be guaranteed if vccp_ext_en is set to '0'.
The bit has to be configured as soon as possible during device init, to start the pre-charging of the bootstrap capacitors soon
enough (refer to Table 148, Driver_config_Part 2 (1A6h)).
Note that this regulator also needs a charge pump voltage coming from the VBOOST pin. Due to this, the VCCP regulator is not functional
when the voltage on the VBOOST pin is below 4.7 V.
6.1.4.2
External VCCP (vccp_ext_en='1')
The VCCP can also be powered by an external voltage source connected to the VCCP pin. The internal VCCP regulator is sized for 12 V
system operation, including the ISO voltage transients specified for those systems. But for 24 V system operation, the internal VCCP linear
regulator dissipates too much power. In this case, the internal VCCP regulator should be switched off by setting the vccp_ext_en bit of the
driver_config_part2 register (1A6h) to '1' and an external regulator needs to be used.
VCCP during initialization VCCP:
1. If is not possible to turn on the internal VCCP regulator for a limited time in parallel to the external voltage source, the DBG pin has
to be tied to logic level '0' and the SPI configuration bit has to stay at '1', to strictly avoid the internal regulator to be switched on at
any time. The logic level of the DBG pin should be forced by a pull-down resistor towards GND.
2. On the other hand, if it is possible to switch on the internal regulator for some limited time in parallel with the external voltage supply
without destroying it, no special measures have to be taken during startup. After bootstrap initialization, the vccp_ext_en bit has to
be set to '1' (refer to Table 148, Driver_config_Part 2 (1A6h)).
6.1.4.3
VCCP undervoltage
VCCP voltage is internally monitored by a voltage comparator to detect if it is in the operating range. In case of an undervoltage when falling
below the lower threshold, the gate driver outputs are switched off by the digital core.
This prevents possible malfunctions and/or failures: in case of an undervoltage, operations are stopped before any malfunction, due to
insufficient gate driver supply voltage. Moreover, in case of a battery voltage disconnection, all MOSFETs are switched off (and therefore
inductive loads are disconnected) before the electrolytic capacitors on the VBATT line are completely discharged. This prevents any
negative voltage on the VBATT line, which may cause failures on the VBATT, VCCP, D_HSx and B_HSx pins due to exceeding its
maximum ratings.
PT2000
35
NXP Semiconductors
6.1.5
Battery voltage monitor
The device includes a battery voltage measurement block which measures the voltage at the VBATT pin with a DAC and comparator
running in ADC mode. Figure 7 shows the structure of the analog part of the block. The battery voltage is divided with a voltage divider
by 16. The battery voltage can be measured in the range of 5.0 V to 36 V with a resolution of 6 bits. The digital core permanently performs
the battery voltage measurements. The result is available both via a SPI register and the internal microcore memory map.
Figure 7. Battery voltage monitoring
The battery voltage threshold can be calculated using the following formula. Table 19 shows some example values.
VBAT = (DAC_VALUE * 39.06 mV) * 16
Table 19. VBAT voltage DAC values
DAC value
HEX
DEC
08
8
…
DAC output voltage/mV
VBAT upper threshold
Min./V
Typ./V
Max./V
313
....
5.0
...
…
…
…
…
…
16
22
859.4
...
13.75
...
…
…
…
…
…
…
39
57
2226.6
...
35.63
...
6.1.6
Boost voltage monitor
The boost voltage monitor implements the voltage regulation of the DC/DC converter without external components. The boost voltage
monitor contains:
• A high accuracy internal voltage divider dividing the voltage at the VBOOST pin to a smaller level VBOOST_DIV
• A programmable DAC (8 bits) either by the SPI (refer to Table 113. Boost_dac (17Fh)) or by microcode creating a reference voltage
• A comparator comparing the reference voltage with the VBOOST_DIV
PT2000
NXP Semiconductors
36
Figure 8. Boost voltage monitor block diagram
When boost voltage is required to drive injectors, the boost voltage monitor use a voltage comparator with a very accurate DAC threshold,
whether the VBOOST boost voltage exceeds the desired target value. All high-side pre-drivers are disabled when the voltage at the
VBOOST pin is less than its undervoltage lockout threshold, which is around 4.7 V.
In applications without boost voltage, the battery voltage is connected to the VBOOST pin to supply the internal charge pump. In such
applications, the boost voltage monitor can be used to detect an undervoltage at the VBOOST pin (vboost_mon_en = 0). This means the
VBOOST pin is used to detect battery undervoltage.
6.1.6.1
Application with VBOOST voltage
The boost voltage threshold can be calculated using the following formula. Table 20 shows some example values.
• VBOOST = (DAC_VALUE * 312.5 mV)
Due to the compensation, concept values below 08h should not be used. Values higher than E1h must not be used, because this results
in a boost voltage higher than 72 V which destroys the device. The real maximum value for the boost set point threshold in the application
is even lower due to dynamic effects like voltage drop in the boost capacitor. It is not recommendable to use a DAC value above D0h
(65 V).
Table 20. Boost voltage DAC values
DAC value
HEX
BIN
08
8
…
DAC output voltage/mV
VBOOST upper threshold
Min./V
Typ./V
Max./V
78
2.45
2.50
2.55
…
…
…
…
…
9A
154
1504
47.16
48.13
49.09
…
…
…
…
…
…
B0
176
1719
53.90
55.00
56.10
…
…
…
…
…
…
D0
208
2031
63.70
65.00
66.30
…
…
…
…
…
…
E1
225
2197
68.91
70.31
71.72
PT2000
37
NXP Semiconductors
6.1.6.2
Application without boost voltage
For this purpose, it is possible to change the internal voltage divider ratio from 1/32 to 1/4 by setting the signal boost_mon_en high. To
detect undervoltage and use the signal uv_vboost to disable the pre-drivers, the uv_vboost bit needs to be set to “1” (refer to Table 162,
driver_status (1B2h)). The uv_vboost signal goes high as soon as the voltage at the VBOOST pin is below the threshold, if the VBOOST
UV monitor is enabled (Vboost_disable_en = 1).
The same digital filter used for the VBOOST voltage measurement is also used for the VBOOST UV monitoring mode. The DAC set point
value in this mode has to be chosen to fulfill two requirements:
• The pre-drivers must not be disabled at a battery voltage above 5.0 V
• The device internal charge pump only works properly down to a battery voltage of 4.7 V
The VBOOST UV threshold can be calculated using the following formula.
• VBOOST = (DAC_VALUE * 39.1 mV)
6.1.7
Charge pump
The PT2000 provides one charge pump with independent outputs for each of the seven high-side drivers. The independent outputs allow
complete flexibility of the topology used, meaning all high-sides can drive MOSFETs with the drain connected to VBOOST or VBAT. But
there is a limitation on the diagnostics only HS2, 4, and 6 can use the VBOOST for monitoring (for example, VBAT or VBOOST).
In most operating topologies and conditions, the bootstrap is the primary source of charge for the bootstrap capacitor, and the charge
pump sustains the voltage at each bootstrap capacitor when it is not being charged by low-side switching.
This charge pump allows 100% duty cycle operation of the high-side MOSFETs while the bootstrap circuitry is not operating (VS_HSx
voltage never goes significantly below the VCCP voltage). In this condition, the charge pump provides current maintaining each bootstrap
capacitor charged via independent current sources, to guarantee a minimum VGS voltage.
The charge pump, supplied by VBOOST, creates gate drive voltages of about 8.0 V greater than the voltage at VBOOST. However, their
current capacity is sufficient only for low frequency switching. The charge pump is not running as long as the POResetB reset signal is
active.
The internal CP can be used to charge the bootstrap capacitors during init with a guaranteed current of 20 A per HS pre-driver. This
current is only available if there is no leakage current from B_HSx pin. Any possible leakage current has to be subtracted from this
available charge current (See Using the charge pump to charge bootstrap capacitors on page 59).
6.2
Clock subsystem
The digital logic is supplied by a clock (cksys) generated by the PLL from the 1.0 MHz clock forced externally on CLK pin. Two internal
clocks are derived from the PLL:
• the main logic clock cksys
• the code RAM clock cksys_cram inverted in respect to cksys
• the Data RAM clock cksys_dram inverted in respect to cksys
If an unsuitable signal is applied on the CLK pin, the device automatically switches to the internal backup clock. The PLL output frequency
can be modulated for EMC purposes. Modulation activation is enabled by default, but can be disabled by the SPI. Refer to Table 151
PLL_Config (1A7h).
PT2000
NXP Semiconductors
38
6.3
High-side pre-driver
The PT2000 provides seven independent high-side pre-drivers designed to drive the gate of external high-side configuration N-channel
logic level MOSFETs. These pre-drivers are dedicated to load driving like injectors or solenoids, and integrate diagnostics features.
Internal to the device is a gate to source pull-down resistor holding the external MOSFETs in the off state while the device is in a power
on reset state (RSTB low). The external FET can be connected to either VBATT or a higher voltage VBOOST, limitation in the diagnostics
is described in the next chapter, only HS2, 4, and 6 can use VBOOST voltage for diagnostics.
The high-side pre-drivers are supplied by an external bootstrap capacitor connected between the S_HSX and B_HSX pins. The driver
slew rate can be selected individually for each of the seven drivers, among a set of four value pairs by the SPI registers (refer to Table 99,
Hs_slewrate (171h)).
Figure 9. High-side pre-driver block diagram
The high-side pre-driver is intended to drive the gate of an external logic level MOSFET in a high-side configuration. The logic command,
hsx_command, to switch the external MOSFET, is provided by the microcores. This command is generated for taking into account the
following signals:
• Logic command coming from channel logic (hsx_in)
• VCCP undervoltage signals (uv_vccp) from VCCP UV monitor: in case of an undervoltage, the external MOSFET is switched off
• VCC5 undervoltage signals (uv_vcc5) from VCC5 UV monitor: in case of an undervoltage, the external MOSFET is switched off
• VBOOST undervoltage signals (uv_vboost) from boost voltage monitor: in case of an undervoltage, the external MOSFET is
switched off if this feature is enabled (refer to Table 162, driver_status (1B2h)
• Signal cksys_drven coming from the clock monitoring: in case of a missing clock (PLL not locked), the external MOSFET is switched
off. This function is disabled by default and can be enabled by setting the cksys_missing_disable_driver bit high (refer to Table 152,
backup_clock_status (1A8h))
• At the high-side pre-driver block signal, DrvEn is added to the control signal for the driver. As long as the DrvEn signal is negated
(low), the high-side pre-driver is switched off. The high-side pre-driver 5 and 7 include a feature to override the switch off path via
the DrvEn signal. As long as the signal hsx_en_ovr is high (only for HS5 and HS7), the pre-driver is not influenced by DrvEn. (refer
to Table 178, HSx_output_config (1DA, 1DDh, 1E0h, 1E3h, 1E6h, 1E9h))
PT2000
39
NXP Semiconductors
The truth table describing the status of hsx_command signal is given in Figure 21.
Table 21. High-side pre-driver truth table
DRV_EN
hs5/7_en_ovr
uv_vccp
uv_vcc5
uv_vboost
cksys_drven
hsx_in
hsx_command
Driver status
0
-
-
-
-
-
-
0
off
-
-
1
-
-
-
-
0
off
-
-
-
1
-
-
-
0
off
-
-
-
-
1
-
-
0
off
-
-
-
-
-
0
-
0
off
-
-
-
-
-
-
0
0
off
0
1
0
0
0
1
1
1
on (hs5/7) / off
(other hsx)
1
-
0
0
0
1
1
1
on
The pre-driver G_HSx output is set according to hsx_command:
• When the hsx_command is high, the G_HSx pin is driven high (pull-up to B_HSx voltage);
• When the hsx_command is low, the G_HSx pin is driven low (pull-down to S_HSx voltage).
6.3.1
High-side pre-driver slew rate control
The driver strength can be selected individually for each of the drivers among a set of values by the SPI registers. There are four selectable
driver strengths. The strength for the rising and falling edge can be chosen individually for each driver. Changing the rising edge affects
the falling edge such as to retain the same absolute slew rate. The given value of voltage slew rate is only an indication and is dependent
on the used MOSFET and the additional gate circuit (refer to Slew rate high-side and low-side selection register).
Table 22. Slew rate settings for HS pre-drivers
6.3.2
hsx_slewrate(1:0)
Slew-rate/ V/μS
RDS(ON)_PMOS
(switching on)/Ω
RDS(ON)_NMOS
(switching off)/Ω
00
300
14.6
5.9
01
50
85
35
10
25
169
69
11
12.5
337
138
Safe state of high-side pre-driver
When reset (RSTB) is asserted or DRV_EN is negated, the G_HSx output is immediately forced to a low level, thus switching off the
external MOSFET, to guarantee a safe condition while the device is not operating. In addition to this, an integrated pull-down resistor
RPD_HSX between G_HSx and S_HSx of about 1.0 M keeps the external MOSFET in the off state even when the bootstrap voltage is low.
PT2000
NXP Semiconductors
40
6.3.3
High-side pre-drivers in low-side configuration
All high-side pre-drivers can be used as low-side pre-drivers. In this configuration, an external bootstrap capacitor is still required because
B_HSx can't be connected to VCCP directly. The drain contact of this high-side pre-driver is still connected to VBOOST or VBATT internally,
so the VDS monitoring for this low-side MOSFET is not functional.
VBAT VCCP
VBOOST
VCC5
Charge
Pump
B_HSx
LDO
Load
hsx_slewrate (1:0)
hsx_command
hsx_drven
uv_vcc5
uv_vccp
uv_vboost
cksys_drven
hsx_in
G_HSx
Rpd_hsx
S_HSx
HS Pre Driver
Rsense
PGND
hs5/7_en_ovr
MC33PT2000
DRVEN
AGND
Figure 10. High-side pre-driver in low-side configuration
PT2000
41
NXP Semiconductors
6.4
High-side VDS and VSRC monitor
The PT2000 monitors VDS and VSRC for diagnostic purposes across each high-side to detect any fault occurring on the external
MOSFET. The drain and source voltages of the connected MOSFETs are needed for VDS monitoring. To save pins, the high-side VDS
monitors have no dedicated drain pins, and the drain voltage of the MOSFETs is available via pins VBATT, for the MOSFETs connected
to battery voltage (HS1, HS3, HS5, HS7) and VBOOST or VBATT for the MOSFETs connected to boost or battery voltage (HS2, HS4, and
HS6).
6.4.1
HS1, 3, 5, 7 VDS monitoring
VBATT
VCC5
SRCpux
Voltage
Threshold
hsx_vds_threshold (3:0)
+
VBOOST / VBAT
hsx_vds_Vbatt_fbk
–
B_HSx
G_HSx
+
–
hsx_src_threshold (3:0)
HS1/3/5/7
lsx_vds_fbk
Load
Voltage
Threshold
VCCP
D_LSx
+
–
lsx_vds_threshold (3:0)
LS1-6
S_HSx
Voltage
Threshold
SRCpdx
hsx_src_fbk
G_LSx
PGND
Figure 11. High-side 1, 3, 5, and 7 VDS VSRC and LS1-6 VDS monitoring
Four high-side VDS monitors for high-side pre-drivers 1, 3, 5, and 7 are composed of two comparators with programmable thresholds, the
first one sensing the voltage between VBATT and the source pin S_HSx and the second one sensing the voltage between the source pin
S_HSx and PGND (voltage across the free-wheeling element, either a diode or a MOSFET). A simplified schematic of the high-side VDS
monitors of HS pre-driver 1, 3, 5, and 7 is shown in Figure 11.
VDS and VSRC threshold are selectable by the SPI using registers vds_threshold_hs and vsrc_thresholds_hs (refer to VDS and VSRC
threshold selection). Selectable values are shown in Table 23.
PT2000
NXP Semiconductors
42
6.4.2
HS2, 4, 6 VDS monitoring
VBATT
hsx_vds_threshold (3:0)
VCC5
VBOOST
Voltage
Threshold
+
hsx_vds_vboost_fbk
VBOOST / VBAT
–
B_HSx
SRCpux
+
hsx_vds_vbatt_fbk
–
G_HSx
S_HSx
Load
hsx_src_fbk
+
–
hsx_src_threshold (3:0)
VCCP
Voltage
Threshold
D_LSx
HS2/4/6
G_LSx
PGND
Figure 12. VDS monitors and load biasing HS2, 4, and 6
The three high-side VDS monitors of pre-drivers 2, 4, and 6 are composed of three comparators with programmable thresholds, the first
one sensing the voltage between VBOOST and the source pin S_HSx (VDS of the high-side MOSFET used as the boost MOSFET) and the
second one sensing the voltage between VBATT and the source pin S_HSx (VDS of the high-side MOSFET used for battery MOSFET and
voltage information for voltage based diagnostics when the MOSFET is in boost configuration) and the third one sensing the voltage
between the source pin S_HSx and PGND (voltage across the free-wheeling element, either a diode or a MOSFET). A simplified
schematic of the high-side VDS monitors of HS pre-driver 2, 4, and 6 is shown in Figure 12.
The selection between “VBATT” or VBOOST is done with the microcode command slfbk (reference Programming Guide and Instruction
Set). VDS and VSRC threshold are selectable by the SPI using registers vds_threshold_hs and vsrc_thresholds_hs (refer to VDS and VSRC
threshold selection). Selectable values are shown in Table 23.
Table 23. VDS monitor threshold selection
hsx_vds/src_threshold(3:0)
Threshold voltage HS VDS / HS VSRC
0000
0.00
1001
0.10
1010
0.20
1011
0.30
1100
0.40
0001
0.50
0010
1.0
0011
1.5
PT2000
43
NXP Semiconductors
Table 23. VDS monitor threshold selection (continued)
hsx_vds/src_threshold(3:0)
Threshold voltage HS VDS / HS VSRC
0100
2.0
0101
2.5
0110
3.0
0111
3.5
The high-side VDS comparator compares VDS of the high-side MOSFET, acquired through VBOOST, VBATT, and the S_HSx pins, with
the selected threshold. In actual implementation, the selected threshold voltage is subtracted to the VBOOST or VBATT voltage and
compared to the S_HSx voltage.
The high-side VSRC comparator compares the voltage across the freewheeling element, acquired through the S_HSx pins and PGND,
with the selected threshold. In actual implementation, the selected threshold voltage is added to PGND voltage and compared to the
S_HSx voltage.
6.5
Low-side pre-driver (LS1-6)
There are six general purpose low-side pre-drivers and all drive external N-Channel logic level type power MOSFETs used in low-side
configurations.
Figure 13. Low-side pre-driver block diagram
Internal to the device, a gate to source pull-down resistor RPD_LSX holds the external MOSFETs in the off state, while the device is in a
power on reset state (RSTB low).
The low-side pre-drivers are supplied by VCCP voltage. The low-side pre-driver is intended to drive the gate of an external logic level
MOSFET in low-side configuration. The logic command lsx_command, to switch the external MOSFET, is provided by the digital block.
This command is generated, taking into account the following signals:
• Logic command coming from channel logic (lsx_in).
• VCCP undervoltage signals (uv_vccp) from the VCCP UV monitor: In case of an undervoltage, the external MOSFET is switched off.
• VCC5 undervoltage signals (uv_vcc5) from VCC5 UV monitor: In case of an undervoltage the external MOSFET is switched off.
PT2000
NXP Semiconductors
44
• Signal cksys_drven coming from the clock monitoring: In case of a missing clock (PLL not locked), the external MOSFET is switched
off. This function is disabled by default and can be enabled by setting the cksys_missing_disable_driver bit high (refer to Table 152,
backup_clock_status (1A8h)).
• For safety purpose DRV_EN is added to the control signal for the driver. As long as DRV_EN signal is negated (low) the low-side
pre-driver is switched off. The low-side pre-driver 6 includes a feature to override the switch off path via the DRV_EN signal (refer to
Table 174, LSx_output_config (1C2h, 1C5h,1C8h, 1CBh, 1CEh, 1D1h)).
The truth table describing the status of lsx_command signal is given in Table 24.
Table 24. Low-side pre-driver truth table
DRV_EN
ls6_en_ovr
uv_vccp
uv_vcc5
cksys_drven
lsx_in
lsx_command
Driver Status
0
-
-
-
-
-
0
off
-
-
1
-
-
-
0
off
-
-
-
1
-
-
0
off
-
-
-
-
0
-
0
off
-
-
-
-
-
0
0
off
-
1
0
0
1
1
1
on
1
-
0
0
1
1
1
on
The pre-driver G_LSx output is set according to lsx_command:
• When lsx_cmd is high, the G_LSx pin is driven high (pull-up to VCCP voltage)
• When lsx_cmd is low, the G_LSx pin is driven low (pull-down to PGND voltage)
6.5.1
Low-side pre-driver slew rate control
All low-side pre-drivers feature a programmable slew-rate control. The settings can be changed independently for each pre-driver by the
signals lsx_slewrate(1:0) coming from the digital core. The given value of voltage slew-rate is only an indication and is dependant on the
used MOSFET and the additional gate circuit.(refer to Slew rate high-side and low-side selection register).
Table 25. Slew rate settings for LS pre-drivers 1-6
RDS(ON)_PMOS (switching RDS(ON)_NMOS (switching
on)/Ω
off)/Ω
lsx_slewrate(1:0)
Slew-rate/ V/μS
00
300
14.6
5.9
01
50
84
35
10
25
170
69
11
12.5
337
138
PT2000
45
NXP Semiconductors
6.5.2
LS1 - LS6 VDS monitor
VCCP
Load
–
lsx_vds_threshold (3:0)
Voltage
Threshold
LS1-6
SRCpdx
lsx_vds_fbk
D_LSx
+
G_LSx
PGND
Figure 14. VDS monitoring LS1 to LS6
For VDS monitoring of the external low-side MOSFET, a comparator with programmable threshold is provided, sensing the voltage
between the drain pin D_LSx and PGND (VDS of the low-side MOSFET). If a sense resistor is connected between the low-side MOSFET
and ground, the voltage drop on the resistor is included in the measurement. VDS threshold are selectable by the SPI using
vds_threshold_ls registers (refer to Table 96, Vds_threshold_ls_Part 1 (16Fh)) and Table 97, Vds_threshold_ls_Part 2 (170h)). Selectable
values are shown in Table 26.
Table 26. Low-side VDS monitor threshold selection
lsx_vds _threshold(3:0)
Threshold Voltage LS VDS
0000
0.00
1001
0.10
1010
0.20
1011
0.30
1100
0.40
0001
0.50
0010
1.0
0011
1.5
0100
2.0
0101
2.5
0110
3.0
0111
3.5
PT2000
NXP Semiconductors
46
6.6
Low-side pre-driver for DC/DC converter (LS7 and LS8)
There are two low-side pre-drivers (LS7-8) targeted for DC/DC converter applications. All are to drive external N-channel logic level type
power MOSFETs used in low-side configurations. If no DC/DC is required, they can be used as general purpose low-side.
VBAT VCCP
MC33PT2000
Load
D_LSx
LDO
ls7/8_slewrate_p (1:0)
uv_vcc5
uv_vccp
ls7/8_slewrate_n (1:0)
ls7/8_command
ls7/8_drven
cksys_drven
ls7/8_in
LS DCDC
Pre Driver
G_LSx
Rpd_ls7/8
Rsense
Ls7/8_en_ovr
PGND
DRVEN
PGND
Figure 15. Low-side pre-driver for DC/DC converter (LS7 and LS8)
Internal to the device, a gate to source pull-down resistor RPD_LSX holds the external MOSFETs in the off state, while the device is in a
power on reset state (RSTB low). The low-side pre-drivers are supplied by VCCP voltage.
The low-side pre-driver is intended to drive the gate of an external logic level MOSFET in low-side configuration. The logic command
lsx_command, to switch the external MOSFET, is provided by the digital block. This command is generated, taking into account the
following signals:
• Logic command coming from channel logic (ls7/8_in).
• VCCP undervoltage signals (uv_vccp) from VCCP UV monitor: in case of undervoltage, the external MOSFET is switched off.
• VCC5 undervoltage signals (uv_vcc5) from VCC5 UV monitor: in case of undervoltage, the external MOSFET is switched off.
• Signal cksys_drven coming from the clock monitoring: in case of a missing clock (PLL not locked), the external MOSFET is switched
off. This function is disabled by default and can be enabled by setting the cksys_missing_disable_driver bit high (refer to Table 152,
backup_clock_status (1A8h)).
• For safety purpose DRV_EN is added to the control signal for the driver. As long as DRV_EN signal is negated (low) the low-side
pre-driver is switched off. The low-side pre-driver for the DC/DC converter includes a feature to override the switch off path via signal
DrvEn. As long as the signals ls7/8_en_ovr are high, the pre-driver is not influenced by DrvEn (refer to Table 175, LS7_output_config
(1D4h) & LS8_output_config (1D7h)).
The pre-driver is capable of PWM operation up to 400 kHz according to the following table.
Table 27. Low-side pre-driver LS7/8 PWM frequency and load
PWM Frequency / kHz
Gate Charge / nC
400
60
300
75
240
100
A maximum duty cycle of 100% is allowed during PWM operations.
PT2000
47
NXP Semiconductors
6.6.1
Low-side pre-driver slew rate control (LS7 and LS8)
The driver strength can be selected among a set of four values by the SPI registers. The strength for the rising and falling edge can be
chosen independently by means of the bits slew rate_ls7/8_rising(1:0) and slew rate_ls7/8_falling(1:0) (refer to Table 101,
Ls_slewrate_Part 2 (173h))
The slew rate is determined by the PMOS and NMOS RDS(on) of the push/pull driver circuitry. The typical gate slew rate values are defined
in Table 28 and Table 29. These values are given as reference and are impacted by the external circuitry.
Table 28. Slew rate settings for LS pre-drivers 7/8 PMOS
LS7/8_slewrate_p(1:0)
Slew-rate/ V/μS
RDSON_PMOS
(switching on)/Ω
00
1500
5.0
01
300
14.6
10
50
85
11
25
170
Table 29. Slew rate settings for LS pre-drivers 7/8 NMOS
6.6.2
LS7/8_slewrate_n(1:0)
Slew-rate/ V/μS
RDSON_PMOS
(switching on)/Ω
00
1500
1.1
01
300
5.9
10
50
35
11
25
69
Low-side VDS monitor D_ls7/D_ls8 for DC/DC
lsx_vds_fast_fbk
lsx_vds_highspeed_en
VCCP
Load
D_LS7/8
lsx_vds_threshold (3:0)
Voltage
Threshold
SRCpdx
lsx_vds_fbk
G_LS7/8
CRES
(only resonant
mode)
Figure 16. Low-side 7 and 8 VDS monitor
PT2000
NXP Semiconductors
48
Two comparators are implemented for the VDS monitoring function of D_LS7/8. One is used for normal VDS monitoring (See LS1 - LS6
VDS monitor on page 46), and the other is a high-speed comparator used for the DC/DC resonant converter application.
Normal VDS monitoring:
• Input impedance of D_LSx has to be switched to low speed by setting lSX_VDS_HIGHSPEED_EN to “0” via the SPI register bit (refer to
Table 116, Vds7_dcdc_config (182h) & Vds8_dcdc_config (183h))
• lSX_VDS_FBK is used for diagnostics
• Clamp voltage = 3.5 V
Fast VDS monitoring (DC/DC resonant converter):
• Input impedance of D_LSx has to be switched to high speed by setting lSX_VDS_HIGHSPEED_EN to “1” via SPI register bit (refer to
Table 116, Vds7_dcdc_config (182h) & Vds8_dcdc_config (183h))
• lsx_vds_dcdc is used for resonant detection
• VDS Threshold needs to be set to 2.5 V
For more details on the DC/DC mode See DC/DC converter control (LS7/8) on page 61.
6.7
Current measurement
There are six total input pairs to measure currents with external shunt resistors in a four-wire configuration.
• Four general purpose blocks (#1, 2, 3, and 4).
• Two extended mode block for DC-DC converters (#5 and 6).
The shunt resistors are used in low-side configuration with one of the shunt terminals tied to ground for all the blocks. This means the
PT2000 measures a differential voltage over the two input pins.
6.7.1
General purpose current measurement block
opampx_gain(1:0)
G_LSz
Diff Ampx
VSENSENx
–
Comp x
oa_eny
Current Measurement (1, 2, 3, 4)
OA_y
oa_gainy(1:0)
DACx
MUX
–
dacx_value (7:0)
VSENSEPx
+
adc_mode
Filter x
Load
RSENSEX
+
MC33PT2000
oa_sely(2:0)
curx_fbk
MUX
adc_modex
The actuator current flowing in an external sense resistor is measured to implement a closed loop current control. The current
measurement block is comprised of a differential amplifier, sensing the voltage across the sense resistor, a voltage comparator, and an
8-bit current DAC.
AGND
Figure 17. General purpose current measurement block diagram
The differential amplifier gain is selectable among four different values by means of the opamapx_gain (1:0) signal, to get the suitable
signal amplification. The gain can be changed at runtime by the microcore using the stgn instruction (reference Programming Guide and
Instruction Set). The differential amplifier also adds a constant offset to its output. Therefore, the output of the amplifier is always positive.
The desired actuator current level can be selected and changed at runtime by the microcore, setting the proper dacx_Value (7:0) threshold
value in the DAC. Each current measurement channel can be used in ADC mode. A track and hold circuit is implemented to keep the
voltage at the comparator input stable during the ADC conversion.
PT2000
49
NXP Semiconductors
The differential amplifier output can be routed to an external pin (OA_1, OA_2, and OA_3). In this configuration, the device output is
usually connected to an ADC input of the MCU for safety and test purposes. The output multiplexer block contains an output amplifier with
selectable gain by means of the oa_gainy(1:0) signal, providing full swing output on OA_y for A/D conversion, if used with 3.3 V or 5.0 V
applications. The target for overall accuracy is about 3.7% at 75% DAC range (see Table 12). This includes the external resistor which is
assumed to have a worst case error of 2.0%.
6.7.1.1
Current sense amplifier
The current sense amplifier provides a voltage which can be monitored through the OA_x pins. A 250 mV offset is added to monitor
negative current, this way output of the amplifier is always positive. The amplifier is fully operational down to an output voltage of typically
100 mV. The current sense amplifier output voltage can be calculated using the following formula:
V DASENSE = V VSENSEPx – V VSENSENx G DADIFF + V DABIAS
VDABIAS is fixed value of 250 mV applied to the differential amplifier output.
The GDADIFF gain value is configurable at runtime (opampx_gain(1:0)), this gain can be selected using the instruction stgn. The allowed
differential mode input voltages depend on the chosen gain value.
6.7.1.2
Current sense DAC
In order to select the proper threshold for current control, an 8-bit current DAC is implemented to provide a threshold to the voltage
comparator (dac_value (7:0)). The current threshold can be calculated using the following formula.
DACVALUE V DACLSB – V DABIAS
I = ------------------------------------------------------------------------------------------------------------------G DADIFF R SENSE
DAC_VALUE is selected and changed at runtime by the digital microcore by means of the signal dacx_value (7:0). A DAC_VALUE below
the hexadecimal value 0Ah, must be avoided, as the current sense differential amplifier does not operate with full performance at output
voltages below 100 mV.
VDAC_LSB is the DAC resolution = 9.77 mV.
VDA_BIAS is the fixed voltage biasing applied to the differential amplifier output = 250 mV. GDA_DIFF is the gain value configurable at
runtime by the SPI (opampx_gain(1:0)). This gain can be selected using the instruction stgn.
RSENSEX is the external sense resistor of the current measurement channel x.
Table 30. Current sense DAC values with a 10 mΩ shunt
DAC value
HEX
BIN
0A
10
…
DAC output voltage / mV
Current threshold with 10 m shunt/A
Gain = 5.79
Gain = 8.68
Gain = 12.53
Gain = 19.25
98
-2.63
-1.76
-1.22
-0.79
…
…
…
…
…
…
19
25
244
-0.10
-0.07
-0.05
-0.03
1A
26
254
0.07
0.05
0.03
0.02
1B
27
264
0.24
0.16
0.11
0.07
…
…
…
…
…
…
…
FF
255
2490
38.69
25.81
17.88
11.64
PT2000
NXP Semiconductors
50
6.7.1.3
Current measurement offset compensation
G_LSz
VSENSEPx
Offs et Comp
DACx
(5+1bits)
MUX
Diff Amp
VSENSENx
Comp x
oa_gainy(1:0)
oa_eny
OAy
adc_modex
Current Measurement
Offset Compensation
(x:1,2,3,4,5,6)
DACx
MUX
dacx_value (7:0)
oa_sely(2:0)
curx_fbk Filter x
Load
250 mV
Bia s V oltage
Rsensex
adc_modex
MC33PT2000
opampx_gain(1:0)
An analog offset compensation is done which compensates the input offset of the current measurement amplifiers one to six. The offset
compensation is started and stopped from the digital microcores using the instruction stoc. The offset compensation must be started while
there is no current flow in the shunt of the related measurement channel.
The compensation uses a small 6-bit DAC (5-bit plus sign) which injects a current at the input stage of the differential amplifier to
compensate the input offset. The offset compensation is finished after a maximum time of 31 x 2.0 s = 62 s. This process is completely
automatic and only the start and stop has to be handled by the microcore.
The offset compensation uses the “ck_ofscmp” generated from the ck_sys. The prescaler can be set using this register (refer to Table 146,
Ck_ofscmp_Prescaler(1A4h)). Because the offset compensation minimum step time can be up to 2.0 s (refer to Table 13), it is mandatory
to set the ck_ofscmp to a maximum of 500 kHz.
Each new offset compensation is started based on the result of the previous offset compensation run for this current measurement
channel. If the offset compensation is stopped from the digital microcore when the analog offset compensation is not finished, the
procedure is aborted, maintaining the last compensation value reached when the procedure was interrupted. This strategy guarantees
each offset compensation decreases the offset of the current measurement amplifier independent of it being finished.
Due to a temperature drift of the differential amplifier input offset, the offset compensation must be performed each time a huge change
in device temperature is expected. If this is not possible, an increased residual offset due to the temperature drift has to be taken into
account.
PGND
Figure 18. Offset compensation block diagram
PT2000
51
NXP Semiconductors
6.7.2
Current measurement for DC/DC
The inputs of the 5th and 6th current sense need to support a very wide range of applications.
Typical applications use the 5th and 6th current sense e.g.
• Just identical to the other current sense blocks or
• To control a DC/DC converter with a low-side current measurement and concurrently provide an overcurrent supervision at the booster
capacitor
The two-point current control of a DC/DC converter results in challenging requirements on latency of the control loop. This means:
• The path from sense input to low-side driver output must achieve a very small delay
• There is no time to change the DAC setting after each switching event.
opampx_gain(1:0)
VBAT
VBOOST
G
G_LS7/8
+
VSENSEP5/6
+
curxl_fbk
Filter
xL
+
Diff Ampx
Comp xL
–
–
DACxL
dacxl_value (7:0)
curxh_fbk
Filter
xH
VSENSEN5/6
RSENSEx
MC33PT2000
+
Comp xH
–
DACxH
dacxh_value (7:0)
+
curxneg_fbk
+
Filter
xNeg
Diff Ampx
–
Comp xNeg
–
DACxNeg
oa_gain3(1:0)
OA_3
oa_en3
DCDC Current Measurement (x=5, 6)
oa_sel3(2:0)
MUX
dacxneg_value (3:0)
Figure 19. DC/DC current measurement (5 & 6) block diagram
Along with the number of concurrent thresholds to supervise, the key feature of the current measurement block for DC/DC is the ability to
provide a short delay from the VSENSE inputs to the G_LS7/8 output. For this application, the digital core contains a hardwired logic for
a two-point current regulation using the cur5/6h_fbk and cur5/6l_fbk signals as inputs to directly control the LS7 or LS8 low-side driver.
Using the negative comparator it is possible to detect boost overcurrent. During this time the low-side is Off and the current flows from the
boost tank capacitor to the load. (See Negative current differential amplifier on page 53)
PT2000
NXP Semiconductors
52
6.7.2.1
Negative current differential amplifier
The key characteristic of the second differential amplifier is it works at negative differential input voltages and therefore has a negative
gain. This is used to detect overcurrent when the low-side is Off.
Table 31. Boost overcurrent sense amplifier overall gain
Gain value
Normal differential mode input voltage
Full scale range current with 10 m shunt
DAC resolution with 10 m shunt
-2.0
-1047 mV …0
-104.7 A
-7.81 A
The current threshold can be calculated using the following formula.
DACVALUE V DACLSB – 250mV
I = -----------------------------------------------------------------------------------------------------------G DADIFF R S ENSE
DAC_VALUE is selected and changed at runtime by the digital microcore by means of the signal dacx_value (3:0).
VDAC LSB is the DAC resolution = 156.25 mV.
VDA_BIAS is the fixed voltage biasing applied to the differential amplifier output = 250 mV.
The Gain Value GDA_DIFF is fixed to -2.0.
RSENSEX is the external sense resistor of the current measurement channel x.
6.7.2.2
Current measurement offset compensation
The analog offset compensation for the differential amplifier 5 and 6 of channel 5 and 6 is done in the same way for channel 1 to 4. The
DAC5/6L and the signal Cur5/6l_fbk are used for the offset compensation. Since the accuracy is not actually critical to detect the
overcurrent, the differential amplifier 5 and 6 negative do not have offset compensation (see Figure 19).
6.8
OA_x output pins, multiplexer and T & H
6.8.1
General features
The output signals of the six current sensing amplifiers are available via three external pins OA_1, OA_2, and OA_3 of the device (refer
to Figure 20). With the OAGainx (1:0) and OAxG1 signal, it is possible to select between five different output gains. This feature is used
to adapt the device to an ADC input range of 3.3 V or 5.0 V, and also to add the possibility of amplifying the output signal even higher for
some special measurement functions. The maximum output voltage at the OA_x pins of VCC5 always has to be taken into account.
For the two higher gains of 3.0 and 5.33, the bias voltage of nominal 250 mV of the input signal is removed before amplifying the signal
and adding again to the amplified signal afterwards.
Table 32. OA_x amplifier gain selection and output voltage
Oagainx(1:0)
OAxG1
Gain value
Output voltage
d.c.
1
1.0
VIN * Gain
00
0
1.33
VIN * Gain
01
0
2.0
VIN * Gain
10
0
3.0
(VIN – 250 mV) * Gain +250 mV
11
0
5.33
(VIN – 250 mV) * Gain +250 mV
The OA1/2/3 output pins includes the possibility of switching to hi-impedance mode to enable the direct connection of two of these output
pins to one micro-controller ADC input. All OA_x output multiplexers can also be switched to VCC2P5 as a third option. This is used to
check the connection between the PT2000 and the microcontroller ADC on the ECU level.
PT2000
53
NXP Semiconductors
Figure 20. OA_x multiplexer
Table 33, Table 34, and Table 35 show the output configuration of the OA_x multiplexers, control is done by register oa_out_config (See
Analog output (OAx) configuration register on page 116).
PT2000
NXP Semiconductors
54
Table 33. OA_1 multiplexer logic table
OaSel1(2:0)
OaEN1
Signal at Output OA_1
000
1
OA_Cur 1 (Feedback of current measurement 1)
001
1
OA_Cur 3 (Feedback of current measurement 3)
010-100
1
Reserved
101
1
VCC2P5
110-111
1
Reserved
xxx
0
HiZ
Table 34. OA_2 multiplexer truth table
OaSel2(2:0)
OaEN2
Signal at Output OA_2
000
1
OA_Cur 2 (Feedback of current measurement 2)
001
1
OA_Cur 4 (Feedback of current measurement 4)
010-100
1
Reserved
101
1
VCC2P5
110-111
1
Reserved
xxx
0
HiZ
Table 35. OA_3 multiplexer truth table
OaSel3(2:0)
OaEN3
Signal at Output OA_3
000
1
OA_Cur 5 (Feedback of current measurement 5)
001
1
OA_Cur 6 (Feedback of current measurement 6)
010-100
1
Reserved
101
1
VCC2P5
110-111
1
Reserved
xxx
0
HiZ
The multiplexer must not be switched to a signal currently processing via another OAx analog output or an internal path. Switching the
multiplexer can cause a glitch on the signal being processed.
6.8.2
OA_2 Pin digital I/O function
6.8.2.1
General requirements
The OA_2 pin can also be used as a digital flag bus input or output flag (14). It can be selected by the SPI configuration of the PT2000
using the registers flags_source and flags_direction (refer to Table 138, Flag_direction (1A1h)). The flag pin (14) has a higher rise/fall time
of about 3.0 s, compared to the other external flag bus pins of the device. For the digital output functionality, the same output stage is
used as with the analog function. As soon as the pin is configured as a digital input, the buffer is switched to hi-impedance. Table 36 shows
how the enable signal is created.
PT2000
55
NXP Semiconductors
Table 36. OA2 enable truth table
flags_source flags_direction
opamp_pin_source OaEN2
(2) (reset=0)
(reset=0)
OA2 Buffer
state
Description
0
d.c.
0
0
HiZ
OA2 pin is used as analog output, enable signal is low
0
d.c.
0
1
On
OA2 pin is used as analog output, enable signal is high
1
1
1
-
HiZ
OA2 pin is used as digital input
1
0
1
-
On
OA2 pin is used as digital output
6.8.2.2
OA_2 pin I/O voltage
The I/O voltage of the OA_2 pins is not automatically set according to the VCCIO voltage supplied to the device. The OA_2 output amplifier
which is also used for the digital output function is supplied by VCC5. The digital input signal to the OA_2 output amplifier is a VCC2P5 based
signal. The I/O voltage has to be selected by choosing the right gain of the OA_2 output amplifier. Table 37 shows how to select the proper
I/O voltage.
Table 37. OA_2 amplifier gain selection (I/O voltage)
OaGain2(1:0)
Gain value
Used for
00 (reset value)
1.33
3.3 V I/O
01
2.0
5.0 V I/O
10
3.0
11
5.33
There is a weak pull-down resistor at the OA_2 input/output. This resister is always present, regardless if the digital or analog functionality
is selected.
6.8.3
OAx output offset and offset error
It is important to have a close look at the output offset of the OAx pins and the output voltage values corresponding to load current values.
The current measurement amplifiers output signal has a fixed offset of 250 mV and also some variable offset of -28.6 mV to +36.4 mV for
this path after analog offset compensation. This offset is independent of the current measurement amplifiers gain setting, but is amplified
by the OAx amplifier gain. The OAx amplifier also adds some input offset of 10…13.5 mV to this calculation. So in sum there is a fixed
offset of 250 mV and a variable offset at the input of the OAx amplifier.
For the two higher gains of 3.0 and 5.33, the bias voltage of nominal 250 mV of the input signal is removed before amplifying the signal
and added again to the amplified signal afterwards. Table 38 gives some examples for load currents, gain settings, and corresponding
output voltage ranges. Note that this calculation only takes into account the offset errors. There are also other errors which have to be
considered in a full error calculation.
Table 38. OAx input and output values
Load current at 10 m
shunt/A
Current measurement
amplifier gain setting
OAx amplifier gain
setting
OAx output voltage OAx output voltage OAx output voltage
Min./mV
Typ./mV
Max./mV
0
8.68
1.33
276
333
399
25.8
8.68
1.33
3256
3312
3378
0
19.25
5.33
45
250
497
1
19.25
5.33
1071
1276
1523
2.5
19.25
5.33
2610
2815
3062
PT2000
NXP Semiconductors
56
7
Functional device operation
7.1
Power-up/down sequence
During power-up, the voltage at the VBATT pin can be clearly higher than the voltage at the VBOOST pin. The functionality of the PT2000
within its functional limits and outside its functional limits (no destruction of connected devices) has to be guaranteed independently from
the slope of the voltage ramp up of the supply voltages (VCC5, VCCIO, VBATT) and the starting value.
7.1.1
Power-up sequence of VCC5, VCC2P5, and reset
After the internal POResetB signal is deactivated, it takes a maximum time of tDIGIOREADY = 100 s until the digital outputs of the device
are functional. CLK can be sent even before this tDIGIOREADY, but it is not taken into account. Inside the logic core, POResetB is combined
with the external reset signal ResetB (active low) and the SPIResetB signal coming from the SPI interface. As long as RSTB is asserted,
the SPI module is inactive. After the first RESETB rising edge, it is required to wait t_SPIREADY_t0 = 100 s to allow time for the fuses to
load.
Note that the logic core is properly supplied at 2.5 V when 5.0 V is present at the VCC5 pin (thus allowing logic core operations and SPI
communication with the microcontroller), even if no voltage is provided at the VBATT pin and by consequence no voltage is present on
the VCCP pin.
Figure 21. Power-up diagram
PT2000
57
NXP Semiconductors
7.1.2
Power-up sequence VCCP and bootstrap capacitors
7.1.2.1
Bootstrap switch control
During initialization phase, the control of the boostrap switch needs to be carefully controlled. The following device configurations are
affected.
• Hsx_bs_lowcurrent: the low-current limit (280 A), which is set only during init independently for each HS pre-driver;
• Vsrc_threshold: the VSRC thresholds of each HSx, which during init is set first to 0.5 V and after some time to 1.0 V. After init phase is
finished the VSRC threshold returns to the value defined in the appropriate register (refer to Table 94, Vsrc_threshold_hs_Part2 (16Eh)).
• Ls_bias: all ls_bias are set active for all LSx outputs during init phase of any HS pre-driver, and then go back to the configuration defined
in the appropriate register (refer to register Table 126, Ls_bias_config (18Ch)) when all HS pre-drivers are out of the init phase.
• Hs_bias: the hs_bias is set inactive for the HSx outputs during init and then returns to the configuration defined in the appropriate
register (refer to Table 125, Hs_bias_config (18Bh)).
During the init phase of the bootstrap capacitors, the vccp_external_enable signal is affected according to what is defined in Table 150,
VCCP external enable setting. In particular, as long as at least one HS pre-driver is in bootstrap init mode, the vccp_external_enable
setting is set to '0' (internal regulator active), if the value of the DBG pin sampled at reset (POResetB and ResetB) was '1'.
The charging of the bootstrap capacitors starts after reset is deactivated and as soon as the VCCP voltage is ramped up. As soon as the
VCCP voltage is above the VCCP undervoltage threshold, a global timer for all hs pre-drivers running on cksys with an end of count value
of 36 ms is started. As soon as the timer reaches the end of count value, the Vsrc_threshold is changed from 0.5 V to 1.0 V for all drivers
still in init mode. At the same moment, the hsx_src_1V bit is set to '1' for all these drivers.
The bootstrap init for each HS pre-driver ends if one of the following conditions is met:
• The bs ready comparator shows the B_HSx voltage is close to the VCCP voltage and at the same time the S_HSx voltage is below
0.5 V or 1.0 V,
• The clamp is activated and at the same time the S_HSx voltage is below 0.5 V or 1.0 V;
• An LS pre-driver connected to the same HS pre-driver is switched on and the corresponding hsx_lsx_act signal is set to '1';
• The connection between LS pre-drivers and HS pre-driver is disabled (hsx_ls_act_dis signal = '1'); or
• The same HS pre-driver is switched on.
In applications where two HS pre-drivers are connected to the same node by their S_HSx pin directly or via a diode, care must be taken.
It is not allowed in these configurations to turn on the hs_bias via the SPI register or the microcode command before all HS pre-drivers
finished their bootstrap init. Otherwise an active hs_bias from one pre-driver may block the init of the other. The init mode of each HS predriver can be quit by setting the corresponding “hsx_ls_act_dis” bit to '1' (refer to Table 127, Bootstrap_charged (18Dh)). This should be
done for each HS pre-driver not used in an application.
7.1.2.2
Using D_LSx pull-down sources to charge bootstrap capacitors
After reset release and after the VCCP voltage is above the UV_VCCP threshold, the charging of the HS pre-driver's bootstrap capacitors
via the D_LSx pull-down sources starts automatically, as long as there is a current path from S_HSx of the HS pre-driver to at least one
D_LSx pin or to GND. To make this possible, there is a requirement to switch the current limitation of the bootstrap path from about 95 mA
to min. 280 A.
Table 39 shows how long it takes to charge a bootstrap capacitor to 7.0 V using the D_LSx current sources and a bootstrap path current
limitation of 280 A, plus the charge pump current of 20 A.
Table 39. Charge times bootstrap Cs using D_LSx sources
Bootstrap capacitor size (typ.)
Charge time (typ.)/ms
100 nF
2.3
330 nF
7.7
1.0 μF
23.3
2.2 μF
51.3
PT2000
NXP Semiconductors
58
7.1.2.3
Using the charge pump to charge bootstrap capacitors
If there is no current path from S_HSx pin to D_LSx or GND, only the internal CP can be used to charge the bootstrap capacitors during
init with a guaranteed current of 20 A per HS pre-driver. This current is only available if there is no leakage current from B_HSx pin. Any
possible leakage current has to be subtracted from this available charge current.
It is not necessary to turn on either the LS MOSFETs or the D_LSx pull-down current sources to charge the bootstrap capacitors during
the init phase, if there is at minimum the current loop via the body diode of the external high-side MOSFET present. In addition, there is
some leakage current path from S_HSx to PGND. The charge pump starts charging the bootstrap capacitors as soon as the device is
supplied with VCC5 and a voltage greater 4.7 V at the VBOOST pin and POResetB is deactivated. Table 40 shows how long it takes to
charge a bootstrap capacitor to 7.0 V using the charge pump current of 20 A.
Table 40. Charge times bootstrap Cs using CP
7.1.2.4
Bootstrap capacitor size (typ.)
Charge time (typ.)/ms
100 nF
35
330 nF
116
1.0 F
350
2.2 F
770
Using LS MOSFETs to charge bootstrap capacitors
After reset release of the device, the charging of the bootstrap capacitors via the D_LSx pull-downs and the internal charge pump starts
automatically. If there is the requirement to speed up the initial charging of the bootstrap capacitors, it is possible to switch on an LS
MOSFET connected to the HS MOSFET. If the device is configured in a proper way (refer Table 131, Hsx_ls_act (18Fh - 195h)) the
bootstrap switch current limit changes to the high limit of about 95 mA as soon as the LS pre-driver is turned on. Because the bootstrap
init mode is left for this HS pre-driver, it must be guaranteed that the internal VCCP regulator is already switched on via the SPI bit, if
required.
After switching on the internal VCCP regulator, the output buffer capacitor at the VCCP pin is charged. The device is still in a VCCP
undervoltage condition, no external MOSFET (HS or LS) can be switched on, and the bootstrap diodes are also kept in the Off state. During
ramp up the voltage on the VCCP pin crosses the VCCP undervoltage threshold. After the voltage is above this threshold (plus a minimum
16 s delay), it is possible to switch on the LS MOSFETs.
There are two possible solutions to charge the HS pre-driver bootstrap capacitors using the path via the LS MOSFETs:
1. Wait for some specific time after VCCP regulator is activated to ensure the VCCP output voltage has reached it's nominal value of
about 7.0 V. This is only possible if the VBATT voltage is at a nominal value. Switch on the LS MOSFET(s) to charge the bootstrap
capacitors. If the VCCP voltage was high enough and the bootstrap capacitors are small compared to the VCCP output buffer
capacitor, this leads to a transfer of charge without crossing the VCCP_UV threshold again. Figure 22 shows this strategy.
PT2000
59
NXP Semiconductors
Figure 22. Power-up: VCCP and bootstrap capacitors - after VCCP fully charged
2. Switch on the LS MOSFET(s) as soon as possible after the VCCP voltage is above the VCCP_UV threshold. This causes the VCCP
voltage to cross the VCCP_UV threshold again and thereby the LS MOSFET(s) and the bootstrap diode are switched off again. The
VCCP voltage recovers from undervoltage and after the delay min. of 16 s, the LS MOSFET(s) and the bootstrap diode are switch
on again. This pulsed charging of the bootstrap capacitors with a frequency of below 50 kHz continues until the voltage of the
bootstrap capacitors is above the VCCP_UV threshold. Figure 23 shows this strategy.
Figure 23. Power-up: VCCP and bootstrap capacitors - before VCCP fully charged
Strategy 2 is preferred, because it adds less constraints to the size of the bootstrap capacitors and the SW implementation. If strategy 1
is tried, but some of the premises are not fulfilled (VBATT/VCCP voltage, size of bootstrap capacitors), the result is the same pulsed charging
described in strategy 2.
PT2000
NXP Semiconductors
60
7.2
DC/DC converter control (LS7/8)
The two DC/DC converters implemented each support three DC/DC converter control modes. These modes can be chosen via microcode
instruction “stdcctl”. This command affects the ls pre-driver which is set as shortcut two of the microcore (see instruction “stdcctl” in the
programming guide).
Table 41. DC/DC converter control modes
DC/DC mode
Microcode instruction
1
stdcctl sync
LSx manual mode (LSx controlled by microcode)
2
stdcctl async
LSx hysteretic mode direct controlled by curYh and curYl feedback signals)
3
stdcctl async_vds
7.2.1
Short description
LSx resonant converter mode. (direct controlled by VdsX_dcdc and curYh_fbk)
General description
The operation modes of the DC/DC converter can be activated by the microcode instruction “stdcctl sync/async/async_vds”. Every
microcore which has access to the LS7/8 pre-driver, according to the crossbar configuration, can activate the DC/DC control modes using
this microcode instruction. The LS7/8 outputs can be controlled by standard control method - microcode instruction (mode1) or automatic
DC/DC converter control modes (mode 2/3).
As soon as a microcore having access to the LS7/8 is unlocked, the automatic DC/DC control is switched off. Mode 2 and mode 3 can be
used to achieve a very fast asynchronous regulation. The current can be changed either through microcode or by writing the DAC
Registers via the SPI (See DAC 1-6 values registers on page 112).
7.2.1.1
Mode 1 (manual mode)
The DC/DC converter control mode 1 is chosen by microcode and is set as the default. The current_feedback_5/6 is monitored by
microcode and the LS7/8 is controlled completely via microcode. The low-side is controlled directly by the microcore using the “sto”
instruction.
7.2.1.2
Mode 2 (hysteretic control)
Mode 2 is intended to be used for standard current controlled ‘asychronous’ DC/DC converters. A very fast current regulation between the
current thresholds 5/6H (higher limit) and 5/6L (lower limit) can be achieved. These two current thresholds can be supplied either from
microcode or by writing to the DAC register (refer to See DAC 1-6 values registers on page 112).
The LSx output is switched on when current_feedback_5/6L is low and switched off when current_feedback_5/6H is high. The path from
the shunt resistor to the LS7/8 output is completely asynchronous to any clock of the device. The current feedback of DAC 5/6H takes
priority, so in cases where both feedbacks are active (DAC 5/6H feedback high and DAC 5/6L feedback is low), the output LS7/8 is driven
low. This mode is used for standard DC/DC control.
Note that when this mode is used LS7, it should be paired with current sense 5 and LS8 with current sense 6.
Figure 24. DC/DC mode 2: hysteretic control
PT2000
61
NXP Semiconductors
7.2.1.3
Mode 3 (LS7/8 resonant mode VDS monitoring)
Mode 3 can be used for controlling resonant converters which require a VDS threshold based activation of the MOSFET. In this case, a
small capacitor (~10 nF) CRES in parallel with the external MOSFET has to be connected, to avoid oscillation when the low-side is off.
To use Mode 3, the signal lSX_VDS_HIGHSPEED_EN has to be set to a “1” via the control bit in the vds7/8_dcdc_config register (see
Table 116, Vds7_dcdc_config (182h) & Vds8_dcdc_config (183h)).
VDS fast monitoring of D_LS7/8 uses the same threshold generator as the normal VDS monitoring, but only the threshold voltages of 2.0 V
and 2.5 V can be used.
Functionality:
As soon as VDS 7/8 drops below the threshold voltage, the MOSFET activates. To switch Off the MOSFET, the Cur5/6H - Feedback signal
is used. The cur5/6h_dcdc current feedback takes priority if both feedbacks are high. LS7 or LS8 is driven low. This event is not
guaranteed in every condition. When LS is off, there is an oscillation on VDS (hence the resonant name) whose amplitude depends on the
"VBOOST-VBAT" value, so a timeout is used to make sure the LS can be enabled again.
Timeout functionality:
If VBOOST drops below VBAT x2, the VDS threshold of 2.5 V is not crossed. The MOSFET cannot be activated again, which means the DC/
DC converter stops. A timeout must be started each time the lower current threshold is reached (cur5/6l_fbk signal changed to low). When
VDS feedback is set low during this timeout period, the timeout monitor stops and is reset. If the VDS feedback cannot set to a low during
this timeout period, the MOSFET activates directly by the timeout logic.
Vboost
ISENSE5/6_HIGH
ISENSE5/6
Cur5/6h_fbk
Ls7/8_command
Ls7/8_vds_fast_fbk
tV DS _DCDC_P D
D_LS7/8
2.5V threshold
Internal Logic
External_Voltage
External_current
Figure 25. DC/DC mode 3 resonant (threshold 2.5 V used)
PT2000
NXP Semiconductors
62
7.3
Device clock manager and PLL init
After 100 s the clock monitor is enabled, Table 42 shows different strategies to start the device.
The clock manager duty is to detect a low frequency (or missing) input reference or a PLL malfunction. To do so, it monitors the PLL output,
to check if the output clock frequency is within acceptable range.This is achieved counting the number of pll_output_clock cycles inside
six periods of the backup reference clock (six periods of 1.0 MHz clock = 6.0 s). The expected number depends on the selected PLL
multiplication factor;
• when the factor is 24, it is detected an invalid clock condition when it is possible to count more than 165 or less than 125
pll_output_clock cycles.
• when the factor is 12, it is detected an invalid clock condition when it is possible to count more than 84 or less than 61 pll_output_clock
cycles.
After requesting the switch back to the external clock reference the device cannot be accessed via the SPI (see Table 152,
backup_clock_status (1A8h)) for about:
• 100 s if there is a valid external clock available
• 290 s (250 s+40 s re-lock time) if there is no valid input clock available and the device has to go back to the backup clock again.
The SPI word transmitted to set the Switch to clock pin bit has to be the last word within a SPI burst.
Table 42. Device clock manager and PLL init
Initial state
1. Step
2. Step
3. Step
Result
Device supplied, but in reset
(ResetB), no ext. clock
Supply external 1.0 MHz
clock at CLK input
Deactivate ResetB
—
Device accessible after 40 s (PLL lock
time) and running on ext. clock
Device supplied, but in reset
(ResetB), no ext. clock
Supply external 1.0 MHz
clock at CLK input
Wait for t > 20 s
Deactivate ResetB
Device accessible immediately and running
on ext. clock
Device supplied, but in reset
(ResetB), no ext. clock
Deactivate ResetB
—
—
Device accessible after 140 s and running
on backup clock
Device supplied, but in reset
(ResetB), no ext. clock
Deactivate ResetB
Supply external
1.0 MHz clock at CLK
input at t < 100 s
—
Device accessible 40 s (PLL lock time)
after CLK available and running on ext. clock
Device running on backup clock,
no ext. clock
Supply external 1.0 MHz
clock at CLK input
Request switch to
external clock
—
Device accessible 100 s after switch
request and running on ext. clock
—
—
Device accessible 290 s after switch
request and running on backup clock
Device running on backup clock, Request switch to external
no ext. clock
clock
7.4
SW initialization flow
7.4.1
Power supply, reset, and clock
• Supply device
• The device needs 5.0 V supply voltage on the VCC5 pin and 3.3 V or 5.0 V supply voltage on the VCCIO pin
• A voltage at the VBATT and/or VBOOST pin is not mandatory for device initialization
• As soon as the device is properly supplied at the VCC5 pin, VCC2P5 regulator is started
• When VCC2P5 is above a specific threshold, the internal POResetB signal is deactivated
• After the internal POResetB signal is deactivated, it takes a maximum time of 100 s until the digital outputs of the device are
functional
• Setup external reference clock of 1.0 MHz at the CLK pin
• The PLL is locked about 25 s after the external CLK is enabled
• If the external clock signal availability cannot be guaranteed within this period, it is recommended to reset the device via ResetB
immediately, or switch to the external clock reference later via the SPI command
• Deactivate ResetB signal
• The external reset signal ResetB has to be deactivated if it has been active
• As soon as there is no POResetB and ResetB signal active, the internal reset RSTB is deactivated
PT2000
63
NXP Semiconductors
7.4.2
SPI configuration
The whole SPI configuration can be done while the device is using the internal backup clock reference. The device registers are not locked
after device reset.
• Check if device is accessible via the SPI
• Check if the device is accessible via the SPI by reading the ID/REV register
• Init the main configuration registers
• Init the main configuration registers including the Clock Prescaler, Flag pin setup,…
• If the application uses the internal VCCP regulator to supply the pre-drivers, this regulator must be switched on now
• Set code width
• If the microcode transmits using one single SPI burst, it is mandatory to write the code width register of each channel used
• If the microcode is transmitted using multiple bursts which include information about the number of words, the code width register
can also be written
• The code width must be set before setting the pre_flash_enable bit, because the checksum calculation information is required
• Download microcode
• Download microcode via the SPI for each channel used
• Set the CRC32 checksum
• Set the checksum_l/h register (32-bit) of each channel used
• Init diagnostics configuration registers
• Init I/O configuration registers
• Init channel configuration registers
• Init DRAM values for the first time
• Depending on the application and the microcode, it could be required to set up DRAM parameters of the channels used
• Set the lock bit in the device_lock register (optional)
7.4.3
Clock monitor, flash enable, and DrvEn
• Check if the device is running on an external reference clock
• It is recommended to verify the device is running on the external clock reference. This can be checked by reading a bit in the
driver_status SPI register
• If the device is running on the backup clk, it is possible to switch the clock manager to external reference via a SPI command
• This is only mandatory if the external clock reference is not available in time and the device is running on the backup oscillator’s clock
• The clock manager is forced to try to switch back to the external reference by a SPI write to a dedicated bit
• SPI transfers have to be avoided when switching the clock reference. The SPI module is in reset as long as there is no valid clock
• Do not switch the clock reference while the first checksum calculation is running
• Set the pre_flash_enable bit
• Set the pre_flash_enable bit of the used channel(s)
• This bit “freezes” the CRAM and enables the signature unit to perform the CRC32 check for the first time
• After the signature unit has finished the first CRC32 check successfully, it sets the flash_enable bit to start the microcore(s) of the
used channel(s)
• The microcode should check for the flash_enable bit with a timeout ensuring the microcores are running
• Activate the DrvEn signal
• Depending on the application and the microcode, it could be required to activate the DrvEn signal if deactivated
7.5
BIST
The device has a built-in self test (BIST) for the memory (MBIST for CRAM and DRAM) and for the logic core (LBIST). The BIST can be
started by the SPI (see Table 170, Bist_interface in write mode (1BDh)). A full LBIST check of the device digital core and MBIST check
of the device memories can be required accessing the BIST_register in Write mode and writing a 16-bit password. This request is
accepted only if all three CRAMs are unlocked. It is recommended to run MBIST and LBIST during the initialization phase, since the DRAM
and CRAM are erased during BIST.
After this request is performed, the LBIST and MBIST check starts and its evolution can be monitored accessing the same BIST_register
in read mode.
PT2000
NXP Semiconductors
64
7.5.1
MBIST
The MBIST is started by writing the MBIST password (B157h) to the BIST register (see Table 170, Bist_interface in write mode (1BDh)).
The overall MBIST operation takes about 2.2 ms (at 24 MHz) to complete. During the memory BIST five different tests are performed using
different patterns to test the RAM. The patterns are:
• All 00, All 11
• All 55, All AA
• All 0F, All F0
• All 00, All FF
• All FF, All 00
While the MBIST is running the digital core of the device is functional. The SPI interface can be used. It is not possible to use the CRAM
and DRAM.
7.5.2
LBIST
The LBIST is started by writing the LBIST password (0666h) to the BIST register (see Table 170, Bist_interface in write mode (1BDh)).
The overall LBIST operation takes about 32 ms (at 24 MHz) to complete. The coverage of the LBIST is > 92%.
The SPI interface is also covered by the LBIST. During the LBIST the device is no longer accessible via the SPI. When the LBIST is started
it takes control of the IRQB pin, which is used as a digital output signal to show the LBIST is busy. The IRQB pin is set low while the LBIST
is running. When the LBIST is finished, the IRQB signal goes high again.
The LBIST could fail in a way the IRQB signal never goes high again. In this case, the microcontroler needs to monitor this and reset the
device. When LBIST is finished (IRQB signal high), the device can be accessed by the SPI again and the LBIST result is available in the
BIST register (see Table 171, Bist_interface in read mode (1BDh)). After reading the results, the LBIST needs to be cleared by sending a
CLEAR command (refer to Table 170, Bist_interface in write mode (1BDh)). This releases the logic and the device returns to its original
state. It is recommended to check if the LBIST result is reset to “00” to ensure the LBIST clear command was successful.
The LBIST can be interrupted by a hardware reset via the RESETB pin. There is a second way to stop the LBIST after it is started by
writing the LBIST password. This is done by setting the Flag0 input pin to high. There is information in the LBIST result indicating the LBIST
was stopped by Flag0. Also in this case, an LBIST clear command (C1A0h) has to be sent or the RESETB pin must be set low to return
to normal operation mode. The FLAG0 pin has a weak PD resistor. If the pin is not connected, the LBIST runs and cannot be stopped by
Flag0.
7.6
Reset sources
The device has three possible reset sources:
• the resetb input reset pin is driven low
• the poresetb (power on reset) signal generated by the internal voltage regulator, incase an undervoltage is detected on VCC2P5
• a SPIresetb request received through SPI, when the appropriate code is written to the “global reset registers” (refer to See SPIReset
global reset register 1 and 2 on page 126). It is kept asserted for a fixed time (333 ns) then it is released.
Reset source can be determined reading the Reset_source register (refer to Table 168, Reset_Source (1B7h)).
Figure 26. VCC2P5 and reset sources
PT2000
65
NXP Semiconductors
As long as RSTB is asserted, the SPI module is also inactive. In order to understand when the device has gone out of reset state, the
microcontroller should poll the device on the SPI. This can be done by either sending any message to the device and checking for the
control pattern (A8h) on the MISO during the command word or by reading out any register with a reset value not equal to zero (e.g. ID
register).
7.7
Cipher unit
This block has the function to secure the code downloaded by the microcontroller into the code RAM via the SPI. The data loaded at device
startup must be encrypted with the suitable cipher. This block receives an encoded SPI stream and decodes it at runtime. The decoded
microcode is then stored in the code RAM. This feature cannot be disabled. The cipher algorithm is re-initialized every time the code
memory is selected by a write operation to the Selection register (3FFh).
7.8
Ground connections
The device integrates three separate ground pins: PGND, DGND, and AGND:
• PGND is the substrate connection and is only connected to the package exposed pad, to guarantee a low-impedance connection and
get optimized EMC performances. PGND is the reference ground for the VCCP regulator, some analog functions, and all of the low-side
pre-drivers. It is highly recommended to directly connect PGND to the ECU ground plane.
• DGND is the reference ground for the digital logic core. It is highly recommended to directly connect DGND to the ECU ground
plane.The microcontroller as well as other logic devices communicating with the device should share the same reference ground
connected to the ground plane to prevent noise.
• AGND is the ground for all the noise sensitive analog blocks integrated into the device. This pin should be connected to the analog
ground of the ECU. A star connection is recommended to guarantee a clean analog signal acquisition of the OAX_x pins from the MCU.
Due to their functionality, some analog functions are referred to PGND:
• VDS monitors the low-side drivers
• VSRC monitors the high-side drivers
• The load biasing S_HSX regulator and the D_LSx pull-down
All the ground pins of the device should be connected to the same ground voltage. Even during transient conditions, the voltage difference
between PGND, DGND, and AGND must be limited to 0.3 V. The layout of the ground connection of the ECU should be carefully
designed to limit the ground noise generated as much as possible, for instance during fast switching of the external power MOSFETs.
The decoupling and filter capacitors at the different supply voltage pins should be implemented as described by the following:
• VCC5 to AGND
• VCCIO to DGND
• VCC2P5 to DGND
• VCCP to PGND
• VBATT to PGND
• VBOOST to AGND or PGND
7.8.1
Detection of missing GND connections
The PT2000 can detect any single or multiple missing connection of any ground pin (PGND, DGND, AGND) of the device. At least one
ground must remain connected to allow the loss of ground detection. If the ground disconnection is detected, the internal signal uv_vccp
is asserted and all the pre-drivers are disabled. The ground lost detection is filtered to allow the device to work in a proper way for a time
of typically tFILTER_UVVCCP via the uv_vccp signal.
7.9
Shutoff path via the DrvEn pin
The device includes a shutoff path via the DrvEn pin, which is used to safely disable the solenoid injection power stage in a fault condition
of the ECU. When the DrvEn pin is negated, all pre-drivers (w/o configuration option for DrvEn) must be switched off. Status of the DRVEN
pin can be read back by the SPI (refer to Table 162).
The shutoff path also works in a defined way (switch off all pre-drivers) when DrvEn is negated, even when the PT2000 is stressed with
a voltage of up to 36 V at the supply and/or microcore interface (SPI, Startx,…) pins. Digital interface pins of the PT2000 are self-protected
against a voltage of up to 36 V: CLK, IRQB, ResetB, DrvEn, MISO, MOSI, SCLK, CSB, Dbg, Startx (7x), Flagx (4x), OA_x (3x).
PT2000
NXP Semiconductors
66
7.9.1
DrvEn shutoff path of the high-side pre-driver
The DrvEn path for the HS pre-drivers HS1 to HS4 and HS6 is implemented to ensure a high safety level. It is designed with a high level
of independence, because there is a direct wire from this pin to the HS pre-driver input and the failure rate of this functionally is very low.
If any of the following failures occur, the shut off path is still functional or the driver must be in a safe off state. These failures are:
• Missing clock signal for the device digital core
• Missing supply voltage for the device digital core
• Missing supply voltage of level shifter
• Missing supply voltage (VBS) of HS pre-driver
• Single damaged pre-driver
Table 43. DrvEn path for HS pre-drivers
HS pre-driver
Implementation
HS1
HS2
HS3
Direct wire from the DrvEn pin to the HS pre-driver input. High independence and low FIT rate.
HS4
HS6
HS5
HS7
7.9.2
Configuration option for the DrvEn path. The signal is routed via the digital core only.
DrvEn Shutoff path of the low-side pre-driver
The DrvEn path for the LS pre-drivers LS1 to LS5 is implemented to ensure a high safety level. It is designed with a high level of
independence, because there is a direct wire from this pin to the HS pre-driver input and the failure rate of this functionally is very low.
If any of the following failures occur, the shut off path is still functional or the driver must be in a safe off state. These failures are:
• Missing clock signal for the device digital core
• Missing supply voltage for the device digital core
• Missing supply voltage VCCP of LS pre-driver
• Single damaged pre-driver
Table 44. DrvEn path for LS pre-drivers
LS Pre-driver
Implementation
LS1
LS2
LS3
Direct wire from the DrvEn pin to the LS pre-driver input. High independence and low FIT rate.
LS4
LS6
LS5
LS7
Configuration option for the DrvEn path. The signal is routed via the digital core only.
PT2000
67
NXP Semiconductors
8
Digital core
The digital core controls the actuation of the electro-actuators. The digital core serves as the main microcore features for actuator control,
structures for HW configuration, and the communication interface with the ECU microcontroller.
There are six total microcores which can run concurrently and independently. The microcores are arranged in channels. Each channel
contains two microcores, one instruction RAM (CRAM), and one data RAM (DRAM). This architecture of shared RAM allows efficient use
of the RAM when multiple actuators need to be controlled in parallel with identical microcode. Each digital core communicates with the
external microcontroller through a SPI bus and by means of a set of single wire I/O. Accessible by the SPI are:
a). Registers with dedicated function
b). Data RAM
To avoid access conflicts, a time division multiplex scheme controls the access to the RAMs by the different entities. Thus, microcode
runtime of one microcore is not influenced by RAM access from the SPI or the other microcores.
8.1
Logic channels description
This section describes the features and operation of the microcores (central processing unit, or CPU, and development support functions)
used in the PT2000.
The PT2000 provides a set of three logic channels each channels which include:
• Two 16-bit processing units (microcores) having a specific programming model
• One Code RAM - 1023 x 16-bit. The memory dedicated to microcode storage is shared between the two microcores of logic channel
• One Data RAM - 64 x 16-bit. The memory dedicated to variable storage is shared between the two microcores of a logic channel
Figure 27 describes logic channel 1. The other channels are identical.
Figure 27. Logic channel 1 diagram
PT2000
NXP Semiconductors
68
8.1.1
Microcores
The microcores are actually small microprocessor cores. These are typically programmed to implement software based finite state
machines controlling the actuator operation. The microcores have access to the analog input and output functions, but are also able to
communicate with each other by a flag bus.
μCore
6
Data RAM
Address Base + Address
6
16
16
6
Code RAM
Uprogram_counter
10
uPC
10
10
10
Auxiliary
Register
Interrupt
Return
Register
start_gen
output commands
10
16
16
16
ALU
10
Instruction_
decoder
16
16
16
16
16
16
Counter 1
tc1
Internal_re
g_mux
eoc_reg1
Counter 2
DAC
3
voltage feedbacks
6
current feedbacks
automatic diasgnostic interrupt
tc2
vboost voltage
eoc_reg2
Counter 3
tc3
eoc_reg3
Counter 4
tc4
16
16
eoc_reg4
Flag Bus
Signal
Data bus
Data
Figure 28. Microcore block diagram
For further detail on how to program the microcores, (reference Programming Guide and Instruction Set).
PT2000
69
NXP Semiconductors
8.1.2
Dual microcore arbiter
This block handles the access to code RAM and data RAM memories by the different possible users:
• the two microcores
• the signature unit (code RAM only)
• the SPI interface
8.1.2.1
Access sequence to code RAM
When the device is operating in single microcore mode, access slots to code RAM are granted according to Table 45.
Table 45. Code RAM access sequence (single microcore mode)
Ck_per
flash_enable
T0
T1
T2
T3
Teven
Todd
1
1
uc0
CHKSM
-
-
-
-
1
0
SPI r/w
SPI r/w
-
-
-
-
2
1
uc0
CHKSM
CHKSM
-
-
-
2
0
SPI r/w
SPI r/w
SPI r/w
-
-
-
3
1
uc0
CHKSM
CHKSM
SPI r
-
-
3
0
SPI r/w
SPI r/w
SPI r/w
SPI r/w
-
-
4
1
uc0
CHKSM
CHKSM
SPI r
CHKSM
SPI r
4
0
SPI r/w
SPI r/w
SPI r/w
SPI r/w
SPI r/w
SPI r/w
The clock divider = ck_per +1 (refer to Table 136, Clock_Prescaler (1A0h)). Teven represents all the time slots with an even number id
from T4, and following T4. Todd represents all the time slots with an odd number id from T5 and following T5. When the device is operating
in dual microcore mode, access slots to Code RAM are granted according to Table 46.
Table 46. Code RAM Access Sequence (dual microcore mode)
Ck_per
flash_enable
T0
T1
T2
T3
Teven
Todd
1
1
uc0
uc1
1
0
SPI r/w
SPI r/w
2
1
uc0
uc1
CHKSM
2
0
SPI r/w
SPI r/w
SPI r/w
3
1
uc0
uc1
CHKSM
SPI r
-
-
3
0
SPI r/w
SPI r/w
SPI r/w
SPI r/w
-
-
4
1
uc0
uc1
CHKSM
SPI r
CHKSM
SPI r
4
0
SPI r/w
SPI r/w
SPI r/w
SPI r/w
SPI r/w
SPI r/w
Cycle stealing when
uc0/1 are in wait
CHKSM
CHKSM
CHKSM
CHKSM
The PT2000 allows using a dual sequencer with a ck_per = 1, which means with a clock at 12 MHZ, however some restrictions apply on
the DRAM access (See Access sequence to data RAM on page 71).
PT2000
NXP Semiconductors
70
8.1.2.2
Access sequence to data RAM
When the device is operating in single microcore mode, access slots to data RAM are granted according to Table 47.
Table 47. Data RAM access sequence (single microcore mode)
Ck_per
flash_enable
T0
T1
T2
T3
Tother
Tlast
1
1
SPI r/w
uc0
-
-
-
-
1
0
SPI r/w
SPI r/w
-
-
-
-
2
1
SPI r/w
SPI r/w
uc0
-
-
-
2
0
SPI r/w
SPI r/w
SPI r/w
-
-
-
3
1
SPI r/w
SPI r/w
SPI r/w
uc0
-
-
3
0
SPI r/w
SPI r/w
SPI r/w
SPI r/w
-
-
4+
1
SPI r/w
SPI r/w
SPI r/w
SPI r/w
SPI r/w
uc0
4
0
SPI r/w
SPI r/w
SPI r/w
SPI r/w
SPI r/w
SPI r/w
The clock divider = ck_per +1’ (refer to Table 136, Clock_Prescaler (1A0h)). Tlast represents the last time slot. Tother represent all time
slots (if any) between T3 and Tlast. When the device is operating in dual microcore mode, access slots to data RAM are granted according
to Table 48
Table 48. Data RAM Access Sequence (dual microcore mode)
Ck_per
flash_enable
T0
T1
T2
T3
Teven
Todd
1
1
uc1
uc0
1
0
SPI r/w
SPI r/w
2
1
uc1
SPI r/w
uc0
2
0
SPI r/w
SPI r/w
SPI r/w
3
1
uc1
SPI r/w
SPI r/w
uc0
-
-
3
0
SPI r/w
SPI r/w
SPI r/w
SPI r/w
-
-
4
1
uc1
SPI r/w
SPI r/w
SPI r/w
SPI r/w
uc0
4
0
SPI r/w
SPI r/w
SPI r/w
SPI r/w
SPI r/w
SPI r/w
Cycle stealing when uc0/
1 are in wait
SPI r/w
SPI r/w
SPI r/w
SPI r/w
Note that when ck_per is equal to 1 and dual microcore mode is enabled, there are some limitations for the DRAM access.
As shown in Table 48 when “ck_per = 1” the SPI has no dedicated access slot to the DRAM. At the same time it is clear for most
applications, both microcores do not have to access the DRAM every microcontroler clock cycle. It is possible to use some unused slots
from the microcores for the SPI.
The limit with the 12 MHz dual sequencing access to the data RAM: there is a strong limit on how many instructions in a row the data ram
can access (load, store instructions). This limit depends on the SPI frequency used in the application.
As a consequence, the microcore 0 and 1 must not block the DRAM access slots for longer than the given number of ck cycles minus 1.
If this limit is achieved, it automatically be reported by the NXP IDE (compiler).
PT2000
71
NXP Semiconductors
Table 49 shows the smallest period in s and ck (12 MHz) clock cycles between the address available and first read data bit for SPI read
access, which could occur based on a given SPI baud rate.
Table 49. SPI baud rate and DRAM access sequence for the ck_prescaler = “1”
Minimum SPI read address to first read data bit delay (5 bits)
SPI baud rate (MHz)
8.1.3
s
ck Cycles (12 MHz)
1.0
5.0
60
2.0
2.5
30
4.0
1.25
15
8.0
0.625
7.5
10
0.5
6.0
Signature unit
The task of the signature unit is to compute a checksum of the CRAM to detect possible memory corruption.
The computation is first started when the corresponding CRAM is locked by the pre_flash_enable (see Table 58, Flash_enable (100h,
120h, 140h)). When the computation is complete, the result of the computation is compared to the checksum registers (see Table 66,
checksum_h (108h, 128h, 148h)) and Table 67, checksum_l (109h, 129h, 149h)). These registers contain the golden checksum, provided
during the init phase through the SPI and calculated automatically by the PT2000 IDE.
If the result is correct, the signature unit sets the flash_enable bit (see Table 58, Flash_enable (100h, 120h, 140h)). If the result is not
correct, an interrupt (optional, refer to Table 58, Flash_enable (100h, 120h, 140h)) is issued towards the microcontroller and both
microcores accessing the same CRAM are disabled.
The signature unit can be disabled by writing the Checksum_failure_disable bit in the flash_enable_reg (refer to Table 58, Flash_enable
(100h, 120h, 140h)). When the signature is disabled, the flash_enable bit is set immediately after the pre_flash_enable bit and a failed
checksum causes only a warning (set the appropriate bit in the flash_enable register) without disabling code execution.
The computation requires a different time according to the ck_per value and to the code_width (refer to Table 65, code_width (107h, 127h,
147h)). The worst case computation time for a ck_per of 1 and higher (ck = cksys/2+1 or smaller) is 20 * tCKSYS * (code_width-2). For
example, for a completely used memory, a ck_per of 2 and a cksys clock frequency of 24 MHz (ck at 6.0 MHz), the computation takes
851 s.
The signature unit works only for a code width of 3 or larger. If a shorter code of 1 to 2 words is used, the signature unit has to be disabled.
8.1.4
SPI backdoor
It is also possible to access (both to read and to write) to all the registers normally accessible through the SPI by using an SPI backdoor.
Both the SPI read and write operations are multi cycle operations. Table 51 shows the number of cycles needed. The registers must not
be changed while the operation is in progress.
To read an SPI register, first the 8 LSBs of the address must be provided in the 8 LSBs of the “SPI address” at internal memory map
address. A read operation must then be requested with the “rdspi” instruction (refer to programming guide). The result is available at the
“SPI data” address of the internal memory map.
To write an SPI register, first the 8 LSBs of the address must be provided in the 8 LSBs of the “SPI address” address and the data to write
must be provided at the “SPI data” address. Then a write operation must be requested with the “wrspi” instruction (refer to programming
guide).
There are some access limitations when requesting write access to SPI registers via the SPI backdoor:
• First of all, it is only possible to write to SPI registers which are not locked at the moment the write operation “wrspi” is requested.
• For some special registers there are additional limitations dependant on the configuration of the device. Table 51 shows the different
limitations.
PT2000
NXP Semiconductors
72
Both the SPI read and write operations are multi cycle operations. Table 50 shows the number of cycles needed. The registers and the
SPI address mode (set using “slsa” instruction) must not be changed while the operation is in progress.
Table 50. Cycles for SPI backdoor read/write
ck_prescaler value
Cycles for SPI backdoor r/w
1
4
2
3
3+
2
Table 51. SPI backdoor access limitation
SPI_registers
Access rule
Configuration
controlling access rule
vds_threshold_hs,
vsrc_threshold_hs,
vds_threshold_ls
Only microcores which are allowed to control a certain HS or LS pre-driver are
allowed to change the corresponding VDS and VSRC threshold. Changes to all other
VDS and VSRC values are ignored.
out_acc_seqXchY
hs_slewrate,
ls_slewrate
Only microcores which are allowed to control a certain HS or LS pre-driver are
allowed to change the corresponding slew rate setting. Changes to all other slew
rate settings are ignored.
out_acc_seqXchY
hs_bias_config
ls_bias_config
Only microcores which are allowed to control a certain HS or LS pre-driver are
allowed to control the corresponding biasing source. Changes to all other biasing
sources are ignored
out_acc_seqXchY
vds7_dcdc_config
vds8_dcdc_config
Only microcores which are allowed to control the LS7 or LS8 pre-driver are allowed
to change the corresponding vds_dcdc_timeout register setting. All other changes
are ignored
out_acc_seqXchY
dac1, dac2, dac3, dac4, dac5l, dac5h,
dac5neg, dac6l, dac6h, dac6neg,
boost_dac
8.1.5
No access is possible through the SPI backdoor
CRAM
The code RAM is a 1024x16 single port RAM memory defined to store the micro-code for the entire channel (both microcore0 and
microcore1 if dual microcore mode is enabled).
When enabled, the two microcores can execute either exactly the same code or separate codes, in which case the memory space
dedicated to each microcore are a subset of the overall CRAM. This use of the CRAM memory is controlled by configuration registers
defining the entry point (meaning the starting address) of each microcore (refer to Table 68, uc0_entry_point (10Ah, 12Ah, 14Ah)and
Table 69, uc1_entry_point (10Bh, 12Bh, 14Bh)).
8.1.6
DRAM
The data RAM is a 64x16-bit RAM which can be used as an interface between microcores and the external microprocessor, and also to
store data used only internally by the microcores. The data RAM is accessed as a “flat” memory, where all the 64 memory locations can
be accessed by the external microcontroller and both microcores.
PT2000
73
NXP Semiconductors
8.2
Serial peripheral interface
The communication between the PT2000 and the main microcontroller is managed with a 16-bit SPI interface.
This block is the module providing the SPI connection features. The block is full-duplex, so it can receive and transmit at the same time.
The device requires a cphase value of 1 and a cpol value of 0. This means the SPI module samples the MOSI signal, during write
operations, on the falling edge of the serial clock. Likewise, during read operations, the SPI module always puts the output value available
on the MISO signal on the rising edge of the sclk clock.
CSB
SCLK
16 CLK
CPOL= 0
MISO
MSB
LSB
CPHA = 1
MOSI
MSB
LSB
Figure 29. SPI protocol diagram
While the PT2000 component has many memory locations to access, it was necessary to develop a protocol to manage this.The protocol
is implemented in such a way, so after a reset occurs and after any burst transaction on the SPI connection, the protocol always waits for
a control word. This is a 16-bit word built as follows:
Table 52. SPI protocol
control_word
Meaning
control_word (bit 15)
r_w: read (1)/write (0) operations
control_word (bits 14 to 5)
offset: start address
control_word (bits 4 to 0)
number: number of operations
When this control word is received, the protocol understands the external micro-controller wants to perform a read (when this bit is set to
1) or write (when this bit is set to 0) operation looking at the r_w bit. Looking at the number value, the protocol then understands how many
concurrent read of write operations the external microcontroller wants to perform (max 31). Finally, looking at the offset value, the protocol
understands where these operations should start, meaning what is the first address in this burst of operations to be accessed.
PT2000
NXP Semiconductors
74
8.2.1
SPI read access
A SPI burst for read access consists of 2 to 32 16-bit words. The way the number of words is defined depends on the SPI mode used (A
or B). Table 53 shows the data transmitted on MOSI and MISO. During the command word the check byte and the SPI error status is
transmitted via the MISO line.
Table 53. SPI read access
MOSI word 1 (control word) – read access
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
Name
r_w
offset
number
Value
1
0 to 1023
n=0 to 31
2
1
0
cksys
missing
frame
error
word
error
0
0
0
MISO word 1 (control word) – read access
Bit
15
14
13
12
11
10
Name
Values
9
8
7
6
5
4
3
check byte
1
0
Value
HEX
1
0
1
0
A
1
0
1
0
A
1
0
1
A
8
MOSI word 2 (data) – read access
Bit
15
14
13
12
11
10
9
Name
Value
8
7
6
5
4
3
2
1
0
0
0
0
0
0
0
0
5
4
3
2
1
0
6
5
4
3
2
1
0
0
0
0
0
0
0
0
5
4
3
2
1
0
empty (don’t care)
0
0
0
0
0
0
0
0
0
MISO word 2 (data) – read access
Bit
15
14
13
12
11
10
9
Name
8
7
6
read data 1
MOSI word n+1 (data) – read access
Bit
15
14
13
12
11
10
9
Name
Value
8
7
empty (don’t care)
0
0
0
0
0
0
0
0
0
MISO word n+1 (data) – read access
Bit
Name
15
14
13
12
11
10
9
8
7
6
read data n
PT2000
75
NXP Semiconductors
8.2.2
SPI write access
A SPI burst for write access consists of 2 to 32 16-bit words. The way the number of words is defined depends on the SPI mode used (A
or B). Table 54 shows the data transmitted on MOSI and MISO. During the command word and all data words, the check byte, and the
SPI error status is transmitted via the MISO line.
Table 54. SPI write access
MOSI word 1 (control word) - write access
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
Name
r_w
offset
number
Value
0
0 to 1023
n=0 to 31
2
1
0
cksys
missing
frame
error
word
error
0
0
0
MISO word 1 (control word) - write access
Bit
15
14
13
12
11
10
Name
Values
9
8
7
6
5
4
3
check byte
1
0
Value
HEX
1
0
1
0
A
1
0
1
0
A
1
0
1
A
8
MOSI word 2 (data) - write access
Bit
15
14
13
12
11
10
9
Name
8
7
6
5
4
3
2
1
0
5
4
3
2
1
0
cksys
missing
frame
error
word
error
0
0
0
write data 1
MISO word 2 (data) - write access
Bit
15
14
13
12
11
10
Name
Values
9
8
7
6
check byte
1
0
Value
HEX
1
0
1
0
A
1
0
1
0
A
1
0
1
A
8
MOSI word n+1 (data) - write access
Bit
15
14
13
12
11
10
9
Name
8
7
6
5
4
3
2
1
0
5
4
3
2
1
0
cksys
missing
frame
error
word
error
0
0
0
write data n
MISO word n+1 (data) - write access
Bit
15
14
13
12
11
10
Name
Values
9
8
7
6
check byte
1
0
Value
HEX
1
A
0
1
0
1
A
0
1
0
1
A
0
1
8
PT2000
NXP Semiconductors
76
8.2.3
SPI protocol
8.2.3.1
Mode A
CSB
MOSI
(read)
control word
MISO
(read)
check byte
error bits
data 1
data n+1
MOSI
(write)
control word
data 1
data n+1
MISO
(write)
check byte
error bits
check byte
error bits
check byte
error bits
SPI watchdog
Figure 30. SPI protocol mode A CSB, MOSI, and MISO
The maximum delay between data belonging to the same burst is specified by the spi_watchdog parameter (refer to Table 153, Spi_config
(1A9h)). Between one data transfer and the next, the SPI chip select can be asserted. If the delay exceeds the watchdog time, the SPI
interface goes into the error state.
It is possible to perform long burst transfers by sending a control word with the parameters number and offset set to zero. The effect varies
according to the current value of the channel select register (refer to Table 56, selection_register (3FFh)):
• If the value of channel select register is “0xxxxx001”, the protocol performs a burst of operations starting from address 0; the number
of operations is specified by the value of the code_width register (refer to Table 64, status_reg_uc1 (106h, 126h, 146h)) of channel
1. This command is used to write the whole CRAM of channel 1 with only one command word.
• If the value of channel select register is “0xxxxx010”, the protocol performs a burst of operations starting from address 0; the number
of operations is specified by the value of the code_width register (refer to Table 64, status_reg_uc1 (106h, 126h, 146h)) of channel
2. This command is used to write the whole CRAM of channel 2 with only one command word.
• If the value of channel select register is “0xxxxx100”, the protocol performs a burst of operations starting from address 0; the number
of operations is specified by the value of the code_width register (refer to Table 64, status_reg_uc1 (106h, 126h, 146h)) of channel
3. This command is used to write the whole CRAM of channel 3 with only one command word.
• If the value of channel select register is “0xxxxx011”, the protocol performs a burst of operations starting from address 0; the number
of operations is specified by the value of the code_width register (refer to Table 64, status_reg_uc1 (106h, 126h, 146h)) of channel
1. This command is used to fully write the CRAMs of channel 1 and 2 (with exactly the same code) with only one command word.
• If the value of channel select register is “0xxxxx101”, the protocol performs a burst of operations starting from address 0; the number
of operations is specified by the value of the code_width register (refer to Table 64, status_reg_uc1 (106h, 126h, 146h)) of channel
1. This command is used to fully write the CRAMs of channel 1 and 3 (with exactly the same code) with only one command word.
• If the value of channel select register is “0xxxxx110”, the protocol performs a burst of operations starting from address 0; the number
of operations is specified by the value of the code_width register (refer to Table 64, status_reg_uc1 (106h, 126h, 146h)) of channel
2. This command is used to fully write the CRAMs of channel 2 and 3 (with exactly the same code) with only one command word.
• If the value of channel select register is “0xxxxx111”, the protocol performs a burst of operations starting from address 0; the number
of operations is specified by the value of the code_width register (refer to Table 64, status_reg_uc1 (106h, 126h, 146h)) of channel
1. This command is used to fully write the CRAMs of channel 1, 2 and 3 (with exactly the same code) with only one command word.
• If the value of channel select register is “1xxxxx000”, the protocol performs a burst of operations starting from address 0; the number
of operations is 192. This command is used to fully write the DRAMs of all three channels with only one command word.
• For all the other values of channel select register, the command is neglected.
PT2000
77
NXP Semiconductors
Sending a control word with the parameter number set to zero and the parameter offset greater than zero is not allowed. This leads to
data corruption in the registers or DRAM.
For example, to initialize the values of 24 LS pre-driver diagnosis configuration registers, it is necessary to:
• Select the communication interface as the target: this is done by writing the value 0100h at the address 3FFh. First send the data
“0_1111111111_00001” (7FE1h) via the SPI. As the ASIC is in idle conditions, it uses this data as a command word. In particular,
this specific command word of the example means: write (because of the initial 0) starting from address 3FFh (the ten bits
immediately after) 1 word (the five bits at the end). The next data to send is 0100h. The SPI block is expecting a write to 3FFh, so
write 0100h in the location 3FFh. As the number of word expected is arrived, the SPI block returns to the idle state;
• Write the value of the 24 registers: the SPI block is waiting for a command word. The correct data to send is “0_0111000000_11000”.
This means write (0) starting form address 1C0h (0111000000) 24 words (11000). The next 24 words are written to the
communication interface registers.
8.2.3.2
Mode B
CSB
MOSI
(read)
control word
MISO
(read)
check byte
error bits
data 1
data n+1
MOSI
(write)
control word
data 1
data n+1
MISO
(write)
check byte
error bits
check byte
error bits
check byte
error bits
Figure 31. SPI protocol mode B CSB, MOSI, and MISO
For the duration of a burst of data, the SPI chip select must be asserted, even between data transfers. The first word after the chip select
assertion is considered to be the command word and the following words are the data. If the number parameter is not zero, the SPI
interface goes into error state if:
• the chip select is de-asserted and the number of words transferred is lower than the number parameters required by the command
word,
• the number of word transferred is equal to the number parameter + 1.
If the number parameter is zero, there is no check on the number of words transferred, and the length of the burst is decided only by the
assertion of SPI chip select. It is not recommended to read from any register which is “reset on read” nor from any register which is located
one address before such a register using a mode B burst with the number parameter set to zero. This may lead to the effect of a register
reset, which is not a read out via the SPI. This problem does not occur if the number parameter is equal to the number of data words
transmitted.
Note: If one additional data word is sent it is detected, but also written. For example:
• SPI write access mode B, parameter number set to 3 and 3 data words written with no error
• SPI write access mode B, parameter number set to 3 and 4 data words written with a SPI frame error after the 4th data word, but the
4th data word is written to RAM or the register.
• SPI write access mode B, parameter number set to 3 and 6 data words written with a SPI frame error after the 4th data word, but the
4th data word is written to RAM or the register. 5th and 6th data words are not written to memory.
PT2000
NXP Semiconductors
78
8.3
SPI address map
Table 55. MC33PT2000 address map
Selection register
[8:0]/chip select
Address
(Hex)
Lock
Description
Table number
Area addressed
yes
Code RAM of channel 1, See CRAM on page 73
Code RAM of
channel 1
yes
Code RAM of channel 2, See CRAM on page 73
Code RAM of
channel 2
yes
Code RAM of channel 3, See CRAM on page 73
Code RAM of
channel 3
no
Data RAM of channel 1, See DRAM on page 73
0
“0…001” /
ch_sel_1(1)
...
3FE
0
“0…010”/
ch_sel_2(1)
...
3FE
0
“0…100”/
ch_sel_3(1)
...
3FE
0
...
“1…000” /
ch_sel_1(0)
2F
Data RAM of
channel 1
30
...
yes
Data RAM of channel 1, private area, See DRAM on page 73
no
Data RAM of channel 2, See DRAM on page 73
3F
40
...
“1…000” /
ch_sel_2(0)
6F
Data RAM of
channel 2
70
...
yes
Data RAM of channel 2, private area, See DRAM on page 73
no
Data RAM of channel 3, See DRAM on page 73
7F
80
...
“1…000” /
ch_sel_3(0)
9F
Data RAM of
channel 3
A0
...
yes
Data RAM of channel 3, private area, See DRAM on page 73
BF
PT2000
79
NXP Semiconductors
Table 55. MC33PT2000 address map
Selection register
[8:0]/chip select
Address
(Hex)
Lock
Description
Table number
Area addressed
C0
…
64 free address
FF
“1…000” /
ch_sel_1(2)
100
yes
flash_enable of channel 1
Table 58
101
no
ctrl_reg_uc0 of channel 1
Table 59
102
no
ctrl_reg_uc1 of channel 1
Table 60
103
yes
start_config_reg_part 1 of channel 1
Table 61
104
yes
start_config_reg_part 2 of channel 1
Table 62
105
-
status_reg_uc0 of channel 1
Table 63
106
-
status_reg_uc1 of channel 1
Table 64
107
yes
code_width of channel 1
Table 65
108
yes
checksum_h of channel 1
Table 66
109
yes
checksum_l of channel 1
Table 67
10A
yes
uc0_entry_point of channel 1
Table 68
10B
yes
uc1_entry_point of channel 1
Table 69
10C
yes
diag_routine_addr of channel 1
Table 70
10D
yes
driver_disabled_routine_addr of channel 1
Table 71
10E
yes
sw_interrupt_routine_addr of channel 1
Table 72
10F
no
uc0_irq_status of channel 1
Table 73
110
no
uc1_irq_status of channel 1
Table 74
111
yes
counter34_prescaler of channel 1
Table 75
112
yes
dac_rxtx_cr_config of channel 1
Table 77
113
no
unlock_word of channel 1
Table 77
Configuration
registers of
channel 1
114
...
12 free addresses
11F
PT2000
NXP Semiconductors
80
Table 55. MC33PT2000 address map
Selection register
[8:0]/chip select
“1…000” /
ch_sel_2(2)
Address
(Hex)
Lock
Description
Table number
120
yes
flash_enable of channel 2
Table 58
121
no
ctrl_reg_uc0 of channel 2
Table 58
122
no
ctrl_reg_uc1 of channel 2
Table 60
123
yes
start_config_reg_part1 of channel 2
Table 61
124
yes
start_config_reg_part2 of channel 2
Table 62
125
-
status_reg_uc0 of channel 2
Table 63
126
-
status_reg_uc1 of channel 2
Table 64
127
yes
code_width of channel 2
Table 65
128
yes
checksum_h of channel 2
Table 66
129
yes
checksum_l of channel 2
Table 67
12A
yes
uc0_entry_point of channel 2
Table 68
12B
yes
uc1_entry_point of channel 2
Table 69
12C
yes
diag_routine_addr of channel 2
Table 70
12D
yes
driver_disabled_routine_addr of channel 2
Table 71
12E
yes
sw_interrupt_routine_addr of channel 2
Table 72
12F
no
uc0_irq_status of channel 2
Table 73
130
no
uc1_irq_status of channel 2
Table 74
131
yes
counter34_prescaler of channel 2
Table 75
132
yes
dac_rxtx_cr_config of channel 2
Table 77
133
no
unlock_word of channel 2
Table 77
Area addressed
Configuration
registers of
channel 2
134
...
12 free addresses
13F
PT2000
81
NXP Semiconductors
Table 55. MC33PT2000 address map
Selection register
[8:0]/chip select
“1…000” /
ch_sel_3(2)
Address
(Hex)
Lock
Description
Table number
140
yes
flash_enable of channel 3
Table 58
141
no
ctrl_reg_uc0 of channel 3
Table 58
142
no
ctrl_reg_uc1 of channel 3
Table 60
143
yes
start_config_reg_part1 of channel 3
Table 61
144
yes
start_config_reg_part2 of channel 3
Table 62
145
-
status_reg_uc0 of channel 3
Table 63
146
-
status_reg_uc1 of channel 3
Table 64
147
yes
code_width of channel 3
Table 65
148
yes
checksum_h of channel 3
Table 66
149
yes
checksum_l of channel 3
Table 67
14A
yes
uc0_entry_point of channel 3
Table 68
14B
yes
uc1_entry_point of channel 3
Table 69
14C
yes
diag_routine_addr of channel 3
Table 70
14D
yes
driver_disabled_routine_addr of channel 3
Table 71
14E
yes
sw_interrupt_routine_addr of channel 3
Table 72
14F
no
uc0_irq_status of channel 3
Table 73
150
no
uc1_irq_status of channel 3
Table 74
151
yes
counter34_prescaler of channel 3
Table 75
152
yes
dac_rxtx_cr_config of channel 3
Table 77
153
no
unlock_word of channel 3
Table 77
Area addressed
Configuration
registers of
channel 3
PT2000
NXP Semiconductors
82
Table 55. MC33PT2000 address map
Selection register
[8:0]/chip select
“1…000” /
ext_sel_io
Address
(Hex)
Lock
Description
Table number
154
yes
fbk_sens_uc0_ch1_part1
Table 81
155
yes
fbk_sens_uc0_ch1_part2
Table 82
156
yes
fbk_sens_uc1_ch1_part1
Table 81
157
yes
fbk_sens_uc1_ch1_part2
Table 82
158
yes
fbk_sens_uc0_ch2_part1
Table 81
159
yes
fbk_sens_uc0_ch2_part2
Table 82
15A
yes
fbk_sens_uc1_ch2_part1
Table 81
15B
yes
fbk_sens_uc1_ch2_part2
Table 82
15C
yes
fbk_sens_uc0_ch3_part1
Table 81
15D
yes
fbk_sens_uc0_ch3_part2
Table 82
15E
yes
fbk_sens_uc1_ch3_part1
Table 81
15F
yes
fbk_sens_uc1_ch3_part2
Table 82
160
yes
out_acc_uc0_ch1
Table 83
161
yes
out_acc_uc1_ch1
Table 83
162
yes
out_acc_uc0_ch2
Table 83
163
yes
out_acc_uc1_ch2
Table 83
164
yes
out_acc_uc0_ch3
Table 83
165
yes
out_acc_uc1_ch3
Table 83
166
yes
cur_block_access_part1
Table 85
167
yes
cur_block_access_part2
Table 86
168
yes
cur_block_access_part3
Table 87
169
yes
fw_link
Table 88
16A
yes
fw_ext_req
Table 90
16B
no
vds_thresholds_hs_part1
Table 91
16C
no
vds_thresholds_hs_part2
Table 92
16D
no
vsrc_thresholds_hs_part1
Table 93
16E
no
vsrc_thresholds_hs_part2
Table 94
16F
no
vds_thresholds_ls_part1
Table 96
170
no
vds_thresholds_ls_part2
Table 97
171
no
hs_slewrate
Table 99
Area addressed
IO configuration
registers
PT2000
83
NXP Semiconductors
Table 55. MC33PT2000 address map
Selection register
[8:0]/chip select
“1…000” /
ext_sel_io
Address
(Hex)
Lock
Description
Table number
172
no
ls_slewrate_part1
Table 100
173
no
ls_slewrate_part2
Table 101
174
no
offset_compensation12
Table 102
175
no
offset_compensation34
Table 103
176
no
offset_compensation56
Table 104
177
no
adc12_result
Table 105
178
no
adc34_result
Table 106
179
no
adc56_result
Table 107
17A
yes
current_filter12
Table 108
17B
yes
current_filter34
Table 109
17C
yes
current_filter5l5h
Table 110
17D
yes
current_filter6l6h
Table 111
17E
yes
current_filter5neg6neg
Table 112
17F
no
boost_dac
Table 113
180
yes
boost_dac_access
Table 114
181
yes
boost_filter
Table 115
182
no
vds7_dcdc_config
Table 116
183
no
vds8_dcdc_config
Table 116
184
-
batt_result
Table 118
185
no
dac12_value
Table 119
186
no
dac34_value
Table 120
187
no
dac5l5h_value
Table 121
188
no
dac5neg_value
Table 122
189
no
dac6l6h_value
Table 123
18A
no
dac6neg_value
Table 124
18B
no
hs_bias_config
Table 125
18C
no
ls_bias_config
Table 126
18D
-
bootstrap_charged
Table 127
18E
-
bootstrap_timer
Table 128
18F
yes
hs1_ls_act
Table 131
Area addressed
IO configuration
registers
PT2000
NXP Semiconductors
84
Table 55. MC33PT2000 address map
Selection register
[8:0]/chip select
“1…000” /
ext_sel_io
Address
(Hex)
Lock
Description
Table number
190
yes
hs2_ls_act
Table 131
191
yes
hs3_ls_act
Table 131
192
yes
hs4_ls_act
Table 131
193
yes
hs5_ls_act
Table 131
194
yes
hs6_ls_act
Table 131
195
yes
hs7_ls_act
Table 131
196
yes
dac_settling_time
Table 132
197
no
oa_out1_config
Table 133
198
no
oa_out2_config
Table 134
199
no
oa_out3_config
Table 135
Area addressed
IO configuration
registers
19A
…
6 free addresses
19F
PT2000
85
NXP Semiconductors
Table 55. MC33PT2000 address map
Selection register
[8:0]/chip select
“1000” /
ext_sel_mcr
Address
(Hex)
Lock
Description
Table number
1A0
yes
Clock_Prescaler
Table 136
1A1
yes
Flags_Direction
Table 138
1A2
yes
Flags_Polarity
Table 141
1A3
yes
Flags_source
Table 145
1A4
yes
Offset_compensation_prescaler
Table 146
1A5
yes
Driver_Config_part1
Table 147
1A6
yes
Driver_Config_part2
Table 148
1A7
yes
PLL_config
Table 151
1A8
yes
Backup_Clock_Status
Table 152
1A9
yes
SPI_config
Table 153
1AA
no
Trace_start
Table 154
1AB
no
Trace_stop
Table 155
1AC
no
Trace_config
Table 156
1AD
yes
Device_lock
Table 157
1AE
no
Reset_behavior
Table 158
1AF
-
Device_unlock
Table 159
1B0
-
Global_reset_code_part1
Table 160
1B1
-
Global_reset_code_part2
Table 161
1B2
no
Driver_Status
Table 162
1B3
-
SPI_error_code
Table 163
1B4
no
Interrupt_register_part1
Table 164
1B5
no
Interrupt_register_part2
Table 165
1B6
-
Device_Identifier
Table 167
1B7
-
Reset_source
Table 168
1B8
----
-
----
1BC
----
1BD
no
BIST_interface
1BE
no
----
1BF
no
----
Area addressed
Main
configuration
registers
Table 170
PT2000
NXP Semiconductors
86
Table 55. MC33PT2000 address map
Selection register
[8:0]/chip select
“1…000” /
ext_sel_diag
Address
(Hex)
Lock
Description
Table number
1C0
yes
ls1_diag_config1
Table 172
1C1
yes
ls1_diag_config2
Table 173
1C2
yes
ls1_output_config
Table 174
1C3
yes
ls2_diag_config1
Table 172
1C4
yes
ls2_diag_config2
Table 173
1C5
yes
ls2_output_config
Table 174
1C6
yes
ls3_diag_config1
Table 172
1C7
yes
ls3_diag_config2
Table 173
1C8
yes
ls3_output_config
Table 174
1C9
yes
ls4_diag_config1
Table 172
1CA
yes
ls4_diag_config2
Table 173
1CB
yes
ls4_output_config
Table 174
1CC
yes
ls5_diag_config1
Table 172
1CD
yes
ls5_diag_config2
Table 173
1CE
yes
ls5_output_config
Table 174
1CF
yes
ls6_diag_config1
Table 172
1D0
yes
ls6_diag_config2
Table 173
1D1
yes
ls6_output_config
Table 174
1D2
yes
ls7_diag_config1
Table 172
1D3
yes
ls7_diag_config2
Table 173
1D4
yes
ls7_output_config
Table 175
1D5
yes
ls8_diag_config1
Table 172
1D6
yes
ls8_diag_config2
Table 173
1D7
yes
ls8_output_config
Table 175
1D8
yes
hs1_diag_config1
Table 176
1D9
yes
hs1_diag_config2
Table 177
1DA
yes
hs1_output_config
Table 178
1DB
yes
hs2_diag_config1
Table 176
1DC
yes
hs2_diag_config2
Table 177
1DD
yes
hs2_output_config
Table 178
1DE
yes
hs3_diag_config1
Table 176
1DF
yes
hs3_diag_config2
Table 177
1E0
yes
hs3_output_config
Table 178
1E1
yes
hs4_diag_config1
Table 176
Area addressed
diagnostics
configuration
registers
PT2000
87
NXP Semiconductors
Table 55. MC33PT2000 address map
Selection register
[8:0]/chip select
“1…000” /
ext_sel_diag
Address
(Hex)
Lock
Description
Table number
1E3
yes
hs4_output_config
Table 178
1E4
yes
hs5_diag_config1
Table 176
1E5
yes
hs5_diag_config2
Table 177
1E6
yes
hs5_output_config
Table 178
1E7
yes
hs6_diag_config1
Table 176
1E8
yes
hs6_diag_config2
Table 177
1E9
yes
hs6_output_config
Table 178
1EA
yes
hs7_diag_config1
Table 176
1EB
yes
hs7_diag_config2
Table 177
1EC
yes
hs7_output_config
Table 178
1ED
-
err_uc0ch1_part1
Table 179
1EE
-
err_uc0ch1_part2
Table 180
1EF
-
err_uc0ch1_part3
Table 181
1F0
-
err_uc1ch1_part1
Table 179
1F1
-
err_uc1ch1_part2
Table 180
1F2
-
err_uc1ch1_part3
Table 181
1F3
-
err_uc0ch2_part1
Table 179
1F4
-
err_uc0ch2_part2
Table 180
1F5
-
err_uc0ch2_part3
Table 181
1F6
-
err_uc1ch2_part1
Table 179
1F7
-
err_uc1ch2_part2
Table 180
1F8
-
err_uc1ch2_part3
Table 181
1F9
-
err_uc0ch3_part1
Table 179
1FA
-
err_uc0ch3_part2
Table 180
1FB
-
err_uc0ch3_part3
Table 181
1FC
-
err_uc1ch3_part1
Table 179
1FD
-
err_uc1ch3_part2
Table 180
1FE
-
err_uc1ch3_part3
Table 181
1FF
yes
diagnostics_option
Table 182
Area addressed
diagnostics
configuration
registers
200
-
511 free addresses
3FE
N/A
3FF
no
Selection_register
Table 56
Selection Register
PT2000
NXP Semiconductors
88
8.3.1
Selection register (3FFh)
The selection register is a 4-bit register aimed to select, before starting the read/write operations toward a given address, which internal
code RAM is accessed or to select all the other addresses (including the 3 data RAMs and all the registers).
Table 56. selection_register (3FFh)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
Name
Reserved
comm.
page
sel
Reserved
R/W
-
r/w
-
r/w
r/w
r/w
Lock
-
no
-
no
no
no
Reset
0000000
0
00000
0
0
0
CRAM_ CRAM_ CRAM_
ch3_sel ch2_sel ch1_sel
Table 57 details the meaning of the 4 bits in this register. Not all possible values are allowed for this register.
Table 57. Selection register
Selection register
comm. page sel
Selection register
CRAM chx
‘0’
“000”
Nothing selected. Further SPI operation, except for the one concerning this register is ignored.
‘0’
“001”
Channel 1 Code RAM selected
‘0’
“010”
Channel 2 Code RAM selected
‘0’
“100”
Channel 3 Code RAM selected
‘0’
“011”
Write operation affects the Code RAM of channel 1 and 2. Read operation is not possible.
‘0’
“101”
Write operation affects the Code RAM of channel 1 and 3. Read operation is not possible.
‘0’
“110”
Write operation affects the Code RAM of channel 2 and 3. Read operation is not possible.
‘0’
“111”
Write operation affects the all three channel’s Code RAM. Read operation is not possible.
‘1’
d.c.
Element addressed
Common page selected. The lower three bits are ignored. “100000000” is written to the register.
This selection register is accessible at address 3FFh and is the only register accessed anyway from the SPI, whatever the value of the
selection register. This means address 3FFh can only be used for this purpose, even if any of the code RAMs is selected, so each 1024x16
code RAM in the MC33PT2000 can actually only store 1023 data. Note that 2 or 3 code RAMs can be written in parallel during normal
mode.
PT2000
89
NXP Semiconductors
8.3.2
Configuration register
8.3.2.1
Flash_enable register
Table 58. Flash_enable (100h, 120h, 140h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
pre
checksum flash_en
en_dual_
chksum_irq chksum_f
flash_en
Reserved
_disable
able
uc
_en
ailure
able
Name
Reserved
R/W
-
r/w
r
r/w
r/w
-
r/w
r
Lock
-
yes, by
pre flash
enable
-
yes, by
itself
yes, by
pre flash
enable
-
yes
-
Reset
000000000
0
0
0
0
0
0
0
This is a 6 bit configuration register which includes the following parameters:
• Checksum_disable. If set, this bit disables the effects of a failed checksum, so microcore execution is not stopped
• Pre_flash_enable. This bit “freezes” the CRAM so the micro-controller cannot further modify the configuration code unless a specific
unlock code is written into register unlock_reg. It enables the signature_unit (See Signature unit on page 72)
• Flash_enable. This bit enables the microcores. It can only be set by the signature_unit after a successful checksum calculation
• En_dual_microcore. This bit is used to enable the dual microcore mode. Note that when using dual microcore ck_per (refer to
Table 136, Clock_Prescaler (1A0h)) set to lower than three, there are some limitations regarding C/DRAM access.
• Checksum_irq_en. If this bit is '1', an interrupt on the_irq_device pin is done in case a CRAM corruption detected
• Checksum_failure. This bit sets to '1' when a mismatch is found between the calculated checksum and the checksum code stored in
the appropriate registers (refer to Table 66, checksum_h (108h, 128h, 148h) and Table 67, checksum_l (109h, 129h, 149h)). This bit
sets when a checksum calculation fails, even if the checksum is disabled. This bit resets each time the pre_flash_enable bit sets to '1'
to lock the memory.
8.3.2.2
Control register microcore0
Table 59. Ctrl_reg_uc0 (101h, 121h, 141h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
Name
Control_register_Shared
Control_register
R/W
configurable r or r/w
r/w
Lock
no
no
Reset
00000000
00000000
2
1
0
• Control_register: these 8 bits can be used to control the execution of the micro-program of uc0, providing control bits which can be read
by the micro-program. For instance one bit could be used to enable/disable recharge pulses on the channel or to re-enable the actuation
after an error condition has been detected.
• Control_register_shared: according to a configuration bit stored in the “control_register_split” register (refer to Table 77,
Dac_rxtx_cr_config (112h, 132h, 152h)), these 8 bits can be used either as control (like the other 8 bits) or like status (like the status
register, refer to Table 63, status_reg_uc0 (105h, 125h, 145h)and Table 64, status_reg_uc1 (106h, 126h, 146h)). In this case, they can
only be read through the SPI, while they can be set by the “set control register bit” instruction.
PT2000
NXP Semiconductors
90
8.3.2.3
Control register microcore1
Table 60. ctrl_reg_uc1 (102h, 122h, 142h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
Name
Control_register_Shared
Control_register
R/W
configurable r or r/w
r/w
Lock
no
no
Reset
00000000
00000000
2
1
0
• Control register: these 8 bits can be used to control the execution of the micro-program of uc0, providing control bits which can be read
by the micro-program itself. For instance one bit could be used to enable/disable recharge pulses on the channel or to re-enable the
actuation after an error condition has been detected.
• Control register shared: according to a configuration bit stored in the “control register split” register (refer to Table 77,
Dac_rxtx_cr_config (112h, 132h, 152h)), these 8 bits can be used either as control (like the other 8 bits) or like status (like the status
register, refer to Table 63, status_reg_uc0 (105h, 125h, 145h)and Table 64, status_reg_uc1 (106h, 126h, 146h)). In this case they can
only be read through the SPI, while they can be set by the “set control register bit” instruction.
8.3.2.4
Start configuration register
These are two configuration registers where it is possible to configure the sensitivity of each microcore to the start signals. It is also
possible to enable a smart start mode for each microcore (reference Programming Guide and Instruction Set).
Table 61. start_config_reg_Part1 (103h, 123h, 143h)
Bit
Name
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
start8_ start7_ start6_ start5_ start4_ start3_ start2_ start1_ start8_ start7_ start6_ start5_ start4_ start3_ start2_ start1_
sens_u sens_u sens_u sens_u sens_u sens_u sens_u sens_u sens_u sens_u sens_u sens_u sens_u sens_u sens_u sens_u
c1
c1
c1
c1
c1
c1
c1
c1
c0
c0
c0
c0
c0
c0
c0
c0
R/W
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
Lock
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
Reset
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
1
0
Table 62. start_config_reg_Part2 (104h, 124h, 144h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
smart_ smart_
start_u start_u
c1
c0
Name
reserved
R/W
-
r/w
r/w
Lock
-
yes
yes
Reset
00000000
0
0
•
•
•
•
•
•
•
•
•
•
start1_sens_uc0: This bit is '1' if the uc0_is sensitive to start1, '0' otherwise
start2_sens_uc0: This bit is '1' if the uc0_is sensitive to start2, '0' otherwise
start3_sens_uc0: This bit is '1' if the uc0_is sensitive to start3, '0' otherwise
start4_sens_uc0: This bit is '1' if the uc0_is sensitive to start4, '0' otherwise
start5_sens_uc0: This bit is '1' if the uc0_is sensitive to start5, '0' otherwise
start6_sens_uc0: This bit is '1' if the uc0_is sensitive to start6, '0' otherwise
start7_sens_uc0: This bit is '1' if the uc0_is sensitive to start7, '0' otherwise
start8_sens_uc0: This bit is '1' if the uc0_is sensitive to start8, '0' otherwise
start1_sens_uc1: This bit is '1' if the uc1_is sensitive to start1, '0' otherwise
start2_sens_uc1: This bit is '1' if the uc1_is sensitive to start2, '0' otherwise
PT2000
91
NXP Semiconductors
•
•
•
•
•
•
•
start3_sens_uc1: This bit is '1' if the uc1_is sensitive to start3, '0' otherwise
start4_sens_uc1: This bit is '1' if the uc1_is sensitive to start4, '0' otherwise
start5_sens_uc1: This bit is '1' if the uc1_is sensitive to start5, '0' otherwise
start6_sens_uc1: This bit is '1' if the uc1_is sensitive to start6, '0' otherwise
start7_sens_uc1: This bit is '1' if the uc1_is sensitive to start7, '0' otherwise
start8_sens_uc1: This bit is '1' if the uc1_is sensitive to start8, '0' otherwise
smart_start_uc0: This bit is '1' if the smart start mode is enabled for uc0, '0' otherwise (reference Programming Guide and Instruction
Set).
• smart_start_uc1: This bit is '1' if the smart start mode is enabled for uc1, '0' otherwise (reference Programming Guide and Instruction
Set).
8.3.2.5
Status register microcore0
This 16-bit register is a read-only register and only provides information about the uc0_status to the external microcontroller. The register
can be used to exchange application dependent information (status bits, for instance regarding the execution phase of the micro-program,
diagnostics results) between the microcore and the main microcontroller according to the way the micro-program is designed. The
registers can be configured so they reset after a SPI read operation to the register (see Table 158, Reset_Behavior (1AEh)).
Table 63. status_reg_uc0 (105h, 125h, 145h)
Bit
15
14
13
12
11
10
9
8
7
Name
status_register
R/W
r
Lock
-
Reset
on read
configurable
Reset
0000000000000000
8.3.2.6
6
5
4
3
2
1
0
Status register microcore1
This 16-bit register is a read-only register and only provides information about the uc1_status to the external microcontroller. The register
can be used to exchange application dependent information (status bits, for instance regarding the execution phase of the micro-program)
between the microcore and the main microcontroller according to the way the micro-program is designed. The registers can be configured
so they reset after a SPI read operation to the register (see Table 158, Reset_Behavior (1AEh)).
Table 64. status_reg_uc1 (106h, 126h, 146h)
Bit
15
14
13
12
11
10
9
8
7
Name
status_register
R/W
r
Lock
-
Reset
on read
configurable
Reset
0000000000000000
6
5
4
3
2
1
0
PT2000
NXP Semiconductors
92
8.3.2.7
Code_width register
This 10-bit register provides the length of the section of the CRAM used to store the code. This information has two uses:
• It is used by the SPI interface to determine the length of the special burst transfer used for CRAM initialization (refer to See SPI protocol
on page 77).
• The signature unit computes the checksum only of the used part of the CRAM. This signature unit only works if the code with is bigger
than 3 lines, if it is not the case signature unit has to be disabled (refer to Table 58, Flash_enable (100h, 120h, 140h))
This allows the application not to write all the CRAM, but only the part which is really used.
Table 65. code_width (107h, 127h, 147h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
Name
Reserved
code width
R/W
-
r/w
Lock
-
yes
Reset
000000
0000000000
8.3.2.8
3
2
1
0
Checksum high register
This 16-bit register contains the 16 MSBs of the checksum of the code contained in the CRAM. The signature_unit (refer to See Signature
unit on page 72) compares the result of its computation to this register and checksum_l.
Table 66. checksum_h (108h, 128h, 148h)
Bit
15
14
13
12
11
10
9
8
7
Name
checksum_high
R/W
r/w
Lock
yes
Reset
0000000000000000
8.3.2.9
6
5
4
3
2
1
0
Checksum low register
This 16-bit register contains the 16 LSBs of the checksum of the code contained in the CRAM. The signature_unit (refer to section See
Signature unit on page 72) compares the result of its computation to checksum_h and this register.
Table 67. checksum_l (109h, 129h, 149h)
Bit
15
14
13
12
11
10
9
8
7
Name
Checksum_low
R/W
r/w
Lock
yes
Reset
0000000000000000
6
5
4
3
2
1
0
PT2000
93
NXP Semiconductors
8.3.2.10
Microcore0 entry point address register
This 10-bit register contains the CRAM address of the first instruction to be executed by microcontroller0.
Table 68. uc0_entry_point (10Ah, 12Ah, 14Ah)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
Name
Reserved
entry_point_address
R/W
-
r/w
Lock
-
yes
Reset
000000
0000001000
8.3.2.11
3
2
1
0
Microcore1 entry point address register
This 10-bit register contains the CRAM address of the first instruction to be executed by uc1. This is done to allow the two microcores to
execute completely independent microcodes (when the two entry point differ), while still having the capability to execute the same program
in case the two entry points coincide.
Table 69. uc1_entry_point (10Bh, 12Bh, 14Bh)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
Name
Reserved
entry_point_address
R/W
-
r/w
Lock
-
yes
Reset
000000
0000001000
8.3.2.12
3
2
1
0
3
2
1
0
Diagnostics interrupt routine address register
Table 70. Diag_routine_addr (10Ch, 12Ch, 14Ch)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
Name
Reserved
diagnostics_routine_address_uc1
diagnostics_routine_address_uc0
R/W
-
r/w
r/w
Lock
-
yes
yes
Reset
0000
000000
000000
• diagnostics_routine_address_uc0. The complete address is “0000” & “diagnostics routine address uc0”: this is the CRAM address of
the first instruction of the interrupt routine to be executed by uc0_when an automatic diagnostics exception is raised.
• diagnostics_routine_address_uc1. The complete address is “0000” & “diagnostics routine address uc1”: this is the CRAM address of
the first instruction of the interrupt routine to be executed by uc1_when an automatic diagnostics exception is raised.
PT2000
NXP Semiconductors
94
8.3.2.13
Driver disabled interrupt routine address register
Table 71. Driver_disable_routine_addr (10Dh, 12Dh, 14Dh)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
Name
Reserved
driver_disable_routine_address_uc1
driver_disable_routine_address_uc0
R/W
-
r/w
r/w
Lock
-
yes
yes
Reset
0000
000000
000000
• driver_disable_routine_address_uc0. The complete address is “0000” & “driver disable routine address uc0”: This is the CRAM address
of the first instruction of the interrupt routine to be executed by uc0_when a disabled driver or cksys missing exception is raised.
• driver_disable_routine_address_uc1. The complete address is “0000” & “driver disable routine address uc1”: This is the CRAM address
of the first instruction of the interrupt routine to be executed by uc1_when a disabled driver or cksys missing exception is raised.
The following events can trigger this interrupt (all configurable):
• DrvEn pin going low
• UV_VCCP
• UV_VCC5
• UV_VBOOST
• cksys missing
• Overtemperature
8.3.2.14
Software interrupt routine address register
Table 72. Sw_interrupt_routine_addr (10Eh, 12Eh, 14Eh)
Bit
Name
15
14
13
12
sw_irq_fall sw_irq_risi sw_irq_falli sw_irq_risi
ing_edge_ ng_edge_ ng_edge_ ng_edge_
start_uc1 start_uc1 start_uc0 start_uc0
11
10
9
8
7
6
5
4
3
2
1
0
software_interrupt_routine_address_uc1
software_interrupt_routine_address_uc0
R/W
r/w
r/w
r/w
r/w
r/w
r/w
Lock
yes
yes
yes
yes
yes
yes
Reset
0
0
0
0
000000
000000
• software_interrupt_routine_address_uc0. The complete address is “0000” & “software interrupt routine address uc0”: This is the CRAM
address of the first instruction of the interrupt routine to be executed by uc0_when a software interrupt is requested.
• software_interrupt_routine_address_uc1. The complete address is “0000” & “software interrupt routine address uc1”: This is the CRAM
address of the first instruction of the interrupt routine to be executed by uc1_when a software interrupt is requested.
• sw_irq_rising_edge_start_uc0. When this bit is set to '1', the software interrupt 0 is generated towards microcore 0 if a rising edge is
detected on the gen_start signal. When set to '0', no software interrupt is required.
• sw_irq_falling_edge_start_uc0. When this bit is set to '1', the software interrupt 0 is generated towards microcore 0 if a falling edge is
detected on the gen_start signal. When set to '0', no software interrupt is required.
• sw_irq_rising_edge_start_uc1. When this bit is set to '1', the software interrupt 1 is generated towards microcore 1 if a rising edge is
detected on the gen_start signal. When set to '0', no software interrupt is required.
• sw_irq_falling_edge_start_uc1. When this bit is set to '1', the software interrupt 1 is generated towards microcore 1 if a falling edge is
detected on the gen_start signal. When set to '0', no software interrupt is required.
PT2000
95
NXP Semiconductors
8.3.2.15
Microcore0 interrupt status register
This 13-bit register stores the information about the interrupt currently being served by uc0. If no interrupt is being served, this register is
cleared.
Table 73. uc0_irq_status (10Fh, 12Fh, 14Fh)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
Name
Reserved
interrupt_ro
utine_in_pro
gress
irq_source
iret_address
R/W
-
r
r
r
Lock
-
no
no
no
Reset
00
0
000
1111111111
3
2
1
0
• Interrupt_routine_in_progress: '1' when an interrupt is being served.
• Irq_source:
• “000”: serving start rising edge interrupt
• “001”: serving driver disable interrupt request
• “010”: serving automatic diagnostics interrupt request
• “011”: serving start falling edge interrupt
• “100”: serving software interrupt request 0
• “101”: serving software interrupt request 1
• “110”: serving software interrupt request 2
• “111”: serving software interrupt request 3
• Iret_address: the value of the return address after the interrupt is served.
The return address after an interrupt is always the address where the code execution would continue if no interrupt had occurred. For wait
and conditional jump instructions, the address is defined considering the status of the feedback at the moment the interrupt request took
place.
8.3.2.16
Microcore1 interrupt status register
This 13-bit register stores the information about the interrupt currently being served by uc1. If no interrupt is being served, this register is
cleared.
Table 74. uc1_irq_status (110h, 130h, 150h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
Name
Reserved
interrupt_ro
utine_in_pro
gress
irq_source
iret_address
R/W
-
r
r
r
Lock
-
no
no
no
Reset
00
0
000
1111111111
3
2
1
0
• Interrupt_routine_in_progress: '1' when an interrupt is being served.
• Irq_source:
• “000”: serving start rising edge interrupt
• “001”: serving driver disable interrupt request
• “010”: serving automatic diagnostics interrupt request
• “011”: serving start falling edge interrupt
• “100”: serving software interrupt request 0
• “101”: serving software interrupt request 1
• “110”: serving software interrupt request 2
• “111”: serving software interrupt request 3
• Iret_address: the value of the return address after the interrupt is served.
PT2000
NXP Semiconductors
96
The return address after an interrupt is always the address where the code execution would continue if no interrupt had occurred. For wait
and conditional jump instructions, the address is defined considering the status of the feedback at the moment the interrupt request took
place.
8.3.2.17
Counter 3 and 4 prescaler register
Table 75. Counter_34_prescaler (111h, 131h, 151h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
Name
counter_4_per_uc1
counter_3_per_uc1
counter_4_per_uc0
counter_3_per_uc0
R/W
r/w
r/w
r/w
r/w
Lock
yes
yes
yes
yes
Reset
0000
0000
0000
0000
0
The counter 3 and 4 of both microcores uses a clock whose period can be programmed to be a multiple of the ck period. Note that the
actual ratio is according to Table 76, Counter prescaler.
Example:
cksys set to 24 MHz (default) with ck_per = 3, resulting with ck at 6.0 MHz
counter_4_per_uc1 = 0010b -> prescaler of 3
counter4_freq = ck /counter_Y_per_ucx = 6.0 MHz /3 = 2.0 MHz
Table 76. Counter prescaler
counter_3/4_per_ucx
Prescaler
0000
1
0001
2
0010
3
0011
4
0100
5
0101
6
0110
7
0111
8
1000
9
1001
10
1010
11
1011
12
1100
13
1101
14
1110
15
1111
16
PT2000
97
NXP Semiconductors
8.3.2.18
DAC Rxtx configuration register
Each microcore can only access four out of six current measurement channel DACs via the internal address map. In addition, either the
two special DACs of current measurement channel five or six can be used. The two DACs linked to their own channel can always be
addressed via sssc and ossc. In addition, the two DACs of one other channel can be addressed via the ssoc and osoc parameter. It can
be decided by register bits or microcode instruction slocdac for each microcore, which of the two other channels (next channel or previous
channel), DACs are accessible and if DACs H and NEG of channel five or six are accessible.
Only one microcore can be addressed at the same time in the channel communication register (rxtx register in the memory map). This
can be decided by register bits or microcode instruction sl56dac.
Table 77. Dac_rxtx_cr_config (112h, 132h, 152h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
oc_dac oc_dac CR_sh CR_sh
dac56_ dac56_
_sel_uc _sel_uc ared_u ared_u
sel_uc1 sel_uc0
1
0
c1
c0
Name
Reserved
rxtx_link_sel_uc1
rxtx_link_sel_uc0
Reserved
R/W
-
r/w
r/w
-
r/w
r/w
r/w
r/w
r/w
r/w
Lock
-
no
no
-
no
no
no
no
yes
yes
Reset
00
000
000
00
0
0
0
0
0
0
• CR_shared_uc0: if set to '0', all 16 of the bits of the control register uc0_are used as control bits. If set to '1', the 8 MSBs of the control
register (control register shared) are used as status bits.
• CR_shared_uc1: if set to '0', all 16 of the bits of the control register uc1_are used as control bits. If set to '1', the 8 MSBs of the control
register (control register shared) are used as status bits.
• oc_dac_sel_uc0: selects the other dac for microcore 0.
• ‘0', channel 1: ssoc refers to dac3, osoc refers to dac4 (next channel = 2)
• ‘0', channel 2: ssoc refers to dac5, osoc refers to dac6 (next channel = 3)
• ‘0', channel 3: ssoc refers to dac1, osoc refers to dac2 (next channel = 1)
• ‘1', channel 1: ssoc refers to dac5, osoc refers to dac6 (prev. channel = 3)
• ‘1', channel 2: ssoc refers to dac1, osoc refers to dac2 (prev. channel = 1)
• ‘1', channel 3: ssoc refers to dac3, osoc refers to dac4 (prev. channel = 2)
• oc_dac_sel_uc1: selects the other dac for microcore 1.
• '0', channel 1: ssoc refers to dac4, osoc refers to dac3 (next channel = 2)
• '0', channel 2: ssoc refers to dac6, osoc refers to dac5 (next channel = 3)
• '0', channel 3: ssoc refers to dac2, osoc refers to dac1 (next channel = 1)
• '1', channel 1: ssoc refers to dac6, osoc refers to dac5 (prev. channel = 3)
• '1', channel 2: ssoc refers to dac2, osoc refers to dac1 (prev. channel = 1)
• '1', channel 3: ssoc refers to dac4, osoc refers to dac3 (prev. channel = 2)
• dac56_sel_ucX: selects the dac5/6 for microcore X.
• '0': dac56h56n refers to dac5
• '1': dac56h56n refers to dac6
Table 78. Other dac configuration
Microcore
dac sssc
dac ossc
uc0, channel 1
dac1
uc1, channel 1
oc_dac_sel_ucX =’0’ (next channel)
oc_dac_sel_ucX =’1’ (previous channel)
dac ssoc
dac osoc
dac ssoc
dac osoc
dac2
dac3
dac4
dac5
dac6
dac2
dac1
dac4
dac3
dac6
dac5
uc0, channel 2
dac3
dac4
dac5
dac6
dac1
dac2
uc1, channel 2
dac4
dac3
dac6
dac5
dac2
dac1
uc0, channel 3
dac5
dac6
dac1
dac2
dac3
dac4
uc1, channel 3
dac6
dac5
dac2
dac1
dac4
dac3
PT2000
NXP Semiconductors
98
• rxtx_link_sel_ucX: selects the target for the channel communication register (rxtx) in the internal memory map for microcore X (can also
be done using the 'stcrt instruction').
• '0': same uc same channel (sssc)
• '1': other uc same channel (ossc)
• '2': same uc next channel (ssnc)
• '3': other uc next channel (osnc)
• '4': sum of highest 4 bits of all rxtx registers (sumh)
• '5': sum of second highest 4 bits of all rxtx registers (suml)
• '6': same uc previous channel (sspc)
• '7': other uc previous channel (ospc)
Table 79. Rxtx register link configuration
Microcore
sssc
ossc
ssnc
osnc
sspc
ospc
uc0, channel 1
uc0Ch1
uc1Ch1
uc0Ch2
uc1Ch2
uc0Ch3
uc1Ch3
uc1, channel 1
uc1Ch1
uc0Ch1
uc1Ch2
uc0Ch2
uc1Ch3
uc0Ch3
uc0, channel 2
uc0Ch2
uc1Ch2
uc0Ch3
uc1Ch3
uc0Ch1
uc1Ch1
uc1, channel 2
uc1Ch2
uc0Ch2
uc1Ch3
uc0Ch3
uc1Ch1
uc0Ch1
uc0, channel 3
uc0Ch3
uc1Ch3
uc0Ch1
uc1Ch1
uc0Ch2
uc1Ch2
uc1, channel 3
uc1Ch3
uc0Ch3
uc1Ch1
uc0Ch1
uc1Ch2
uc0Ch2
8.3.2.19
Unlock word register
The actuation channel execution can be stopped by writing the unlock code at this SPI address. The unlock code is “1011111011101111”
(binary) or “BEEF” (hexadecimal). As this is not a register, no SPI read operations can be performed at this address.
Table 80. Unlock_word (113h, 133h, 153h)
Bit
15
14
13
12
11
10
9
8
7
Name
Unlock_word
R/W
w
Lock
no
Reset
-
6
5
4
3
2
1
0
PT2000
99
NXP Semiconductors
8.3.3
IO configuration registers
8.3.3.1
Feedback microcore sensitivities registers
These 12 registers (two for each microcore). Select the feedback to which each microcore is sensitive (e.g. configures if ucX chY is
sensitive to VDS errors on HS1).
Table 81. Fbk_sens_ucxchy_part1 (154h, 156h, 158h, 15Ah, 15Ch, 15Eh)
Bit
Name
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
Hs7_V Hs6_V Hs5_V Hs4_V Hs3_V Hs2_V Hs1_V
Hs7_V Hs6_V Hs5_V Hs4_V Hs3_V Hs2_V Hs1_V
Reserv
Reserv
src_se src_se src_se src_se src_se src_se src_se
sd_sen sd_sen sd_sen sd_sen sd_sen sd_sen sd_sen
ed
ed
ns
ns
ns
ns
ns
ns
ns
s
s
s
s
s
s
s
R/W
-
r/w
r/w
r/w
r/w
r/w
r/w
r/w
-
r/w
r/w
r/w
r/w
r/w
r/w
r/w
Lock
-
yes
yes
yes
yes
yes
yes
yes
-
yes
yes
yes
yes
yes
yes
yes
Reset
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
6
5
4
3
2
1
0
Table 82. Fbk_sens_ucxchy_part2 (155h, 157h, 159h, 15Bh, 15Dh, 15Fh)
Bit
15
14
13
12
11
10
9
8
7
Ls7_V
Ls1_V
Ls8_Vd
Ls6_Vd Ls5_Vd Ls4_Vd Ls3_Vd Ls2_Vd
ds_sen
ds_sen
s_sens
s_sens s_sens s_sens s_sens s_sens
s
s
Name
Reserved
R/W
-
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
Lock
-
yes
yes
yes
yes
yes
yes
yes
yes
Reset
00000000
0
0
0
0
0
0
0
0
8.3.3.2
Microcores output access registers
These six registers are designed to provide access rights to manage the control signals (output_command, VDS threshold, VSRC threshold,
fw auto, en_halt_x) of each output block to the required microcores. Each bit controls the access from one microcore to manage the control
signals of an output: if the value is set to 1, the microcore can drive the control signals (output_command, VDS threshold, VSRC threshold,
fw auto, en_halt_x), otherwise access is denied.
Table 83. Out_acc_ucx_chy (160h, 161h, 162h, 163h, 164h, 165h)
Bit
Name
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
Acc_uc Acc_uc Acc_uc Acc_uc Acc_uc Acc_uc Acc_uc Acc_uc
Acc_uc Acc_uc Acc_uc Acc_uc Acc_uc Acc_uc Acc_uc
Reserv
X_chY X_chY X_chY X_chY X_chY X_chY X_chY X_chY
X_chY X_chY X_chY X_chY X_chY X_chY X_chY
ed
_ls8
_ls7
_ls6
_ls5
_ls4
_ls3
_ls2
_ls1
_hs7
_hs6
_hs5
_hs4
_hs3
_hs2
_hs1
R/W
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
-
r/w
r/w
r/w
r/w
r/w
r/w
r/w
Lock
yes
yes
yes
yes
yes
yes
yes
yes
-
yes
yes
yes
yes
yes
yes
yes
Reset
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
The requests coming from the microcores are not continuous; instead the microcores perform a request each time a change to a control
signal (output_command, VDS threshold, VSRC threshold, fw auto, en_halt_x) is required. If multiple microcores have access to the same
output block, as a shared resource, this block is able to handle the collision: if more than one microcore wants to change one of the control
signals in the same ck cycle, priorities are used as defined in Table 84, Out_acc_ucxchy collision handling.
If one of the microcores which have access to a pre-driver not locked, the other microcore can switch on the pre-driver for only one ck
cycle maximum. After one ck cycle the output is switched off again, because this request comes from the disabled microcore. This is a
safety feature of the device. If requests to change a control signal are received from different microcores (assuming both have access
rights) in different ck cycles, all the requested changes are applied in sequence.
PT2000
NXP Semiconductors
100
Table 84. Out_acc_ucxchy collision handling
8.3.3.3
Microcore
Priority
uc0-ch1
1 (highest)
uc1-ch1
2
uc0-ch2
3
uc1-ch2
4
uc0-ch3
5
uc1-ch3
6 (lowest)
Microcore current sense access registers
This register is designed to provide access rights to manage the control signals (DAC value, Opamp gain, Ofscomp request) of each
current measure block to the required microcores. Each bit controls the access from one microcore to manage the control signals of a
current measure block: if the value is set to 1, the microcore can drive those input signals, otherwise access is denied.
The pins of the current measurement channel 4 are multiplexed with digital IO pins. The current measurement function is activated via the
flags_source (refer to Table 145, Flag_source (1A3h)) and flags_direction register (refer to Table 138, Flag_direction (1A1h)). Current
measure blocks 5 and 6 are different, as it requires 3 DAC values instead of just one as in the others. The “acc ucX chY curr 5/6L” bits
grants access to all the control signals (DAC value 5/6L, ofscmp request, opamp gain) save for the DAC values 5/6H and 5/6Neg, which
are controlled by the “acc ucX chY curr 5/6H 5/6Neg” bits.
Table 85. Cur_block_access_part1 channel1 (166h)
Bit
Name
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
acc_uc
acc_uc
acc_uc
acc_uc
acc_uc
acc_uc acc_uc acc_uc acc_uc acc_uc
acc_uc
acc_uc acc_uc acc_uc acc_uc acc_uc
1_ch1_
1_ch1_
0_ch1_
0_ch1_
1_ch1_
1_ch1_ 1_ch1_ 1_ch1_ 1_ch1_ 1_ch1_
0_ch1_
0_ch1_ 0_ch1_ 0_ch1_ 0_ch1_ 0_ch1_
curr6H
curr5H
curr6H
curr5H
curr6L
curr5L curr4
curr3
curr2
curr1
curr6L
curr5L curr4
curr3
curr2
curr1
_6Neg
_5Neg
_6Neg
_5Neg
R/W
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
Lock
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
Reset
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
9
8
7
6
5
4
3
2
1
0
Table 86. Cur_block_access_part2 channel2 (167h)
Bit
Name
15
14
13
12
11
10
acc_uc
acc_uc
acc_uc
acc_uc
acc_uc
acc_uc acc_uc acc_uc acc_uc acc_uc
acc_uc
acc_uc acc_uc acc_uc acc_uc acc_uc
1_ch2_
1_ch2_
0_ch2_
0_ch2_
1_ch2_
1_ch2_ 1_ch2_ 1_ch2_ 1_ch2_ 1_ch2_
0_ch2_
0_ch2_ 0_ch2_ 0_ch2_ 0_ch2_ 0_ch2_
curr6H
curr5H
curr6H
curr5H
curr6L
curr5L curr4
curr3
curr2
curr1
curr6L
curr5L curr4
curr3
curr2
curr1
_6Neg
_5Neg
_6Neg
_5Neg
R/W
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
Lock
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
Reset
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
PT2000
101
NXP Semiconductors
Table 87. Cur_block_access_part3 channel3 (168h)
Bit
Name
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
acc_uc
acc_uc
acc_uc
acc_uc
acc_uc
acc_uc acc_uc acc_uc acc_uc acc_uc
acc_uc
acc_uc acc_uc acc_uc acc_uc acc_uc
1_ch3_
1_ch3_
0_ch3_
0_ch3_
1_ch3_
1_ch3_ 1_ch3_ 1_ch3_ 1_ch3_ 1_ch3_
0_ch3_
0_ch3_ 0_ch3_ 0_ch3_ 0_ch3_ 0_ch3_
curr6H
curr5H
curr6H
curr5H
curr6L
curr5L curr4
curr3
curr2
curr1
curr6L
curr5L curr4
curr3
curr2
curr1
_6Neg
_5Neg
_6Neg
_5Neg
R/W
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
Lock
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
Reset
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
The requests coming from the microcores are not continuous, but they perform a request each time a change to a control signal (Dac,
opamp gain, ofscmp request) is required. If multiple microcores have access to the same current measure block, as a shared resource,
this block is able to handle the collision: if more than one microcore wants to change one of the control signals in the same moment, only
one of the requested values is applied. If requests to change a control signal are received from different microcores (assuming both have
access rights) in different ck cycles, all the requested changes are applied in sequence.
8.3.3.4
Freewheeling link register
Due to some HS pre-driver having two possible fw slaves, there is the need to select which of the links is affected by the stfw instruction
(refer to programming guide for more details on this instruction). This configuration is done in the fw_link register.
Table 88. Fw_link (169h)
Bit
Name
•
•
•
•
•
•
•
•
•
•
•
•
15
14
Reserve Flag3_f
d
w_link
13
12
11
10
9
Flag2_f
w_link
Flag1_f
w_link
Flag0_f
w_link
Reserved
8
7
6
5
4
3
2
1
0
Hs7_f Reserv Ls7_fw Ls6_fw Ls5_fw Ls4_fw Ls3_fw Ls2_fw Ls1_fw
w_link
ed
_link
_link
_link
_link
_link
_link
_link
R/W
-
r/w
r/w
r/w
r/w
-
r/w
-
r/w
r/w
r/w
r/w
r/w
r/w
r/w
Lock
-
yes
yes
yes
yes
-
yes
-
yes
yes
yes
yes
yes
yes
yes
Reset
0
0
0
0
0
00
0
0
0
0
0
0
0
0
0
Ls1_fw_link: if set, the Ls1 is driven as a fw relative to Hs1, when activated via stfw instruction.
Ls2_fw_link: if set, the Ls2 is driven as a fw relative to Hs2, when activated via stfw instruction.
Ls3_fw_link: if set, the Ls3 is driven as a fw relative to Hs3, when activated via stfw instruction.
Ls4_fw_link: if set, the Ls4 is driven as a fw relative to Hs4, when activated via stfw instruction.
Ls5_fw_link: if set, the Ls5 is driven as a fw relative to Hs5, when activated via stfw instruction.
Ls6_fw_link: if set, the Ls6 is driven as a fw relative to Hs6, when activated via stfw instruction.
Ls7_fw_link: if set, the Ls7 is driven as a fw relative to Hs7, when activated via stfw instruction.
Hs7_fw_link: if set, the Hs7 is driven as a fw relative to Hs1, when activated via stfw instruction.
Flag0_fw_link: if set, the Flag0 is driven as a fw relative to Hs4, when activated via stfw instruction.
Flag1_fw_link: if set, the Flag1 is driven as a fw relative to Hs5, when activated via stfw instruction.
Flag2_fw_link: if set, the Flag2 is driven as a fw relative to Hs6, when activated via stfw instruction.
Flag3_fw_link: if set, the Flag3 is driven as a fw relative to Hs7, when activated via stfw instruction.
PT2000
NXP Semiconductors
102
Table 89. Freewheeling link register
Freewheeling pre-driver output
Related pre-driver high-side
LS1
HS1
LS2
HS2
LS3
HS3
LS4
HS4
LS5
HS5
LS6
HS6
LS7
HS7
Flag0
HS4
Flag1
HS5
Flag2
HS6
Flag3
HS7
8.3.3.5
Freewheeling external request configuration register
After the freewheeling configuration (see Table 89, Freewheeling link register) it is possible to activate automatic freewheeling by writing
the corresponding bit of this register even when the microcode is not running. This can also be enabled by the stfw instruction.
Table 90. Fw_external_request (16ah)
Bit
•
•
•
•
•
•
•
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
Name
Reserved
Hs7_f
w_en
Hs6_f
w_en
Hs5_f
w_en
Hs4_f
w_en
Hs3_f
w_en
Hs2_f
w_en
Hs1_f
w_en
R/W
-
r/w
r/w
r/w
r/w
r/w
r/w
r/w
Lock
-
yes
yes
yes
yes
yes
yes
yes
Reset
000000000
0
0
0
0
0
0
0
Hs1_fw_en: if set, the fw relative to Hs1 is activated, otherwise the status is defined by the microcore request (see stfw instruction).
Hs2_fw_en: if set, the fw relative to Hs2 is activated, otherwise the status is defined by the microcore request (see stfw instruction).
Hs3_fw_en: if set, the fw relative to Hs3 is activated, otherwise the status is defined by the microcore request (see stfw instruction).
Hs4_fw_en: if set, the fw relative to Hs4 is activated, otherwise the status is defined by the microcore request (see stfw instruction).
Hs5_fw_en: if set, the fw relative to Hs5 is activated, otherwise the status is defined by the microcore request (see stfw instruction).
Hs6_fw_en: if set, the fw relative to Hs6 is activated, otherwise the status is defined by the microcore request (see stfw instruction).
Hs7_fw_en: if set, the fw relative to Hs7 is activated, otherwise the status is defined by the microcore request (see stfw instruction).
Figure 32. Automatic freewheeling example
PT2000
103
NXP Semiconductors
8.3.3.6
VDS and VSRC threshold selection
Each comparator threshold is expressed on 4 bits. These registers can be written through the SPI. The microcores can change the value
of each field at runtime, provided they have the access right to control the related output (refer to Table 83, Out_acc_ucx_chy (160h, 161h,
162h, 163h, 164h, 165h)).
Table 91. Vds_threshold_hs_Part1 (16Bh)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
Name
Vds_thr_Hs4
Vds_thr_Hs3
Vds_thr_Hs2
Vds_thr_Hs1
R/W
r/w
r/w
r/w
r/w
Lock
no
no
no
no
Reset
0000
0000
0000
0000
0
Table 92. Vds_threshold_hs_Part2 (16Ch)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
Name
Reserved
Vds_thr_Hs7
Vds_thr_Hs6
Vds_thr_Hs5
R/W
-
r/w
r/w
r/w
Lock
-
no
no
no
Reset
0000
0000
0000
0000
0
Table 93. Vsrc_threshold_hs_Part1 (16Dh)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
Name
Vsrc_thr_Hs4
Vsrc_thr_Hs3
Vsrc_thr_Hs2
Vsrc_thr_Hs1
R/W
r/w
r/w
r/w
r/w
Lock
no
no
no
no
Reset
0000
0000
0000
0000
0
Table 94. Vsrc_threshold_hs_Part2 (16Eh)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
Name
Reserved
Vsrc_thr_Hs7
Vsrc_thr_Hs6
Vsrc_thr_Hs5
R/W
-
r/w
r/w
r/w
Lock
-
no
no
no
Reset
0000
0000
0000
0000
0
Note that when reading back this register, what is actually read from the SPI is not the content of the register, but the real configuration
of the thresholds, in particular the HSx Vsrc thresholds. (see See Bootstrap switch control on page 58).
PT2000
NXP Semiconductors
104
Table 95. Vsrc_threshold_hs and vds_threshold_hs value
hsx_vds/src_threshold(3:0)
Threshold voltage HS VDS / HS VSRC (V)
0000
0.00
1001
0.10
1010
0.20
1011
0.30
1100
0.40
0001
0.50
0010
1.0
0011
1.5
0100
2.0
0101
2.5
0110
3.0
0111
3.5
Table 96. Vds_threshold_ls_Part 1 (16Fh)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
Name
Vds thr Ls4
Vds thr Ls3
Vds thr Ls2
Vds thr Ls1
R/W
r/w
r/w
r/w
r/w
Lock
no
no
no
no
Reset
0000
0000
0000
0000
0
Table 97. Vds_threshold_ls_Part 2 (170h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
Name
Vds thr Ls8
Vds thr Ls7
Vds thr Ls6
Vds thr Ls5
R/W
r/w
r/w
r/w
r/w
Lock
no
no
no
no
Reset
0000
0000
0000
0000
0
PT2000
105
NXP Semiconductors
Table 98. Vds_threshold_ls value
8.3.3.7
lsx_vds _threshold(3:0)
Threshold Voltage LS VDS (V)
0000
0.00
1001
0.10
1010
0.20
1011
0.30
1100
0.40
0001
0.50
0010
1.0
0011
1.5
0100
2.0
0101
2.5
0110
3.0
0111
3.5
Slew rate high-side and low-side selection register
These registers store the slew rate configuration value for each output driver. The microcores can change the value of each field at
runtime, provided they have the access right to control the related output (refer to Table 83, Out_acc_ucx_chy (160h, 161h, 162h, 163h,
164h, 165h)). Each output has the same slew rate for the rising and falling edge, save for the low-side 7 and 8.
Table 99. Hs_slewrate (171h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
Name
Reserved
slewrate_hs7
slewrate_hs6
slewrate_hs5
slewrate_hs4
slewrate_hs3
slewrate_hs2
slewrate_hs1
R/W
-
r/w
r/w
r/w
r/w
r/w
r/w
r/w
Lock
-
no
no
no
no
no
no
no
Reset
00
00
00
00
00
00
00
00
Refer to Table 22 for the slew rates values.
Table 100. Ls_slewrate_Part 1 (172h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
Name
Reserved
slewrate_ls6
slewrate_ls5
slewrate_ls4
slewrate_ls3
slewrate_ls2
slewrate_ls1
R/W
-
r/w
r/w
r/w
r/w
r/w
r/w
Lock
-
no
no
no
no
no
no
Reset
0000
00
00
00
00
00
00
Refer to Table 25 for slew rates values.
PT2000
NXP Semiconductors
106
Table 101. Ls_slewrate_Part 2 (173h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
slewrate_LS8_ri slewrate_LS8_fa slewrate_LS7_ri slewrate_LS7_f
sing
lling
sing
alling
Name
Reserved
R/W
-
r/w
r/w
r/w
r/w
Lock
-
no
no
no
no
Reset
00000000
00
00
00
00
Refer to Table 28 and Table 29 for slew rates values.
8.3.3.8
Offset compensation results registers
It is possible to measure the offset of each current measure block, including opamp, DAC and comparator; for current measure block 5
and 6, only comparator 5L and 6L, the relative opamp, and the DAC 5L and 6L are considered. The measured offset is automatically
compensated during normal operation. The compensation must be enabled by the microcores (when the input current to the current
measurement block is 0) with the “stoc” instruction (refer to programming user guide).
The offset can be read through the SPI registers. It is also possible to change the value compensated by writing these registers. If the
offset compensation is requested by microcores, it starts from the precedent result (or from the data forced through the SPI). As the offset
can be both positive and negative, all the values in these registers are represented as two’s complement.
Table 102. Offset_compensation12 (174h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
Name
Reserved
Sign_offset_cur2
Offset_cur2
Reserved
Sign_offset_cur1
Offset_cur1
R/W
-
r/w
r/w
-
r/w
r/w
Lock
-
no
no
-
no
no
Reset
00
0
00000
00
0
00000
1
0
Table 103. Offset_compensation34 (175h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
Name
Reserved
Sign_offset_cur4
Offset_cur4
Reserved
Sign_offset_cur3
Offset_cur3
R/W
-
r/w
r/w
-
r/w
r/w
Lock
-
no
no
-
no
no
Reset
00
0
00000
00
0
00000
1
0
1
0
Table 104. Offset_compensation56 (176h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
Name
Reserved
Sign_offset_cur6L
Offset_cur6L
Reserved
Sign_offset_cur5L
Offset_cur5L
R/W
-
r/w
r/w
-
r/w
r/w
Lock
-
no
no
-
no
no
Reset
00
0
00000
00
0
00000
The offset values are stored in registers using the two’s complement notation. The values can range from -32 to 31. The value is then
converted to sign-module notation before being transferred to the analog section.
PT2000
107
NXP Semiconductors
8.3.3.9
ADC conversion results registers
It is possible to use the current measure block to perform an ADC conversion. A conversion is performed when requested by a microcore
(reference Programming Guide and Instruction Set) with the correct access rights (refer to Table 83, Out_acc_ucx_chy (160h, 161h, 162h,
163h, 164h, 165h)). The DAC5L and 6L is used when performing an ADC conversion using current measurement channel 5 and 6.
A signal path via the OAx multiplexer, a track and hold circuit, the OAx amplifier, and the DACfb multiplexer is used for ADC mode. While
using ADC mode on current measurement channel 1 and 3, the OA1 output is blocked. While using ADC mode on channel 2 or 4, the
OA2 output is blocked, and while using ADC mode on channel 5 or 6, the OA3 output is blocked (see Figure 20). The OAx multiplexer
must be set to the right input and the OAx output must be enabled manually. The OAx amplifier is set to a gain of 1.0 automatically. It is
not possible to do ADC conversion at the same time at channel 1 and 3, on channel 2 and 4, or on channel 5 and 6.
The conversion takes 11 ck_ofscmp clock cycles (refer to Table 146, Ck_ofscmp_Prescaler(1A4h)). 4 ck_ofscmp clock cycles are needed
for the first bit, because the OAx amplifier output has to settle first after changing the gain. After the first bit 1, a clock cycle is needed for
every of the 7 following bits. The PT2000 has a “track and hold” circuit for the ADC mode. The switch of the track and hold circuit is opened
before the ADC conversion starts and is closed again when ADC mode is switched off. The result of the conversion is stored in the
corresponding adc register after the conversion is finished. It is available to the microcore as long as the ADC mode is on and available
via the SPI register until the next ADC conversion is started.
To trigger a new conversion, switch off the ADC mode and switch it on again, note that a minimum of 1 ck_ofscmp clock cycle is needed
between “stadc on” and “stadc off” (reference Programming Guide and Instruction Set). The result can be read via the SPI registers
(Table 105, Adc12_results (177h), Table 106, Adc34_results (178h), and Table 107, Adc56_results (179h)).
Table 105. Adc12_results (177h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
Name
conversion_2_value
conversion_1_value
R/W
r
r
Lock
no
no
Reset
10000000
10000000
2
1
0
2
1
0
2
1
0
Table 106. Adc34_results (178h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
Name
conversion_4_value
conversion_3_value
R/W
r
r
Lock
no
no
Reset
10000000
10000000
Table 107. Adc56_results (179h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
Name
conversion_6_value
conversion_5_value
R/W
r
r
Lock
no
no
Reset
10000000
10000000
PT2000
NXP Semiconductors
108
8.3.3.10
Current filters configuration registers
The 10 current feedback are filtered before feeding them to the microcores. The filters of all the current feedback are independent.
Table 108. Current_filter12 (17Ah)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
Name
Filter_Ty
pe2
Reserved
Filter_length_2
Filter_Ty
pe1
Reserved
Filter_length_1
R/W
r/w
-
r/w
r/w
-
r/w
Lock
yes
-
yes
yes
-
yes
Reset
0
00
00001
0
00
00001
1
0
1
0
Table 109. Current_filter34 (17Bh)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
Name
Filter_Typ
e4
Reserved
Filter_length_4
Filter_Ty
pe3
Reserved
Filter_length_3
R/W
r/w
-
r/w
r/w
-
r/w
Lock
yes
-
yes
yes
-
yes
Reset
0
00
00001
0
00
00001
Table 110. Current_filter5l5h (17Ch)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
Name
Filter_Type5
H
Reserved
Filter_length_5H
Filter_Typ
e5L
Reserved
Filter_length_5L
R/W
r/w
-
r/w
r/w
-
r/w
Lock
yes
-
yes
yes
-
yes
Reset
0
00
00001
0
00
00001
0
Table 111. Current_filter6l6h (17Dh)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
Name
Filter_Type6
H
Reserved
Filter_length_6H
Filter_Typ
e6L
Reserved
Filter_length_6L
R/W
r/w
-
r/w
r/w
-
r/w
Lock
yes
-
yes
yes
-
yes
Reset
0
00
00001
0
00
00001
0
Table 112. Current_filter5neg6neg (17Eh)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
Name
Filter
Type
6Neg
Reserved
Filter length 6Neg
Filter
Type
5Neg
Reserved
Filter length 5Neg
R/W
r/w
-
r/w
r/w
-
r/w
Lock
yes
-
yes
yes
-
yes
Reset
0
00
00001
0
00
00001
0
PT2000
109
NXP Semiconductors
• Filter_type. This 1 bit parameter selects the type of filter used for the relative current feedback:
• if 0 - Any different sample resets the filter counter
• if 1 - Any different sample decreases the filter counter
• Filter_lenght. This 5-bit parameter set the filtering time for the current feedback signal.
tFTN = tCK x (Filter_length + 1)
8.3.3.11
Boost DAC configuration registers
This block contains the threshold for the boost DAC. This register can be set either from the SPI interface or from a microcore. It is possible
to limit the microcore access to the boost_dac register by setting access rights. End of line offset compensation is provided for the boost
monitoring, requiring no microcode operation.
Table 113. Boost_dac (17Fh)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
Name
Reserved
boost_threshold
R/W
-
r/w
Lock
-
no
Reset
00000000
00000000
2
1
0
2
1
0
Table 114. Boost_dac_access (180h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
uc1_ch uc0_ch uc1_ch uc0_ch uc1_ch uc0_ch
3 acc
3 acc
2 acc
2 acc
1 acc
1 acc
Name
Reserved
R/W
-
r/w
r/w
r/w
r/w
r/w
r/w
Lock
-
yes
yes
yes
yes
yes
yes
Reset
0000000000
0
0
0
0
0
0
5
4
3
2
1
0
• Boost_threshold. This 8-bit parameter is the threshold used for boost voltage monitoring.
• ucX chY acc. This 1-bit parameter (active high) grants access to the dac_boost register.
Table 115. Boost_filter (181h)
Bit
15
14
13
12
11
10
9
8
7
6
Name
Reserved
filter_ty
pe
Boost_fbk_filter
R/W
-
r/w
r/w
Lock
-
yes
yes
Reset
000
0
000000000001
• Filter_type: This 1 bit parameter selects the type of filter used:
• if 0 - Any different sample resets the filter counter
• if 1 - Any different sample decreases the filter counter
• Boost_fbk_filter: This 12-bit parameter sets the filtering time for the output of the vboost comparator.
The filtering time is: tFTN = tCK x (x_filter + 1)
PT2000
NXP Semiconductors
110
8.3.3.12
VDS low-side 7/8 configuration register
These two registers are used for configuring the timeout for VDS monitoring of DC/DC resonant converter. If VBOOST drops below 2 x VBAT,
VDS would not fall below the VDS threshold of 2.5 V, which would not activate the MOSFET in resonant DC/DC converter mode again.
Therefore this timeout is required to force the MOSFET to be switched on. The access for this register is only via the SPI.
Table 116. Vds7_dcdc_config (182h) & Vds8_dcdc_config (183h)
Bit
15
14
13
12
11
10
9
8
lsx_vds_hig Cur_dcdc
hspeed_en x_fbk_sel
7
6
5
4
3
2
vdsx_
to_en
vdsx_dcdc_timeout
r/w
r/w
r/w
no
no
no
no
0
0
0
00000000
Name
dcdcx mode
Reserved
R/W
r
-
r/w
Lock
-
-
Reset
00
000
1
0
• Vdsx_dcdc timeout: This 8 bit parameter defines the time duration of the DC/DC converter (VDS7/8 monitoring Ls7/8). It is needed only
if the async_vds mode is used. Timeout is used if the VDS threshold 2.5 V is not reached.
• The timeout is: tFTN = tCK x (x_filter + 1)
• Vdsx_to_en: VDS7/8 timeout is enabled. MOSFET is activated automatically when the timeout has been exceeded
• Cur_dcdcx_fbk_sel for async_vds and async mode:
• For LS7:
• 0: selects cur5h_dcdc feedback signal
• 1: selects cur6h_dcdc feedback signal
• For LS8:
• 0: selects cur6h_dcdc feedback signal
• 1: selects cur5h_dcdc feedback signal
• Lsx_vds_highspeed_en: Enable high speed VDS comparator for DC/DC control
• 0: standard low speed VDS monitor enabled
• 1: high speed VDS monitor for DC/DC control enabled
• dcdcx_mode. This bits shows when the automatic DC/DC control feature for LS7/8 is enabled. Refer to See DC/DC converter control
(LS7/8) on page 61 for the behavior of LS7/8 during this mode.
Table 117. DC/DC mode
DC/DC Mode
00, 10
Description
Sync mode enabled. LS7/8 controlled by microcore command
01
Async mode enabled with two current thresholds.
11
Async mode enabled with one current threshold and VDS monitor.
8.3.3.13
Battery monitoring results
This block contains the result of the batt DAC plus comparator in ADC mode. This register can be read either from the SPI interface or
from a microcore.
Table 118. batt_results (184h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
Name
Reserved
batt_result
R/W
-
r
Lock
-
no
Reset
00000000
000000
2
1
0
The ofs_comp_prescaler is used to define the step length of the ADC conversion. The ADC mode is running continuously. One conversion
needs 7 cycles.
PT2000
111
NXP Semiconductors
8.3.3.14
DAC 1-6 values registers
Other than from microcores, it is possible to set the DAC for the current measure blocks by writing to these registers.
Table 119. Dac12_value (185h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
Name
DAC 2 value
DAC 1 value
R/W
r/w
r/w
Lock
no
no
Reset
00000000
00000000
2
1
0
2
1
0
2
1
0
2
1
0
Table 120. Dac34_value (186h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
Name
DAC 4 value
DAC 3 value
R/W
r/w
r/w
Lock
no
no
Reset
00000000
00000000
Table 121. Dac5l5h_value (187h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
Name
DAC 5H value
DAC 5L value
R/W
r/w
r/w
Lock
no
no
Reset
00000000
00000000
Table 122. Dac5neg_value (188h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
Name
Reserved
DAC 5Neg value
R/W
-
r/w
Lock
-
no
Reset
000000000000
0000
Table 123. Dac6l6h_value (189h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
Name
DAC 6H value
DAC 6L value
R/W
r/w
r/w
Lock
no
no
Reset
00000000
00000000
2
1
0
PT2000
NXP Semiconductors
112
Table 124. Dac6neg_value (18Ah)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
Name
Reserved
DAC 6Neg value
R/W
-
r/w
Lock
-
no
Reset
000000000000
0000
8.3.3.15
0
Load bias configuration register
These two registers configure the biasing for each output. The microcores can change the value of each field at runtime, provided they
have the access right to control the related output (refer to Table 83, Out_acc_ucx_chy (160h, 161h, 162h, 163h, 164h, 165h)). High-side
2 and high-side 4 have two biasing structures, one identical (hsx_en_pu) to the other high-sides and one stronger (hsx_en_s_pu).
Note that when reading back this register, what is actually read from the SPI is not the content of the register, but the real configuration of
the HS and LS bias, therefore after the masks imposed by the init phase of the bootstrap switch (see See Bootstrap switch control on page
58). Low-side bias is enabled by default, and they stay ON even after boostrap charge.
Table 125. Hs_bias_config (18Bh)
Bit
15
14
13
12
11
10
9
hs4_en Re-ser- hs2_en
s_pu
ved
s_pu
8
7
Reserved
6
5
4
3
2
1
0
hs7_en hs6_en hs5_en hs4_en hs3_en hs2_en hs1_en
_pu
_pu
_pu
_pu
_pu
_pu
_pu
Name
Reserved
R/W
-
r/w
-
r/w
-
r/w
r/w
r/w
r/w
r/w
r/w
r/w
Lock
-
no
-
no
-
no
no
no
no
no
no
no
Reset
0000
0
0
0
00
0
0
0
0
0
0
0
11
10
9
7
6
5
4
3
2
1
0
Table 126. Ls_bias_config (18Ch)
Bit
15
14
13
12
8
Name
Reserved
ls8_en
_pd
ls7_en
_pd
ls6_en
_pd
ls5_en
_pd
ls4_en
_pd
ls3_en
_pd
ls2_en
_pd
ls1_en
_pd
R/W
-
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
Lock
-
no
no
no
no
no
no
no
no
Reset
00000000
1
1
1
1
1
1
1
1
8.3.3.16
Boostrap charged/timer status registers
This register reads the charge status of the HS bootstrap capacitors during initialization phase. (See Bootstrap switch control on page 58).
Table 127. Bootstrap_charged (18Dh)
Bit
Name
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
hs7_bs hs6_bs hs5_bs hs4_bs hs3_bs hs2_bs hs1_bs
Reserv hs7_sr hs6_sr hs5_sr hs4_sr hs3_sr hs2_sr hs1_sr Reserv
_charg _charg _charg _charg _charg _charg _charg
ed
c_1V
c_1V
c_1V
c_1V
c_1V
c_1V
c_1V
ed
ed
ed
ed
ed
ed
ed
ed
R/W
-
r
r
r
r
r
r
r
-
r
r
r
r
r
r
r
Lock
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
Reset
0
0
0
0
0
0
0
0
0
1
1
1
1
1
1
1
PT2000
113
NXP Semiconductors
Table 128. Bootstrap_timer (18Eh)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
Name
bootstrap_init_timer
Reserved
R/W
r
-
Lock
-
-
Reset
000000
0000000000
3
2
1
0
• hsx_bs_charged: when '0', the bootstrap capacitor for HSx is charged
• hsx_src_1V: when '1' it was necessary for this pre-driver to switch the VSRC threshold to 1.0 V to finish the bootstrap init
• bootstrap init timer: this shows the current value of the six MSBs of the bootstrap init timer. The value is '110100' when the timer expires
Table 129, Bootstrap_charged Bits shows the exact meaning of the bits hsx_bs_charged and hsx_src_1V.
Table 129. Bootstrap_charged Bits
hsx_bs_charged
hsx_src_1V
Description
1
0
Bootstrap capacitor not charged, bootstrap init timer not lapsed, VSRC = 0.5 V (reset value)
1
1
Bootstrap capacitor not charged, timer lapsed, VSRC = 1.0 V
0
0
Bootstrap capacitor charged, VSRC = 0.5 V when charging finished
0
1
Bootstrap capacitor charged, VSRC = 1.0 V when charging finished
The bootstrap init timer value can be used, together with the other bits of the register, to identify in detail how much time has passed since
VCCP voltage was stable and which threshold is used to detect the charge of the bootstrap capacitor.
Table 130. Bootstrap init timer
Bit value
Description
000000
VCCP voltage is not stable (undervoltage)
000001
VCCP voltage is stable since 0.68 ms (214 / 24 MHz (52)). Source HS voltage threshold used to detect bootstrap charge is 0.5 V
…
100000
…
110011
110100 (final value)
…
VCCP voltage is stable since 21.8 ms (52). Source HS voltage threshold used to detect bootstrap charge is 0.5 V
…
VCCP voltage is stable since 34.8 ms (52). Source HS voltage threshold used to detect bootstrap charge is 0.5 V
VCCP voltage is stable since at least 35.5 ms (52). Source HS voltage threshold used to detect bootstrap charge is 1.0 V.
Notes
52.
PLL factor set to 1 means 24 MHz cksys. This calculation will be different if PLL factor is set to 0.
PT2000
NXP Semiconductors
114
8.3.3.17
High-side 1-7 ground reference configuration registers
Table 131. Hsx_ls_act (18Fh - 195h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
Name
hsx ls
act dis
Reserved
R/W
r/w
-
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
Lock
yes
-
yes
yes
yes
yes
yes
yes
yes
yes
Reset
0
0000000
1
1
1
1
1
1
1
1
hsx_ls_ hsx_ls7 hsx_ls6 hsx_ls5 hsx_ls4 hsx_ls3 hsx_ls2 hsx_ls1
act_dis _act
_act
_act
_act
_act
_act
_act
These seven registers are used to configure the ground reference of the hs1 to hs7 source pins.
The hsx_ls_act signal is high if any of the LSX pins connected to the HSX source pin is switched on or if the function is disabled by the
hsx_ls_act_dis bit.
•
•
•
•
•
•
•
•
•
hsx_ls1_act: must be set to '1' if ls1 is connected to the same load as hsx.
hsx_ls2_act: must be set to '1' if ls2 is connected to the same load as hsx.
hsx_ls3_act: must be set to '1' if ls3 is connected to the same load as hsx.
hsx_ls4_act: must be set to '1' if ls4 is connected to the same load as hsx.
hsx_ls5_act: must be set to '1' if ls5 is connected to the same load as hsx.
hsx_ls6_act: must be set to '1' if ls6 is connected to the same load as hsx.
hsx_ls7_act: must be set to '1' if ls7 is connected to the same load as hsx.
hsx_ls8_act: must be set to '1' if ls8 is connected to the same load as hsx.
hsx_ls_act_dis: set this bit to disable the link between hsx and ls pre-drivers. If this bit is set the hsx_ls_act signal is forced to '0'
regardless if an ls is active or not.
8.3.3.18
DAC settling time register
This register is used to set the DAC settling time: while this time is being counted, no micro-code checks on the related current feedback
is true. This is not applicable to the VBoost Dac.
Table 132. Dac_settling_time (196h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
Name
Reserved
dac_settling_time
R/W
-
r/w
Lock
-
yes
Reset
0000000000
000000
1
0
Every time the value of related DAC register is written, the current feedback is marked as invalid for
tX = tCK x (dac_settling_time + Filter_length + 4)
The filter_length value can be set in the current filter registers (refer to See Current filters configuration registers on page 109 and See
Boost DAC configuration registers on page 110). Since filter configuration can be different for each DAC, the settling time is also different.
PT2000
115
NXP Semiconductors
8.3.3.19
Analog output (OAx) configuration register
These three registers configure the function of the three OA_OUTx pins.
Table 133. Oa_out1_config (197h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
Name
Reserved
oa1_g1
oa_sel1
oa1_gain
oa1_en
R/W
-
r/w
r/w
r/w
r/w
Lock
-
no
no
no
no
Reset
000000000
0
000
00
0
• oa1 en: when '1', the selected source is sent to the OA_OUT1 pin, otherwise it is put in high-impedance to connect all OAx pins to the
same MCU ADC.
• oa1 gain: select the gain to apply to the signal
• “00”: gain 1.33
• “01”: gain 2.0
• “10”: gain 3.0
• “11”: gain 5.33
• oa1 g1: select the gain to apply to the signal
• “0”: gain according to oa1 gain
• “1”: gain forced to 1.0
• oa_sel1: select the signal to send to the OA_OUT1 pin.
• “000”: output from current measurement block 1
• “001”: output from current measurement block 3
• “101”: 2.5 Volt
Table 134. Oa_out2_config (198h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
Name
Reserved
oa2_g1
oa_sel2
oa2_gain
oa2_en
R/W
-
r/w
r/w
r/w
r/w
Lock
-
no
no
no
no
Reset
000000000
0
000
00
0
• oa2 en: when '1' the selected source is sent to OA_OUT2.
• oa2 gain: select the gain to apply to the signal.
• “00”: gain 1.33
• “01”: gain 2.0
• “10”: gain 3.0
• “11”: gain 5.33
• oa2 g1: select the gain to apply to the signal
• “0”: gain according to oa2 gain
• “1”: gain forced to 1.0
• oa_sel2: select the signal to send to the OA_OUT2 pin.
• “000”: output from current measurement block 2
• “001”: output from current measurement block 4
• “101”: 2.5 Volt
PT2000
NXP Semiconductors
116
Table 135. Oa_out3_config (199h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
Name
Reserved
oa3_g1
oa_sel3
oa3_gain
oa3_en
R/W
-
r/w
r/w
r/w
r/w
Lock
-
no
no
no
no
Reset
000000000
0
000
00
0
• oa3 en: when '1', the selected source is sent to the OA_OUT3 pin, otherwise it is put in high-impedance to connect all OAx pins to the
same MCU ADC.
• oa3 gain: select the gain to apply to the signal
• “00”: gain 1.33
• “01”: gain 2.0
• “10”: gain 3.0
• “11”: gain 5.33
• oa3 g1: select the gain to apply to the signal.
• “0”: gain according to oa3 gain
• “1”: gain forced to 1.0
• oa_sel3: select the signal to send to the OA_OUT3 pin.
• “000”: output from current measurement block 5
• “001”: output from current measurement block 6
• “101”: 2.5 Volt
• “111”: VCCA
8.3.4
Main configuration registers
8.3.4.1
“Ck” clock prescaler configuration register
This is a 6-bit register setting the divider ratio to generate the ck clock starting from cksys (24 MHz or 12 MHz refer to Table 151,
PLL_Config (1A7h)). The ck_per register must not be changed again after the microcores are running. During operation the register should
be locked. Note that the actual divider ratio is ck = cksys/(ck_per+1). Therefore setting ck_per to “000100” sets ck = cksys/ (4+1).
Table 136. Clock_Prescaler (1A0h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
Name
Reserved
ck_per
R/W
-
r/w
Lock
-
yes
Reset
0000000000
000000
1
0
Depending on the ck_per setting, different device/channel operation modes is possible according to Table 137, Ck_per and device modes
and See Dual microcore arbiter on page 70.
PT2000
117
NXP Semiconductors
Table 137. Ck_per and device modes
microcore frequency
Clock divider at 24 MHz cksys (PLL
factor = 1)
ck_per
0
0+1=1
SPI access (r/w) to
registers and DRAM
SPI access (r/w) to
CRAM after flash
enable
Single/dual
microcore
Drive outputs from
flag pins
yes (r/w)
no
no
no
yes (r/w)
no
yes
yes
12 MHz
(53)
1
1+1=2
2
2+1=3
8.0 MHz
yes (r/w)
yes (r)
yes
yes
3
4
6.0 MHz
yes (r/w)
yes (r)
yes
yes
Notes
53.
Some limitations apply on the number of consecutive DRAM access and SPI frequency (See Dual microcore arbiter on page 70).
8.3.4.2
Flags direction configuration register
This is a 16-bit register where each bit sets the direction of the corresponding flag as shown in Table 139, Flags_source & Flags_direction
registers. The value of this register is used only for the flags which drive or can be driven by a device pin as specified in the flag_source
register.
Table 138. Flag_direction (1A1h)
Bit
15
Name
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
flag_dir flag_dir flag_dir flag_dir flag_dir flag_dir flag_dir flag_dir flag_dir flag_dir flag_dir flag_dir flag_dir flag_dir flag_dir flag_dir
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
Dbg
OA2
Irq
Start8
Start7
Start6
Start5
Start4
Start3
Start2
Start1
Flag4
Flag3
Flag2
Flag1
Flag0
R/W
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
Lock
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
Reset
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
1
Table 139. Flags_source & Flags_direction registers
flags_source(x)
flags_direction(x)
flag_bus(x) source
0
0/1
The corresponding pin is used for its non-flag function (start,_irq, analog OA2, extFWx, etc.).
Flag_bus(x) is driven by int_flags(x).
1
0
1
1 (reset value)
The corresponding pin is used as an output flag. The device pin is driven by int_flags(x).
Flag_bus(x) is driven by int_flags(x).
The corresponding pin is used as an input flag. The Flag_bus(x) is driven by the device pin.
Table 140. Flags_source & Flags_direction registers for Flag 4 and 12
flags_source flags_source flags_direction flags_direction
(12)
(4)
(12)
(4)
flag_bus (12) source
flag_bus (4) source
-
0
-
-
The pin is used for current measurement
channel VsenseN4.
The pin is used for current measurement
channel VsenseP4.
0
1
-
0
The pin is used for its non-flag function
start8.
The corresponding pin is used as an
output flag.
-
1 (reset value)
The pin is used for its non-flag function
start8.
The corresponding pin is used as an
input flag.
0 (reset value) 1 (reset value)
1
1
0
0
The corresponding pin is used as an
output flag.
The corresponding pin is used as an
output flag.
1
1
0
1
The corresponding pin is used as an input
flag.
The corresponding pin is used as an
input flag.
PT2000
NXP Semiconductors
118
Table 140. Flags_source & Flags_direction registers for Flag 4 and 12
flags_source flags_source flags_direction flags_direction
(12)
(4)
(12)
(4)
flag_bus (12) source
flag_bus (4) source
1
1
1
0
The corresponding pin is used as an input
flag.
The corresponding pin is used as an
output flag.
1
1
1
1
The corresponding pin is used as an input
flag.
The corresponding pin is used as an
input flag.
8.3.4.3
Flags polarity register
This is a 16-bit register where each bit sets the polarity of the corresponding flag as shown in Table 142, Flags_polarity. If a 1 is set, the
corresponding flag inverts. The value of this register is only used for the flags driven by or drive a device pin, as specified in the flag_source
register.
Table 141. Flag_polarity (1A2h)
Bit
Name
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
flag_po flag_po flag_po flag_po flag_po flag_po flag_po flag_po flag_po flag_po flag_po flag_po flag_po flag_po flag_po flag_po
l_15
l14
l13
l12
l11
l10
l9
l8
l7
l6
l5
l4
l3
l2
l1
l0
Dbg
OA2
Irq
Start8
Start7
Start6
Start5
Start4
Start3
Start2
Start1
Flag4
Flag3
Flag2
Flag1
Flag0
R/W
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
Lock
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
Reset
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
Table 142. Flags_polarity
flags_polarity(x)
flag_bus(x) condition
0
as it is
1
inverted
Some bits of this register are also used to set the polarity of the start pins when they are not used as flag I/O.
Table 143. Flag_polarity register (1A2h)
Bit
15
14
13
12
11
10
9
8
7
6
Name
-
-
-
R/W
-
-
-
r/w
r/w
r/w
r/w
r/w
r/w
r/w
Lock
-
-
-
yes
yes
yes
yes
yes
yes
Reset
0
0
0
0
0
0
0
0
0
5
4
3
2
1
0
-
-
-
-
-
r/w
-
-
-
-
-
yes
yes
-
-
-
-
-
0
0
0
0
0
0
0
start_p start_p start_p start_p start_p start_p start_p start_p
ol8
ol7
ol6
ol5
ol4
ol3
ol2
ol1
Table 144. Start_polarity
flags_polarity(x)
flag_bus(x) condition
0
Start active high
1
Start active Low
PT2000
119
NXP Semiconductors
8.3.4.4
Flags source register
All of the 16 flags have a configurable source. This is a 16-bit register where each bit sets the source of the corresponding flag as shown
in Table 139, Flags_source & Flags_direction registers. The flag 12 pin can even be used for three different functions (refer to Table 140,
Flags_source & Flags_direction registers for Flag 4 and 12)
Table 145. Flag_source (1A3h)
Bit
Name
15
14
13
12
11
10
9
8
7
6
5
4
3
flag_sr flag_sr flag_sr flag_sr flag_sr flag_sr flag_sr flag_sr flag_sr flag_sr flag_sr flag_sr
c15
c14
c13
c12
c11
c10
c9
c8
c7
c6
c5
c4
2
1
0
flag_sr flag_sr
c3
c2
flag_sr flag_sr
c1
c0
Dbg
OA2
Irq
Start8
Start7
Start6
Start5
Start4
Start3
Start2
Start1
Vsense
4
Flag3
Flag2
Flag1
Flag0
R/W
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
Lock
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
Reset
1
0
1
0
0
0
0
0
0
0
0
1
1
1
1
1
8.3.4.5
Offset compensation and ADC clock (ck_ofscmp) prescaler
This is an 8-bit register setting the divider ratio to generate the ck_ofscmp clock starting from cksys. This clock feeds the following blocks:
• Current measurement block (See Current measurement offset compensation on page 51)
• Battery voltage measurement (See Battery voltage monitor on page 36)
• ADC conversion (See ADC conversion results registers on page 108)
Note that the actual divider ratio is ck_ofscmp = ck_ofscmp_per + 1. Therefore setting ck_ofscmp_per to “00001000” ck_ofscmp is
cksys/9. The reset value is 2.0 s (cksys at 24 MHz).
Table 146. Ck_ofscmp_Prescaler(1A4h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
Name
Reserved
ck_ofscmp_per
R/W
-
r/w
Lock
-
yes
Reset
00000000
00101111
8.3.4.6
2
1
0
Driver interrupt configuration registers
These two registers can configure which conditions concur to the driver disable, which conditions concur to the interrupt generation, and
if the interrupt request must be generated toward the microcontroller and the microcores.
Table 147. Driver_config_Part 1 (1A5h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
Overte
Irq_uc1 Irq_uc0 Irq_uc1 Irq_uc0 Irq_uc1 Irq_uc0
Drv_en Vboost Vcc5_ir Vccp_ir
Irq_uc_
mp_irq
Iret_en _ch3_e _ch3_e _ch2_e _ch2_e _ch1_e _ch1_e
_irq_en _irq_en q_en
q_en
en
_en
n
n
n
n
n
n
Name
Reserved
R/W
-
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
Lock
-
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
Reset
000
0
0
0
0
0
0
0
0
0
0
0
0
0
PT2000
NXP Semiconductors
120
Table 148. Driver_config_Part 2 (1A6h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
Name
vccp_e
xt_en
Reserved
R/W
r/w
-
r/w
r/w
Lock
yes
-
yes
yes
Reset
1
0000000000000
0
0
Vboost Vboost
_mon_ _disabl
en
e_en
The driver_enable block generates a local interrupt masking the five possible disable conditions with the following bits:
• Drv_en_irq_en: if set, the drv_en generates the local interrupt
• Vboost_irq_en: if set, an undervoltage on VBOOST generates the local interrupt
• Vcc5_irq_en: if set, an undervoltage on VCC5 generates the local interrupt
• Vccp_irq_en: if set, an undervoltage on VCCP generates the local interrupt
• Overtemp_irq_en: if set, the over temperature condition generates the local interrupt
If a local interrupt is generated, it is possible to propagate it to an external device (micro controller) and to the six microcores. This is done
when the following bits are set:
•
•
•
•
•
•
•
Irq_uc_en, for the external device using the IRQB pin
Irq_uc0_ch1_en, for the microcore 0 of channel 1
Irq_uc1_ch1_en, for the microcore 1 of channel 1
Irq_uc0_ch2_en, for the microcore 0 of channel 2
Irq_uc1_ch2_en, for the microcore 1 of channel 2
Irq_uc0_ch3_en, for the microcore 1 of channel 3
Irq_uc1_ch3_en, for the microcore 1 of channel 3
Table 149. Truth table for propagation of UV Vboost_irq
Configuration
Resulting behavior
Vboost_irq_en
Vboost_disable_en
Irq_ ucx_chy_en
Irq_uc_en
UV Vboost bit set
irq_to microcore
irq_to μC (Irqb
pin)
0
0
d.c.
d.c.
no
no
no
0
1
d.c.
d.c.
yes
no
no
1
0
0
d.c.
no
no
no
1
0
1
d.c.
no
no
no
1
1
0
0
yes
no
no
1
1
0
1
yes
no
yes
1
1
1
0
yes
yes
no
1
1
1
1
yes
yes
yes
This register also contains some other configuration bit concerning the output drivers:
• iret_en: the driver_enable block automatically generates an iret request toward all the microcores (this request can be filtered by
microcode if not required). No iret request is generated if the interrupt was triggered by a loss of clock. It is possible to select two types
of iret:
• If iret_en is set to '0', an iret request is sent to the microcores when the drivers are re-enabled after a disable condition
• If iret_en is set to '1', an iret request is sent to the microcores when the drivers_status register is cleared. For the iret to happen, either
write the driver status register or to read it while the reset on read configuration is active
• Vboost_disable_en: if set, an undervoltage of VBOOST disables the output drivers
• Vboost_mon_en: this signal configures the divider on the VBOOST voltage
• If Vboost_mon_en is set to '0', VBOOST is divided by 32 and then compared with a threshold.
• If Vboost_mon_en is set to '1', VBOOST is divided by 4 and then compared with a threshold.
PT2000
121
NXP Semiconductors
• vccp_ext_enable: if set to '0', the internal voltage regulator is enabled and the corresponding pin is used only to connect a bypass
capacitor. If set to '1', the internal voltage regulator is disabled and the VCCP voltage must be supplied externally through the
corresponding pin. During bootstrap switch init (See Bootstrap switch control on page 58), this setting is bypassed and the value of the
vccp_ext_enable signal is set to the inverted value of the DBG pin sampled at reset (POResetB and ResetB). This is better defined in
Table 150, VCCP external enable setting. This means the DBG pin, at reset, needs to be configured as an input whose value is latched
at the rising edge of the POResetB and ResetB signal, and used to set the configuration of the VCCP internal regulator during the init
phase of the bootstrap switch. A SPI reset leaves the latched information unchanged. The DBG pin has an internal weak pull-up resistor
so its value is '1' when not connected (n.c.).
Table 150. VCCP external enable setting
dbg pin (latched)
SPI bit
BS Init (min. 1 HS)
VCCP external enable
1 (n.c.)
-
1
0 (internal reg ON)
1 (n.c.)
1
0
1 (internal reg OFF)
1 (n.c.)
0
0
0 (internal reg ON)
0
1
-
1 (internal reg OFF)
0
0
-
0 (internal reg ON)
8.3.4.7
PLL factor and speed configuration register
Table 151. PLL_Config (1A7h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
PLL_spre
PLL_fact
ad_disabl
or
e
Name
Reserved
R/W
-
r/w
r/w
Lock
-
yes
yes
Reset
00000000000000
0
1
• PLL_factor: if set to '0', the PLL multiplication factor is 12, otherwise it is 24
• PLL_spread_disable: if set to '0' the PLL output clock has a spread, otherwise it has no spread
The PLL factor is changed synchronously with clock monitor cycle to avoid a clock monitor alert when changing between 12 MHz and
24 MHz. This register is reset by POReset, ResetB, and the SPI reset.
8.3.4.8
Backup clock status register
Table 152. backup_clock_status (1A8h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
Name
Reserved
cksys_mi
ssing_dis
able_driv
er
Reserved
R/W
-
r/w
-
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r/w
r
Lock
-
yes
-
yes
yes
yes
yes
yes
yes
yes
no
no
Reset
0
0
00000
0
0
0
0
0
0
0
0
0
uc1_ch uc0_ch
uc0_ch uc1_ch uc0_ch
switch_to
uc1_ch
uc_irq_
loss_of
3_irq_e 3_irq_e
2_irq_e 1_irq_e 1_irq_e
_clock_pi
2 rq en
en
_clock
n
n
n
n
n
n
This 11-bit register is meant to provide the external microcontroller a way to monitor the status of the clock signal. This is done by latching
the information occurring on a switch to the backup_reference signal:
• Loss_of_clock: this read_only bit (loss_of_clock) latches the condition when the input reference is missing
PT2000
NXP Semiconductors
122
• Switch_to_clock_pin: this bit (active on rising edge) is used to provide a way to reset the loss of clock condition. If this bit is set during
a loss of clock condition it is reset as soon as the clock manager switches the PLL input to the external reference. If this bit sets while
there is no loss of clock, the bit resets immediately without any effect.
• uc_irq_en: enable the generation of an interrupt request to the external micro controller when cksys missing is detected. This interrupt
is active until this register is read
• uc0_ch1_irq_en: enable the generation of an interrupt request to microcore 0 channel 1 when cksys missing is detected
• uc1_ch1_irq_en: enable the generation of an interrupt request to microcore 1 channel 1 when cksys missing is detected
• uc0_ch2_irq_en: enable the generation of an interrupt request to microcore 0 channel 2 when cksys missing is detected
• uc1_ch2_irq_en: enable the generation of an interrupt request to microcore 1 channel 2 when cksys missing is detected
• uc0_ch3_irq_en: enable the generation of an interrupt request to microcore 0 channel 3 when cksys missing is detected
• uc1_ch3_irq_en: enable the generation of an interrupt request to microcore 1 channel 3 when cksys missing is detected
• cksys_missing_disable_driver: if set, the output drivers are disabled via the signal cksys_drven as long as the cksys_missing signal
is '1'.
Once the loss_of_clock bit sets, it can be reset only by completing a “switch to clock” pin. For this operation to complete, it must be
requested when the main clock input pin again provides a valid clock frequency.
The interrupt to the external micro and to the microcores is triggered as long as the cksys_missing signal is set. The microcore is able to
process the interrupt as soon as there is a clock available. It is triggered every time the clock manager switches to the internal clock
reference and when the clock manager tries to switch back to the external clock reference, due to a SPI request. The interrupt can even
occur multiple times during cksys_missing state.
8.3.4.9
SPI configuration register
The spi_config register (address 1A9h) is an 8-bit register storing the SPI protocol configuration and SPI diagnostics.
Table 153. Spi_config (1A9h)
Bit
15
14
13
12
11
10
9
8
7
6
MISO_sle protocol_
wrate
mode
Name
Reserved
R/W
-
r/w
Lock
-
Reset
00000000
5
4
3
2
irq_en
watchdog
r/w
r/w
r/w
yes
yes
yes
yes
0
0
0
01010
1
0
• Miso_slewrate: selects one of the two possible values for the slew rate of the MISO pin.
• 0 slow slew rate
• 1 fast slew rate
• Protocol_mode: select the type of burst transmission accepted by the protocol, '0' means mode A, '1' means mode B.
• irq_enable: enable the SPI interface to request an interrupt toward the microcontroller if an incorrect SPI transmission is received.
• Watchdog: when using mode A, the maximum time the SPI chip select can be inactive during a burst is expressed as follows:
tWATCHDOG = tCKSYS * ((watchdog + 1) x 32768)
where tCKSYS is the period of the cksys internal clock.
When changing the SPI protocol mode by a write access to this register, it has to be done using a SPI transmission which is compatible
to mode A and B (see See Mode A on page 77 and See Mode B on page 78). This means it must not use '0' as number of operations for
the SPI transmission, and must not deassert the chip select during the transmission. Changing the protocol mode can be done as often
as required.
PT2000
123
NXP Semiconductors
8.3.4.10
Tracer start/stop registers
Table 154. Trace_start (1AAh)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
Name
Reserved
start_address
R/W
-
r/w
Lock
-
no
Reset
000000
0000000000
3
2
1
0
The trigger_address field contains the address used to synchronize the PT2000 trace_unit with the external tracer. If the trace operation
is enabled and the trace unit is in the idle state, when the uPC value of the selected microcore reaches this address, the sync code is
transmitted on the DBG pin. Then the trace_unit goes to the next phase.trace_stop Register (1ABh)
Table 155. Trace_stop (1ABh)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
Name
Reserved
stop_address
R/W
-
r/w
Lock
-
no
Reset
000000
0000000000
3
2
1
0
The stop_address field contains the address used to finalize the trace operation. If the trace operation is ongoing (trace phase), when the
uPC value of the selected microcore reaches this address, the trace_unit goes to the next phase (post trigger phase).
8.3.4.11
Tracer configuration register
Table 156. Trace_config (1ACh)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
Name
Trace
enable
Reserved
uc select
Post trigger length
R/W
r/w
-
r/w
r/w
Lock
no
-
no
no
Reset
0
0000
000
00000000
2
1
0
• Trace enable. When this bit is set to '1', the trace_unit starts the first phase of the trace operation. This bit can be set to '0' by the user,
to immediately stop the PT2000 trace unit transmission. This bit is automatically reset after the trace operation is complete (all the four
phases are finished).
• uc select. Select which is the microcore target of the trace operation:
• “000”: microcore 0, channel 1
• “001”: microcore 1, channel 1
• “010”: microcore 0, channel 2
• “011”: microcore 1, channel 2
• “100”: microcore 0, channel 3
• “101”: microcore 1, channel 3
• Post trigger length. This field selects the duration of the post trigger phase, expressed as number of ck clock cycles. Writing 255 in the
post_trigger_length field of the trace_config register causes the trace unit to output a continuos stream after the stop point. With this,
run the trace operation for an unlimited amount of time and simply deactivate it by writing zero in the trace_enable bit of the trace config
register.
PT2000
NXP Semiconductors
124
8.3.4.12
Lock device register
It is possible to lock some registers of the PT2000. Locked registers can be read but cannot be written. The lock is not mandatory for the
correct working of the device; it is only a safety feature. It is possible to reset this lock by writing an unlock password. It is also possible to
independently lock a section of each Data RAM, the last 16 addresses.
Table 157. Device_Lock (1ADh)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
Dram3_pr Dram2_pr Dram1_pr
Dev_l
ivate_are ivate_are ivate_are
ock
a_lock
a_lock
a_lock
Name
Reserved
R/W
-
r/w
r/w
r/w
r/w
Lock
no
yes, by
itself
yes, by
itself
yes, by
itself
yes
Reset
000000000000
0
0
0
0
The dev_lock bit can be set by writing the device lock register. It cannot be reset by writing the device_lock register, but only by writing
the correct password in “unlock password”. If the device lock bit is set, all the register bits marked as “lock = yes” in this documentation
can no longer be changed by the SPI. Note that there are some bits not locked by the device lock bit, but locked by other mechanism.
Each of the lock bits for a DRAM is locked by itself and not by the dev lock bit as all the other registers in the device. When the correct
“unlock password” is provided, these three bit are also reset (refer to Table 80, Unlock_word (113h, 133h, 153h)).
8.3.4.13
Reset register behavior
Some registers of the device can be configured to reset when read by an external device through the SPI; read accesses by microcores
using the SPI backdoor never reset those registers.
Table 158. Reset_Behavior (1AEh)
Bit
Name
15
14
13
12
11
10
9
8
SR_uc SR_uc SR_uc SR_uc SR_uc SR_uc
Driver_en Reserv
1_ch3_ 0_ch3_ 1_ch2_ 0_ch2_ 1_ch1_ 0_ch1_
able_RB
ed
RB
RB
RB
RB
RB
B
7
6
Reserved
5
4
3
2
1
0
diag_u diag_u diag_u diag_u diag_u diag_u
c1_ch3 c0_ch3 c1_ch2 c0_ch2 c1_ch1 c0_ch1
_RB
_RB
_RB
_RB
_RB
_RB
R/W
r/w
-
r/w
r/w
r/w
r/w
r/w
r/w
-
r/w
r/w
r/w
r/w
r/w
r/w
Lock
no
-
no
no
no
no
no
no
-
no
no
no
no
no
no
Reset
0
0
0
0
0
• Driver enable reset behavior: if set to '1' driver_status register is reset on read (refer to Table 162, driver_status (1B2h))
• Automatic diagnostics uc0_ch1 reset behavior: if set to '1' err_uc register of microcore 0 of channel 1 is reset on read (See Automatic
diagnostics error status register on page 137). The three registers are reset when the err_ucXchY_3 register is read
• Automatic diagnostics uc1_ch1 reset behavior: if set to '1' err_uc register of microcore 1 of channel 1 is reset on read (See Automatic
diagnostics error status register on page 137). The three registers are reset when the err_ucXchY_3 register is read
• Automatic diagnostics uc0_ch2 reset behavior: if set to '1' err_uc register of microcore 0 of channel 2 is reset on read (See Automatic
diagnostics error status register on page 137). The three registers are reset when the err_ucXchY_3 register is read
• Automatic diagnostics uc1_ch2 reset behavior: if set to '1' err_uc register of microcore 1 of channel 2 is reset on read (See Automatic
diagnostics error status register on page 137). The three registers are reset when the err_ucXchY_3 register is read
• Automatic diagnostics uc0_ch3 reset behavior: if set to '1' err_uc register of microcore 0 of channel 3 is reset on read (See Automatic
diagnostics error status register on page 137). The three registers are reset when the err_ucXchY_3 register is read
• Automatic diagnostics uc1_ch3 reset behavior: if set to '1' err_uc register of microcore 1 of channel 3 is reset on read (See Automatic
diagnostics error status register on page 137). The three registers are reset when the err_ucXchY_3 register is read
• Status register uc0_ch1 reset behavior: if set to '1' the status register of microcore 0 of channel 1 is reset on read (See Status register
microcore0 on page 92 and See Status register microcore1 on page 92)
• Status register uc1_ch1 reset behavior: if set to '1' the status register of microcore 1 of channel 1 is reset on read (See Status register
microcore0 on page 92 and See Status register microcore1 on page 92)
• Status register uc0_ch2 reset behavior: if set to '1' the status register of microcore 0 of channel 2 is reset on read (See Status register
microcore0 on page 92 and See Status register microcore1 on page 92)
PT2000
125
NXP Semiconductors
• Status register uc1_ch2 reset behavior: if set to '1' the status register of microcore 1 of channel 2 is reset on read (See Status register
microcore0 on page 92 and See Status register microcore1 on page 92)
• Status register uc0_ch3 reset behavior: if set to '1' the status register of microcore 0 of channel 3 is reset on read (See Status register
microcore0 on page 92 and See Status register microcore1 on page 92)
• Status register uc1_ch3 reset behavior: if set to '1' the status register of microcore 1 of channel 3 is reset on read (See Status register
microcore0 on page 92 and See Status register microcore1 on page 92)
The reset on read feature is implemented so no data is lost when the reset of the register is requested and at the same time there is a
request to set a bit in the register from the microcode. The bit sets and transmits via the SPI the next time the register is read.
8.3.4.14
Unlock device register
Table 159. Device_Unlock (1AFh)
Bit
15
14
13
12
11
10
9
8
7
Name
Unlock_password
R/W
w
Lock
-
Reset
-
6
5
4
3
2
1
0
Writing the password 1337h in the unlock password field, resets the device_lock register (refer to Table 157, Device_Lock (1ADh)).
8.3.4.15
SPIReset global reset register 1 and 2
This 32-bit register is divided into two 16-bit slices. When the correct “global reset code” is written in this register, a SPIreset is generated.
This reset lasts for eight cksys clock cycles, then the global reset registers are reset. The global reset code is “F473h” for Global reset
register 1 and “57A1h” for Global reset register 2.
Table 160. Global_Reset_code_part1 (1B0h)
Bit
15
14
13
12
11
10
9
8
7
6
Name
Global_Reset_Register_code_1
R/W
w
Lock
no
Reset
0000h
5
4
3
2
1
0
5
4
3
2
1
0
Table 161. Global_Reset_code_part2 (1B1h)
Bit
15
14
13
12
11
10
9
8
7
6
Name
Global_Reset_Register_code_2
R/W
w
Lock
no
Reset
0000h
PT2000
NXP Semiconductors
126
8.3.4.16
Driver disable status register
This 7-bit register is meant to provide the external micro-controller a way to monitor the status of the output drivers. This is done latching
any error condition which disables the output drivers. Some of these error conditions must be enabled (refer to Table 152,
backup_clock_status (1A8h) and Table 147, Driver_config_Part 1 (1A5h)).
Table 162. driver_status (1B2h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
cksys_ DrvEn DrvEn_ Overte uv_vboo
uv_vcc5 uv_vccp
missing _latch value
mp
st
Name
Reserved
R/W
-
r
r
r
r
r
r
r
Lock
-
-
-
-
-
-
-
-
Reset
0000000000000
0
1
-
0
0
0
0
• cksys_missing: this bit is set if the cksys missing condition it disables the drivers. This condition can be configured (refer to Table 152,
backup_clock_status (1A8h)).
• DrvEn_latch: this bit latches the condition when the DRVEN input pin is inactive. The bit is reset to 1.
1: DRVEN pin was NOT low since last reset of the driver_status register
0: DRVEN pin was low since the last reset of the driver_status register
• DrvEn_value: this bit is not an error condition; it is only a “living copy” of the drv_en pin.
1: DRVEN pin is high
0: DRVEN pin is low
• Overtemperature: this bit latches the condition where an over temperature is present. It is not used to disable the drivers.
• Uv_vboost: this bit is set if the undervoltage on the vboost disables the high-side drivers. This condition can be configured (refer to
Table 147, Driver_config_Part 1 (1A5h)).
• Uv_Vcc5: this bit latches the undervoltage condition on Vcc5.
• Uv_vccp: this bit latches the undervoltage condition on Vccp and the error from GND loss detection.
Once an error bit has been set, it can only be reset by an SPI write operation in this register (if the corresponding error is no more present).
The same error bits are reset even upon SPI read operations but only when a proper enable bit is set (refer to Table 158, Reset_Behavior
(1AEh)).
8.3.4.17
SPI error status register
Table 163. Spi_error (1B3h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
cksys_mi frame_err word_err
ssing
or
or
Name
Reserved
R/W
-
r
r
r
Lock
-
-
-
-
Reset
0000000000000
0
0
0
The spi_error register is a 3-bit register split in this way:
• spi_error(2): cksys_missing error condition
• spi_error(1): frame incomplete error condition
• spi_error(0): word incomplete error condition
The duty of this block is to monitor the spi_protocol and the spi_interface to find errors during the communication with the microcontroller.
If an error is detected, the corresponding code is stored in the spi_error_code register. To warn the microcontroller, during the write transfer
(from microcontroller to asic), the MISO signal transfers a diagnostic word: the first 13 bits of this word are constant (“1010101010101”)
and are used to detect short-circuits on the MISO line. The last three bits copy the three LSBs of the spi_error register.
After an error code writes in this register, the register becomes write-protected to latch the error condition and is blind to other occurring
errors. This is because after one error, others are often generated: for example for an incomplete word, which can cause an incorrect
interpretation of a command word and lead to a frame incomplete error.
PT2000
127
NXP Semiconductors
By latching only the first occurring error, it is possible to read the cause of the failure in the communication, without having to see all the
side effects. Furthermore, the PT2000 has the possibility to generate an interrupt request toward the microcontroller by setting the
appropriate bit in the spi_config register (refer to Table 153, Spi_config (1A9h)).
When an error is met in the SPI connection, the SPI protocol inside the PT2000 moves to a state where it only accepts a specific two word
SPI transmission with command word (B661h) meant to read the spi_error register (refer to Table 163, Spi_error (1B3h)). This command
causes the device to transmit a single word to the SPI master and then reset the protocol (along with the interrupt if enabled). If the value
of the selection register was set to the value 0100h (selecting the generic configuration registers) before the error, the word transmitted
is the error code and the error code register is reset immediately, otherwise a random word is sent and the error state of the SPI protocol
is reset. In this second case, the error code register can be read (and thus reset) in a following burst. The following are the possible kind
of errors and their relative codes (during correct operations the value of the register is 0000h).
• cksys_missing: this error is set if a SPI transfer is required (which means if the SPI chip select CSB is pulled low) while the cksys clock
is missing.
• frame_error: this error is set if the number of data words in a burst is not the expected number programmed in the command word:
• Mode A is selected, the slave_protocol block received a control word specifying n word transfers, but the microcontroller performs
less operations and then ends the communication. In this case, this module provides a watchdog function if during a programmed
transfer, the communication with the microcontroller is inactive for a time longer than a prefixed limit, so the transfer is considered
aborted and an error is detected.
• Mode B is selected, the number parameter is not zero in the command word and the number of transferred words is different from
the one programmed in the command word.
• A frame error can also occur when the access limitations to DRAM in dual sequencer mode at maximum ck are violated (refer to
Table 49)
• word_error: during the transfer of a word long data, the device receives or sends an incorrect number of bits (15 or 17 instead of 16,
for example). If multiple words are being transferred in a row with the chip select always active (the fastest way), the error is detected
at the end of the sequence and it is not possible to say which is the incorrect word. To be sure of the incorrect data, the chip select
must be deactivated and reactivated between each word transfer.
8.3.4.18
Interruption status registers
These two registers latch the status of all the interrupt requests toward the external microcontroller. They also latch the halt signal
generated by the automatic diagnostics toward the six microcores.
Table 164. Interrupt_Register_Part1 (1B4h)
Bit
15
14
13
12
11
10
9
8
irq_uc1 irq_uc0 irq_uc1 irq_uc0 irq_uc1 irq_uc0
_ch3
_ch3
_ch2
_ch2
_ch1
_ch1
7
6
Reserved
5
4
3
2
1
0
halt_uc halt_uc halt_uc halt_uc halt_uc halt_uc
1_ch3 0_ch3 1_ch2 0_ch2 1_ch1 0_ch1
Name
Reserved
R/W
-
r
r
r
r
r
r
-
r
r
r
r
r
r
Lock
no
no
no
no
no
no
no
no
no
no
no
no
no
no
Reset
00
0
0
0
0
0
0
00
0
0
0
0
0
0
10
9
8
5
4
3
2
1
0
Table 165. Interrupt_Register_Part2 (1B5h)
Bit
15
14
13
12
11
checks checks cksys_
checksu
um_ch um_ch missin SPI_irq drv_irq
m_ch3
2
1
g
7
6
Name
Reserved
Reserved
R/W
-
r
r
r
r
r
r
-
Lock
no
no
no
no
no
no
no
no
Reset
00
0
0
0
0
0
0
00000000
PT2000
NXP Semiconductors
128
Table 166. Interrupt register bit description
Bit name
Function
halt uc0_ch1
‘1’ if the automatic diagnostics has detected a short-circuit on uc0_ch1
halt uc1_ch1
‘1’ if the automatic diagnostics has detected a short-circuit on uc1_ch1
halt uc0_ch2
‘1’ if the automatic diagnostics has detected a short-circuit on uc0_ch2
halt uc1_ch2
‘1’ if the automatic diagnostics has detected a short-circuit on uc1_ch2
halt uc0_ch3
‘1’ if the automatic diagnostics has detected a short-circuit on uc0_ch3
halt uc1_ch3
‘1’ if the automatic diagnostics has detected a short-circuit on uc1_ch3
irq_uc0_ch1
‘1’ if the microcode of uc0_ch1 has asserted its interrupt request
irq_uc1_ch1
‘1’ if the microcode of uc1_ch1 has asserted its interrupt request
irq_uc0_ch2
‘1’ if the microcode of uc0_ch2 has asserted its interrupt request
irq_uc1_ch2
‘1’ if the microcode of uc1_ch2 has asserted its interrupt request
irq_uc0_ch3
‘1’ if the microcode of uc0_ch3 has asserted its interrupt request
irq_uc1_ch3
‘1’ if the microcode of uc1_ch3 has asserted its interrupt request
Drv_irq
‘1’ if the driver status block has disabled the output drivers
SPI_irq
‘1’ if the SPI interface has detected an error on the SPI communication
cksys_missing
‘1’ if the clock monitor has detected a cksys missing condition
Checksum_ch1
‘1’ if the checksum of the code RAM of ch1 is wrong
Checksum_ch2
‘1’ if the checksum of the code RAM of ch2 is wrong
Checksum_ch3
‘1’ if the checksum of the code RAM of ch3 is wrong
PT2000
129
NXP Semiconductors
D is
ab
le
o
n=1
(1A8h
)
irƋ en = 1 (1A8h)
Microcore interrupt
(driver_disable_rouƟne )
HS + LS Pre-driver
Disable
Vb
=1
is a
b le
ost
d
DrvEN
Overtemp
SPI_CoŶĮŐ
(1A9h)
DrivĞƌͺŽŶĮŐ
(1A5h, 1A6h)
(1A
5h)
Vboost_uv
IrƋƵc en & irƋ ucX chX en =1 (1A5h)
VCC5_uv
Flash_enable
(100h, 120h,
140h)
SPI Error
Interrupt
register
(1B4h)
IRQB
pin
Microcore
Disable
CRC32
error
Interrupt status registers
Interrupt
register
(1B5h)
/ƌƋ en = 1 (1A9h)
_Clock
8h)
X irƋ e
IrƋ
u
uc X c h
=1
r
ng_drive
Clk missi = 1
Disable
cX c
hX e
n
chX
VCCP_uv
Checksum irƋen = 1 (100h, 120h, 140h)
Disable
uc X
Disable
AuƚŽŵĂƟc
diagnosis
Microcore interrupt
(automaƟc_diagnosƟc )
Halt
SW
interrupt
“reƋi”
Microcore interrupt
(sŽŌware)
uCode
͞ƐƟƌƋ”
instrucƟŽn
Interrupt from microcores
Microcore interrupt
Interrupt source
SƟrƋ instrucƟon
NXP Semiconductors
ReƋi instrucƟŽn
8.3.4.19
Interrupt subsystem overview
Figure 33 gives an overview over the handling and configuration of the different interrupt sources of the device.
Figure 33. Interrupt subsystem
PT2000
130
8.3.4.20
Device identifier register
Table 167. Device_Identifier (1B6h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
Name
Device_id
Mask_id
Sw_id
R/W
r
r
r
Lock
-
-
-
Reset
10101110
0011
0010
0
This register provide a device identifier for the component. The three fields are:
• Device id is a constant. It identifies the PT2000 device.
• Mask id is a version number of the mask set used for the device. Different mask sets must have a different mask id.
• Sw id is a version number related to the mask set.
8.3.4.21
Reset source status register
This 3-bit register identifies which resets were asserted since the last time this register was read. Each time this register is accessed, it is
also reset.
Table 168. Reset_Source (1B7h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
Name
Reserved
SPI reset Po resetb
resetb
R/W
-
r
r
r
Lock
-
-
-
-
Reseton
read
-
yes
yes
yes
Reset
0000000000000
*
*
*
Table 169. Reset Source Register Bits
Bit Name
function
SPI reset
‘1’ if the global SPI reset was asserted since the last time this register was read
Poresetb
‘1’ if the power on reset was asserted since the last time this register was read
resetb
8.3.4.22
‘1’ if the reset pin was asserted since the last time this register was read. After POResetB this bit is in an unknown state.
BIST configuration register
The BIST register is used in write mode to trigger the BIST execution.
Table 170. Bist_interface in write mode (1BDh)
Bit
15
14
13
12
11
10
9
8
7
6
Name
BIST activation password
R/W
w
Lock
no
Reset
-
5
4
3
2
1
0
PT2000
131
NXP Semiconductors
The BIST passwords are:
• B157h: MBIST
• 0666h: LBIST
• C1A0: Clear LBIST (need to be sent after LBIST is done)
Note that after a LBIST is done a clear BIST command needs to be sent to reenable the logic.
In Read mode the register shows the BIST result.
Table 171. Bist_interface in read mode (1BDh)
Bit
•
•
•
•
•
•
•
•
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
Name
Reserved
LBIST_result
MBIST_result
R/W
-
r
r
Lock
-
no
no
Reset
000000000000
00
00
MBIST result: set to “00” if the memory BIST was never requested
MBIST result: set to “01” if the memory BIST operation is in progress
MBIST result: set to “10” if the memory BIST operation was successfully completed
MBIST result: set to “11” if the memory BIST operation has failed
LBIST result: set to “00” if the logic BIST was never requested or a clear command has been sent
LBIST result: set to “10” if the logic BIST operation was successfully completed
LBIST result: set to “11” if the logic BIST operation has failed
LBIST result: set to “01” if the logic BIST was stopped by Flag0
8.3.5
Diagnostics configuration registers
8.3.5.1
Automatic diagnostics reaction time
If the disable window is exceeded and the automatic diagnostics detects an error between the HSx_in and the filtered HSx_Vds_fbk signal,
an interrupt is generated toward the microcore. This interrupts the program counter of the microcore and sets to the first instruction of the
error routine (refer to Table 70, Diag_routine_addr (10Ch, 12Ch, 14Ch)).
It takes four clock cycles (666 ns at 6.0 MHz) until the execution of the first microcode operation of the error routine is completed. This
means if the first microcode command is used to switch off all pre-drivers, this action is delayed by four clock cycles. In more detail, it
takes one clock cycle to detect the error, one clock cycle to generate the interrupt, one clock cycle to move the program counter to the
error routine, and one clock cycle to execute the first instruction.
Figure 34. Example of VDS automatic diagnostics filtering and disable windows
PT2000
NXP Semiconductors
132
8.3.5.2
LS1 to LS6 output/filter/diag configuration register
These registers define the automatic diagnostics parameter and output routing option from the low-side 1-6 output.
Table 172. LSx_diag_config1 (1C0h, 1C3h, 1C6h, 1C9h, 1CCh, 1CFh, 1D2h, 1D5h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
Name
Reserved
Filter_t
ype
Filter_length
Disable_window
R/W
-
r/w
r/w
r/w
Lock
-
yes
yes
yes
Reset
00
0
000000
0000000
1
0
1
0
Table 173. LSx_diag_config2 (1C1h, 1C4h, 1C7h, 1CAh, 1CDh, 1D0h, 1D3h, 1D6h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
Name
Reserved
Error_table
R/W
-
r/w
Lock
-
yes
Reset
000000000000
0000
Table 174. LSx_output_config (1C2h, 1C5h,1C8h, 1CBh, 1CEh, 1D1h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
Name
LSx_ov
r
Reserved
output_routing
inv
R/W
r/w
-
r/w
r/w
Lock
yes
-
yes
yes
Reset
0
0000000000
11111
0
• Filter_type. This 1-bit parameter selects the type of filter used:
• if 0 - Any different sample resets the filter counter
• if 1 - Any different sample decreases the filter counter
• Filter_lenght. This 6 bits parameter set the filtering time for the input feedback signal.
tFTN = tCK x (Filter_length + 1)
• Error_table. This 4-bit parameter defines the logical value of an error signal, starting from the output and the related VDS feedback
signal. This table defines the output of the coherency check between the driven output and the acquired feedback. A logic 1 value
means there is no coherency in the check and an error signal towards the micro-microcore should be generated.
output_command = 0
(pre-driver switched off)
output_command = 1
(pre-driver switched on)
LSx_Vds_feed = 0 (VDS below threshold)
error_table(0)
error_table (2)
LSx_Vds_feed = 1 (VDS above threshold)
error_table (1)
error_table (3)
• Disable_window. This 7-bit parameter configures a time period during which any check on the LSx_Vds_feed signal is disabled after
any change on the output_command signal.
tDTL = tCK x (Disable_window + 4)
• Output_routing. This 4-bit parameter defines if the LSx output is controlled by the microcores or by an input flag pin. When an input flag
pin is selected, the signal from the flag pin and the control signal from the microcores are combined by a logic OR. When a flag pin is
selected to drive the output, it is possible to control low-sides without programming the microcore.
PT2000
133
NXP Semiconductors
output_routing
flag (54)
output_command
0
Flag0
driven from flag0
1
Flag1
driven from flag1
2
Flag2
driven from flag2
3
Flag3
driven from flag3
4
Vsense4
driven from flag4
5
Start1
driven from flag5
6
Start2
driven from flag6
7
Start3
driven from flag7
8
Start4
driven from flag8
9
Start5
driven from flag9
10
Start6
driven from flag10
11
Start7
driven from flag11
12
Start8
driven from flag12
13
Irq
driven from flag13
14
OA2
driven from flag14
15
Dbg
driven from flag15
16-31
driven from the microcores
Notes
54.
Configuration is linked to the value of flag source register (see Table 145).
• Invert: This parameter inverts the polarity of the LSx output signal, with respect to the polarity defined by the microcore. This affects
the output command toward the pre-drivers, but the error_table of the associated feedback is not affected since diagnostics already
takes into account the pre-driver status (even when the invert bit is set). The invert bit doesn't affect the polarity of the pre-driver when
it is driven from a flag pin.
• LSx_ovr: if set to '1', the low-side x output driver is not influenced by the drv_en.
This bit is only writeable for LS6. For all the other pre-drivers, this feature is not available. The drv_en path is always active (hard wired).
8.3.5.3
LS7 and LS8 output/filter/diag configuration register
For LS7 and LS8, the LSx_diag_config1/2 registers have the same layout as for LS1-6 (refer to Table 172, LSx_diag_config1 (1C0h,
1C3h, 1C6h, 1C9h, 1CCh, 1CFh, 1D2h, 1D5h) and Table 173, LSx_diag_config2 (1C1h, 1C4h, 1C7h, 1CAh, 1CDh, 1D0h, 1D3h, 1D6h).
Table 175, LS7_output_config (1D4h) & LS8_output_config (1D7h) shows the layout of the LS7/8_output_config register.
Table 175. LS7_output_config (1D4h) & LS8_output_config (1D7h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
Name
LSx_ov
r
Reserved
output_routing
inv
R/W
r/w
-
r/w
r/w
Lock
yes
-
yes
yes
Reset
0
000000000
11111
0
• Output_routing: This 4-bit parameter defines if the LSx output is controlled by the microcores or by an input flag pin. When an input flag
pin is selected, the signal from the flag pin and the control signal from the microcores are combined by a logic OR. When a flag pin is
selected to drive the output, it is possible to control low-sides without programming the microcore.
PT2000
NXP Semiconductors
134
output_routing
flag (55)
output_command
0
Flag0
driven from flag0
1
Flag1
driven from flag1
2
Flag2
driven from flag2
3
Flag3
driven from flag3
4
Vsense4
driven from flag4
5
Start1
driven from flag5
6
Start2
driven from flag6
7
Start3
driven from flag7
8
Start4
driven from flag8
9
Start5
driven from flag9
10
Start6
driven from flag10
11
Start7
driven from flag11
12
Start8
driven from flag12
13
Irq
driven from flag13
14
OA2
driven from flag14
15
Dbg
driven from flag15
16-31
driven from the microcores
Notes
55.
Configuration is linked to the value of flag source register (see Table 145).
• Invert: This parameter inverts the polarity of the LSx output signal, with respect to the polarity defined by the microcore. The invert bit
doesn't affect the polarity of the pre-driver when it is driven from a flag pin.
• LSx_ovr: if set to '1', the low-side x output driver is not influenced by the drv_en.
8.3.5.4
HSx output/filter/diag configuration register
These registers define the automatic diagnostics parameter and output routing option fro the high-side X output.
Table 176. HSx_diag_config1 (1D8h, 1DBh, 1DEh, 1E0h, 1E4h, 1E7h, 1EAh)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
Name
Reserved
Filter_t
ype
Filter_length
Disable_window
R/W
-
r/w
r/w
r/w
Lock
-
yes
yes
yes
Reset
00
0
000000
0000000
1
0
1
0
Table 177. HSx_diag_config2 (1D9h, 1DCh, 1DFh, 1E2h, 1E5h, 1E8h, 1EBh)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
Name
Reserved
Error_table_src
Error_table_vds
R/W
-
r/w
r/w
Lock
-
yes
yes
Reset
00000000
0000
0000
PT2000
135
NXP Semiconductors
Table 178. HSx_output_config (1DA, 1DDh, 1E0h, 1E3h, 1E6h, 1E9h)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
Name
HSx ovr
reserved
dead_time
output_routing
inv
R/W
r/w
-
r/w
r/w
r/w
Lock
yes
-
yes
yes
yes
Reset
0
000
00000
11111
0
• Error_table_vds: This 4-bit parameter defines the logical value of an error signal, starting from the output and the related VDS feedback
signal. This table defines the output of the coherency check between the driven output and the acquired feedback. A logic 1 value
means there is no coherency in the check and then an error signal towards the micro-microcore should be generated.
output_command = 0
(Pre-driver switched off)
output_command = 1
(Pre-driver switched on)
HSx_Vds_feed = 0
(VDS below threshold)
error_table(0)
error_table (2)
HSx_Vds_feed = 1
(VDS above threshold)
error_table (1)
error_table (3)
• Disable_window: This 7-bit parameter configures a time period during which any check on the HSx_Vds_feed and HSx_Vsrc_feed
signals is disabled after any change on the output_command signal.
tDTL = tCK x (Disable_window + 4)
• Error_table_src: This 4-bit parameter defines the logical value of an error signal, starting from the output and the related VSRC feedback
signal. This table defines the output of the coherency check between the driven output and the acquired feedback. A logic 1 value
means there is no coherency in the check and then an error signal towards the micro-microcore should be generated.
output_command = 0
(pre-driver switched off)
output_command = 1
(pre-driver switched on)
HSx_Vsrc_feed = 0
(VSRC below threshold)
error_table(0)
error_table (2)
HSx_Vsrc_feed = 1
(VSRC above threshold)
error_table (1)
error_table (3)
• Filter_type. This 1 bit parameter selects the type of filter used:
• if 0 - Any different sample resets the filter counter
• if 1 - Any different sample decreases the filter counter
• Dead_time: This 5-bit register is used to store the value of the dead_time end of count used in the generation of the free wheeling output
(delay between the high-side output and the free wheeling output). The FW command goes high after a programmable time (tFWDLY)
with respect to the high-side falling edge. In this mode the high-side command rising edge is always delayed of the same programmable
time (tFWDLY) with respect to the rising edge requested by the microcores.
tFWDLY = Tck x (Dead_time + 1)
• Output_routing: This 4-bit parameter defines if the HSx output is controlled by the microcores or by an input flag pin. When an input
flag pin is selected, the signal from the flag pin and the control signal from the microcores are combined by a logic OR. When a flag pin
is selected to drive the output, it is possible to control low-sides without programming the microcore.
output_routing
flag (56)
output_command
0
Flag0
driven from flag0
1
Flag1
driven from flag1
2
Flag2
driven from flag2
3
Flag3
driven from flag3
4
Vsense4
driven from flag4
5
Start1
driven from flag5
PT2000
NXP Semiconductors
136
output_routing
flag (56)
output_command
6
Start2
driven from flag6
7
Start3
driven from flag7
8
Start4
driven from flag8
9
Start5
driven from flag9
10
Start6
driven from flag10
11
Start7
driven from flag11
12
Start8
driven from flag12
13
Irq
driven from flag13
14
OA2
driven from flag14
15
Dbg
driven from flag15
16-31
driven from the microcores
Notes
56.
Configuration is linked to the value of flag source register (see Table 145).
• Invert: This parameter inverts the polarity of the HSx output signal, with respect to the polarity defined by the microcore. This affects
the output command towards the pre-drivers, but the error_table of the associated feedback is not affected since diagnostics already
takes into account the pre-driver status (even when the invert bit is set). The invert bit doesn't affect the polarity of the pre-driver when
it is driven from a flag pin.
• Filter_lenght. This 6-bit parameter sets the filtering time for the input feedback signal.
• tFTN = tCK x (Filter_length + 1)
• HSx ovr: if set to '1', the high-side x output driver is not influenced by the drv_en. This bit is only writeable for HS5 and HS7. For all the
other pre-drivers this feature is not available, the drv_en path is always active (hard wired).
8.3.5.5
Automatic diagnostics error status register
This is the status register controlled by automatic diagnostics: one for each microcore. This register stores all meaningful information
whenever an error condition is detected on any of the pairs (output / feedback) to which the microcore is sensitive. The information stored
in the register with regards to the output commands and the related voltage (VDS and VSRC) feedback.
A cksys_missing (PLL output clock not valid) condition does not trigger the err_ucXchY to be latched. If the register is latched, the
cksys_missing bit shows the cksys status at the same moment when the automatic diagnostics error occurred. The cksys_missing bit sets
when the PLL output clock was not valid at the time the automatic diagnostics error occurred. The registers can be configured as reset on
read. Refer also to section Table 158, Reset_Behavior (1AEh). Those three registers are reset when the err_ucXchY_3 register is read.
Note that automatic diagnostics are enabled using the endiag or endiaga instructions (reference Programming Guide and Instruction Set).
Table 179. Err_ucxchy_part1 (1EDh, 1F0h, 1F3h, 1F6h, 1F9h, 1FCh)
Bit
Name
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
Reserv cmd_H Vsrc_H Vds_H cmd_H Vsrc_H Vds_H cmd_H Vsrc_H Vds_H cmd_H Vsrc_H Vds_H cmd_H Vsrc_H Vds_H
ed
s5
s5
s5
s4
s4
s4
s3
s3
s3
s2
s2
s2
s1
s1
s1
R/W
-
r
r
r
r
r
r
r
r
r
r
r
r
r
r
r
Lock
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
Reset on
read
-
conf.
conf.
conf.
conf.
conf.
conf.
conf.
conf.
conf.
conf.
conf.
conf.
conf.
conf.
conf.
Reset
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
PT2000
137
NXP Semiconductors
Table 180. Err_ucxchy_part2 (1EEh, 1F1h, 1F4h, 1F7h, 1FAh, 1FDh)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
Name
cksys_mi
ssing
Reserved
cmd_
Hs7
Vsrc_
Hs7
Vds_
Hs7
cmd_
Hs6
Vsrc_
Hs6
Vds_
Hs6
R/W
r
-
r
r
r
r
r
r
Lock
-
-
-
-
-
-
-
-
Reset
on read
conf.
-
conf.
conf.
conf.
conf.
conf.
conf.
Reset
0
000000000
0
0
0
0
0
0
5
4
3
2
1
0
Table 181. Err_ucxchy_part3 (1EFh, 1F2h, 1F5h, 1F8h, 1FBh, 1FEh)
Bit
Name
15
14
13
12
11
10
9
8
7
6
cmd_L Vds_Ls cmd_L Vds_Ls cmd_L Vds_Ls cmd_L Vds_Ls cmd_L Vds_Ls cmd_L Vds_Ls cmd_L Vds_Ls cmd_L Vds_Ls
S8
8
S7
7
s6
6
s5
5
s4
4
s3
3
s2
2
s1
1
R/W
r
r
r
r
r
r
r
r
r
r
r
r
r
r
r
r
Lock
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
Reset on
read
conf.
conf.
conf.
conf.
conf.
conf.
conf.
conf.
conf.
conf.
conf.
conf.
conf.
conf.
conf.
conf.
Reset
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
8.3.5.6
Automatic diagnostics command/feedback coherency
The PT2000 performs automatic diagnostics by checking the coherency between the commands it sends to the MOSFETs and the VDS/
VSRC feedback it gets. The following register configure if the check is between:
• diag_option = 0 => coherency check between what the microcore wants to drive, using instructions like sto/stos/ldca/ldcd and the
feedback from the MOSFETS
• diag_option = 1 => coherency check between what the device is really driving, using instructions like sto/stos/ldca/ldcd, but also
including the status of overtemperature/drven pin/undervoltages/etc. and the feedback from the MOSFETS
For example, in case of an overtemperature/drven pin/undervoltages/etc., drivers are disabled:
In case of diag_option =0 =>, automatic diagnosis coherency check fails and detects an error (microcores are trying to drive but the output
does not move due to a disabled driver, VDS/VSRC feedback incoherent with driving request => fail)
In case of diag_option =1 =>, automatic diagnosis coherency check does not detect anything (microcores are trying to drive, but the output
does not move due to a disabled driver, VDS/VSRC feedback is in this case first compared to “no driving” => ok)
To summarize if the diag_option = 0 then automatic diagnostics is able to cover all kind of faults.
Table 182. diagnostics_option register (1FFh)
Bit
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0
Name
Reserved
Diag_opt
ion
R/W
-
r/w
Lock
-
yes
Reset
000000000000000
1
PT2000
NXP Semiconductors
138
VBoost
VBoost
100nF
VBoost
330Ω
4.7nF
4.7nF
330Ω
330pF
330pF
MCU ADC
330Ω
330Ω
4.7nF
4.7nF
START1
4.7nF
PUMP
4.7nF
15mΩ
M
VPWR
VSENSE_N2
OA_2
VSENSE_P2
D_LS4
G_LS4
D_LS3
G_LS3
B_HS4
G_HS4
S_HS4
B_HS3
G_HS3
S_HS3
VSENSE_N1
D_LS2
G_LS2
OA_1
VSENSE_P1
D_LS1
G_LS1
B_HS2
G_HS2
S_HS2
B_HS1
G_HS1
S_HS1
START4
330Ω
S_HS7
4.7nF
CSB
DBG
FLAG2
FLAG1
START5
To MCU SPI
MOSI
To MCU IOs
(optional)
SCKL
330pF
100nF
VPWR
470μF
100nF
100nF
100nF 1μH
VCC5
To MCU IOs
100nF
Supplies
470μF
1μH
6μH
100nF
MC33PT2000
6 Cylinder
3 Bank
START6
D_LS8
G_LS8
100nF
MCU ADC
START7
VSENSE_P3
OA_3
D_LS6
G_LS6
D_LS5
G_LS5
B_HS6
G_HS6
S_HS6
B_HS5
G_HS5
S_HS5
VSENSE_N5
VSENSE_P5
G_LS7
D_LS7
VBOOST
VSENSE_N6
VSENSE_P6
RESET
To MCU eTPU
100nF
FLAG0
VSENSE_N3
START2
B_HS7
FLAG3
VBAT
START3
G_HS7
DRVEN
VCCIO
VBoost
PUMP
330Ω
MISO
VCCP
330pF
MCU ADC
330pF
330Ω
4.7nF
330Ω
4.7nF
4.7nF
330Ω
10mΩ
VPWR
330pF
VBoost
VBoost
10μH
100nF
220nF
15mΩ
6
VBoos
4.7
VBoos
330Ω
4.7nF
4.7nF
330Ω
100nF
DC/DC
5.1Ω
4.7nF
INJECTOR5
VCC2P5
CLK
139
IRQB
9.1
AGND
DGND
PGND
9
Typical applications
The PT2000 can be configured in several applications. Figure 35 and Figure 36 shows the PT2000 in a typical application.
Application diagram: 3 bank, 6 cylinder with DC/DC
Figure 35. Example of application circuit (6 cylinder 3 bank with DC/DC)
PT2000
NXP Semiconductors
INJECTOR1
FW1
100nF
BANK2
4.7nF
VBoost
15mΩ
4.7nF
330Ω
4.7nF
330Ω
330pF
330pF
MCU ADC
330Ω
START1
4.7nF
PUMP
4.7nF
15mΩ
M
VPWR
VSENSE_N2
OA_2
VSENSE_P2
D_LS4
G_LS4
D_LS3
G_LS3
B_HS4
G_HS4
S_HS4
B_HS3
G_HS3
S_HS3
VSENSE_N1
D_LS2
G_LS2
OA_1
VSENSE_P1
D_LS1
G_LS1
B_HS2
G_HS2
S_HS2
B_HS1
G_HS1
S_HS1
START4
330Ω
S_HS7
4.7nF
CSB
DBG
FLAG2
FLAG1
START5
To MCU SPI
330pF
100nF
VPWR
470μF
100nF
100nF
100nF 1μH
VCC5
100nF
Supplies
470μF
1μH
6μH
100nF
To MCU IOs
OA_3
D_LS6
G_LS6
D_LS5
G_LS5
B_HS6
G_HS6
S_HS6
B_HS5
G_HS5
S_HS5
VSENSE_N5
VSENSE_P5
G_LS7
D_LS7
VBOOST
VSENSE_N6
VSENSE_P6
RESET
To MCU IOs
(optional)
SCKL
MC33PT2000
3 Cylinder
3 Bank
START6
D_LS8
G_LS8
330Ω
START7
VSENSE_P3
330Ω
4.7nF
100nF
MCU ADC
FLAG0
VSENSE_N3
CLK
To MCU eTPU
100nF
FLAG3
VBAT
START2
B_HS7
MISO
VCCP
START3
G_HS7
DRVEN
VCCIO
VBoost
PUMP
330Ω
MOSI
VCC2P5
IRQB
AGND
DGND
PGND
NXP Semiconductors
330pF
MCU ADC
330pF
330Ω
4.7nF
330Ω
4.7nF
330Ω
VBoost
10μH
10mΩ
VPWR
4.7nF
100nF
330pF
220nF
6
VBoos
DC/DC
5.1Ω
100nF
INJECTOR3
BAN
4.7nF
4.7nF
330Ω
VBoost
330Ω
15mΩ
FW3
9.2
Application diagram: 3 bank, 3 cylinder (full overlap) with DC/DC
Figure 36. Application diagram 3 bank, 3 cylinder with synchronous rectification and DC/DC
PT2000
140
10
Packaging
10.1
Package mechanical dimensions
Package dimensions are provided in package drawings. To find the most current package outline drawing, go to www.nxp.com and
perform a keyword search for the drawing’s document number.
Package
Suffix
80-Pin LQFP
AF
Package outline drawing number
98ASA00505D
PT2000
141
NXP Semiconductors
PT2000
NXP Semiconductors
142
PT2000
143
NXP Semiconductors
PT2000
NXP Semiconductors
144
11
Reference section
Table 183. PT2000 reference
Description
URL
Programming guide and instruction set
http://www.nxp.com/files/analog/doc/user_guide/PT2000SWUG.pdf
Product summary page
http://www.nxp.com/PT2000
PT2000
145
NXP Semiconductors
12
Revision history
Revision
Date
1.0
3/2015
• Initial release
3/2015
• Made minor corrections
4/2015
•
•
•
•
•
Corrected typo error on High-side VDS Threshold in Table 8
Corrected typo error on Low-side VDS Threshold in Table 9
Changed Current Measurement for DC/DC title to heading 3
Updated reset value in Table 122 (low-side pull-down disable by default)
Updated figure 35 and 36 to use current sense measurement 6 for Bank 3, recommended in order to use OA3 for Bank3
4/2015
•
•
•
•
•
•
Added Shutoff path via the DrvEn pin section.
IVBATT_OPER value updated to fit with maximum current allowed on VCCP in Table 5
IVCC5 updated with 6 microcores ON and biasing enabled in Table 5
Total Error VBOOST_DAC updated in Table 5
OAx Input impedance updated in Table 15
LBIST clear command added in LBIST
6/2015
• Corrected Figure 20
• Added description detail to section 7.2.1.3
2.0
3.0
Description of changes
• Updated IVCC5 characteristic in Table 5
• Added Table 50
11/2015
4.0
12/2015
•
•
•
•
•
Added note (18)
Updated section 6.1.4.1
Updated section 8.2.3.2
Updated section 8.3.3.12
Updated the example in section 8.3.2.17
•
•
•
•
Corrected package suffix
Added the VCS_OFF_GD parameter
Corrected Table 167
Corrected table titles for Table 172, Table 173, Table 174, Table 176, Table 177, Table 178, Table 179, Table 180, and
Table 181
Updated the formula for calculating current threshold
Update Figure 33
Updated package drawing
Updated form and style
5.0
4/2016
•
•
•
•
6.0
6/2016
• Added SPI timings to Table 18
• added clarification to Section 7.1.1. Power-up sequence of VCC5, VCC2P5, and reset, page 57
• Updated Figure 21
• Added Table 3, Resistor types
7.0
9/2016
• Added Pull resistor type column to Table 2, PT2000 pin definitions (2), (3), (4)
• Added notes (3) and (4).
• Made minor correction to Section 7.2.1.3. Mode 3 (LS7/8 resonant mode VDS monitoring), page 62
• Updated Figure 3 (replaced VSENSEN8 by VSENSEN2)
• Updated min. value for VBATT and SRVCCC5 in Table 5
• Updated typical value for IVCCIO in Table 5
8.0
4/2017
• Added note (16) and (52)
• Made minor corrections to Application without boost voltage, Low-side VDS monitor D_ls7/D_ls8 for DC/DC, VDS lowside 7/8 configuration register, and DAC settling time register
• Updated Table 145
9.0
4/2017
• Deleted SRVCCC5 characteristic from Table 5
PT2000
NXP Semiconductors
146
Revision
Date
10.0
9/2017
• Updated Figure 1
• Updated Table 126 (changed all reset values to 1)
• Updated Table 152
11.0
6/2018
•
•
•
•
12.0
1/2019
• Changed document status from Advance information to Technical data
5/2022
CIN 202205014I
Counter 3 and 4 prescaler register
• Changed Example to counter_4_per_uc1 = 0010b from counter_4_per_uc1 = 0001b
Table 76
• Changed prescaler of 1100 to 13 from 14
• Changed prescaler of 1101 to 14 from 16
• Changed prescaler of 1110 to 15 from 32
• Changed prescaler of 1111 to 16 from 64
13.0
Description of changes
Updated Table 5 (added the Vcc5_BGmin parameter)
Minor typo corrections in Table 11, Table 13 and Table 16
Updated bit 5 and bit 13 values in Table 102, Table 103 and Table 104
Updated Figure 33 (replaced 1B4h by 1B5h and 1B5h by 1B4h)
PT2000
147
NXP Semiconductors
How to Reach Us:
Information in this document is provided solely to enable system and software implementers to use NXP products.
Home Page:
NXP.com
There are no expressed or implied copyright licenses granted hereunder to design or fabricate any integrated circuits
Web Support:
http://www.nxp.com/support
products herein.
based on the information in this document. NXP reserves the right to make changes without further notice to any
NXP makes no warranty, representation, or guarantee regarding the suitability of its products for any particular
purpose, nor does NXP assume any liability arising out of the application or use of any product or circuit, and
specifically disclaims any and all liability, including without limitation, consequential or incidental damages. "Typical"
parameters that may be provided in NXP data sheets and/or specifications can and do vary in different applications,
and actual performance may vary over time. All operating parameters, including "typicals," must be validated for each
customer application by the customer's technical experts. NXP does not convey any license under its patent rights nor
the rights of others. NXP sells products pursuant to standard terms and conditions of sale, which can be found at the
following address:
http://www.nxp.com/terms-of-use.html.
NXP, the NXP logo, Freescale, the Freescale logo and SMARTMOS are trademarks of NXP B.V. All other product or
service names are the property of their respective owners. All rights reserved.
© NXP B.V. 2022.
Document Number: MC33PT2000
Rev. 13
5/2022