

## Freescale Semiconductor APPLICATION NOTE

# Programmable Time Accumulator TPU Function (PTA)

By Richard Soja

#### **1** Functional Overview

This TPU input function measures the high time, low time or period of an input signal over a user defined number of periods, presenting the result to the host CPU in the form of a 32-bit accumulation.

#### **2 Detailed Description**

The programmable time accumulator (PTA) function measures either period, high time or low time of an input signal over a programmable number of periods. The number of periods over which the measurement is made is selectable over the range 1 to 255. Four modes of measurement are available, selected via the host sequence bits.

Mode 1 measures total high time over the selected number of periods.

Mode 2 measures total low time over the selected number of periods.

Mode 3 measures total period over the selected number of periods, starting on a rising edge.

Mode 4 measures total period over the selected number of periods, starting on a falling edge.

Figure 1 shows the four operating modes. All four examples in the figure are based on a MAX\_COUNT value of seven. Shaded areas in the bar below each waveform indicate which parts of the waveform are actually measured. Lightly shaded areas are part of the next measurement.

The output of the PTA function is a 32-bit result expressed in TCR counts. The user can select either TCR1 or TCR2 as the timebase for the measurement.

The function operates continuously. After the specified number of periods has elapsed, the TPU updates the 32-bit result parameter, generates an interrupt request to the host CPU, and restarts the measurement process.

This function is very similar to the original PPWA function, although it has several major enhancements over that function:

- 1. 32-bit accumulation instead of 24 bit.
- 2. Option of high or low time measurement instead of high time only.
- 3. Option of starting period accumulation on rising or falling edge instead of rising only.
- 4. Better noise immunity.

The PTA function does not link to other TPU channels at the end of each accumulation. If this feature is required, the period/pulse width accumulation (PPWA) function should be used.



© Freescale Semiconductor, Inc., 2004. All rights reserved.

For More Information On This Product, Go to: www.freescale.com







#### **3 Function Code Size**

Total TPU function code size determines what combination of functions can fit in a given ROM or emulation memory microcode space. The code size of the PTA function is:

55  $\mu$  instructions + 8 entries = 63 long words



#### **4 Function Parameters**

This section provides detailed descriptions of function parameters stored in channel parameter RAM. **Figure 2** shows TPU parameter RAM address mapping. **Figure 3** shows the parameter RAM assignment used by the function. In the diagrams, Y = M111, where M is the value of the module mapping bit (MM) in the system integration module configuration register (Y = \$7 or \$F).

| Channel | Base     |    |    | Par | amete | r Addr | ess |    |    |
|---------|----------|----|----|-----|-------|--------|-----|----|----|
| Number  | Address  | 0  | 1  | 2   | 3     | 4      | 5   | 6  | 7  |
| 0       | \$YFFF## | 00 | 02 | 04  | 06    | 08     | 0A  |    |    |
| 1       | \$YFFF## | 10 | 12 | 14  | 16    | 18     | 1A  |    | —  |
| 2       | \$YFFF## | 20 | 22 | 24  | 26    | 28     | 2A  |    | _  |
| 3       | \$YFFF## | 30 | 32 | 34  | 36    | 38     | 3A  |    |    |
| 4       | \$YFFF## | 40 | 42 | 44  | 46    | 48     | 4A  |    | —  |
| 5       | \$YFFF## | 50 | 52 | 54  | 56    | 58     | 5A  |    | _  |
| 6       | \$YFFF## | 60 | 62 | 64  | 66    | 68     | 6A  |    | —  |
| 7       | \$YFFF## | 70 | 72 | 74  | 76    | 78     | 7A  |    | —  |
| 8       | \$YFFF## | 80 | 82 | 84  | 86    | 88     | 8A  |    | _  |
| 9       | \$YFFF## | 90 | 92 | 94  | 96    | 98     | 9A  |    | —  |
| 10      | \$YFFF## | A0 | A2 | A4  | A6    | A8     | AA  |    | _  |
| 11      | \$YFFF## | B0 | B2 | B4  | B6    | B8     | BA  |    | _  |
| 12      | \$YFFF## | C0 | C2 | C4  | C6    | C8     | CA  |    | _  |
| 13      | \$YFFF## | D0 | D2 | D4  | D6    | D8     | DA  |    | —  |
| 14      | \$YFFF## | E0 | E2 | E4  | E6    | E8     | EA  | EC | EE |
| 15      | \$YFFF## | F0 | F2 | F4  | F6    | F8     | FA  | FC | FE |

--- = Not Implemented (reads as \$00)

#### Figure 2 TPU Channel Parameter RAM CPU Address Map

|          | 15              | 14        | 13 | 12    | 11   | 10 | 9 | 8            | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------|-----------------|-----------|----|-------|------|----|---|--------------|-----|---|---|---|---|---|---|---|
| \$YFFFW0 | CHANNEL_CONTROL |           |    |       |      |    |   |              |     |   |   |   |   |   |   |   |
| \$YFFFW2 |                 |           | Μ  | IAX_C | COUN | IT |   | PERIOD_COUNT |     |   |   |   |   |   |   |   |
| \$YFFFW4 |                 | LAST_TIME |    |       |      |    |   |              |     |   |   |   |   |   |   |   |
| \$YFFFW6 |                 |           |    |       |      |    |   | ACC          | CUM |   |   |   |   |   |   |   |
| \$YFFFW8 |                 |           |    |       |      |    |   | H            | W   |   |   |   |   |   |   |   |
| \$YFFFWA | LW              |           |    |       |      |    |   |              |     |   |   |   |   |   |   |   |

W = Channel Number

Parameter Write Access

| Written by CPU         |
|------------------------|
| Written by TPU         |
| Written by CPU and TPU |
| Unused parameters      |

Figure 3 Parameter RAM Assignment



#### 4.1 CHANNEL\_CONTROL

This 9-bit parameter is used during initialization by the TPU to configure the PTA channel. It defines the timebase which is to be used for measurement, and the type of input transition to be detected. The valid options for CHANNEL\_CONTROL are shown in the following table. The correct operation of the PTA function is only guaranteed for the values of CHANNEL\_CONTROL shown in **Table 1**.

| 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7  | 6  | 5 | 4 | 3   | 2 | 1 | 0  |
|----------|----|----|----|----|----|---|---|----|----|---|---|-----|---|---|----|
| NOT USED |    |    |    |    |    |   |   | TE | 3S |   |   | PAC |   | P | SC |

CHANNEL\_CONTROL must be written by the CPU before initialization. The following table defines the allowable data for this parameter.

