## Motorola Semiconductor Engineering Bulletin

# EB280

## Programming the Channel Control Registers on the Time Processor Unit

By Sharon Darley Austin, Texas

### Introduction

The time processor unit (TPU) has several control registers that are shared by all 16 channels. Some of these registers, such as the channel interrupt enable register and channel interrupt status register, are not always used.

However, four registers must always be initialized:

- Channel function select registers
- Host sequence registers
- Host service request registers
- Channel priority registers



## **General Information**

| Channel Function<br>Select Registers | The channel function select registers (CFSR1–CFSR3) contain the function numbers assigned to each individual channel. Each register holds the function numbers for four of the channels. These function numbers determine the TPU function assigned to each channel. They are mask set dependent because they are determined by the microcode assembly.                                                                                                                                                              |
|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Host Sequence<br>Registers           | The host sequence registers (HSQR0 and HSQR1) contain the host<br>sequence bits for the function running on a particular channel. Each host<br>sequence register contains the host sequence bits for eight channels.<br>The host sequence bits determine the mode of a particular function. For<br>example, a function counting input transitions may operate in a single-<br>shot mode or a continuous mode. Or, a function generating a square<br>wave may or may not request other channels to synchronize to it. |
|                                      | The host sequence bits are different for each function because they are<br>determined by the microcode for each function. The author of the<br>microcode for a particular function determines what different<br>combinations of the host sequence bits will mean for that function.                                                                                                                                                                                                                                  |
| Host Service<br>Request Registers    | The host service request registers (HSRR0 and HSRR1) contain the service request bits for each channel. Each service register contains the service request bits for eight channels. The service request bits ask the TPU microengine to service a particular channel. Usually, the first service request is for initialization. Another common service request is for that of an immediate update.                                                                                                                   |
|                                      | Like the host sequence bits, the host service bits are different for each function because they are determined by the microcode for each function.                                                                                                                                                                                                                                                                                                                                                                   |
|                                      | However, the host service bits are different from other control bits because, while the CPU can set the service bits, only the TPU can clear                                                                                                                                                                                                                                                                                                                                                                         |

| them. In fact, clearing the bits to 0 is how the TPU tells the CPU that it |
|----------------------------------------------------------------------------|
| has serviced the channel.                                                  |

The host service request register should not be written unless:

- 1. All of the other parameters and control bits are already initialized or the channel is currently disabled via the channel priority register, and
- 2. The current state of the host service request register is 0. The program must wait until a previous service request has been cleared to 0 before issuing a new service request.

If the TPU is running two or more channels that share a host service request register and that are not going to be given simultaneous service requests, the most prudent way to enable them for initialization is to first disable all channels via the channel priority registers and then write to the service request registers.

Finally, enable each channel as needed via the channel priority registers. This method ensures that conflicts do not occur within the host service request registers.

Channel PriorityThe channel priority registers determine how often each channel isRegistersserviced.

The three priority levels are:

- High
- Medium
- Low

If the priority bits are set to 0, then a channel has no priority and is disabled. The TPU microengine will not service the channel at all unless it has a non-0 priority level. The priority scheme is discussed further in the TPU reference manual.

#### Summary

In summary, there are three possible situations for which a host service request may be issued:

- Initializing a channel out of reset Disable the channel via the channel priority register, initialize the parameter RAM and other control registers, and give the host service request for initialization. The final step is to enable the channel via the channel priority register.
- 2. Changing the function operating on a particular channel Follow the same steps as for initialization out of reset.
- Giving a channel a host service request other than that for initialization — Do not disable the channel. Instead, wait for the TPU to clear the previous host service request. Then, issue a new request. Usually, this would be for an immediate update or to force an output state on a particular pin.

Motorola reserves the right to make changes without further notice to any products herein. Motorola makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does Motorola 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 Motorola 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. Motorola does not convey any license under its patent rights or the rights of others. Motorola 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 Motorola product could create a situation where personal injury or death may occur. Should Buyer purchase or use Motorola products for any such unintended or unauthorized application, Buyer shall indemnify and hold Motorola 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 Motorola was negligent regarding the design or manufacture of the part. Motorola and ( $\widehat{A}$ ) are registered trademarks of Motorola, Inc. Motorola, Inc. is an Equal Opportunity/Affirmative Action Employer.

#### How to reach us:

USA/EUROPE/Locations Not Listed: Motorola Literature Distribution, P.O. Box 5405, Denver, Colorado 80217, 1-800-441-2447 or 1-303-675-2140. Customer Focus Center, 1-800-521-6274

JAPAN: Motorola Japan Ltd.: SPD, Strategic Planning Office, 141, 4-32-1 Nishi-Gotanda, Shinagawa-ku, Tokyo, Japan, 03-5487-8488 ASIA/PACIFIC: Motorola Semiconductors H.K. Ltd., Silicon Harbour Centre, 2 Dai King Street, Tai Po Industrial Estate, Tai Po, New Territories, Hong Kong, 852-26629298

Mfax<sup>™</sup>, Motorola Fax Back System: RMFAX0@email.sps.mot.com; http://sps.motorola.com/mfax/; TOUCHTONE, 1-602-244-6609; US and Canada ONLY, 1-800-774-1848

HOME PAGE: http://motorola.com/sps/



Mfax is a trademark of Motorola, Inc.

© Motorola, Inc., 1999