# TMS320C674x/OMAP-L1x Processor Enhanced Capture (eCAP) Module

# **User's Guide**



Literature Number: SPRUFL2A June 2009



# **Contents**

| Pref | ace     |                                                                           | 6         |
|------|---------|---------------------------------------------------------------------------|-----------|
| 1    | Introd  | uction                                                                    | 8         |
|      | 1.1     | Purpose of the Peripheral                                                 | . 8       |
|      | 1.2     | Features                                                                  | . 8       |
| 2    | Archit  | ecture                                                                    | 9         |
|      | 2.1     | Capture and APWM Operating Mode                                           | 10        |
|      | 2.2     | Capture Mode Description                                                  | 11        |
| 3    | Applic  | cations                                                                   | 18        |
|      | 3.1     | Absolute Time-Stamp Operation Rising Edge Trigger Example                 | 19        |
|      | 3.2     | Absolute Time-Stamp Operation Rising and Falling Edge Trigger Example     | 21        |
|      | 3.3     | Time Difference (Delta) Operation Rising Edge Trigger Example             | 23        |
|      | 3.4     | Time Difference (Delta) Operation Rising and Falling Edge Trigger Example | 25        |
|      | 3.5     | Application of the APWM Mode                                              | 27        |
| 4    | Regis   | ters                                                                      | 34        |
|      | 4.1     | Time-Stamp Counter Register (TSCTR)                                       | 34        |
|      | 4.2     | Counter Phase Control Register (CTRPHS)                                   | 35        |
|      | 4.3     | Capture 1 Register (CAP1)                                                 | 35        |
|      | 4.4     | Capture 2 Register (CAP2)                                                 | 36        |
|      | 4.5     | Capture 3 Register (CAP3)                                                 | 36        |
|      | 4.6     | Capture 4 Register (CAP4)                                                 | 37        |
|      | 4.7     | ECAP Control Register 1 (ECCTL1)                                          | 37        |
|      | 4.8     | ECAP Control Register 2 (ECCTL2)                                          | 39        |
|      | 4.9     | ECAP Interrupt Enable Register (ECEINT)                                   | 40        |
|      | 4.10    | ECAP Interrupt Flag Register (ECFLG)                                      | 42        |
|      | 4.11    | ECAP Interrupt Clear Register (ECCLR)                                     |           |
|      | 4.12    | ECAP Interrupt Forcing Register (ECFRC)                                   |           |
|      | 4.13    | Revision ID Register (REVID)                                              | 45        |
| App  | endix A | Revision History                                                          | <b>46</b> |



# **List of Figures**

| 1  | Multiple eCAP Modules                                                      | . 9 |
|----|----------------------------------------------------------------------------|-----|
| 2  | Capture and APWM Modes of Operation                                        | 10  |
| 3  | Capture Function Diagram                                                   | 11  |
| 4  | Event Prescale Control                                                     | 12  |
| 5  | Prescale Function Waveforms                                                | 12  |
| 6  | Continuous/One-shot Block Diagram                                          | 13  |
| 7  | Counter and Synchronization Block Diagram                                  | 14  |
| 8  | Interrupts in eCAP Module                                                  | 16  |
| 9  | PWM Waveform Details Of APWM Mode Operation                                | 17  |
| 10 | Capture Sequence for Absolute Time-Stamp, Rising Edge Detect               | 19  |
| 11 | Capture Sequence for Absolute Time-Stamp, Rising and Falling Edge Detect   | 21  |
| 12 | Capture Sequence for Delta Mode Time-Stamp, Rising Edge Detect             | 23  |
| 13 | Capture Sequence for Delta Mode Time-Stamp, Rising and Falling Edge Detect | 25  |
| 14 | PWM Waveform Details of APWM Mode Operation                                | 27  |
| 15 | Multichannel PWM Example Using 4 eCAP Modules                              |     |
| 16 | Multiphase (channel) Interleaved PWM Example Using 3 eCAP Modules          | 32  |
| 17 | Time-Stamp Counter Register (TSCTR)                                        |     |
| 18 | Counter Phase Control Register (CTRPHS)                                    |     |
| 19 | Capture 1 Register (CAP1)                                                  | 35  |
| 20 | Capture 2 Register (CAP2)                                                  | 36  |
| 21 | Capture 3 Register (CAP3)                                                  |     |
| 22 | Capture 4 Register (CAP4)                                                  |     |
| 23 | ECAP Control Register 1 (ECCTL1)                                           |     |
| 24 | ECAP Control Register 2 (ECCTL2)                                           |     |
| 25 | ECAP Interrupt Enable Register (ECEINT)                                    |     |
| 26 | ECAP Interrupt Flag Register (ECFLG)                                       |     |
| 27 | ECAP Interrupt Clear Register (ECCLR)                                      |     |
| 28 | ECAP Interrupt Forcing Register (ECFRC)                                    | 44  |
| 29 | Revision ID Register (REVID)                                               | 45  |



# **List of Tables**

| 1   | ECAP Initialization for CAP Mode Absolute Time, Rising Edge Trigger             | 20 |
|-----|---------------------------------------------------------------------------------|----|
| 2   | ECAP Initialization for CAP Mode Absolute Time, Rising and Falling Edge Trigger | 22 |
| 3   | ECAP Initialization for CAP Mode Delta Time, Rising Edge Trigger                | 24 |
| 4   | ECAP Initialization for CAP Mode Delta Time, Rising and Falling Edge Triggers   | 26 |
| 5   | ECAP Initialization for APWM Mode                                               | 28 |
| 6   | ECAP1 Initialization for Multichannel PWM Generation with Synchronization       | 30 |
| 7   | ECAP2 Initialization for Multichannel PWM Generation with Synchronization       | 30 |
| 8   | ECAP3 Initialization for Multichannel PWM Generation with Synchronization       | 30 |
| 9   | ECAP4 Initialization for Multichannel PWM Generation with Synchronization       | 30 |
| 10  | ECAP1 Initialization for Multichannel PWM Generation with Phase Control         | 33 |
| 11  | ECAP2 Initialization for Multichannel PWM Generation with Phase Control         | 33 |
| 12  | ECAP3 Initialization for Multichannel PWM Generation with Phase Control         | 33 |
| 13  | Control and Status Register Set                                                 | 34 |
| 14  | Time-Stamp Counter Register (TSCTR) Field Descriptions                          | 34 |
| 15  | Counter Phase Control Register (CTRPHS) Field Descriptions                      | 35 |
| 16  | Capture 1 Register (CAP1) Field Descriptions                                    | 35 |
| 17  | Capture 2 Register (CAP2) Field Descriptions                                    | 36 |
| 18  | Capture 3 Register (CAP3) Field Descriptions                                    | 36 |
| 19  | Capture 4 Register (CAP4) Field Descriptions                                    | 37 |
| 20  | ECAP Control Register 1 (ECCTL1) Field Descriptions                             | 37 |
| 21  | ECAP Control Register 2 (ECCTL2) Field Descriptions                             | 39 |
| 22  | ECAP Interrupt Enable Register (ECEINT) Field Descriptions                      | 41 |
| 23  | ECAP Interrupt Flag Register (ECFLG) Field Descriptions                         | 42 |
| 24  | ECAP Interrupt Clear Register (ECCLR) Field Descriptions                        | 43 |
| 25  | ECAP Interrupt Forcing Register (ECFRC) Field Descriptions                      | 44 |
| 26  | Revision ID Register (REVID) Field Descriptions                                 | 45 |
| A-1 | Document Revision History                                                       | 46 |



# Read This First

#### **About This Manual**

Describes the enhanced capture (eCAP) module. The eCAP module is used in systems where accurate timing of external events is important.

#### **Notational Conventions**

This document uses the following conventions.

- Hexadecimal numbers are shown with the suffix h. For example, the following number is 40 hexadecimal (decimal 64): 40h.
- Registers in this document are shown in figures and described in tables.
  - Each register figure shows a rectangle divided into fields that represent the fields of the register.
     Each field is labeled with its bit name, its beginning and ending bit numbers above, and its read/write properties below. A legend explains the notation used for the properties.
  - Reserved bits in a register figure designate a bit that is used for future device expansion.

#### **Related Documentation From Texas Instruments**

The following documents describe the TMS320C674x Digital Signal Processors (DSPs) and OMAP-L1x Applications Processors. Copies of these documents are available on the Internet at <a href="https://www.ti.com">www.ti.com</a>. Tip: Enter the literature number in the search box provided at www.ti.com.

The current documentation that describes the DSP, related peripherals, and other technical collateral, is available in the C6000 DSP product folder at: <a href="https://www.ti.com/c6000">www.ti.com/c6000</a>.