| TBS                                                 | PAC                                       | PSC                                    | Action Taken                                                                                                                                                                                                                                                                |
|-----------------------------------------------------|-------------------------------------------|----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8765                                                | 432                                       | 10                                     |                                                                                                                                                                                                                                                                             |
| 0000                                                | 011<br>011                                | 11<br>11<br>11                         | Measurement high pulse width with TCR1 timebase<br>Measurement low pulse width with TCR1 timebase<br>Measurement period on rising edge with TCR1 timebase                                                                                                                   |
| 0 0 0 0<br>0 0 0 0<br>0 0 1 0<br>0 0 1 0<br>0 0 1 0 | 0 1 0<br>0 1 1<br>0 1 1<br>0 0 1<br>0 1 0 | 1 1<br>1 1<br>1 1<br>1 1<br>1 1<br>1 1 | Measurement period on falling edge with TCR1 timebase<br>Measurement high pulse width with TCR2 timebase<br>Measurement low pulse width with TCR2 timebase<br>Measurement period on rising edge with TCR2 timebase<br>Measurement period on falling edge with TCR2 timebase |
| 1111                                                | 111                                       | 11                                     | No change to channel configuration. Use when previously configured correctly                                                                                                                                                                                                |

#### Table 1 PTA CHANNEL\_CONTROL Options

NOTE: Other values of CHANNEL\_CONTROL may result in indeterminate operation.

#### 4.1.1 MAX\_COUNT

This 8-bit parameter is written by the CPU before initialization. It determines the number of periods or pulses which are accumulated before the measurement restarts. Any value in the range 0 to 255 is valid. A value of zero or one results in the accumulation of one period or pulse width.

#### 4.1.2 PERIOD\_COUNT

This 8-bit parameter is used by the TPU to count the number of input signal periods that have elapsed since the start of the last measurement sequence. When PERIOD\_COUNT equals MAX\_COUNT, a measurement sequence has been completed. Prior to starting the function with an initialization host service request, the CPU must initialize PERIOD\_COUNT to zero.

#### 4.1.3 LAST\_TIME

The LAST\_TIME parameter is a 16-bit value used by the TPU as temporary storage. It contains the event time of the latest input transition or accumulating match during active measurement of pulse width or period.

#### 4.1.4 ACCUM

ACCUM is a 16-bit value used by the TPU as temporary storage for the incomplete pulse width or period measurement. This parameter is reset to zero by the TPU after each complete measurement sequence, but must be initialized to zero by the CPU prior to issuing the initialization host service request.



#### 4.1.5 HW

This 16-bit parameter is updated by the TPU during the period or pulse width measurement. At the end of a measurement sequence, HW contains the upper word of the 32-bit accumulated result. HW should be cleared to zero by the CPU prior to issuing the initialization host service request. It must also be cleared after the result has been read, before the next accumulation exceeds 16 bits.

#### 4.1.6 LW

This 16-bit parameter is updated by the TPU at the end of the period or pulse width measurement sequence to contain the lower word of the 32-bit accumulated result. LW is not cleared by the TPU during initialization. It must be cleared by the CPU prior to issuing the initialization host service request.

#### **5** Function Initialization

Initialize the PTA function as follows.

- 1. Disable the intended PTA channel by clearing appropriate priority bits (unnecessary from reset).
- 2. Select the PTA function on the channel by writing the PTA function number to the channel function select bits.
- Initialize MAX\_COUNT, PERIOD\_COUNT, ACCUM, HW, and LW in the channel parameter RAM.
- 4. Initialize CHANNEL\_CONTROL and the channel host sequence bits to select the type of measurement to be made and the measurement timebase.
- 5. Issue an HSR%11 to initialize the channel and start the accumulation sequence.
- 6. Enable servicing of the channel by assigning the channel priority (H, M or L).

The TPU then executes the initialization state of the PTA function and starts accumulating period or pulse widths after the first valid start transition.

When the accumulation is complete, the TPU signals the host CPU via an interrupt request. The CPU must then read the 32-bit result from LW and HW (use a long word access for coherency), and reset HW to zero in preparation for the next accumulation. If required, MAX\_COUNT can also be updated at this time to alter the number of periods over which the next accumulation will be made.

#### 6 Performance and Use of Function

#### 6.1 Performance

Like all TPU functions, the performance limit of the PTA function in a given application is dependent to some extent on the service time (latency) associated with activity on other TPU channels. This is due to the operational nature of the scheduler. In the case of the PTA function, this limits the maximum frequency and minimum pulse widths of the signal that can be properly measured.

Since the scheduler assures that the worst case latencies in any TPU application can be calculated, it is recommended that the guidelines given in the TPU reference manual are used along with the information given in the PTA function state timing table to perform an analysis on any proposed TPU application that appears to approach the performance limits of the TPU.



| State Number and Name       | Max. CPU Clock Cycles | RAM Accesses by TPU |
|-----------------------------|-----------------------|---------------------|
| S0 INIT_PTA                 | 6                     | 1                   |
| S1 POS_TRANS0_PTA           |                       |                     |
| High time accumulate        | 54                    | 6                   |
| Low time accumulate         | 54                    | 6                   |
| Period accumulate — Rising  | 16                    | 2                   |
| Period accumulate — Failing | 16                    | 2                   |
| S2 POS_TRANS1_PTA           |                       |                     |
| High time accumulate        | 18                    | 2                   |
| Low time accumulate         | 12                    | 1                   |
| Period accumulate — Rising  | 44                    | 6                   |
| Period accumulate — Failing | 44                    | 6                   |
| S3 NEG_TRANS0_PTA           |                       |                     |
| High time accumulate        | 50                    | 6                   |
| Low time accumulate         | 50                    | 6                   |
| Period accumulate — Rising  | 16                    | 2                   |
| Period accumulate — Failing | 16                    | 2                   |
| S4 NEG_TRANS1_PTA           |                       |                     |
| High time accumulate        | 12                    | 1                   |
| Low time accumulate         | 22                    | 2                   |
| Period accumulate — Rising  | 44                    | 6                   |
| Period accumulate — Failing | 44                    | 6                   |

#### Table 2 PTA Function State Timing

NOTE: Execution times do not include the time slot transition time (TST = 10 CPU clocks)

#### 6.2 Usage Notes and Restrictions

#### 6.2.1 Clearing HW

At the end of the accumulation sequence, the 32-bit result of the PTA function is resident in HW and LW and the function issues an interrupt request to the CPU. The CPU must read the result and clear HW to zero before the next accumulation has exceeded 16 bits. This is because HW is updated during the measurement process, unlike LW, which is accumulated in ACCUM and then copied into LW at the end of the measurement.

