Section 34. Input Capture with Dedicated Timer

HIGHLIGHTS

34.1 Introduction ............................................................................................................... 34-2
34.2 Input Capture Registers ............................................................................................... 34-3
34.3 Initialization ............................................................................................................. ..... 34-6
34.4 Input Capture Timer Clock Source Selection ............................................................... 34-6
34.5 Input Capture Event Modes ......................................................................................... 34-6
34.6 Capture Buffer Operation ........................................................................................... 34-10
34.7 Input Capture Interrupts ............................................................................................ 34-11
34.8 Input Capture Operation in Power-Saving States ...................................................... 34-11
34.9 Input Capture Timer Functionality .............................................................................. 34-12
34.10 I/O Pin Control ...........................................................................................................34-16
34.11 Register Maps ............................................................................................................ 34-17
34.12 Electrical Specifications ............................................................................................. 34-18
34.13 Design Tips ................................................................................................................34-19
34.14 Related Application Notes ....................................................................................... 34-20
34.15 Revision History ....................................................................................................... 34-21
34.1 INTRODUCTION

This section describes the Input Capture with Dedicated Timer module and its associated operational modes. The input capture module is used to capture a timer value from an independent timer base upon an event on the input pin. The input capture features are useful in applications requiring frequency (time period) and pulse measurement. Figure 34-1 depicts a simplified block diagram of the Input Capture module.

Note: Refer to the specific device data sheet for further information on the number of channels available in a particular device. All input capture channels are functionally identical. In this section, an 'x' in the register name is a generic reference to an input capture channel in place of a specific input capture channel number.

The input capture module has multiple operating modes. Modes are selected via the ICxCON1 register. The operating modes of the input capture module include:

- Capture timer value on every falling edge of input applied at the ICx pin
- Capture timer value on every rising edge of input applied at the ICx pin
- Capture timer value on every 4th rising edge of input applied at the ICx pin
- Capture timer value on every 16th rising edge of input applied at the ICx pin
- Capture timer value on every rising and every falling edge of input applied at the ICx pin
- Device wake-up from capture pin during CPU Sleep and Idle modes

The input capture module contains a dedicated 16-bit, synchronous, up-counting timer used for input capture function. It is the value of this timer that is written to the FIFO when a capture event occurs. In addition, the internal value may be read (with a synchronization delay) using the ICxTMR register. Refer to the specific device data sheet for further information on the ICxTMR register and its memory map details.

In Cascade mode operation, the input capture timers can be grouped in pairs for the purpose of cascading them to form 32-bit timers using the cascade input and cascade output of the module. In Synchronous mode operation, the input capture timer can be synchronized with other modules using the Sync_trig input source of the module, which is selected using the SYNCSEL<4:0> bits in the ICxCON2 register.

The input capture module has a four-level FIFO buffer. The number of capture events required to generate a CPU interrupt can be selected by the user.

Figure 34-1: Input Capture with Dedicated Timer Block Diagram

Legend: R = Rising Edge; F = Falling Edge; R/F = Raising or Falling Edge
Section 34. Input Capture with Dedicated Timer

34.2 INPUT CAPTURE REGISTERS

Each capture channel available on the PIC24F family devices has the following registers. Here ‘x’ denotes the number of capture peripheral:

- ICxCON1: Input Capture x Control Register1
- ICxCON2: Input Capture x Control Register2
- ICxBUF: Input Capture x Buffer Register
- ICxTMR: Input Capture x Timer Register

Register 34-1: ICxCON1: Input Capture x Control Register 1

<table>
<thead>
<tr>
<th>U-0</th>
<th>U-0</th>
<th>R/W-0</th>
<th>R/W-0</th>
<th>R/W-0</th>
<th>R/W-0</th>
<th>U-0</th>
<th>U-0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>ICSDL</td>
<td>ICTSEL2</td>
<td>ICTSEL1</td>
<td>ICTSEL0</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

bit 15  ICSIDL: Input Capture Stop in Idle Control bit
0 = Input capture will continue to operate in CPU Idle mode
1 = Input capture will Halt in CPU Idle mode

bit 12-10  ICTSEL<12:10>: Input Capture Timer Select bits
000 = Clock source of Timer3 is the clock source of the capture counter
001 = Clock source of Timer2 is the clock source of the capture counter
010 = Clock source of Timer4 is the clock source of the capture counter
011 = Clock source of Timer5 is the clock source of the capture counter
100 = Clock source of Timer1 is the clock source of the capture counter
101 = Reserved
110 = Reserved
111 = System clock is the counter source for capture