- SPRUGM5 TMS320C6742 DSP System Reference Guide. Describes the C6742 DSP subsystem, system memory, device clocking, phase-locked loop controller (PLLC), power and sleep controller (PSC), power management, and system configuration module.
- <u>SPRUGJO</u> *TMS320C6743 DSP System Reference Guide*. Describes the System-on-Chip (SoC) including the C6743 DSP subsystem, system memory, device clocking, phase-locked loop controller (PLLC), power and sleep controller (PSC), power management, and system configuration module.
- SPRUFK4 TMS320C6745/C6747 DSP System Reference Guide. Describes the System-on-Chip (SoC) including the C6745/C6747 DSP subsystem, system memory, device clocking, phase-locked loop controller (PLLC), power and sleep controller (PSC), power management, and system configuration module.
- SPRUGM6 TMS320C6746 DSP System Reference Guide. Describes the C6746 DSP subsystem, system memory, device clocking, phase-locked loop controller (PLLC), power and sleep controller (PSC), power management, and system configuration module.
- SPRUGJ7 TMS320C6748 DSP System Reference Guide. Describes the C6748 DSP subsystem, system memory, device clocking, phase-locked loop controller (PLLC), power and sleep controller (PSC), power management, and system configuration module.
- SPRUG84 OMAP-L137 Applications Processor System Reference Guide. Describes the System-on-Chip (SoC) including the ARM subsystem, DSP subsystem, system memory, device clocking, phase-locked loop controller (PLLC), power and sleep controller (PSC), power management, ARM interrupt controller (AINTC), and system configuration module.



- SPRUGM7 OMAP-L138 Applications Processor System Reference Guide. Describes the System-on-Chip (SoC) including the ARM subsystem, DSP subsystem, system memory, device clocking, phase-locked loop controller (PLLC), power and sleep controller (PSC), power management, ARM interrupt controller (AINTC), and system configuration module.
- SPRUFK9 TMS320C674x/OMAP-L1x Processor Peripherals Overview Reference Guide. Provides an overview and briefly describes the peripherals available on the TMS320C674x Digital Signal Processors (DSPs) and OMAP-L1x Applications Processors.
- SPRUFK5 TMS320C674x DSP Megamodule Reference Guide. Describes the TMS320C674x digital signal processor (DSP) megamodule. Included is a discussion on the internal direct memory access (IDMA) controller, the interrupt controller, the power-down controller, memory protection, bandwidth management, and the memory and cache.
- SPRUFE8 TMS320C674x DSP CPU and Instruction Set Reference Guide. Describes the CPU architecture, pipeline, instruction set, and interrupts for the TMS320C674x digital signal processors (DSPs). The C674x DSP is an enhancement of the C64x+ and C67x+ DSPs with added functionality and an expanded instruction set.
- SPRUG82 TMS320C674x DSP Cache User's Guide. Explains the fundamentals of memory caches and describes how the two-level cache-based internal memory architecture in the TMS320C674x digital signal processor (DSP) can be efficiently used in DSP applications. Shows how to maintain coherence with external memory, how to use DMA to reduce memory latencies, and how to optimize your code to improve cache efficiency. The internal memory architecture in the C674x DSP is organized in a two-level hierarchy consisting of a dedicated program cache (L1P) and a dedicated data cache (L1D) on the first level. Accesses by the CPU to the these first level caches can complete without CPU pipeline stalls. If the data requested by the CPU is not contained in cache, it is fetched from the next lower memory level, L2 or external memory.



# Enhanced Capture (eCAP) Module

The enhanced capture (eCAP) module is essential in systems where accurate timing of external events is important.

#### 1 Introduction

### 1.1 Purpose of the Peripheral

Uses for eCAP include:

- Sample rate measurements of audio inputs
- Speed measurements of rotating machinery (for example, toothed sprockets sensed via Hall sensors)
- Elapsed time measurements between position sensor pulses
- Period and duty cycle measurements of pulse train signals
- Decoding current or voltage amplitude derived from duty cycle encoded current/voltage sensors

#### 1.2 Features

The eCAP module includes the following features:

- 32-bit time base counter
- 4-event time-stamp registers (each 32 bits)
- Edge polarity selection for up to four sequenced time-stamp capture events
- · Interrupt on either of the four events
- Single shot capture of up to four event time-stamps
- · Continuous mode capture of time-stamps in a four-deep circular buffer
- Absolute time-stamp capture
- Difference (Delta) mode time-stamp capture
- All above resources dedicated to a single input pin
- When not used in capture mode, the ECAP module can be configured as a single channel PWM output



www.ti.com Architecture

#### 2 Architecture

The eCAP module represents one complete capture channel that can be instantiated multiple times depending on the target device. In the context of this guide, one eCAP channel has the following independent key resources:

- Dedicated input capture pin
- 32-bit time base counter
- 4 × 32-bit time-stamp capture registers (CAP1-CAP4)
- 4-stage sequencer (Modulo4 counter) that is synchronized to external events, ECAP pin rising/falling edges.
- Independent edge polarity (rising/falling edge) selection for all 4 events
- Input capture signal prescaling (from 2-62)
- One-shot compare register (2 bits) to freeze captures after 1 to 4 time-stamp events
- Control for continuous time-stamp captures using a 4-deep circular buffer (CAP1-CAP4) scheme
- Interrupt capabilities on any of the 4 capture events

Multiple identical eCAP modules can be contained in a system as shown in Figure 1. The number of modules is device-dependent and is based on target application needs. In this document, the letter x within a signal or module name is used to indicate a generic eCAP instance on a device.



Figure 1. Multiple eCAP Modules



Architecture www.ti.com

### 2.1 Capture and APWM Operating Mode

You can use the eCAP module resources to implement a single-channel PWM generator (with 32 bit capabilities) when it is not being used for input captures. The counter operates in count-up mode, providing a time-base for asymmetrical pulse width modulation (PWM) waveforms. The CAP1 and CAP2 registers become the active period and compare registers, respectively, while CAP3 and CAP4 registers become the period and capture shadow registers, respectively. Figure 2 is a high-level view of both the capture and auxiliary pulse-width modulator (APWM) modes of operation.



Figure 2. Capture and APWM Modes of Operation

- A single pin is shared between CAP and APWM functions. In capture mode, it is an input; in APWM mode, it
  is an output.
- (2) In APWM mode, writing any value to CAP1/CAP2 active registers also writes the same value to the corresponding shadow registers CAP3/CAP4. This emulates immediate mode. Writing to the shadow registers CAP3/CAP4 invokes the shadow mode.



www.ti.com Architecture

# 2.2 Capture Mode Description

Figure 3 shows the various components that implement the capture function.

CTR=CMP

Registers: ECEINT, ECFLG, ECCLR, ECFRC

ECCTL2[SYNCI\_EN, SYNCOSEL, SWSYNC] ECCTL2[CAP/APWM] CTRPHS APWM mode (phase register-32 bit) SYNCIn → CTR\_OVF OVF CTR [0-31] TSCTR SYNCOut PWM (counter-32 bit) PRD [0-31] Delta-mode compare logic CMP [0-31] 32 CTR=PRD ◀ CTR [0-31] CTR=CMP PRD [0-31] ECCTL1 [ CAPLDEN, CTRRSTx] **ECAP**x 32 LD1 MODE SELECT CAP1 Polarity  $\blacktriangleright$ (APRD active) select APRD CMP [0-31] 32 CAP2 LD2 Polarity LD (ACMP active) select Event Event 32 ACMP qualifier shadow Prescale ECCTL1[EVTPS] Polarity CAP3 LD3 select LD (APRD shadow) LD4 CAP4 Polarity LD (ACMP shadow) select Edge Polarity Select ECCTL1[CAPxPOL] Capture events CEVT[1:4] Interrupt Continuous / to Interrupt Trigger Oneshot and CTR\_OVF Capture Control Flag CTR=PRD control

ECCTL2 [ RE-ARM, CONT/ONESHT, STOP\_WRAP]

Figure 3. Capture Function Diagram



Architecture www.ti.com

#### 2.2.1 Event Prescaler

An input capture signal (pulse train) can be prescaled by N = 2-62 (in multiples of 2) or can bypass the prescaler. This is useful when very high frequency signals are used as inputs. Figure 4 shows a functional diagram and Figure 5 shows the operation of the prescale function.

PSout

| Description of the content of the content

**Figure 4. Event Prescale Control** 

(1) When a prescale value of 1 is chosen (ECCTL1[13:9] = 0000) the input capture signal by-passes the prescale logic completely.



Figure 5. Prescale Function Waveforms



www.ti.com Architecture

#### 2.2.2 Edge Polarity Select and Qualifier

 Four independent edge polarity (rising edge/falling edge) selection multiplexers are used, one for each capture event.

- Each edge (up to 4) is event qualified by the Modulo4 sequencer.
- The edge event is gated to its respective CAP*n* register by the Mod4 counter. The CAP*n* register is loaded on the falling edge.

#### 2.2.3 Continuous/One-Shot Control

- The Mod4 (2 bit) counter is incremented via edge qualified events (CEVT1-CEVT4).
- The Mod4 counter continues counting (0->1->2->3->0) and wraps around unless stopped.
- A 2-bit stop register is used to compare the Mod4 counter output, and when equal stops the Mod4 counter and inhibits further loads of the CAP1-CAP4 registers. This occurs during one-shot operation.

The continuous/one-shot block controls the start/stop and reset (zero) functions of the Mod4 counter via a mono-shot type of action that can be triggered by the stop-value comparator and re-armed via software control.

Once armed, the eCAP module waits for 1-4 (defined by stop-value) capture events before freezing both the Mod4 counter and contents of CAP1-4 registers (time-stamps).

Re-arming prepares the eCAP module for another capture sequence. Also re-arming clears (to zero) the Mod4 counter and permits loading of CAP1-4 registers again, providing the CAPLDEN bit is set.