#### 6.2.2 Maximum Accumulation

The PTA function allows a maximum accumulation of 32 bits of the selected TCR clock. If HW overflows during the accumulation, an interrupt is generated to the CPU, but the function continues to run normally. Investigation of the parameters by the CPU may reveal that an overflow has occurred, but under some circumstances it may be difficult to tell this condition from a valid termination of a measurement sequence. For this reason, the prescaler of the selected timebase should be set to ensure that the long-est measurement under worst case conditions does not exceed 32 bits.

#### 6.2.3 Reading the Incomplete Accumulation

Under some circumstances, it may be advantageous to get an approximation of how far the active accumulation has progressed. This can be achieved by reading HW and ACCUM (LW) coherently, then reading PERIOD\_COUNT to determine the number of periods over which the partial accumulation has been made. Note that PERIOD\_COUNT may have an error of one with respect to the accumulated value read, and that the partial accumulation can be up to one pulse width/period or \$8000 TCR clocks (if pulse width/period very long) less than the real value at the instant of reading.



#### 6.2.4 Changing Modes

Avoid changing measurement modes while the function is running. The correct way to change modes is to stop the function by clearing the channel priority bits, then follow the procedure outlined under **5 Function Initialization** to restart the function in the new mode.

#### 6.2.5 Noise Immunity

The PTA function is designed to filter out individual pulses which are too short to be measured correctly. These will not cause anomalous results in any of the measurement modes. However, repetitive noise on the input signal can cause anomalous results and also increased TPU activity, leading to an overall reduction in system performance. For this reason, every effort should be made to present the TPU with a noise free signal. Guaranteed minimum measurable pulse width or period can be determined by calculating worst-case latency for the PTA function. Refer to **6 Performance and Use of Function** for more information.

#### 7 Host Interface to Function

This section provides information concerning the TPU host interface to the function. **Figure 4** is a TPU address map. Detailed TPU register diagrams follow the figure. In the diagrams, Y = M111, where M is the value of the module mapping bit (MM) in the system integration module configuration register (Y =\$7 or \$F).

| Address  | 15 8 7                                        | 0 |
|----------|-----------------------------------------------|---|
| \$YFFE00 | TPU MODULE CONFIGURATION REGISTER (TPUMCR)    |   |
| \$YFFE02 | TEST CONFIGURATION REGISTER (TCR)             |   |
| \$YFFE04 | DEVELOPMENT SUPPORT CONTROL REGISTER (DSCR)   |   |
| \$YFFE06 | DEVELOPMENT SUPPORT STATUS REGISTER (DSSR)    |   |
| \$YFFE08 | TPU INTERRUPT CONFIGURATION REGISTER (TICR)   |   |
| \$YFFE0A | CHANNEL INTERRUPT ENABLE REGISTER (CIER)      |   |
| \$YFFE0C | CHANNEL FUNCTION SELECTION REGISTER 0 (CFSR0) |   |
| \$YFFE0E | CHANNEL FUNCTION SELECTION REGISTER 1 (CFSR1) |   |
| \$YFFE10 | CHANNEL FUNCTION SELECTION REGISTER 2 (CFSR2) |   |
| \$YFFE12 | CHANNEL FUNCTION SELECTION REGISTER 3 (CFSR3) |   |
| \$YFFE14 | HOST SEQUENCE REGISTER 0 (HSQR0)              |   |
| \$YFFE16 | HOST SEQUENCE REGISTER 1 (HSQR1)              |   |
| \$YFFE18 | HOST SERVICE REQUEST REGISTER 0 (HSRR0)       |   |
| \$YFFE1A | HOST SERVICE REQUEST REGISTER 1 (HSRR1)       |   |
| \$YFFE1C | CHANNEL PRIORITY REGISTER 0 (CPR0)            |   |
| \$YFFE1E | CHANNEL PRIORITY REGISTER 1 (CPR1)            |   |
| \$YFFE20 | CHANNEL INTERRUPT STATUS REGISTER (CISR)      |   |
| \$YFFE22 | LINK REGISTER (LR)                            |   |
| \$YFFE24 | SERVICE GRANT LATCH REGISTER (SGLR)           |   |
| \$YFFE26 | DECODED CHANNEL NUMBER REGISTER (DCNR)        |   |

Figure 4 TPU Address Map



## Freescale Semiconductor, Inc.

