0
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心
发布
  • 发文章

  • 发资料

  • 发帖

  • 提问

  • 发视频

创作活动
MC33PT2000AF

MC33PT2000AF

  • 厂商:

    NXP(恩智浦)

  • 封装:

    LQFP80_EP

  • 描述:

    MC33PT2000AF

  • 数据手册
  • 价格&库存
MC33PT2000AF 数据手册
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
MC33PT2000AF 价格&库存

很抱歉,暂时无法提供与“MC33PT2000AF”相匹配的价格&库存,您可以联系我们找货

免费人工找货