In continuous mode, the Mod4 counter continues to run (0->1->2->3->0, the one-shot action is ignored, and capture values continue to be written to CAP1-4 in a circular buffer sequence.



Figure 6. Continuous/One-shot Block Diagram



Architecture www.ti.com

#### 2.2.4 32-Bit Counter and Phase Control

This counter provides the time-base for event captures, and is clocked via the system clock.

A phase register is provided to achieve synchronization with other counters, via a hardware and software forced sync. This is useful in APWM mode when a phase offset between modules is needed.

On any of the four event loads, an option to reset the 32-bit counter is given. This is useful for time difference capture. The 32-bit counter value is captured first, then it is reset to 0 by any of the LD1-LD4 signals.



Figure 7. Counter and Synchronization Block Diagram



www.ti.com Architecture

#### 2.2.5 CAP1-CAP4 Registers

These 32-bit registers are fed by the 32-bit counter timer bus, CTR[0-31] and are loaded (capture a time-stamp) when their respective LD inputs are strobed.

Loading of the capture registers can be inhibited via control bit CAPLDEN. During one-shot operation, this bit is cleared (loading is inhibited) automatically when a stop condition occurs, StopValue = Mod4.

CAP1 and CAP2 registers become the active period and compare registers, respectively, in APWM mode.

CAP3 and CAP4 registers become the respective shadow registers (APRD and ACMP) for CAP1 and CAP2 during APWM operation.

#### 2.2.6 Interrupt Control

An Interrupt can be generated on capture events (CEVT1-CEVT4, CTROVF) or APWM events (CTR = PRD, CTR = CMP). See Figure 8.

A counter overflow event (FFFF FFFFh->0000 0000h) is also provided as an interrupt source (CTROVF).

The capture events are edge and sequencer qualified (that is, ordered in time) by the polarity select and Mod4 gating, respectively.

One of these events can be selected as the interrupt source (from the eCAPn module) going to the interrupt controller.

Seven interrupt events (CEVT1, CEVT2, CEVT3, CEVT4, CNTOVF, CTR = PRD, CTR = CMP) can be generated. The interrupt enable register (ECEINT) is used to enable/disable individual interrupt event sources. The interrupt flag register (ECFLG) indicates if any interrupt event has been latched and contains the global interrupt flag bit (INT). An interrupt pulse is generated to the interrupt controller only if any of the interrupt events are enabled, the flag bit is 1, and the INT flag bit is 0. The interrupt service routine must clear the global interrupt flag bit and the serviced event via the interrupt clear register (ECCLR) before any other interrupt pulses are generated. You can force an interrupt event via the interrupt force register (ECFRC). This is useful for test purposes.

#### 2.2.7 Shadow Load and Lockout Control

In capture mode, this logic inhibits (locks out) any shadow loading of CAP1 or CAP2 from APRD and ACMP registers, respectively.

In APWM mode, shadow loading is active and two choices are permitted:

- Immediate APRD or ACMP are transferred to CAP1 or CAP2 immediately upon writing a new value.
- On period equal, CTR[31:0] = PRD[31:0]

Note: The CEVT1, CEVT2, CEVT3, CEVT4 flags are only active in capture mode (ECCTL2[CAP/APWM == 0]). The CTR = PRD, CTR = CMP flags are only valid in APWM mode (ECCTL2[CAP/APWM == 1]). CNTOVF flag is valid in both modes.



Architecture www.ti.com

Figure 8. Interrupts in eCAP Module





www.ti.com Architecture

#### 2.2.8 APWM Mode Operation

Main operating highlights of the APWM section:

- The time-stamp counter bus is made available for comparison via 2 digital (32-bit) comparators.
- When CAP1/2 registers are not used in capture mode, their contents can be used as Period and Compare values in APWM mode.
- Double buffering is achieved via shadow registers APRD and ACMP (CAP3/4). The shadow register
  contents are transferred over to CAP1/2 registers either immediately upon a write, or on a CTR = PRD
  trigger.
- In APWM mode, writing to CAP1/CAP2 active registers will also write the same value to the corresponding shadow registers CAP3/CAP4. This emulates immediate mode. Writing to the shadow registers CAP3/CAP4 will invoke the shadow mode.
- During initialization, you must write to the active registers for both period and compare. This
  automatically copies the initial values into the shadow values. For subsequent compare updates,
  during run-time, you only need to use the shadow registers.



Figure 9. PWM Waveform Details Of APWM Mode Operation

#### The behavior of APWM active-high mode (APWMPOL == 0) is:

```
CMP = 0x00000000, output low for duration of period (0% duty)
CMP = 0x00000001, output high 1 cycle
CMP = 0x00000002, output high 2 cycles
CMP = PERIOD, output high except for 1 cycle (<100% duty)
CMP = PERIOD+1, output high for complete period (100% duty)</pre>
CMP > PERIOD+1, output high for complete period
```

#### The behavior of APWM active-low mode (APWMPOL == 1) is:

```
CMP = 0x00000000, output high for duration of period (0% duty)
CMP = 0x00000001, output low 1 cycle
CMP = 0x00000002, output low 2 cycles
CMP = PERIOD, output low except for 1 cycle (<100% duty)
CMP = PERIOD+1, output low for complete period (100% duty)</pre>
CMP > PERIOD+1, output low for complete period
```



Applications www.ti.com

#### 3 Applications

The following sections will provide Applications examples and code snippets to show how to configure and operate the eCAP module. For clarity and ease of use, below are useful #defines which will help in the understanding of the examples.

```
// ECCTL1 ( ECAP Control Reg 1)
//==========
// CAPxPOL bits
#define EC_RISING
                                   0x0
#define EC_FALLING
                                   0x1
// CTRRSTx bits
#define EC_ABS_MODE
                                   0 \times 0
#define
          EC_DELTA_MODE
                                   0x1
// PRESCALE bits
#define EC_BYPASS
                                   0x0
          EC DIV1
#define
                                   0x0
#define EC_DIV2
                                   0x1
#define EC_DIV4
#define EC_DIV6
#define EC_DIV8
                                   0x2
                                   0x3
                                   0x4
#define EC_DIV10
                                   0x5
// ECCTL2 ( ECAP Control Reg 2)
// CONT/ONESHOT bit
#define EC_CONTINUOUS
                                   0x0
#define EC_ONESHOT
                                   0x1
// STOPVALUE bit
#define EC_EVENT1
                                   0x0
#define EC_EVENT2
                                   0x1
#define EC_EVENT3
#define EC_EVENT4
                                   0x2
                                   0x3
// RE-ARM bit
#define
          EC_ARM
                                   0x1
// TSCTRSTOP bit
#define EC_FREEZE #define EC_RUN
                                   0x0
                                   0x1
// SYNCO_SEL bit
#define EC_SYNCIN #define EC_CTR_PRD
                                   0x0
                                   0x1
#define EC_SYNCO_DIS
                                   0x2
// CAP/APWM mode bit
#define EC_CAP_MODE
                                   0x0
#define
          EC_APWM_MODE
                                   0x1
// APWMPOL bit
#define EC_ACTV_HI
                                   0x0
#define
          EC_ACTV_LO
                                   0x1
// Generic
#define EC_DISABLE #define EC_ENABLE
                                   0x0
                                   0x1
#define EC_FORCE
                                   0x1
```



www.ti.com Applications

# 3.1 Absolute Time-Stamp Operation Rising Edge Trigger Example

Figure 10 shows an example of continuous capture operation (Mod4 counter wraps around). In this figure, TSCTR counts-up without resetting and capture events are qualified on the rising edge only, this gives period (and frequency) information.

On an event, the TSCTR contents (time-stamp) is first captured, then Mod4 counter is incremented to the next state. When the TSCTR reaches FFFF FFFFh (maximum value), it wraps around to 0000 0000h (not shown in Figure 10), if this occurs, the CTROVF (counter overflow) flag is set, and an interrupt (if enabled) occurs, CTROVF (counter overflow) Flag is set, and an Interrupt (if enabled) occurs. Captured time-stamps are valid at the point indicated by the diagram, after the 4th event, hence event CEVT4 can conveniently be used to trigger an interrupt and the CPU can read data from the CAP*n* registers.



Figure 10. Capture Sequence for Absolute Time-Stamp, Rising Edge Detect



Applications www.ti.com

Table 1. ECAP Initialization for CAP Mode Absolute Time, Rising Edge Trigger

| Register | Bit         | Value         |
|----------|-------------|---------------|
| ECCTL1   | CAP1POL     | EC_RISING     |
| ECCTL1   | CAP2POL     | EC_RISING     |
| ECCTL1   | CAP3POL     | EC_RISING     |
| ECCTL1   | CAP4POL     | EC_RISING     |
| ECCTL1   | CTRRST1     | EC_ABS_MODE   |
| ECCTL1   | CTRRST2     | EC_ABS_MODE   |
| ECCTL1   | CTRRST3     | EC_ABS_MODE   |
| ECCTL1   | CTRRST4     | EC_ABS_MODE   |
| ECCTL1   | CAPLDEN     | EC_ENABLE     |
| ECCTL1   | PRESCALE    | EC_DIV1       |
| ECCTL2   | CAP_APWM    | EC_CAP_MODE   |
| ECCTL2   | CONT_ONESHT | EC_CONTINUOUS |
| ECCTL2   | SYNCO_SEL   | EC_SYNCO_DIS  |
| ECCTL2   | SYNCI_EN    | EC_DISABLE    |
| ECCTL2   | TSCTRSTOP   | EC_RUN        |

#### Example 1. Code Snippet for CAP Mode Absolute Time, Rising Edge Trigger

www.ti.com Applications

# 3.2 Absolute Time-Stamp Operation Rising and Falling Edge Trigger Example

In Figure 11 the eCAP operating mode is almost the same as in the previous section except capture events are qualified as either rising or falling edge, this now gives both period and duty cycle information: Period1 =  $t_3 - t_1$ , Period2 =  $t_5 - t_3$ , ...etc. Duty Cycle1 (on-time %) =  $(t_2 - t_1)$  / Period1 x 100%, etc. Duty Cycle1 (off-time %) =  $(t_3 - t_2)$  / Period1 x 100%, etc.



Figure 11. Capture Sequence for Absolute Time-Stamp, Rising and Falling Edge Detect



Applications www.ti.com

Table 2. ECAP Initialization for CAP Mode Absolute Time, Rising and Falling Edge Trigger

| Register | Bit         | Value         |
|----------|-------------|---------------|
| ECCTL1   | CAP1POL     | EC_RISING     |
| ECCTL1   | CAP2POL     | EC_FALLING    |
| ECCTL1   | CAP3POL     | EC_RISING     |
| ECCTL1   | CAP4POL     | EC_FALLING    |
| ECCTL1   | CTRRST1     | EC_ABS_MODE   |
| ECCTL1   | CTRRST2     | EC_ABS_MODE   |
| ECCTL1   | CTRRST3     | EC_ABS_MODE   |
| ECCTL1   | CTRRST4     | EC_ABS_MODE   |
| ECCTL1   | CAPLDEN     | EC_ENABLE     |
| ECCTL1   | PRESCALE    | EC_DIV1       |
| ECCTL2   | CAP_APWM    | EC_CAP_MODE   |
| ECCTL2   | CONT_ONESHT | EC_CONTINUOUS |
| ECCTL2   | SYNCO_SEL   | EC_SYNCO_DIS  |
| ECCTL2   | SYNCI_EN    | EC_DISABLE    |
| ECCTL2   | TSCTRSTOP   | EC_RUN        |

#### Example 2. Code Snippet for CAP Mode Absolute Time, Rising and Falling Edge Trigger



www.ti.com Applications

### 3.3 Time Difference (Delta) Operation Rising Edge Trigger Example

Figure 12 shows how the eCAP module can be used to collect Delta timing data from pulse train waveforms. Here Continuous Capture mode (TSCTR counts-up without resetting, and Mod4 counter wraps around) is used. In Delta-time mode, TSCTR is Reset back to Zero on every valid event. Here Capture events are qualified as Rising edge only. On an event, TSCTR contents (time-stamp) is captured first, and then TSCTR is reset to Zero. The Mod4 counter then increments to the next state. If TSCTR reaches FFFF FFFFh (maximum value), before the next event, it wraps around to 0000 0000h and continues, a CNTOVF (counter overflow) Flag is set, and an Interrupt (if enabled) occurs. The advantage of Delta-time Mode is that the CAPn contents directly give timing data without the need for CPU calculations: Period1 =  $T_1$ , Period2 =  $T_2$ ,...etc. As shown in Figure 12, the CEVT1 event is a good trigger point to read the timing data,  $T_1$ ,  $T_2$ ,  $T_3$ ,  $T_4$  are all valid here.



Figure 12. Capture Sequence for Delta Mode Time-Stamp, Rising Edge Detect



Applications www.ti.com

Table 3. ECAP Initialization for CAP Mode Delta Time, Rising Edge Trigger

| Register | Bit         | Value         |
|----------|-------------|---------------|
| ECCTL1   | CAP1POL     | EC_RISING     |
| ECCTL1   | CAP2POL     | EC_RISING     |
| ECCTL1   | CAP3POL     | EC_RISING     |
| ECCTL1   | CAP4POL     | EC_RISING     |
| ECCTL1   | CTRRST1     | EC_DELTA_MODE |
| ECCTL1   | CTRRST2     | EC_DELTA_MODE |
| ECCTL1   | CTRRST3     | EC_DELTA_MODE |
| ECCTL1   | CTRRST4     | EC_DELTA_MODE |
| ECCTL1   | CAPLDEN     | EC_ENABLE     |
| ECCTL1   | PRESCALE    | EC_DIV1       |
| ECCTL2   | CAP_APWM    | EC_CAP_MODE   |
| ECCTL2   | CONT_ONESHT | EC_CONTINUOUS |
| ECCTL2   | SYNCO_SEL   | EC_SYNCO_DIS  |
| ECCTL2   | SYNCI_EN    | EC_DISABLE    |
| ECCTL2   | TSCTRSTOP   | EC_RUN        |

#### Example 3. Code Snippet for CAP Mode Delta Time, Rising Edge Trigger



www.ti.com Applications

# 3.4 Time Difference (Delta) Operation Rising and Falling Edge Trigger Example

In Figure 13 the eCAP operating mode is almost the same as in previous section except Capture events are qualified as either Rising or Falling edge, this now gives both Period and Duty cycle information: Period1 =  $T_1 + T_2$ , Period2 =  $T_3 + T_4$ , ...etc Duty Cycle1 (on-time %) =  $T_1$  / Period1 × 100%, etc Duty Cycle1 (off-time %) =  $T_2$  / Period1 × 100%, etc

During initialization, you must write to the active registers for both period and compare. This will then automatically copy the init values into the shadow values. For subsequent compare updates, that is, during run-time, only the shadow registers must be used.



Figure 13. Capture Sequence for Delta Mode Time-Stamp, Rising and Falling Edge Detect



Applications www.ti.com

Table 4. ECAP Initialization for CAP Mode Delta Time, Rising and Falling Edge Triggers

| Register | Bit         | Value         |
|----------|-------------|---------------|
| ECCTL1   | CAP1POL     | EC_RISING     |
| ECCTL1   | CAP2POL     | EC_FALLING    |
| ECCTL1   | CAP3POL     | EC_RISING     |
| ECCTL1   | CAP4POL     | EC_FALLING    |
| ECCTL1   | CTRRST1     | EC_DELTA_MODE |
| ECCTL1   | CTRRST2     | EC_DELTA_MODE |
| ECCTL1   | CTRRST3     | EC_DELTA_MODE |
| ECCTL1   | CTRRST4     | EC_DELTA_MODE |
| ECCTL1   | CAPLDEN     | EC_ENABLE     |
| ECCTL1   | PRESCALE    | EC_DIV1       |
| ECCTL2   | CAP_APWM    | EC_CAP_MODE   |
| ECCTL2   | CONT_ONESHT | EC_CONTINUOUS |
| ECCTL2   | SYNCO_SEL   | EC_SYNCO_DIS  |
| ECCTL2   | SYNCI_EN    | EC_DISABLE    |
| ECCTL2   | TSCTRSTOP   | EC_RUN        |

#### Example 4. Code Snippet for CAP Mode Delta Time, Rising and Falling Edge Triggers



www.ti.com Applications

# 3.5 Application of the APWM Mode

#### 3.5.1 Simple PWM Generation (Independent Channel/s) Example

In this example, the eCAP module is configured to operate as a PWM generator. Here a very simple single channel PWM waveform is generated from output pin APWMn. The PWM polarity is active high, which means that the compare value (CAP2 reg is now a compare register) represents the on-time (high level) of the period. Alternatively, if the APWMPOL bit is configured for active low, then the compare value represents the off-time.



Figure 14. PWM Waveform Details of APWM Mode Operation



Applications www.ti.com

| Table 5  | ECAD  | Initialization | £ ~ = | A DIA/RA | Mada  |
|----------|-------|----------------|-------|----------|-------|
| l able 5 | F(:AP | initialization | tor   | APWIN    | MUUGE |

| Register | Bit       | Value        |
|----------|-----------|--------------|
| CAP1     | CAP1      | 0x1000       |
| CTRPHS   | CTRPHS    | 0x0          |
| ECCTL2   | CAP_APWM  | EC_APWM_MODE |
| ECCTL2   | APWMPOL   | EC_ACTV_HI   |
| ECCTL2   | SYNCI_EN  | EC_DISABLE   |
| ECCTL2   | SYNCO_SEL | EC_SYNCO_DIS |
| ECCTL2   | TSCTRSTOP | EC_RUN       |

#### Example 5. Code Snippet for APWM Mode

#### 3.5.2 Multichannel PWM Generation with Synchronization Example

Figure 15 takes advantage of the synchronization feature between eCAP modules. Here 4 independent PWM channels are required with different frequencies, but at integer multiples of each other to avoid "beat" frequencies. Hence one eCAP module is configured as the Master and the remaining 3 are Slaves all receiving their synch pulse (CTR = PRD) from the master. Note the Master is chosen to have the lower frequency (F1 = 1/20,000) requirement. Here Slave2 Freq =  $2 \times F1$ , Slave3 Freq =  $4 \times F1$  and Slave4 Freq =  $5 \times F1$ . Note here values are in decimal notation. Also, only the APWM1 output waveform is shown.

www.ti.com Applications

DC bus Motor Motor Motor Motor dc dc dc dc brush brush brush brush APWM2 APWM1 APWM3 APWM4

Figure 15. Multichannel PWM Example Using 4 eCAP Modules





Applications www.ti.com

Table 6. ECAP1 Initialization for Multichannel PWM Generation with Synchronization

|          | •         |              |  |
|----------|-----------|--------------|--|
| Register | Bit       | Value        |  |
| CAP1     | CAP1      | 20000        |  |
| CTRPHS   | CTRPHS    | 0            |  |
| ECCTL2   | CAP_APWM  | EC_APWM_MODE |  |
| ECCTL2   | APWMPOL   | EC_ACTV_HI   |  |
| ECCTL2   | SYNCI_EN  | EC_DISABLE   |  |
| ECCTL2   | SYNCO_SEL | EC_CTR_PRD   |  |
| ECCTL2   | TSCTRSTOP | EC_RUN       |  |

Table 7. ECAP2 Initialization for Multichannel PWM Generation with Synchronization

| Register | Bit       | Value        |
|----------|-----------|--------------|
| CAP1     | CAP1      | 10000        |
| CTRPHS   | CTRPHS    | 0            |
| ECCTL2   | CAP_APWM  | EC_APWM_MODE |
| ECCTL2   | APWMPOL   | EC_ACTV_HI   |
| ECCTL2   | SYNCI_EN  | EC_ENABLE    |
| ECCTL2   | SYNCO_SEL | EC_SYNCI     |
| ECCTL2   | TSCTRSTOP | EC_RUN       |

Table 8. ECAP3 Initialization for Multichannel PWM Generation with Synchronization

| Register | Bit       | Value        |
|----------|-----------|--------------|
| CAP1     | CAP1      | 5000         |
| CTRPHS   | CTRPHS    | 0            |
| ECCTL2   | CAP_APWM  | EC_APWM_MODE |
| ECCTL2   | APWMPOL   | EC_ACTV_HI   |
| ECCTL2   | SYNCI_EN  | EC_ENABLE    |
| ECCTL2   | SYNCO_SEL | EC_SYNCI     |
| ECCTL2   | TSCTRSTOP | EC_RUN       |

Table 9. ECAP4 Initialization for Multichannel PWM Generation with Synchronization

| Register | Bit       | Value        |
|----------|-----------|--------------|
| CAP1     | CAP1      | 4000         |
| CTRPHS   | CTRPHS    | 0            |
| ECCTL2   | CAP_APWM  | EC_APWM_MODE |
| ECCTL2   | APWMPOL   | EC_ACTV_HI   |
| ECCTL2   | SYNCI_EN  | EC_ENABLE    |
| ECCTL2   | SYNCO_SEL | EC_SYNCO_DIS |
| ECCTL2   | TSCTRSTOP | EC_RUN       |

www.ti.com Applications

#### Example 6. Code Snippet for Multichannel PWM Generation with Synchronization

#### 3.5.3 Multichannel PWM Generation with Phase Control Example

In Figure 16, the Phase control feature of the APWM mode is used to control a 3 phase Interleaved DC/DC converter topology. This topology requires each phase to be off-set by 120° from each other. Hence if "Leg" 1 (controlled by APWM1) is the reference Leg (or phase), that is, 0°, then Leg 2 need 120° off-set and Leg 3 needs 240° off-set. The waveforms in Figure 16 show the timing relationship between each of the phases (Legs). Note eCAP1 module is the Master and issues a sync out pulse to the slaves (modules 2, 3) whenever TSCTR = Period value.



Applications www.ti.com

Comple-Comple-Complementary mentary and mentary and and deadband deadband deadband logic logic logic APWM1 APWM2 APWM3 Vout **TSCTR** 1200 APRD(1) 700 APRD(1) -SYNCO pulse (CTR=PRD) APWM1 CTRPHS(2)=800 **№** Φ2=120° APWM2  $\Phi$ 3=240° CTRPHS(3)=400 APWM3

Figure 16. Multiphase (channel) Interleaved PWM Example Using 3 eCAP Modules



www.ti.com Applications

Table 10. ECAP1 Initialization for Multichannel PWM Generation with Phase Control

| Register | Bit       | Value        |
|----------|-----------|--------------|
| CAP1     | CAP1      | 1200         |
| CTRPHS   | CTRPHS    | 0            |
| ECCTL2   | CAP_APWM  | EC_APWM_MODE |
| ECCTL2   | APWMPOL   | EC_ACTV_HI   |
| ECCTL2   | SYNCI_EN  | EC_DISABLE   |
| ECCTL2   | SYNCO_SEL | EC_CTR_PRD   |
| ECCTL2   | TSCTRSTOP | EC_RUN       |

Table 11. ECAP2 Initialization for Multichannel PWM Generation with Phase Control

| Register | Bit       | Value        |
|----------|-----------|--------------|
| CAP1     | CAP1      | 1200         |
| CTRPHS   | CTRPHS    | 800          |
| ECCTL2   | CAP_APWM  | EC_APWM_MODE |
| ECCTL2   | APWMPOL   | EC_ACTV_HI   |
| ECCTL2   | SYNCI_EN  | EC_ENABLE    |
| ECCTL2   | SYNCO_SEL | EC_SYNCI     |
| ECCTL2   | TSCTRSTOP | EC_RUN       |

Table 12. ECAP3 Initialization for Multichannel PWM Generation with Phase Control

| Register | Bit       | Value        |
|----------|-----------|--------------|
| CAP1     | CAP1      | 1200         |
| CTRPHS   | CTRPHS    | 400          |
| ECCTL2   | CAP_APWM  | EC_APWM_MODE |
| ECCTL2   | APWMPOL   | EC_ACTV_HI   |
| ECCTL2   | SYNCI_EN  | EC_ENABLE    |
| ECCTL2   | SYNCO_SEL | EC_SYNCO_DIS |
| ECCTL2   | TSCTRSTOP | EC_RUN       |

#### Example 7. Code Snippet for Multichannel PWM Generation with Phase Control



Registers www.ti.com

# Registers

Table 13 shows the eCAP module control and status register set. All 32-bit registers are aligned on even address boundaries and are organized in little-endian mode. The 16 least-significant bits of a 32-bit register are located on lowest address (even address).

Note: In APWM mode, writing to CAP1/CAP2 active registers also writes the same value to the corresponding shadow registers CAP3/CAP4. This emulates immediate mode. Writing to the shadow registers CAP3/CAP4 invokes the shadow mode.

Table 13. Control and Status Register Set

| Offset | Acronym | Description                         | Size (×16) | Section      |
|--------|---------|-------------------------------------|------------|--------------|
| 0h     | TSCTR   | Time-Stamp Counter Register         | 2          | Section 4.1  |
| 4h     | CTRPHS  | Counter Phase Offset Value Register | 2          | Section 4.2  |
| 8h     | CAP1    | Capture 1 Register                  | 2          | Section 4.3  |
| Ch     | CAP2    | Capture 2 Register                  | 2          | Section 4.4  |
| 10h    | CAP3    | Capture 3 Register                  | 2          | Section 4.5  |
| 14h    | CAP4    | Capture 4 Register                  | 2          | Section 4.6  |
| 28h    | ECCTL1  | Capture Control Register 1          | 1          | Section 4.7  |
| 2Ah    | ECCTL2  | Capture Control Register 2          | 1          | Section 4.8  |
| 2Ch    | ECEINT  | Capture Interrupt Enable Register   | 1          | Section 4.9  |
| 2Eh    | ECFLG   | Capture Interrupt Flag Register     | 1          | Section 4.10 |
| 30h    | ECCLR   | Capture Interrupt Clear Register    | 1          | Section 4.11 |
| 32h    | ECFRC   | Capture Interrupt Force Register    | 1          | Section 4.12 |
| 5Ch    | REVID   | Revision ID Register                | 2          | Section 4.13 |

#### 4.1 Time-Stamp Counter Register (TSCTR)

The time-stamp counter register (TSCTR) is shown in Figure 17 and described in Table 14.

Figure 17. Time-Stamp Counter Register (TSCTR)



LEGEND: R/W = Read/Write: -n = value after reset

#### Table 14. Time-Stamp Counter Register (TSCTR) Field Descriptions

| Ī | Bit  | Field | Value        | Description                                                          |
|---|------|-------|--------------|----------------------------------------------------------------------|
|   | 31-0 | TSCTR | 0-FFFF FFFFh | Active 32-bit counter register that is used as the capture time-base |



www.ti.com Registers

# 4.2 Counter Phase Control Register (CTRPHS)

The counter phase control register (CTRPHS) is shown in Figure 18 and described in Table 15.

#### Figure 18. Counter Phase Control Register (CTRPHS)



LEGEND: R/W = Read/Write; -n = value after reset

#### Table 15. Counter Phase Control Register (CTRPHS) Field Descriptions

| Bit  | Field  | Value        | Description                                                                                                                                                                                                                                                                          |
|------|--------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | CTRPHS | 0-FFFF FFFFh | Counter phase value register that can be programmed for phase lag/lead. This register shadows TSCTR and is loaded into TSCTR upon either a SYNCI event or S/W force via a control bit. Used to achieve phase control synchronization with respect to other eCAP and EPWM time-bases. |

# 4.3 Capture 1 Register (CAP1)

The capture 1 register (CAP1) is shown in Figure 19 and described in Table 16.

#### Figure 19. Capture 1 Register (CAP1)



LEGEND: R/W = Read/Write; -n = value after reset

#### Table 16. Capture 1 Register (CAP1) Field Descriptions

| Bit  | Field | Value        | Description                                             |
|------|-------|--------------|---------------------------------------------------------|
| 31-0 | CAP1  | 0-FFFF FFFFh | This register can be loaded (written) by:               |
|      |       |              | Time-Stamp (i.e., counter value) during a capture event |
|      |       |              | Software - may be useful for test purposes              |
|      |       |              | APRD active register when used in APWM mode             |



Registers www.ti.com

# 4.4 Capture 2 Register (CAP2)

The capture 2 register (CAP2) is shown in Figure 20 and described in Table 17.

# Figure 20. Capture 2 Register (CAP2)



LEGEND: R/W = Read/Write; -n = value after reset

### Table 17. Capture 2 Register (CAP2) Field Descriptions

| Bit  | Field | Value        | Description                                             |
|------|-------|--------------|---------------------------------------------------------|
| 31-0 | CAP2  | 0-FFFF FFFFh | This register can be loaded (written) by:               |
|      |       |              | Time-Stamp (i.e., counter value) during a capture event |
|      |       |              | Software - may be useful for test purposes              |
|      |       |              | ACMP active register when used in APWM mode             |

#### 4.5 Capture 3 Register (CAP3)

The capture 3 register (CAP3) is shown in Figure 21 and described in Table 18.

# Figure 21. Capture 3 Register (CAP3)



LEGEND: R/W = Read/Write; -n = value after reset

#### Table 18. Capture 3 Register (CAP3) Field Descriptions

| Bit  | Field | Value        | Description                                                                                                                                                                                          |
|------|-------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | CAP3  | 0-FFFF FFFFh | In CMP mode, this is a time-stamp capture register. In APWM mode, this is the period shadow (APRD) register. You update the PWM period value through this register. In this mode, CAP3 shadows CAP1. |



www.ti.com Registers

# 4.6 Capture 4 Register (CAP4)

The capture 4 register (CAP4) is shown in Figure 22 and described in Table 19.

#### Figure 22. Capture 4 Register (CAP4)



LEGEND: R/W = Read/Write; -n = value after reset

### Table 19. Capture 4 Register (CAP4) Field Descriptions

| Bit  | Field | Value        | Description                                                                                                                                                                                            |
|------|-------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0 | CAP4  | 0-FFFF FFFFh | In CMP mode, this is a time-stamp capture register. In APWM mode, this is the compare shadow (ACMP) register. You update the PWM compare value through this register. In this mode, CAP4 shadows CAP2. |

# 4.7 ECAP Control Register 1 (ECCTL1)

The ECAP control register 1 (ECCTL1) is shown in Figure 23 and described in Table 20.

#### Figure 23. ECAP Control Register 1 (ECCTL1)



LEGEND: R/W = Read/Write; -n = value after reset

#### Table 20. ECAP Control Register 1 (ECCTL1) Field Descriptions

| Bit   | Field     | Value | Description                                                 |
|-------|-----------|-------|-------------------------------------------------------------|
| 15-14 | FREE/SOFT | 0-3h  | Emulation Control                                           |
|       |           | 0     | TSCTR counter stops immediately on emulation suspend        |
|       |           | 1h    | TSCTR counter runs until = 0                                |
|       |           | 2h-3h | TSCTR counter is unaffected by emulation suspend (Run Free) |
| 13-9  | PRESCALE  | 0-1Fh | Event Filter prescale select                                |
|       |           | 0     | Divide by 1 (i.e,. no prescale, by-pass the prescaler)      |
|       |           | 1     | Divide by 2                                                 |
|       |           | 2h    | Divide by 4                                                 |
|       |           | 3h    | Divide by 6                                                 |
|       |           | 4h    | Divide by 8                                                 |
|       |           | 5h    | Divide by 10                                                |
|       |           |       |                                                             |
|       |           | 1Eh   | Divide by 60                                                |
|       |           | 1Fh   | Divide by 62                                                |



Registers www.ti.com

# Table 20. ECAP Control Register 1 (ECCTL1) Field Descriptions (continued)

| Bit | Field   | Value | Description                                                                                          |
|-----|---------|-------|------------------------------------------------------------------------------------------------------|
| 8   | CAPLDEN |       | Enable Loading of CAP1-4 registers on a capture event                                                |
|     |         | 0     | Disable CAP1-4 register loads at capture event time.                                                 |
|     |         | 1     | Enable CAP1-4 register loads at capture event time.                                                  |
| 7   | CTRRST4 |       | Counter Reset on Capture Event 4                                                                     |
|     |         | 0     | Do not reset counter on Capture Event 4 (absolute time stamp operation)                              |
|     |         | 1     | Reset counter after Capture Event 4 time-stamp has been captured (used in difference mode operation) |
| 6   | CAP4POL |       | Capture Event 4 Polarity select                                                                      |
|     |         | 0     | Capture Event 4 triggered on a rising edge (RE)                                                      |
|     |         | 1     | Capture Event 4 triggered on a falling edge (FE)                                                     |
| 5   | CTRRST3 |       | Counter Reset on Capture Event 3                                                                     |
|     |         | 0     | Do not reset counter on Capture Event 3 (absolute time stamp)                                        |
|     |         | 1     | Reset counter after Event 3 time-stamp has been captured (used in difference mode operation)         |
| 4   | CAP3POL |       | Capture Event 3 Polarity select                                                                      |
|     |         | 0     | Capture Event 3 triggered on a rising edge (RE)                                                      |
|     |         | 1     | Capture Event 3 triggered on a falling edge (FE)                                                     |
| 3   | CTRRST2 |       | Counter Reset on Capture Event 2                                                                     |
|     |         | 0     | Do not reset counter on Capture Event 2 (absolute time stamp)                                        |
|     |         | 1     | Reset counter after Event 2 time-stamp has been captured (used in difference mode operation)         |
| 2   | CAP2POL |       | Capture Event 2 Polarity select                                                                      |
|     |         | 0     | Capture Event 2 triggered on a rising edge (RE)                                                      |
|     |         | 1     | Capture Event 2 triggered on a falling edge (FE)                                                     |
| 1   | CTRRST1 |       | Counter Reset on Capture Event 1                                                                     |
|     |         | 0     | Do not reset counter on Capture Event 1 (absolute time stamp)                                        |
|     |         | 1     | Reset counter after Event 1 time-stamp has been captured (used in difference mode operation)         |
| 0   | CAP1POL |       | Capture Event 1 Polarity select                                                                      |
|     |         | 0     | Capture Event 1 triggered on a rising edge (RE)                                                      |
|     |         | 1     | Capture Event 1 triggered on a falling edge (FE)                                                     |



www.ti.com Registers

# 4.8 ECAP Control Register 2 (ECCTL2)

The ECAP control register 2 (ECCTL2) is shown in Figure 24 and described in Table 21.

# Figure 24. ECAP Control Register 2 (ECCTL2)



LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 21. ECAP Control Register 2 (ECCTL2) Field Descriptions

| Bit   | Field     | Value | Description                                                                                                                                                                                                     |
|-------|-----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-11 | Reserved  | 0     | Reserved                                                                                                                                                                                                        |
| 10    | APWMPOL   |       | APWM output polarity select. This is applicable only in APWM operating mode                                                                                                                                     |
|       |           | 0     | Output is active high (Compare value defines high time)                                                                                                                                                         |
|       |           | 1     | Output is active low (Compare value defines low time)                                                                                                                                                           |
| 9     | CAP/APWM  |       | CAP/APWM operating mode select                                                                                                                                                                                  |
|       |           | 0     | ECAP module operates in capture mode. This mode forces the following configuration:                                                                                                                             |
|       |           |       | Inhibits TSCTR resets via CTR = PRD event                                                                                                                                                                       |
|       |           |       | Inhibits shadow loads on CAP1 and 2 registers                                                                                                                                                                   |
|       |           |       | Permits user to enable CAP1-4 register load                                                                                                                                                                     |
|       |           |       | ECAPn/APWMn pin operates as a capture input                                                                                                                                                                     |
|       |           | 1     | ECAP module operates in APWM mode. This mode forces the following configuration:                                                                                                                                |
|       |           |       | Resets TSCTR on CTR = PRD event (period boundary                                                                                                                                                                |
|       |           |       | Permits shadow loading on CAP1 and 2 registers                                                                                                                                                                  |
|       |           |       | Disables loading of time-stamps into CAP1-4 registers                                                                                                                                                           |
|       |           |       | ECAPn/APWMn pin operates as a APWM output                                                                                                                                                                       |
| 8     | SWSYNC    |       | Software-forced Counter (TSCTR) Synchronizing. This provides a convenient software method to synchronize some or all ECAP time bases. In APWM mode, the synchronizing can also be done via the CTR = PRD event. |
|       |           | 0     | Writing a zero has no effect. Reading always returns a zero                                                                                                                                                     |
|       |           | 1     | Writing a one forces a TSCTR shadow load of current ECAP module and any ECAP modules down-stream providing the SYNCO_SEL bits are 0,0. After writing a 1, this bit returns to a zero.                           |
|       |           |       | Note: Selection CTR = PRD is meaningful only in APWM mode; however, you can choose it in CAP mode if you find doing so useful.                                                                                  |
| 7-6   | SYNCO_SEL | 0-3h  | Sync-Out Select                                                                                                                                                                                                 |
|       |           | 0     | Select sync-in event to be the sync-out signal (pass through)                                                                                                                                                   |
|       |           | 1h    | Select CTR = PRD event to be the sync-out signal                                                                                                                                                                |
|       |           | 2h    | Disable sync out signal                                                                                                                                                                                         |
|       |           | 3h    | Disable sync out signal                                                                                                                                                                                         |
| 5     | SYNCI_EN  |       | Counter (TSCTR) Sync-In select mode                                                                                                                                                                             |
|       |           | 0     | Disable sync-in option                                                                                                                                                                                          |
|       |           | 1     | Enable counter (TSCTR) to be loaded from CTRPHS register upon either a SYNCI signal or a S/W force event.                                                                                                       |
| 4     | TSCTRSTOP |       | Time Stamp (TSCTR) Counter Stop (freeze) Control                                                                                                                                                                |
|       |           | 0     | TSCTR stopped                                                                                                                                                                                                   |
|       |           | 1     | TSCTR free-running                                                                                                                                                                                              |



Registers www.ti.com

Table 21. ECAP Control Register 2 (ECCTL2) Field Descriptions (continued)

| Bit | Field       | Value | Description                                                                                                                                                                                                                                                                                                                      |
|-----|-------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | RE-ARM      |       | One-Shot Re-Arming Control, that is, wait for stop trigger. Note: The re-arm function is valid in one shot or continuous mode.                                                                                                                                                                                                   |
|     |             | 0     | Has no effect (reading always returns a 0)                                                                                                                                                                                                                                                                                       |
|     |             | 1     | Arms the one-shot sequence as follows:  1) Resets the Mod4 counter to zero 2) Unfreezes the Mod4 counter 3) Enables capture register loads                                                                                                                                                                                       |
| 2-1 | STOP_WRAP   | 0-3h  | Stop value for one-shot mode. This is the number (between 1-4) of captures allowed to occur before the CAP(1-4) registers are frozen, that is, capture sequence is stopped. Wrap value for continuous mode. This is the number (between 1-4) of the capture register in which the circular buffer wraps around and starts again. |
|     |             | 0     | Stop after Capture Event 1 in one-shot mode. Wrap after Capture Event 1 in continuous mode.                                                                                                                                                                                                                                      |
|     |             | 1h    | Stop after Capture Event 2 in one-shot mode. Wrap after Capture Event 2 in continuous mode.                                                                                                                                                                                                                                      |
|     |             | 2h    | Stop after Capture Event 3 in one-shot mode. Wrap after Capture Event 3 in continuous mode.                                                                                                                                                                                                                                      |
|     |             | 3h    | Stop after Capture Event 4 in one-shot mode. Wrap after Capture Event 4 in continuous mode.                                                                                                                                                                                                                                      |
|     |             |       | Notes: STOP_WRAP is compared to Mod4 counter and, when equal, 2 actions occur:                                                                                                                                                                                                                                                   |
|     |             |       | Mod4 counter is stopped (frozen)                                                                                                                                                                                                                                                                                                 |
|     |             |       | Capture register loads are inhibited In one-shot mode, further interrupt events are blocked until re-armed.                                                                                                                                                                                                                      |
| 0   | CONT/ONESHT |       | Continuous or one-shot mode control (applicable only in capture mode)                                                                                                                                                                                                                                                            |
|     |             | 0     | Operate in continuous mode                                                                                                                                                                                                                                                                                                       |
|     |             | 1     | Operate in one-shot mode                                                                                                                                                                                                                                                                                                         |