Legend:
- HS = Hardware Settable bit
- R = Readable bit
- HC = Hardware Clearable bit
- U = Unimplemented bit, read as ‘0’
- ‘0’ = Bit is cleared
- HS = Set by Hardware

bit 9-7  Unimplemented: Read as ‘0’

bit 6-5  ICI<1:0>: Number of Captures per Interrupt Select bits (this field is not used if ICM<2:0> = 001 or 111)
11 = Interrupt on every fourth capture event
10 = Interrupt on every third capture event
01 = Interrupt on every second capture event
00 = Interrupt on every capture event

bit 4  ICOV: Input Capture Overflow Status Flag bit (read-only)
1 = Input capture buffer overflow occurred
0 = No input capture buffer overflow occurred

bit 3  ICBNE: Input Capture Buffer Not Empty Status bit (read-only)
1 = Input capture buffer is not empty, at least one more capture value can be read
0 = Input capture buffer is empty

bit 2-0  ICM<2:0>: Input Capture Mode Select bits
111 = Input capture functions as interrupt pin only in CPU Sleep and Idle mode (Interrupt mode), rising edge detect only, all other control bits are not applicable
110 = Unused (module disabled)
101 = Capture mode, every 16th rising edge (Prescaler Capture mode)
100 = Capture mode, every 4th rising edge (Prescaler Capture mode)
011 = Capture mode, every rising edge (Simple Capture mode)
010 = Capture mode, every falling edge (Simple Capture mode)
001 = Capture mode, every edge, rising and falling (Edge Detect mode (ICI<1:0> is not used in this mode)
000 = Input capture off
Register 34-2: ICxCON2: Input Capture x Control Register 2

<table>
<thead>
<tr>
<th>bit 15</th>
<th>bit 8</th>
</tr>
</thead>
<tbody>
<tr>
<td>U-0</td>
<td>U-0</td>
</tr>
<tr>
<td>U-0</td>
<td>U-0</td>
</tr>
<tr>
<td>U-0</td>
<td>U-0</td>
</tr>
<tr>
<td>U-0</td>
<td>U-0</td>
</tr>
<tr>
<td>U-0</td>
<td>U-0</td>
</tr>
<tr>
<td>U-0</td>
<td>IC32</td>
</tr>
</tbody>
</table>

Legend:

R = Readable bit
W = Writable bit
U = Unimplemented bit, read as ‘0’
-n = Value at POR
HC = Cleared in Hardware
‘0’ = Bit is cleared
HS = Set by Hardware

bit 15-9 Unimplemented: Read as ‘0’

bit 8 IC32: 32-Bit Timer Mode Select bit (Cascade mode)

- 1 = ODD IC and EVEN IC form a single 32-bit input capture module
- 0 = Cascade module operation disabled

bit 7 ICTRIG: Trigger Operation Select bit

- 1 = Input source used to trigger the input capture timer (Trigger mode)
- 0 = Input source used to synchronize input capture timer to timer of another module (Synchronization mode)

bit 6 TRIGSTAT: Timer Trigger Status bit

- 1 = ICxTMR has been triggered and is running
- 0 = ICxTMR has not been triggered and is being held clear

bit 5 Unimplemented: Read as ‘0’

Note 1: The IC32 bit in both ODD and EVEN IC must be set to enable Cascade mode.

2: These options should only be selected as a trigger source. These inputs should not be used as a synchronization source.

3: Input source is selected by the SYNCSEL<4:0> bits of the ICxCON2 register

4: This bit is set by the selected input source (selected by SYNCSEL<4:0> bits). It can be read, set and cleared in software. Please refer to Section 34.9.2 “Trigger Timer Operation” for more information about this bit.
Register 34-2: ICxCON2: Input Capture x Control Register 2 (Continued)

bit 4-0  SYNCSLET<4:0>: Input Source Select for Synchronization and Trigger Operation bits

00000 = Not synchronized to any other module
00001 = Input is OC1
00010 = Input is OC2
00011 = Input is OC3
00100 = Input is OC4
00101 = Input is OC5
00110 = Input is OC6
00111 = Input is OC7
01000 = Input is OC8
01001 = Input is OC9
01010 = Input is ICAP5
01011 = Input is TMR1
01100 = Input is TMR2
01101 = Input is TMR3
01110 = Input is TMR4
01111 = Input is TMR5
10000 = Reserved
10001 = Reserved
10010 = Input is ICAP7
10011 = Input is ICAP8
10100 = Input is ICAP1
10101 = Input is ICAP2
10110 = Input is ICAP3
10111 = Input is ICAP4
11000 = Input is CMP1(2)
11001 = Input is CMP2(2)
11010 = Input is CMP3(2)
11011 = Input is AD(2)
11100 = Input is CTMU(2)
11101 = Input is ICAP6
11110 = Input is ICAP9
11111 = Reserved

Note 1: The IC32 bit in both ODD and EVEN IC must be set to enable Cascade mode.

2: These options should only be selected as a trigger source. These inputs should not be used as a synchronization source.

3: Input source is selected by the SYNCSLET<4:0> bits of the ICxCON2 register

4: This bit is set by the selected input source (selected by SYNCSLET<4:0> bits). It can be read, set and cleared in software. Please refer to Section 34.9.2 “Trigger Timer Operation” for more information about this bit.
34.3 INITIALIZATION

When the input capture module is reset or is in the Off mode (ICM<2:0> = 000), the input capture logic will:

- Reset the overflow condition flag to a logic ‘0’
- Reset the receive capture FIFO to the empty state
- Reset the prescale count

34.4 INPUT CAPTURE TIMER CLOCK SOURCE SELECTION

The PIC24F family devices may have one or more input capture channels. Each channel can select between one of eight clock sources for its time base by using the ICTSEL<12:10> bits. Refer to the device data sheet for the specific timers that can be selected. The clock should be selected before enabling the module and should not be changed during operation.

Selection of the timer clock source is accomplished through the ICTSEL control bits (ICxCON1<12:10>). The timers can be set to use the internal clock source (Fosc/2), or use an external clock source applied at the TxCK pin with Synchronization mode enabled in the timer.

34.5 INPUT CAPTURE EVENT MODES

The input capture module captures the 16-bit value of the input capture timer value when an event occurs at the ICx pin. The capture events can be classified into three categories:

1. Simple Capture Event modes:
   - Capture timer value on every falling edge of input at ICx pin
   - Capture timer value on every rising edge of input at ICx pin

2. Capture timer value on every edge (rising and falling).

3. Prescaler Capture Event modes:
   - Capture timer value on every 4th rising edge of input at ICx pin
   - Capture timer value on every 16th rising edge of input at ICx pin

These Input Capture modes are configured by setting the appropriate Input Capture Mode bits (ICM2:ICM0) in the ICxCON1 register (ICxCON1<2:0>).

34.5.1 Simple Capture Events

The input capture module can capture a timer value (dedicated timer) based on its edge selection (rising or falling as defined by the mode) of the input applied to the ICx pin. These modes are configured by setting the ICM bits (ICM2:ICM0) in the ICxCON1 register (ICxCON1<2:0>) to ‘011’ or ‘010’, respectively. In these modes, the prescaler counter is not used. See Figure 34-2 and Figure 34-3 for timing diagrams of a simple capture event.

The input capture logic detects and synchronizes the rising or falling edge of the capture pin signal on the internal instruction clock. If the rising/falling edge has occurred, the capture module logic will write the current timer value to the capture buffer and will trigger the interrupt generation logic when the number of elapsed capture events matches the number specified by the ICI control bits (ICI1:ICI0) in the ICxCON1 register (ICxCON1<6:5>), and the respective Input Capture Interrupt Flag, ICxIF, is asserted two instruction cycles after the capture buffer write event.
If the capture timer increments every instruction cycle, the captured timer value will be the value that was present one or two instruction cycles after the time of the event on the ICx pin. This time delay is a function of the actual ICx edge event related to the instruction clock cycle and delay associated with the input capture logic. If the input clock to the capture time base is prescaled, then the delay in the captured value can be eliminated. See Figure 34-2 and Figure 34-4 for more details.

The input capture pin has minimum high time and low time specifications. Refer to Section 34.12 “Electrical Specifications” for further details.

Figure 34-2: Simple Capture Timing Diagram, Time Base Prescaler = 1:1

Figure 34-3: Simple Capture Timing Diagram, Time Base Prescaler = 1:4
34.5.1.1 CHANGING BETWEEN CAPTURE MODES

It is recommended that the user turns off the capture module (clear the ICM2:ICM0 bits (ICxCON1<2:0>)) before switching to a new mode. If the user switches to a new Capture mode, the prescaler counter will not be cleared. Therefore, at the time of switching modes, it is possible that the first capture event and its associated interrupt is generated due to a non-zero prescaler counter.

34.5.2 Prescaler Capture Events

The capture module has two Prescaler Capture modes. The Prescaler Capture modes are selected by setting the ICM2:ICM0 bits (ICxCON1<2:0>) to ‘100’ or ‘101’, respectively. In these modes, the capture module counts four or sixteen rising edge pin events before a capture event occurs.

The prescaler capture counter is incremented on every valid rising edge applied to the capture pin. The rising edge applied to the pin effectively serves as a clock to a counter. When the prescaler counter equals four or sixteen counts (depending on the mode selected), the counter will output a valid capture event signal, which is then synchronized to the instruction clock cycle.

This synchronized capture event signal will trigger a capture buffer write event and signal the interrupt generation logic. The respective Input Capture Interrupt Flag, ICxIF, is asserted two instruction cycles after the capture buffer write event.

The input capture pin has minimum high time and low time specifications. Refer to Section 34.12 “Electrical Specifications” for further details.

Switching from one prescale setting to another may generate an interrupt. Also, the prescaler counter will not be cleared; therefore, the first capture may be from a non-zero prescaler.

Example 34-1 shows the recommended method for switching between prescaler capture settings.

The prescaler counter is cleared when:
• The capture channel is turned off (ICM2:ICM0 = 000)
• Any device Reset

The prescaler counter is not cleared when:
• The user switches from one active Capture mode to another

Example 34-1: Prescaler Capture Code Example

```
//The following code example will set the Input Capture1 module for interrupts on every
//second capture event; captured on every fourth rising edge. The clock source for the timer
//would be the system clock. Sync_trig source is disabled.
// Setup Input Capture1 interrupt for desired priority level (this example assigns level 1
//priority)
IFS0bits.IC1IF = 0; // Clear the IC1 interrupt status flag
IEC0bits.IC1IE = 1; // Enable IC1 interrupts
IPC0bits.IC1IP = 1; // Set module interrupt priority as 1
IC1CON1 = 0x1C24; // Turn on Input Capture 1 Module
IC1CON2 = 0x0040; // Turn on Input Capture 1 Module

// The following code shows how to read the capture buffer when
// an interrupt is generated.
// Example code for Input Capture 1 ISR:
unsigned int Capture1, Capture2;
void __attribute__((__interrupt__)) _IC1Interrupt(void)
{
    IFS0bits.IC1IF = 0; // Reset respective interrupt flag
    Capture1 = IC1BUF; // Read and save off first capture entry
    Capture2 = IC1BUF; // Read and save off second capture entry
} 
```
34.5.3 Edge Detection Mode

The capture module can capture a time base count value on every rising and falling edge of the input signal applied to the ICx pin. The Edge Detection mode is selected by setting the ICM2:ICM0 bits (ICxCON1<2:0>) to '001'. In this mode, the prescaler capture counter is not used. See Figure 34-4 for a simplified timing diagram.

When the input capture module is configured for an edge detection (Edge Detection mode), the module will:

- Set the Input Capture Interrupt Flag (ICxF) on every edge; rising and falling.
- The interrupt for Capture mode bits, (ICI1:ICI0) of the ICxCON1 register (ICxCON1<6:5>), are not used in this mode. Every capture event will generate an interrupt.

As with the simple Capture Event mode, the input capture logic detects and synchronizes the rising and falling edge of the capture pin signal on the internal phase clocks. If the rising or falling edge has occurred, the capture module logic will write the current timer count on to the capture buffer and signal the interrupt generation logic. The respective Input Capture Interrupt Flag, ICxF, is asserted two instruction cycles after the capture buffer write event.

The captured timer count value will be 1 or 2 instruction cycles (TCY) after the occurrence of the edge at the ICx pin (see Figure 34-4).

Figure 34-4: Edge Detection Mode Timing Diagram

![Edge Detection Mode Timing Diagram](image-url)
34.6 CAPTURE BUFFER OPERATION

Each capture channel has a FIFO buffer associated with it. The ICxBUF register is memory mapped and provides access to the FIFO. When the input capture module is reset (ICxCON1<2:0> = 000), the input capture logic will:

- Clear the overflow condition flag (i.e., clear ICOV (ICxCON1<4>) to ‘0’)
- Reset the capture buffer to the empty state (clears ICBNE (ICxCON1<3>) to ‘0’)

Reading the FIFO buffer under the following conditions will lead to indeterminate results:

- The input capture module is first disabled, and at some later time, re-enabled
- When a FIFO read is performed when the buffer is empty
- After a device Reset

There are two status flags which provide status on the FIFO buffer:

- ICBNE (ICxCON1<3>): Input Capture Buffer Not Empty
- ICOV (ICxCON1<4>): Input Capture Overflow

34.6.1 Input Capture Buffer Not Empty (ICBNE)

The ICBNE read-only status bit (ICxCON1<3>) will be set on the first input capture event and remain set until all the capture events have been read from the capture buffer. For example, if three capture events have occurred, then three reads of the capture buffer are required before the ICBNE (ICxCON1<3>) bit gets cleared. If four capture events occur, then four reads are required to clear the ICBNE (ICxCON1<3>) bit. After each read, the remaining word(s) will be allowed to move to the next available top location. Since the ICBNE reflects the capture buffer state, the ICBNE status bit will be cleared during a device Reset.

34.6.2 Input Capture Overflow (ICOV)

The ICOV read-only status bit (ICxCON1<4>) will be set when the capture buffer overflows. In the event that the buffer is full with four capture events, and a fifth capture event occurs prior to reading of the buffer, an overrun condition will occur. The ICOV (ICxCON1<4>) bit will be set to logic ‘1’ and the respective capture event interrupt will not be generated. In addition, the fifth capture event is not recorded and subsequent capture events will not alter the current buffer contents.

To clear the overrun condition, the capture buffer must be read four times. Upon the fourth read, the ICOV (ICxCON1<4>) status flag will be cleared and the capture channel will resume normal operation.

Clearing of the overflow condition can be accomplished in the following ways:

- Set ICM2:ICM0 bits (ICxCON1<2:0>) = 000
- Read the capture buffer until ICBNE (ICxCON1<3>) = 0
- Any device Reset

A FIFO overflow occurs under the following conditions:

- ICM<2:0> is not equal to ‘000’ (not off) and
- ICM<2:0> is not equal to ‘110’ (not disabled) and
- ICM<2:0> is not equal to ‘001’ (not in Edge Detect Mode) and
- (Idle_mode = 0 or ICSIDL = 0 or ICM<2:0> is not equal to ‘111’) and
- FIFO is full
- Capture event has occurred

34.6.2.1 ICOV AND INTERRUPT ONLY MODE

The input capture module can also be configured to function as an external interrupt pin. For this mode, the ICI1:ICI0 bits (ICxCON1<6:5>) must be cleared to ‘00’. Interrupts will be generated independent of buffer reads.
34.7  INPUT CAPTURE INTERRUPTS

The input capture module has the ability to generate interrupts based upon a selected number of capture events. A capture event is defined as a write of a time base value into the capture buffer. This setting is configured by the control bits, ICI1:ICI0 (ICxCON1<6:5>).

Except for the case when ICI<1:0> = 00 or ICM <2:0> = 001, no interrupts will be generated until a buffer overflow condition is removed (see Section 34.6.2 “Input Capture Overflow (ICOV)”).

When the capture buffer has been emptied, either by a Reset condition or a read operation, the interrupt count is reset. This allows for the resynchronization of the interrupt count to the FIFO entry status.

34.7.1 Interrupt Control Bits

Each input capture channel has Interrupt Capture Flag bits (ICxF), Interrupt Capture Enable bits (ICxIE) and Interrupt Capture Interrupt Priority bits (ICxIP<2:0>).

34.8  INPUT CAPTURE OPERATION IN POWER-SAVING STATES

34.8.1 Input Capture Operation in Sleep Mode

When the device enters Sleep mode, the system clock is disabled. In Sleep mode, the input capture module can only function as an external interrupt source and the capture result is not valid. This mode is enabled by setting control bits, ICM<2:0> = 111. In this mode, a rising edge on the capture pin will generate a device wake-up from Sleep condition. If the respective module interrupt bit is enabled, and the module priority is of the required priority, an interrupt will be generated; an active timer is not required.

In the event the capture module is configured for a mode other than ICM<2:0> = 111, and the PIC24F device enters Sleep mode, no external pin stimulus, rising or falling, will generate a wake-up condition from Sleep.

34.8.2 Input Capture Operation in Idle Mode

When the device enters Idle mode, the system clock sources remain functional and the CPU stops executing code. The ICSIDL bit (ICxCON1<13>) selection will determine if the module will stop in Idle mode or continue to operate in Idle mode.

If ICSIDL = 0 (ICxCON1<13>), the module will continue operation in Idle mode. Full functionality of the input capture module is provided (including the 4:1 and 16:1 prescaler capture settings) as defined by ICM2:ICM0 control bits (ICxCON1<2:0>). These modes require that the selected timer is enabled during Idle mode as well.

If the Input Capture mode is configured for ICM<2:0> = 111, the input capture pin will serve only as an external interrupt pin. In this mode, a rising edge on the capture pin will generate a device wake-up from Idle mode. A capture time base does not have to be enabled. If the respective module interrupt enable bit is set, and the user-assigned priority is greater than the current CPU priority level, an interrupt will be generated.

If ICSIDL = 1 (ICxCON1<13>), the module will stop in Idle mode. The module will perform the same functions when stopped in Idle mode as for Sleep mode (see Section 34.8.1 “Input Capture Operation in Sleep Mode”).
34.8.3 Device Wake-up on Sleep/Idle

An input capture event can generate a device wake-up or interrupt, if enabled, if the device is in Idle or Sleep mode.

Independent of the timer being enabled, the input capture module will wake-up from Sleep or Idle mode when a capture event occurs if the following are true:

- Input Capture Mode bits, ICM<2:0> = 111 (ICxCON1<2:0>) and
- The Interrupt Capture Enable bit (ICxE) is asserted

This same wake-up feature will interrupt the CPU if the respective interrupt is enabled (ICxE = 1) and is of the required priority.

This wake-up feature is useful for including additional external pin interrupts. The following conditions are true when the input capture module is used in this mode:

- The prescaler capture counter is not utilized while in this mode
- The ICI1:ICI0 bits (ICxCON1<6:5>) are not applicable

34.8.4 Doze Mode

Input capture operation in Doze mode is the same as in normal mode. When the device enters Doze mode, the system clock sources remain functional and the CPU may run at a slower clock rate. Refer to Section 10. “Power-Saving Features” of the “PIC24F Family Reference Manual” for further details.

34.8.5 Selective Peripheral Module Control

The Peripheral Module Disable (PMD) registers provide a method to disable the input capture module by stopping all clock sources supplied to it. When the module is disabled, via the appropriate PMD control bit, it is in minimum power consumption state. The control and status registers associated with the module will also be disabled, so any write to these registers will have no effect, and read values will be invalid and return zero. Refer to Section 10. “Power-Saving Features” of the “PIC24F Family Reference Manual” for further details.

34.9 INPUT CAPTURE TIMER FUNCTIONALITY

The input capture module contains a 16-bit synchronous up-counting timer used for the capture function. This timer has the following functionality:

- Synchronous operation – The timer rolls over when it reaches FFFFh or when the Sync_trig input is enabled.
- Triggered operation (hardware and/or software) – The timer starts operation based on a hardware or software trigger and can be cleared and stopped by software.
- Cascaded operation (32-Bit Timer mode) – The EVEN timer will increment when the associated ODD timer rolls over, and the ODD timer increments every timer clock period when enabled

34.9.1 Synchronous Timer Operation

Synchronous operation of the timer is enabled when:

- ICTRG = 0 and
- Valid synchronization input is selected using the SYNCSEL<4:0> bits

In synchronous operation, the TRIGSTAT bit has no function. The timer can be synchronized with other modules using the Sync_trig input source of the module, which is selected using the SYNCSEL<4:0> bits.

Figure 34-5 and Figure 34-6 show the timer operation in conjunction with a Sync_trig input source. When a valid synchronization input is selected using Sync_trig input source bits, the timer increments on every timer clock (selected by the ICTSEL<12:10> bits). When the selected Sync_trig input source = 1, the timer will be cleared on the next rising edge of the timer clock. As long as the Sync_trig input source = 1, the timer will remain cleared.
When the Sync_trig input source is negated, the timer will resume incrementing on the next positive edge of the timer clock. The Sync_trig input is driven by the synchronization output of another module (typically an output compare or input capture module).

When initializing timers that have synchronous timer operation enabled, the timer being used as the source of synchronization must be enabled last.

**Note 1:** Synchronized timers must select the same clock source to ensure proper function.

2: When initializing timers that have synchronous timer operation enabled, the timer being used as the source of synchronization must be enabled last.

3: The Sync_trig input must be synchronous to the timer clock to ensure proper operation.

**Figure 34-5:** Synchronous Operation Timing (ICTRIG = 0)

**Figure 34-6:** Synchronous Operation Timing (ICTRIG = 0)
34.9.2 Trigger Timer Operation

Triggered operation of the timer is enabled when ICTRIG = 1 and a valid Sync_trig input source is selected using the SYNCSEL<4:0> bits. During triggered operation, the TRIGSTAT bit is set by hardware or software and can be cleared by software.

The TRIGSTAT bit has the following functions during trigger operation:

- TRIGSTAT = 0
  - Timer is held in Reset
- TRIGSTAT = 1
  - Timer released from Reset
  - Timer increments on every positive clock

Trigger operation is shown in Figure 34-7. When triggered timer operation is enabled, the timer will be held in a cleared state. It will remain in this cleared state until a trigger occurs on the selected Sync_trig input source (SYNCSEL<4:0>), at which point, the TRIGSTAT bit is set. In addition to being set by hardware, the TRIGSTAT bit may also be set in software. Once the TRIGSTAT bit is set, the timer is released from Reset and starts running. When the TRIGSTAT bit is cleared in software, the timer is reset to 0000h and is ready for another Sync_trig input assertion.

When TRIGSTAT = 0, the timer is held in Reset (0000h), but the input capture functionality is still active. If an input capture event occurs during this time, the value of the timer (0000h) will be captured into the FIFO buffer.

In the process of setting up the input capture module, make sure to set all other input capture configurations and the TRIGSTAT bit is still zero (0) before changing the ICM<2:0> bits from zero (0) to enable the input capture module. Trigger functionality is based on the rising edge of the Sync_trig input rather than the level trigger.

**Note:** The Sync_trig input must be synchronous to the timer clock and must be a minimum of one timer clock cycle in width to ensure proper operation.

Figure 34-7: Trigger Operation Timing (ICTRIG = 1)
34.9.3 Cascaded Timer Operation (32-Bit Timer Mode)

Cascaded operation of the timer is enabled when IC32 = 1. Timers can be grouped in pairs for the purpose of cascading them to form 32-bit timers using the cascade input and cascade output of the module. They are grouped as ODD and EVEN pairs (1-2, 3-4, 5-6, 7-8). IC9 is not cascaded. When cascading, the ODD timer will be the Least Significant 16 bits and the EVEN timer will be the Most Significant 16 bits.

Cascade operation is shown in Figure 34-8. As long as cascade input is low, the timer will not be incremented. When the cascade input is high, the timer will be incremented on the rising edge of the timer clock.

![Figure 34-8: Cascaded Timer Operation](image)

**Note 1:** When operating two timers in a cascade configuration, the modules must use the same clock source.

2: When cascading timers, both timers must have IC32 = 1.

3: When initializing cascaded modules, the module being used as the source of cascade_out (i.e., Least Significant 16 bits) should be enabled last.

While cascading, the cascade_out from the ODD input capture module will be connected to cascade_in of the EVEN input capture module. When the ICx timer of the ODD module reaches FFFFh, it will assert the cascade_out, which will cause the ICx timer of the EVEN module to be incremented in the next clock cycle.
34.9.3.1 TIMER CONFIGURATION

Based on the timer functionality as described in Figure 34-8, there are many different configurations that the timer can be operated in:

- **Normal Configuration** – The timer operates as a standard up-counter, rolling over to 0000h only when it reaches FFFFh. This mode is set by IC32 = 0, ICTRIG = 0 and SYNCSEL<4:0> = 0h. In this mode, the TRIGSTAT bit is unused.

- **Synchronous Configuration** – The timer may be synchronized with another timer such that both timers roll over simultaneously. This mode is set by IC32 = 0, ICTRIG = 0 and SYNCSEL<4:0> is not equal to 0h. In this mode, the TRIGSTAT bit is unused.

- **Software Triggered Configuration** – The timer may be triggered by software to start the timer operation. This mode is set by IC32 = 0, ICTRIG = 1 and SYNCSEL<4:0> = 0h. In this mode, the TRIGSTAT bit is used.

- **Hardware/Software Triggered Configuration** – The timer may be triggered by a trigger outside the module (i.e., comparator, etc.) or by software to start the timer operation. This mode is set by IC32 = 0, ICTRIG = 1 and SYNCSEL<4:0> is not equal to 0h. In this mode, the TRIGSTAT bit is used.

- **Normal Cascaded Configuration** – The timer may be cascaded with another timer so that two 16-bit timers can be combined to form a single 32-bit timer. This mode is set by IC32 = 1, ICTRIG = 0 and SYNCSEL<4:0> = 0h. In this mode, the TRIGSTAT bit is unused.

- **Synchronous Cascaded Configuration** – The timer may be cascaded with another timer to form a 32-bit timer that is synchronized with another 32-bit timer. This mode is set by IC32 = 1, ICTRIG = 0 and SYNCSEL<4:0> is not equal to 0h. In this mode, the TRIGSTAT bit is unused.

- **Software Triggered Cascaded Configuration** – The timer may be cascaded with another timer to form a 32-bit timer that may be triggered by software to start the timer operation. This mode is set by IC32 = 1, ICTRIG = 1 and SYNCSEL<4:0> = 0h. In this mode, the TRIGSTAT bit is used.

- **Hardware/Software Triggered Cascaded Configuration** – The timer may be cascaded with another timer to form a 32-bit timer that may be triggered from outside the module itself (by comparator, etc.), or by software to start the timer operation. This mode is set by IC32 = 1, ICTRIG = 1 and SYNCSEL<4:0> is not equal to 0h. In this mode, the TRIGSTAT bit is used. All other combinations of Configuration bits are undefined and should not be used.

34.10 I/O PIN CONTROL

When the capture module is enabled, the user must ensure that the I/O pin direction is configured for an input by setting the associated TRIS bit. The pin direction is not set when the capture module is enabled. Furthermore, all other peripherals multiplexed with the input pin must be disabled.
## 34.11 REGISTER MAPS

The summaries of the registers associated with the PIC24F input capture with dedicated timer module are provided in Table 34-1.

<table>
<thead>
<tr>
<th>File Name</th>
<th>Bit 15</th>
<th>Bit 14</th>
<th>Bit 13</th>
<th>Bit 12</th>
<th>Bit 11</th>
<th>Bit 10</th>
<th>Bit 9</th>
<th>Bit 8</th>
<th>Bit 7</th>
<th>Bit 6</th>
<th>Bit 5</th>
<th>Bit 4</th>
<th>Bit 3</th>
<th>Bit 2</th>
<th>Bit 1</th>
<th>Bit 0</th>
<th>All Resets</th>
</tr>
</thead>
<tbody>
<tr>
<td>ICxBUF</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>xxxxx</td>
</tr>
<tr>
<td>ICxCON1</td>
<td></td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>IC1</td>
<td>IC0</td>
<td>ICV</td>
<td>ICBNE</td>
<td>ICM2</td>
<td>ICM1</td>
<td>ICM0</td>
<td>00000</td>
</tr>
<tr>
<td>ICxCON2</td>
<td></td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>IC32</td>
<td>ICTRIG</td>
<td>TRIGSTAT</td>
<td>—</td>
<td>SyncSel4</td>
<td>SyncSel3</td>
<td>SyncSel2</td>
<td>SyncSel1</td>
<td>SyncSel0</td>
</tr>
<tr>
<td>ICxTMR</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0000</td>
</tr>
</tbody>
</table>

**Legend:**  
- x = unknown value on Reset, — = unimplemented, read as ‘0’. Reset values are shown in hexadecimal.
34.12 ELECTRICAL SPECIFICATIONS

34.12.1 AC Characteristics

Figure 34-9: Input Capture Timings

Table 34-2: Input Capture

<table>
<thead>
<tr>
<th>Param. No.</th>
<th>Symbol</th>
<th>Characteristic</th>
<th>No Prescaler</th>
<th>With Prescaler</th>
<th>Min</th>
<th>Max</th>
<th>Units</th>
<th>Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>IC10</td>
<td>TccL</td>
<td>ICx Input Low Time – Synchronous Timer</td>
<td>TCY + 20</td>
<td>20 ns</td>
<td>ts</td>
<td>ts</td>
<td>ns</td>
<td>Must also meet parameter IC15</td>
</tr>
<tr>
<td>IC11</td>
<td>TccH</td>
<td>ICx Input Low Time – Synchronous Timer</td>
<td>TCY + 20</td>
<td>20 ns</td>
<td>ts</td>
<td>ts</td>
<td>ns</td>
<td>Must also meet parameter IC15</td>
</tr>
<tr>
<td>IC15</td>
<td>TccP</td>
<td>ICx Input Period – Synchronous Timer</td>
<td>2 * TCY + 40 ( N )</td>
<td>20 ns</td>
<td>ts</td>
<td>ts</td>
<td>ns</td>
<td>N = prescale value (1, 4, 16)</td>
</tr>
</tbody>
</table>
Section 34. Input Capture with Dedicated Timer

34.13 DESIGN TIPS

Question 1: Can the input capture module be used to wake the device from Sleep mode?

Answer: Yes. When the input capture module is configured to ICM<2:0> = 111 and the respective channel Interrupt Capture Enable bit is asserted (ICxIE = 1), a rising edge on the capture pin will wake-up the device from Sleep (see Section 34.8 “Input Capture Operation in Power-Saving States”).
34.14 RELATED APPLICATION NOTES

This section lists application notes that are related to this section of the manual. These application notes may not be written specifically for the PIC24F device family, but the concepts are pertinent and could be used with modification and possible limitations. The current application notes related to the Input Capture with Dedicated Timer are:

<table>
<thead>
<tr>
<th>Title</th>
<th>Application Note #</th>
</tr>
</thead>
<tbody>
<tr>
<td>Using the CCP Module(s)</td>
<td>AN594</td>
</tr>
<tr>
<td>Implementing Ultrasonic Ranging</td>
<td>AN597</td>
</tr>
</tbody>
</table>

**Note:** Please visit the Microchip web site (www.microchip.com) for additional application notes and code examples for the PIC24F family of devices.
34.15  REVISION HISTORY

Revision A (February 2008)
This is the initial released revision of this document.