| CIER —                       | - Chan                                                                  | nel Inte     | errupt I | Enable | Regist    | er          |          |        |         |             |      |      |         | \$YF        | FE0A  |
|------------------------------|-------------------------------------------------------------------------|--------------|----------|--------|-----------|-------------|----------|--------|---------|-------------|------|------|---------|-------------|-------|
| 15                           | 14                                                                      | 13           | 12       | 11     | 10        | 9           | 8        | 7      | 6       | 5           | 4    | 3    | 2       | 1           | 0     |
| CH 15                        | CH 14                                                                   | CH 13        | CH 12    | CH 11  | CH 10     | CH 9        | CH 8     | CH 7   | CH 6    | CH 5        | CH 4 | CH 3 | CH 2    | CH 1        | CH 0  |
|                              | CH Interrupt Enable                                                     |              |          |        |           |             |          |        |         |             |      |      |         |             |       |
|                              | 0 Channel interrupts disabled                                           |              |          |        |           |             |          |        |         |             |      |      |         |             |       |
| 1 Channel interrupts enabled |                                                                         |              |          |        |           |             |          |        |         |             |      |      |         |             |       |
| CFSR[0                       | CFSR[0:3] — Channel Function Select Registers       \$YFFE0C - \$YFFE12 |              |          |        |           |             |          |        |         |             |      |      |         |             |       |
| 15                           | 14                                                                      | 13           | 12       | 11     | 10        | 9           | 8        | 7      | 6       | 5           | 4    | 3    | 2       | 1           | 0     |
| C                            | FS (CH 15                                                               | 5, 11, 7, 3) |          | (      | CFS (CH 1 | 4, 10, 6, 2 | 2)       |        | CFS (CH | 13, 9, 5, 1 | )    |      | CFS (CH | 12, 8, 4, 0 | )     |
| CFS[4:0                      | )] — P                                                                  | TA Fun       | nction N | lumbe  | r (Assi   | gned c      | luring r | nicroc | ode as  | sembly      | /)   |      |         |             |       |
| HSQR[(                       | D:1] —                                                                  | Host S       | Sequer   | ice Re | gisters   |             |          |        |         |             |      | \$Y  | FFE14   | 4 – \$YI    | FFE16 |

| 15     | 14 | 13   | 12    | 11   | 10    | 9  | 8     | 7  | 6     | 5    | 4     | 3  | 2    | 1  | 0    |
|--------|----|------|-------|------|-------|----|-------|----|-------|------|-------|----|------|----|------|
| CH 15, | 7  | CH 1 | 14, 6 | CH . | 13, 5 | CH | 12, 4 | CH | 11, 3 | CH 1 | 10, 2 | СН | 9, 1 | СН | 8, 0 |

| СН | Operating Mode              |
|----|-----------------------------|
| 00 | High Time Accumulate        |
| 01 | Low Time Accumulate         |
| 10 | Period Accumulate — Rising  |
| 11 | Period Accumulate — Falling |

#### HSRR[1:0] — Host Service Request Registers

#### 13 3 15 12 11 10 9 2 1 14 8 7 6 5 4 0 CH 15, 7 CH 14, 6 CH 13, 5 CH 12, 4 CH 11, 3 CH 10, 2 CH 9, 1 CH 8, 0

| СН | Initialization                    |
|----|-----------------------------------|
| 00 | No Host Service (Reset Condition) |
| 01 | No effect                         |
| 10 | No effect                         |
| 11 | Initialize Function               |

#### CPR[1:0] — Channel Priority Registers

#### **\$YFFE1C – \$YFFE1E**

| 15    | 14   | 13   | 12   | 11   | 10    | 9  | 8     | 7  | 6     | 5  | 4     | 3  | 2    | 1  | 0    |
|-------|------|------|------|------|-------|----|-------|----|-------|----|-------|----|------|----|------|
| CH 15 | i, 7 | CH 1 | 4, 6 | CH . | 13, 5 | CH | 12, 4 | СН | 11, 3 | CH | 10, 2 | CH | 9, 1 | СН | 8, 0 |

| СН | Channel Priority |
|----|------------------|
| 00 | Disabled         |
| 01 | Low              |
| 10 | Middle           |
| 11 | High             |

| 7     | 6    | 5  |
|-------|------|----|
| CH 11 | , 3  | CI |
|       |      |    |
| atina | Mode |    |

## TPU Programming Library

TPUPN06/D

For More Information On This Product, Go to: www.freescale.com

\$YFFE18 - \$YFFE1A



| ( | CISR — | - Chan | nel Inte | errupt S | Status | Regist | er   |        |          |           |        |      |      |      | \$YF | FE20 |
|---|--------|--------|----------|----------|--------|--------|------|--------|----------|-----------|--------|------|------|------|------|------|
|   | 15     | 14     | 13       | 12       | 11     | 10     | 9    | 8      | 7        | 6         | 5      | 4    | 3    | 2    | 1    | 0    |
|   | CH 15  | CH 14  | CH 13    | CH 12    | CH 11  | CH 10  | CH 9 | CH 8   | CH 7     | CH 6      | CH 5   | CH 4 | CH 3 | CH 2 | CH 1 | CH 0 |
|   |        |        |          |          |        |        |      |        |          |           |        |      |      |      |      |      |
|   |        |        |          |          |        | СН     |      | Int    | terrupt  | Status    |        |      |      |      |      |      |
| 0 |        |        |          |          |        | 0      | C    | hannel | interrup | ot not as | serted |      |      |      |      |      |

1

#### 8 Examples

The following two examples contain CPU32 code needed to initialize the PTA function for low pulse measurements and period on rising edge measurements using the TCR1 timebase. The code includes the initialization and use of basic interrupt handlers for these measurement modes. The assembled code was executed on a BCC board.

Channel interrupt asserted

#### 8.1 Example A: Low Pulse Measurement

This example shows how to initialize the PTA function for low pulse measurement and how to implement an interrupt handler. The channel generates an interrupt service request after each low pulse is measured. On every interrupt the handler logs all the PTA parameter RAM to BCC external RAM, between addresses \$6000 and \$6FFF. In addition, the interrupt handler also ensures the HW result if the function is cleared to zero after it is logged. The data log pointer is a word maintained at address \$5FFE. In this example, the PTA function has been assembled as function number \$F, but the function number can be different, depending on the application.

#### 8.2 Parameter RAM Content

After the CPU has initialized the parameter RAM for low pulse measurement, and before the host service request is issued, the parameter RAM content should be as follows:

|          | 15 |   |   |   |   |   |   | 8 | 7 |   |   |   |   |   |   | 0 |
|----------|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| \$YFFF10 | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| \$YFFF12 | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| \$YFFF14 | х  | х | х | х | х | х | х | х | х | х | х | х | х | х | х | х |
| \$YFFF16 | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| \$YFFF18 | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| \$YFFF1A | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

After the PTA function generates an interrupt service request to indicate that a low pulse measurement has been made, the parameter RAM content should be as follows:

|          | 15 |                                 |   |   |   |      |        | 8      | 7     |       |      |   |   |   |   | 0 |
|----------|----|---------------------------------|---|---|---|------|--------|--------|-------|-------|------|---|---|---|---|---|
| \$YFFF10 | 0  | 0                               | 0 | 0 | 0 | 0    | 0      | 0      | 0     | 0     | 0    | 0 | 1 | 1 | 1 | 1 |
| \$YFFF12 | 0  | 0                               | 0 | 0 | 0 | 0    | 0      | 1      | 0     | 0     | 0    | 0 | 0 | 0 | 0 | 0 |
| \$YFFF14 | х  | х                               | х | х | х | х    | х      | х      | х     | х     | х    | х | х | х | х | х |
| \$YFFF16 | х  | х                               | х | х | х | х    | х      | х      | х     | х     | х    | х | х | х | х | х |
| \$YFFF18 |    | High Word of Measured Low Pulse |   |   |   |      |        |        |       |       |      |   |   |   |   |   |
| \$YFFF1A |    |                                 |   |   | L | ow V | /ord c | of Mea | asure | d Low | Puls | е |   |   |   |   |



#### 8.3 Program Listing

| TPRAM0                                   |         | equ    | \$ffffff00    | TPU    | Channel           | 0 para   | meter RAM base  | address     |            |
|------------------------------------------|---------|--------|---------------|--------|-------------------|----------|-----------------|-------------|------------|
| TMCR                                     |         | equ    | \$ffffe00     | TPU    | Module (          | Configu  | ration          |             |            |
| TICR                                     |         | equ    | \$ffffe08     | TPU    | Interrup          | pt Conf  | iguration       |             |            |
| CIER                                     |         | equ    | \$fffffe0a    | TPU    | Channel           | Interr   | upt Enable      |             |            |
| CFSR3                                    |         | equ    | \$fffffe12    | TPU    | Channel           | Functi   | on Select Regi  | ster 3      |            |
| HSQR1                                    |         | equ    | \$fffffe16    | TPU    | Host Sec          | quence : | Register 1      |             |            |
| HSRR1                                    |         | equ    | \$fffffela    | TPU    | Host Ser          | rvice R  | equest Registe  | r 1         |            |
| CPR0                                     |         | equ    | \$fffffelc    | TPU    | Channel           | Priori   | ty Register O   |             |            |
| CPR1                                     |         | equ    | \$fffffele    | TPU    | Channel           | Priori   | ty Register 1   |             |            |
| CISR                                     |         | equ    | \$fffffe21    | TPU    | Channel           | Interr   | upt Status      |             |            |
| log_count                                |         | equ    | \$5FFE        | Data   | log cou           | unter.   |                 |             |            |
| * Channel                                | Functi  | on a   | ssignments    |        |                   |          |                 |             |            |
| PTA                                      |         | equ    | TPRAM0        |        |                   |          |                 |             |            |
| * PTA Para                               | ameter  | RAM    | constants     |        |                   |          |                 |             |            |
| channel_co<br>TCR1.                      | ontrol  | equ    | \$000F        | Dete   | ct risin          | ng/fall  | ing edges, cap  | ture and m  | atch on    |
| max_count                                |         | equ    | 1             | Numk   | er of pe          | eriods   | to accumulate.  |             |            |
|                                          | sectio  | n.te   | xt            |        |                   |          |                 |             |            |
| * Set up o                               | data lo | og po  | inter         |        |                   |          |                 |             |            |
|                                          | move.w  | 7 #\$6 | 000,log_count | 2      |                   |          |                 |             |            |
|                                          | clr.l   | d0     |               |        |                   |          |                 |             |            |
|                                          | movec   | d0,v   | br            |        |                   |          |                 |             |            |
|                                          | move.w  | 1 #\$0 | 4C0,TMCR      | Ensu   | ire TPU :         | is in e  | mulation mode,  | 240 ns re   | s.         |
| * 11-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1 | T       | ~ ~    | hannal aanfi  |        |                   |          |                 |             |            |
| * FIrst se                               | et up E | CDD0   | nannel contig | Jurat  | 1011<br>Tre schev | duler d  | isabled before  | setting n   | arametera  |
|                                          | move.w  | 7 #\$0 | 00F,CFSR3     | PTA    | on Chan           | 0.       | ISADIEU DEIDIE  | seccing p   | arameters  |
|                                          |         |        | ·             |        |                   |          |                 |             |            |
| * Now init                               | cialize | e PTA  | parameter RA  | AM on  | Channel           | 0        |                 |             |            |
| * Ac                                     | ldr off | set    | Paramete      | er Na  | me                | Para     | ameter Position | n           |            |
| *                                        | 00      |        | channel_      | _cont  | rol               |          | 9 LSbits        |             |            |
| *                                        | 02      |        | max_cour      | nt     |                   |          | MS byte         |             |            |
| *                                        | 02      |        | period_c      | count  |                   |          | LS byte         |             |            |
| *                                        | 04      |        | last_tir      | ne     |                   |          | Word            |             |            |
| *                                        | 06      |        | accum         |        |                   |          | Word            |             |            |
| *                                        | 08      |        | HW            |        |                   |          | Word            |             |            |
| *                                        | 0A      |        | LW            |        |                   |          | Word            |             |            |
|                                          | move.w  | / #ch  | annel_control | L,PTA  | Timeb             | ase sel  | lect            |             |            |
|                                          | move.w  | 7 #(m  | ax_count<<8)  | , PTA+ | 2 Number          | of per   | riods to accum  | ulate       |            |
|                                          | clr.w   | PTA+   | б             |        | TPU d             | loesn't  | clear Accum.    |             |            |
|                                          | clr.l   | PTA+   | 8             |        | TPU d             | loesn't  | initialize HW   | :LW Result  | •          |
| * Host sec                               | quence  | bits   | 0,1 dictate   | Puls   | e-High/L          | ow or B  | Period-Rising/I | Falling mea | asurement. |
|                                          | move.w  | 7 #\$O | 001,HSQR1     | Low    | Pulse me          | easurem  | ent.            |             |            |
| * Now set                                | up and  | l ena  | ble PTA inter | rupt.  |                   |          |                 |             |            |
|                                          | ori.w   | #1,T   | MCR           | Set    | IARB to           | non-ze   | ro value, and   |             |            |
|                                          | move.w  | , #\$0 | 640,TICR      | TPU    | intr le           | vel 6,   | Base vector nu  | m=\$40.     |            |
|                                          | move.]  | . #PT  | ASRV,\$40*4   | Set    | up PTA y          | vector   | (Base=\$40, cha | nnel 0)     |            |
|                                          | move.w  | , #\$0 | 001,CIER      | Enab   | ole chan          | 0 inte   | rrupt (PMM)     | /           |            |
|                                          | move.w  | 1 #\$2 | 500,SR        | Drop   | ) intr le         | evel be  | low TPU's       |             |            |
| + <b>a</b> ]                             |         |        |               |        | 555               |          |                 |             |            |
| * Send Hos                               | st serv | rice   | request and s | start  | PTA               |          | 1 1             |             |            |
|                                          | move.v  | / ₩ŞU  | UUS,HSKKI     | HOST   | . service         | ∛עדווד = | 1 I             |             |            |



|                   | move.w #\$0003,CPR1                     | Enable scheduler for PTA                |                     |
|-------------------|-----------------------------------------|-----------------------------------------|---------------------|
|                   | bra *                                   | TPU should be running now, (            | CPU in idle loop    |
| * * * * * * * *   | * * * * * * * * * * * * * * * * * * * * | *****                                   | * * * * * * * * *   |
| * Interr          | upt function: PTASRV                    |                                         | *                   |
| * Descri          | ption: Entered when bit                 | 0 of CISR register is set.              | *                   |
| *                 | This happens wher                       | n the PTA function has                  | *                   |
| *                 | completed the acc                       | cumulated measurement.                  | *                   |
| *                 | PTA Parameter RAM                       | 1 on channel 0 is logged                | *                   |
| *                 | and whole 32-bit                        | result is cleared if low                | *                   |
| *                 | word of result is                       | s non-zero.                             | *                   |
| *Input c          | onditions: bit 0 of CISE                | R is'1'.                                | *                   |
| *                 | HW:LW holds r                           | neasurement result.                     | *                   |
| *Output           | conditions: bit 0 of CIS                | SR is'0'                                | *                   |
| *                 | (provided CH                            | PU interrupt latency is not             | *                   |
| *                 | exceeded).                              |                                         | *                   |
| *                 | HW:LW is cle                            | eared to zero.                          | *                   |
| * * * * * * * * * | * * * * * * * * * * * * * * * * * * * * | * * * * * * * * * * * * * * * * * * * * | * * * * * * * * * * |
|                   |                                         |                                         |                     |
| PTASRV            | equ *                                   | PTA interrupt service routin            | ne                  |
|                   | bclr #0,CISR+1                          | Clear PTA status flag                   |                     |
|                   |                                         |                                         |                     |
| log_all           | bsr ptalog                              | Log data                                |                     |
|                   | tst.w PTA+\$A                           | If LW Result < > 0 Then                 |                     |
|                   | beq log_ex                              |                                         |                     |
| log_clr           | clr.l PTA+8                             | clear whole 32-bit result, s            | since TPU doesn't.  |
| 7                 |                                         |                                         |                     |
| log_ex            | equ *                                   | <b>1</b> .                              |                     |
|                   | rte                                     | and return                              |                     |
| * * * * * * * * * | * * * * * * * * * * * * * * * * * * * * | * * * * * * * * * * * * * * * * * * * * | * * * * * * * * *   |
| * Subrou          | tine: ntalog                            |                                         | *                   |
| * Descri          | otion: If data space is                 | available 8 words of                    | *                   |
| *                 | channel 0 paramet                       | er are logged in next 8                 | *                   |
| *                 | word locations                          | ter are rogged in next o                | *                   |
| * Tnnut           | conditions: log count po                | vints to next free data log             | *                   |
| *                 | location of                             | is greater than or equal                | *                   |
| *                 | to the limit                            | if no data space                        | *                   |
| *                 | available                               | ii no data space                        | *                   |
| * ()1+D11+        | conditions: log count                   | ncremented by 16 or is                  | *                   |
| *                 | greater the                             | an or equal to the limit if             | *                   |
| *                 | no more dat                             | a space available                       | *                   |
| *                 | CPU registe                             | ars a? a3 d? changed                    | *                   |
| *                 |                                         | arb uz, us, uz changea                  | *                   |
| * * * * * * * *   | * * * * * * * * * * * * * * * * * * * * | *****                                   | * * * * * * * * *   |
|                   |                                         |                                         |                     |
| ptalog            | move.w log_count,a2                     |                                         |                     |
| _                 | cmpa #\$7000,a2                         | If log limit reached then               |                     |
|                   | bge ptalogex                            | do nothing, else                        |                     |
|                   | move.w #TPRAM0,a3                       | Get start address of require            | ed data             |
|                   | moveq #7,d2                             | -                                       |                     |
| loop              | move.w (a3)+,(a2)+                      | and log parameters.                     |                     |
| -                 | dbra d2,loop                            |                                         |                     |
|                   | move.w a2,log_count                     | Save next log position                  |                     |
| ptalogex          | rts                                     | and return                              |                     |
|                   | end                                     |                                         |                     |



#### 8.4 Example B: Rising Edge Period Measurement

This example shows how to initialize the PTA function for period measurement on each rising edge, and how to set up and implement an interrupt handler. On every interrupt service request, the handler logs all the PTA parameter RAM to BCC external RAM, between addresses \$6000 and \$6FFF. In addition, the interrupt handler also ensures the HW result of the function is cleared to zero after it is logged. The data log pointer is a word maintained at address \$5FFE. In this example, the PTA function has been assembled as function number \$F, but the function number can be different, depending on the application.

#### 8.5 Parameter RAM Content

After the CPU has initialized the parameter RAM for period measurement on rising edge, and before the host service request is issued, the parameter RAM content should be as follows:

|          | 15 |   |   |   |   |   |   | 8 | 7 |   |   |   |   |   |   | 0 |
|----------|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| \$YFFF10 | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 |
| \$YFFF12 | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| \$YFFF14 | х  | х | х | х | х | х | х | х | х | х | х | х | х | х | х | х |
| \$YFFF16 | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| \$YFFF18 | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| \$YFFF1A | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

After the PTA function generates an interrupt service request to indicate that a period measurement has been made, the parameter RAM content should be as follows:

|          | 15 |   |   |   |   |      |      | 8      | 7     |       |       |   |   |   |   | 0 |
|----------|----|---|---|---|---|------|------|--------|-------|-------|-------|---|---|---|---|---|
| \$YFFF10 | 0  | 0 | 0 | 0 | 0 | 0    | 0    | 0      | 0     | 0     | 0     | 0 | 0 | 1 | 1 | 1 |
| \$YFFF12 | 0  | 0 | 0 | 0 | 0 | 0    | 0    | 1      | 0     | 0     | 0     | 0 | 0 | 0 | 0 | 0 |
| \$YFFF14 | х  | х | х | х | х | х    | х    | х      | х     | х     | х     | х | х | х | х | х |
| \$YFFF16 | х  | х | х | х | х | х    | х    | х      | х     | х     | х     | х | х | х | х | х |
| \$YFFF18 |    |   |   |   |   | High | Word | d of M | easu  | red P | eriod |   |   |   |   |   |
| \$YFFF1A |    |   |   |   |   | Low  | Word | d of M | easui | ed Pe | eriod |   |   |   |   |   |

#### 8.6 Program Listing

| TPRAMO eo   | qu \$ffffff00 | TPU Channel 0 parameter RAM base address |
|-------------|---------------|------------------------------------------|
| TMCR eq     | qu \$fffffe00 | TPU Module Configuration                 |
| TICR ed     | qu \$fffffe08 | TPU Interrupt Configuration              |
| CIER eq     | qu \$fffffe0a | TPU Channel Interrupt Enable             |
| CFSR3 eq    | qu \$fffffe12 | TPU Channel Function Select Register 3   |
| HSQR1 ed    | qu \$fffffe16 | TPU Host Sequence Register 1             |
| HSRR1 ed    | qu \$fffffela | TPU Host Service Request Register 1      |
| CPR0 eq     | qu \$fffffelc | TPU Channel Priority Register 0          |
| CPR1 eq     | qu \$fffffele | TPU Channel Priority Register 1          |
| CISR eq     | qu \$fffffe21 | TPU Channel Interrupt Status             |
| log_count e | qu \$5FFE     | Data log counter.                        |

\* Channel Function assignments PTA equ TPRAMO

<sup>\*</sup> PTA Parameter RAM constants



## Freescale Semiconductor, Inc.

| channel_control<br>max_count      | equ \$0007<br>equ 1                   | Detect only rising edges, capture and match on TCR1.<br>Number of periods to accumulate. |
|-----------------------------------|---------------------------------------|------------------------------------------------------------------------------------------|
| secti                             | on.text                               |                                                                                          |
| * Set up data l<br>move.          | og pointer<br>w #\$6000,log_coun      | t                                                                                        |
| clr l                             | d0                                    |                                                                                          |
| moved                             | d0.vbr                                | Necessary for BDM downloads.                                                             |
| move.                             | w #\$04C0,TMCR                        | Ensure TPU is in emulation mode, 240 ns res.                                             |
| * First set up                    | PTA channel confi                     | guration                                                                                 |
| clr.1                             | CPR0                                  | Ensure scheduler disabled before setting parameters                                      |
| move.                             | w #\$000F,CFSR3                       | PTA on Chan 0.                                                                           |
| * Now initializ                   | ze PTA parameter R                    | AM on Channel 0                                                                          |
| * Addr of                         | fset Paramet                          | er Name Parameter Position                                                               |
| * 00                              | channel                               | control 9 LSbits                                                                         |
| * 02                              | max cou                               | nt MS byte                                                                               |
| * 02                              | max_cou                               | aount IS byte                                                                            |
| * 04                              | periou_                               | mo Word                                                                                  |
| * 04                              | IdSt_tI                               | word                                                                                     |
| ^ U6                              | accum                                 | word                                                                                     |
| ^ U8                              | HW                                    | word                                                                                     |
| * 0A                              | LW                                    | Word                                                                                     |
| move.                             | w #channel_contro                     | l,PTA Timebase select                                                                    |
| move.                             | <pre>w #(max_count&lt;&lt;8)</pre>    | ,PTA+2 Number of periods to accumulate                                                   |
| clr.w                             | / PTA+6                               | TPU doesn't clear Accum.                                                                 |
| clr.1                             | PTA+8                                 | TPU doesn't initialize HW:LW Result.                                                     |
| * Host sequence<br>* measurement. | e bits 0,1 dictate                    | Pulse-High/Low or Period-Rising/Falling                                                  |
| move.                             | w #\$0002,HSQR1                       | Period measurement on rising edges.                                                      |
| * Now set up an                   | nd enable PTA inte                    | rrupt                                                                                    |
| ori.w                             | #1,TMCR                               | Set IARB to non-zero value, and                                                          |
| move.                             | w #\$0640.TICR                        | TPU intr level 6. Base vector num=\$40.                                                  |
| move.                             | 1 #PTASRV.\$40*4                      | Set up PMM vector (Base=\$40, channel 0)                                                 |
| move                              | w #\$0001.CTER                        | Enable chan () interrupt (PMM)                                                           |
| move.                             | w #\$2500,SR                          | Drop intr level below TPU's intr level                                                   |
| * Send Host ser                   | vice request and                      | start PTA                                                                                |
| move.                             | w #\$0003,HSRR1                       | Host service init%11                                                                     |
| move.                             | w #\$0003,CPR1                        | Enable scheduler for PTA                                                                 |
| bra *                             |                                       | TPU should be running now!                                                               |
| * * * * * * * * * * * * * * * *   | * * * * * * * * * * * * * * * * * * * | ******                                                                                   |
| * Interrupt fun                   | nction: PTASRV                        | *                                                                                        |
| * Description:                    | Entered when bit                      | 0 of CISR register is set *                                                              |
| *                                 | This happens when                     | the PTA function has *                                                                   |
| *                                 | completed the acc                     | umulated measurement. *                                                                  |
| *                                 | PTA Parameter RAM                     | on channel 0 is logged *                                                                 |
| *                                 | and whole 32-bit                      | result is cleared if low *                                                               |
| *                                 | word of result is                     | non-zero. *                                                                              |
| *Input conditio                   | ons: bit 0 of CISR                    | .is'l'. *                                                                                |



```
HW:LW holds measurement result.
*Output conditions: bit 0 of CISR is'0'
                 (provided CPU interrupt latency is not *
                 exceeded).
                 HW:LW is cleared to zero.
PTASRV
        equ *
                            PTA interrupt service routine
        bclr #0,CISR+1
                           Clear PTA status flag
log_all bsr ptalog
                           Log data
        tst.w PTA+$A
                           If LW Result < > 0 Then
        beq log_ex
                            clear whole 32-bit result, since TPU doesn't.
log_clr
        clr.l PTA+8
        equ *
loq ex
                            and return
        rte
* Subroutine: ptalog
 Description: If data space is available, 8 words of
*
            channel 0 parameter are logged in next 8
*
            word locations.
 Input conditions: log_count points to next free data log *
                 location, or is greater than or equal *
*
                 to the limit if no data space
*
                 available.
*
 Output conditions: log_count incremented by 16, or is
                 greater than or equal to the limit if
*
                 no more data space available.
                 CPU registers a2, a3, d2 changed
ptalog
        move.w log_count,a2
        cmpa #$7000,a2
                           If log limit reached then
        bge ptalogex
                           do nothing, else
        move.w #TPRAM0,a3
                           Get start address of required data
        moveq #7,d2
        move.w (a3)+,(a2)+
                            and log parameters.
loop
        dbra d2,loop
        move.w a2,log_count
                            Save next log position
                            and return
ptalogex rts
```

end

### **9** Function Algorithm

The following description is provided as a guide only, to aid understanding of the function. The exact sequence of operations in microcode may be different from that shown, in order to optimize speed and code size. TPU microcode source listings for all functions in the TPU function library can be downloaded from the Freesca; e Freeware bulletin board. Refer td*Jsing the TPU Function Library and TPU Emulation Mode* (TPUPN00/D) for detailed instructions on downloading and compiling microcode.

The programmable time accumulator function consists of five states. The function uses matches in addition to transition detection to measure the desired signal property. Using matches in this way extends the maximum period and pulse widths that can be successfully measured beyond the \$FFFF TCR count limit. For clarity, the following description refers to an internal flag that is not available to the user. Flag0 tracks the pin state from the previous channel service, to ensure correct startup in the various measurement modes. Flag0 is used in conjunction with the new pin state, shared match/transition flag and the host service request bits to determine which of the PTA function states are executed.



#### 9.1 State 0: INIT\_PTS

This state, entered as a result of HSR %11, configures the channel. Condition: HSR1, HSR0, M/TSR, LSR, Pin, Flag0 = 11XXXX

The channel is configured with the contents of the CHANNEL\_CONTROL parameter If pulse measurement has been selected via the host sequence bits, flag0 is set, otherwise it is cleared Negate MRL, TDL, LSL The state ends

#### 9.2 State 1: POS\_TRANS0\_PTA

This state is entered as a result of a positive transition or a match when the pin is one and flag0 is zero.

Condition: HSR1, HSR0, M/TSR, LSR, Pin, Flag0 = 001X10

If Pulse Measurement Then If Match Then {High Pulse assumed} ACCUM TIME NEXT MATCH Else {Low Pulse, Transition assumed} Check Pin If Pin = 1 Then Flag0:= 1 ACCUM\_TIME CHECK COUNT Endif Endif Else {Period Measurement} If Match Then {Possible pending match from previous mode} Clear Match Flag Else **Clear Transition Flag** Flag0:= 1NEXT\_MATCH Endif

Endif

#### 9.3 State 2: POS\_TRANS1\_PTA

This state is entered as a result of a positive transition or a match when the pin is one and flag0 is one.

Condition: HSR1, HSR0, M/TSR, LSR, Pin, Flag0 = 001X11

If Pulse Measurement Then If Match Then Clear Match Flag Else Check\_Pin If High Pulse Then If Pin = 1 Then Flag0:= 0 NEXT\_MATCH Endif Endif Else If Match Then

{Period Measurement}



ACCUM\_TIME NEXT\_MATCH Else ACCUM\_TIME CHECK\_COUNT NEXT\_MATCH Endif

Endif

#### 9.4 State 3: NEG\_TRANS0\_PTA

This state is entered as a result of a negative transition or a match when the pin is zero and flag0 is zero.

Condition: HSR1, HSR0, M/TSR, LSR, Pin, Flag0 = 001X00

| If Pulse Measurement Then<br>If Match Then<br>ACCUM_TIME<br>NEXT MATCH          | {Low Pulse assumed}                                        |
|---------------------------------------------------------------------------------|------------------------------------------------------------|
| Else                                                                            | {High Pulse, Transition assumed}                           |
|                                                                                 | {High Pulse Match is Invalid State and not processed here} |
| Check_Pin<br>If Pin = 0 Then<br>Flag0:= 1<br>ACCUM_TIME<br>CHECK_COUNT<br>Endif |                                                            |
| Endif                                                                           |                                                            |
| Else                                                                            | {Period Measurement, Transition assumed}                   |
| If Match Then{<br>Clear Match Flag                                              | {Possible pending match from previous mode}                |
| Else                                                                            |                                                            |
| Flag0:= 1<br>NEXT_MATCH<br>Clear Transition Flag                                |                                                            |
| Endif                                                                           |                                                            |
| Endif                                                                           |                                                            |

#### 9.5 State 4: NEG\_TRANS1\_PTA

This state is entered as a result of a negative transition or a match when the pin is zero and flag0 is one.

Condition: HSR1, HSR0, M/TSR, LSR, Pin, Flag0 = 001X01

If Pulse Measurement Then If Match Then Clear Match Flag Else Check\_Pin If Low Pulse Then If Pin = 0 Then Flag0:= 0 NEXT\_MATCH Endif Endif Endif

{Period Measurement}



If Match Then ACCUM\_TIME NEXT\_MATCH Else ACCUM\_TIME CHECK\_COUNT NEXT\_MATCH Endif Endif

#### 9.6 Pseudocode Subroutines

#### ACCUM\_TIME

ACCUM:= ACCUM + (EVENT\_TIME – LAST\_TIME) If Overflow Then HW:= HW + 1 If Overflow Then Generate Interrupt to CPU Endif Endif

NEXT\_MATCH

LAST\_TIME:= EVENT\_TIME Schedule Match at (EVENT\_TIME + Max)

#### CHECK\_COUNT

PERIOD\_COUNT:= PERIOD\_COUNT + 1 If PERIOD\_COUNT ≥ MAX\_COUNT Then LW:= ACCUM Generate Interrupt to CPU ACCUM:= 0 PERIOD\_COUNT:= 0 Endif

#### Check\_Pin

Get new pin level and coherently clear transition flag



NOTES



NOTES



#### How to Reach Us:

Home Page: www.freescale.com

E-mail: support@freescale.com

#### USA/Europe or Locations Not Listed:

Freescale Semiconductor Technical Information Center, CH370 1300 N. Alma School Road Chandler, Arizona 85224 +1-800-521-6274 or +1-480-768-2130 support@freescale.com

#### Europe, Middle East, and Africa:

Freescale Halbleiter Deutschland GmbH Technical Information Center Schatzbogen 7 81829 Muenchen, Germany +44 1296 380 456 (English) +46 8 52200080 (English) +49 89 92103 559 (German) +33 1 69 35 48 48 (French) support@freescale.com

#### Japan:

Freescale Semiconductor Japan Ltd. Headquarters ARCO Tower 15F 1-8-1, Shimo-Meguro, Meguro-ku, Tokyo 153-0064 Japan 0120 191014 or +81 3 5437 9125 support.japan@freescale.com

#### Asia/Pacific:

Freescale Semiconductor Hong Kong Ltd. Technical Information Center 2 Dai King Street Tai Po Industrial Estate Tai Po, N.T., Hong Kong +800 2666 8080 support.asia@freescale.com

#### For Literature Requests Only:

Freescale Semiconductor Literature Distribution Center P.O. Box 5405 Denver, Colorado 80217 1-800-441-2447 or 303-675-2140 Fax: 303-675-2150 LDCForFreescaleSemiconductor@hibbertgroup.com Information in this document is provided solely to enable system and software implementers to use Freescale Semiconductor products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits or integrated circuits based on the information in this document. Freescale Semiconductor reserves the right to make changes without further notice to any products herein. Freescale Semiconductor makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does Freescale Semiconductor assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters which may be provided in Freescale Semiconductor data sheets and/or specifications can and do vary in different applications and actual performance may vary over time. All operating parameters, including "Typicals" must be validated for each customer application by customer's technical experts. Freescale Semiconductor does not convey any license under its patent rights nor the rights of others. Freescale Semiconductor products are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which the failure of the Freescale Semiconductor product could create a situation where personal injury or death may occur. Should Buyer purchase or use Freescale Semiconductor products for any such unintended or unauthorized application, Buyer shall indemnify and hold Freescale Semiconductor and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claim alleges that Freescale Semiconductor was negligent regarding the design or manufacture of the part.



For More Information On This Product, Go to: www.freescale.com