# 4.9 ECAP Interrupt Enable Register (ECEINT)

The ECAP interrupt enable register (ECEINT) is shown in Figure 25 and described in Table 22.

The interrupt enable bits (CEVTn) block any of the selected events from generating an interrupt. Events will still be latched into the flag bit (ECFLG register) and can be forced/cleared via the ECFRC/ECCLR registers.

The proper procedure for configuring peripheral modes and interrupts is:

- 1. Disable global interrupts
- 2. Stop eCAP counter
- 3. Disable eCAP interrupts
- 4. Configure peripheral registers
- 5. Clear spurious eCAP interrupt flags
- 6. Enable eCAP interrupts
- 7. Start eCAP counter
- 8. Enable global interrupts



www.ti.com Registers

# Figure 25. ECAP Interrupt Enable Register (ECEINT)

15 8

Reserved

R-0

7 6 5 4 3 2 1 0 CETV1 CTR=CMP CTR=PRD CTROVF CEVT4 CEVT3 CEVT2 Reserved R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R-0

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 22. ECAP Interrupt Enable Register (ECEINT) Field Descriptions

| Bit  | Field    | Value | Description                                     |
|------|----------|-------|-------------------------------------------------|
| 15-8 | Reserved | 0     | Reserved                                        |
| 7    | CTR=CMP  |       | Counter Equal Compare Interrupt Enable          |
|      |          | 0     | Disable Compare Equal as an Interrupt source    |
|      |          | 1     | Enable Compare Equal as an Interrupt source     |
| 6    | CTR=PRD  |       | Counter Equal Period Interrupt Enable           |
|      |          | 0     | Disable Period Equal as an Interrupt source     |
|      |          | 1     | Enable Period Equal as an Interrupt source      |
| 5    | CTROVF   |       | Counter Overflow Interrupt Enable               |
|      |          | 0     | Disable counter Overflow as an Interrupt source |
|      |          | 1     | Enable counter Overflow as an Interrupt source  |
| 4    | CEVT4    |       | Capture Event 4 Interrupt Enable                |
|      |          | 0     | Disable Capture Event 4 as an Interrupt source  |
|      |          | 1     | Enable Capture Event 4 as an Interrupt source   |
| 3    | CEVT3    |       | Capture Event 3 Interrupt Enable                |
|      |          | 0     | Disable Capture Event 3 as an Interrupt source  |
|      |          | 1     | Enable Capture Event 3 as an Interrupt source   |
| 2    | CEVT2    |       | Capture Event 2 Interrupt Enable                |
|      |          | 0     | Disable Capture Event 2 as an Interrupt source  |
|      |          | 1     | Enable Capture Event 2 as an Interrupt source   |
| 1    | CEVT1    |       | Capture Event 1 Interrupt Enable                |
|      |          | 0     | Disable Capture Event 1 as an Interrupt source  |
|      |          | 1     | Enable Capture Event 1 as an Interrupt source   |
| 0    | Reserved | 0     | Reserved                                        |



Registers www.ti.com

# 4.10 ECAP Interrupt Flag Register (ECFLG)

The ECAP interrupt flag register (ECFLG) is shown in Figure 26 and described in Table 23.

Figure 26. ECAP Interrupt Flag Register (ECFLG)



LEGEND: R = Read only; -n = value after reset

#### Table 23. ECAP Interrupt Flag Register (ECFLG) Field Descriptions

| Bit  | Field    | Value | Description                                                                           |
|------|----------|-------|---------------------------------------------------------------------------------------|
| 15-8 | Reserved | 0     | Reserved                                                                              |
| 7    | CTR=CMP  |       | Compare Equal Compare Status Flag. This flag is only active in APWM mode.             |
|      |          | 0     | Indicates no event occurred                                                           |
|      |          | 1     | Indicates the counter (TSCTR) reached the compare register value (ACMP)               |
| 6    | CTR=PRD  |       | Counter Equal Period Status Flag. This flag is only active in APWM mode.              |
|      |          | 0     | Indicates no event occurred                                                           |
|      |          | 1     | Indicates the counter (TSCTR) reached the period register value (APRD) and was reset. |
| 5    | CTROVF   |       | Counter Overflow Status Flag. This flag is active in CAP and APWM mode.               |
|      |          | 0     | Indicates no event occurred.                                                          |
|      |          | 1     | Indicates the counter (TSCTR) has made the transition from 0xFFFFFFF to 0x00000000    |
| 4    | CEVT4    |       | Capture Event 4 Status Flag This flag is only active in CAP mode.                     |
|      |          | 0     | Indicates no event occurred                                                           |
|      |          | 1     | Indicates the fourth event occurred at ECAPn pin                                      |
| 3    | CEVT3    |       | Capture Event 3 Status Flag. This flag is active only in CAP mode.                    |
|      |          | 0     | Indicates no event occurred.                                                          |
|      |          | 1     | Indicates the third event occurred at ECAPn pin.                                      |
| 2    | CEVT2    |       | Capture Event 2 Status Flag. This flag is only active in CAP mode.                    |
|      |          | 0     | Indicates no event occurred.                                                          |
|      |          | 1     | Indicates the second event occurred at ECAPn pin.                                     |
| 1    | CEVT1    |       | Capture Event 1 Status Flag. This flag is only active in CAP mode.                    |
|      |          | 0     | Indicates no event occurred.                                                          |
|      |          | 1     | Indicates the first event occurred at ECAPn pin.                                      |
| 0    | INT      |       | Global Interrupt Status Flag                                                          |
|      |          | 0     | Indicates no interrupt generated.                                                     |
| İ    |          | 1     | Indicates that an interrupt was generated.                                            |



www.ti.com Registers

# 4.11 ECAP Interrupt Clear Register (ECCLR)

The ECAP interrupt clear register (ECCLR) is shown in Figure 27 and described in Table 24.

Figure 27. ECAP Interrupt Clear Register (ECCLR)



LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 24. ECAP Interrupt Clear Register (ECCLR) Field Descriptions

| Bit  | Field    | Value | Description                                                                                                           |
|------|----------|-------|-----------------------------------------------------------------------------------------------------------------------|
| 15-8 | Reserved | 0     | Reserved                                                                                                              |
| 7    | CTR=CMP  |       | Counter Equal Compare Status Flag                                                                                     |
|      |          | 0     | Writing a 0 has no effect. Always reads back a 0                                                                      |
|      |          | 1     | Writing a 1 clears the CTR=CMP flag condition                                                                         |
| 6    | CTR=PRD  |       | Counter Equal Period Status Flag                                                                                      |
|      |          | 0     | Writing a 0 has no effect. Always reads back a 0                                                                      |
|      |          | 1     | Writing a 1 clears the CTR=PRD flag condition                                                                         |
| 5    | CTROVF   |       | Counter Overflow Status Flag                                                                                          |
|      |          | 0     | Writing a 0 has no effect. Always reads back a 0                                                                      |
|      |          | 1     | Writing a 1 clears the CTROVF flag condition                                                                          |
| 4    | CEVT4    |       | Capture Event 4 Status Flag                                                                                           |
|      |          | 0     | Writing a 0 has no effect. Always reads back a 0.                                                                     |
|      |          | 1     | Writing a 1 clears the CEVT3 flag condition.                                                                          |
| 3    | CEVT3    |       | Capture Event 3 Status Flag                                                                                           |
|      |          | 0     | Writing a 0 has no effect. Always reads back a 0.                                                                     |
|      |          | 1     | Writing a 1 clears the CEVT3 flag condition.                                                                          |
| 2    | CEVT2    |       | Capture Event 2 Status Flag                                                                                           |
|      |          | 0     | Writing a 0 has no effect. Always reads back a 0.                                                                     |
|      |          | 0     | Writing a 1 clears the CEVT2 flag condition.                                                                          |
| 1    | CEVT1    |       | Capture Event 1 Status Flag                                                                                           |
|      |          | 0     | Writing a 0 has no effect. Always reads back a 0.                                                                     |
|      |          | 1     | Writing a 1 clears the CEVT1 flag condition.                                                                          |
| 0    | INT      |       | Global Interrupt Clear Flag                                                                                           |
|      |          | 0     | Writing a 0 has no effect. Always reads back a 0.                                                                     |
|      |          | 1     | Writing a 1 clears the INT flag and enable further interrupts to be generated if any of the event flags are set to 1. |



Registers www.ti.com

# 4.12 ECAP Interrupt Forcing Register (ECFRC)

The ECAP interrupt forcing register (ECFRC) is shown in Figure 28 and described in Table 25.

#### Figure 28. ECAP Interrupt Forcing Register (ECFRC)



LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 25. ECAP Interrupt Forcing Register (ECFRC) Field Descriptions

| Bit  | Field    | Value | Description                                       |
|------|----------|-------|---------------------------------------------------|
| 15-8 | Reserved | 0     | Reserved                                          |
| 7    | CTR=CMP  |       | Force Counter Equal Compare Interrupt             |
|      |          | 0     | No effect. Always reads back a 0.                 |
|      |          | 1     | Writing a 1 sets the CTR=CMP flag bit.            |
| 6    | CTR=PRD  |       | Force Counter Equal Period Interrupt              |
|      |          | 0     | No effect. Always reads back a 0.                 |
|      |          | 1     | Writing a 1 sets the CTR=PRD flag bit.            |
| 5    | CTROVF   |       | Force Counter Overflow                            |
|      |          | 0     | No effect. Always reads back a 0.                 |
|      |          | 1     | Writing a 1 to this bit sets the CTROVF flag bit. |
| 4    | CEVT4    |       | Force Capture Event 4                             |
|      |          | 0     | No effect. Always reads back a 0.                 |
|      |          | 1     | Writing a 1 sets the CEVT4 flag bit               |
| 3    | CEVT3    |       | Force Capture Event 3                             |
|      |          | 0     | No effect. Always reads back a 0.                 |
|      |          | 1     | Writing a 1 sets the CEVT3 flag bit               |
| 2    | CEVT2    |       | Force Capture Event 2                             |
|      |          | 0     | No effect. Always reads back a 0.                 |
|      |          | 1     | Writing a 1 sets the CEVT2 flag bit.              |
| 1    | CEVT1    |       | Force Capture Event 1                             |
|      |          | 0     | No effect. Always reads back a 0.                 |
|      |          | 1     | Writing a 1 sets the CEVT1 flag bit.              |
| 0    | Reserved | 0     | Reserved                                          |



www.ti.com Registers

# 4.13 Revision ID Register (REVID)

The revision ID register (REVID) is shown in Figure 29 and described in Table 26.

# Figure 29. Revision ID Register (REVID)



LEGEND: R = Read only; -n = value after reset

# Table 26. Revision ID Register (REVID) Field Descriptions

| Bit  | Field | Value      | Description  |
|------|-------|------------|--------------|
| 31-0 | REV   | 44D2 2100h | Revision ID. |



Appendix A www.ti.com

# **Appendix A Revision History**

Table A-1 lists the changes made since the previous version of this document.

**Table A-1. Document Revision History** 

| Reference     | Additions/Modifications/Deletions           |
|---------------|---------------------------------------------|
| Global        | Changed PIE to Interrupt Controller.        |
| Figure 1      | Changed figure.                             |
| Figure 3      | Changed figure.                             |
| Section 2.2.6 | Changed fourth paragraph.                   |
|               | Changed fourth sentence in fifth paragraph. |

#### **IMPORTANT NOTICE**

Texas Instruments Incorporated and its subsidiaries (TI) reserve the right to make corrections, modifications, enhancements, improvements, and other changes to its products and services at any time and to discontinue any product or service without notice. Customers should obtain the latest relevant information before placing orders and should verify that such information is current and complete. All products are sold subject to TI's terms and conditions of sale supplied at the time of order acknowledgment.

TI warrants performance of its hardware products to the specifications applicable at the time of sale in accordance with TI's standard warranty. Testing and other quality control techniques are used to the extent TI deems necessary to support this warranty. Except where mandated by government requirements, testing of all parameters of each product is not necessarily performed.

TI assumes no liability for applications assistance or customer product design. Customers are responsible for their products and applications using TI components. To minimize the risks associated with customer products and applications, customers should provide adequate design and operating safeguards.

TI does not warrant or represent that any license, either express or implied, is granted under any TI patent right, copyright, mask work right, or other TI intellectual property right relating to any combination, machine, or process in which TI products or services are used. Information published by TI regarding third-party products or services does not constitute a license from TI to use such products or services or a warranty or endorsement thereof. Use of such information may require a license from a third party under the patents or other intellectual property of the third party, or a license from TI under the patents or other intellectual property of TI.

Reproduction of TI information in TI data books or data sheets is permissible only if reproduction is without alteration and is accompanied by all associated warranties, conditions, limitations, and notices. Reproduction of this information with alteration is an unfair and deceptive business practice. TI is not responsible or liable for such altered documentation. Information of third parties may be subject to additional restrictions

Resale of TI products or services with statements different from or beyond the parameters stated by TI for that product or service voids all express and any implied warranties for the associated TI product or service and is an unfair and deceptive business practice. TI is not responsible or liable for any such statements.

TI products are not authorized for use in safety-critical applications (such as life support) where a failure of the TI product would reasonably be expected to cause severe personal injury or death, unless officers of the parties have executed an agreement specifically governing such use. Buyers represent that they have all necessary expertise in the safety and regulatory ramifications of their applications, and acknowledge and agree that they are solely responsible for all legal, regulatory and safety-related requirements concerning their products and any use of TI products in such safety-critical applications, notwithstanding any applications-related information or support that may be provided by TI. Further, Buyers must fully indemnify TI and its representatives against any damages arising out of the use of TI products in such safety-critical applications.

TI products are neither designed nor intended for use in military/aerospace applications or environments unless the TI products are specifically designated by TI as military-grade or "enhanced plastic." Only products designated by TI as military-grade meet military specifications. Buyers acknowledge and agree that any such use of TI products which TI has not designated as military-grade is solely at the Buyer's risk, and that they are solely responsible for compliance with all legal and regulatory requirements in connection with such use.

TI products are neither designed nor intended for use in automotive applications or environments unless the specific TI products are designated by TI as compliant with ISO/TS 16949 requirements. Buyers acknowledge and agree that, if they use any non-designated products in automotive applications, TI will not be responsible for any failure to meet such requirements.

Following are URLs where you can obtain information on other Texas Instruments products and application solutions:

**Applications Products Amplifiers** amplifier.ti.com Audio www.ti.com/audio Data Converters Automotive www.ti.com/automotive dataconverter.ti.com DLP® Products Broadband www.dlp.com www.ti.com/broadband DSP Digital Control dsp.ti.com www.ti.com/digitalcontrol Clocks and Timers www.ti.com/clocks Medical www.ti.com/medical Military Interface www.ti.com/military interface.ti.com Optical Networking Logic logic.ti.com www.ti.com/opticalnetwork Power Mgmt power.ti.com Security www.ti.com/security Telephony Microcontrollers microcontroller.ti.com www.ti.com/telephony Video & Imaging www.ti-rfid.com www.ti.com/video RF/IF and ZigBee® Solutions www.ti.com/lprf Wireless www.ti.com/wireless

> Mailing Address: Texas Instruments, Post Office Box 655303, Dallas, Texas 75265 Copyright © 2009, Texas Instruments Incorporated