# Handling of On-Chip DMAC Interrupts in the NS32GX320

National Semiconductor Application Note 700 Zohar Peleg September 1990



## INTRODUCTION

The on-chip Interrupt Control Unit (ICU) of the NS32GX320 manages up to 15 levels of interrupt requests. Two of these levels, 6 and 14, may be requested internally by the on-chip DMAC, or externally by issuing the level number on the IRO-3 input pins. The on-chip DMAC may request an interrupt due to 3 possible events on each of its 2 channels. Each event is associated with a status bit that may be read and cleared by the software. The status bits are sticky, and will keep issuing an interrupt request until they are cleared by the software.

After receiving a DMAC interrupt, the user must perform the following tasks:

- 1. Detect the cause of the interrupt.
- 2. Clear the corresponding status bit(s).
- 3. Handle the event and (if required) resume channel's operation.

This application note describes how to perform these three tasks.

## BACKGROUND

There are 3 events that can cause an interrupt in each DMAC channel. These are:

- 1. TC—Terminal Count. This occurs when the channel's transfer is completed by a terminal count condition (BLTC register reaches zero).
- 2. EOT—End Of Transfer. This occurs when the transfer is externally terminated by the assertion of an EOT signal.

 OVR—Channel OverRun. This occurs in non-autoinitialize mode when the current transfer is completed, and the parameters for the next transfer are not ready (VLD bit in the CNTL register is zero).

Each of these events has a corresponding status bit in the DMAC status register called STAT (*Figure 1*), and an enable bit in the DMAC interrupt mask register called IMSK (*Figure 2*). The status bit is set when the event has occurred. An interrupt will be requested when both the status bit and corresponding enable bit are set. A status bit is cleared by writing "1" into it. Writing "0" does not change the bit.

The DMAC interrupt request may have a priority level of 6 or 14. This priority level is programmed by setting the DMAC Interrupt Priority bit (DIP) in the IMSK register (DIP = 0 means the priority level is 6, DIP = 1 means the priority level is 14).

When a channel is stopped due to EOT or OVR (when unmasked), the channel enable bit (CHEN) in the control register (CNTL) is cleared (*Figure 3*). Channel operation is resumed by setting the CHEN bit to "1". This can be done only after clearing or masking the pending bit(s).

Interrupts of priorities 6 and 14 may also be caused by external events. Though it is not recommended to do this, there are ways to detect when this occurs. Note that the more sources there are for an interrupt priority level, the more software checks are required to detect the cause of the interrupt.



Handling of On-Chip DMAC Interrupts in the NS32GX320

©1995 National Semiconductor Corporation TL/EE10869

RRD-B30M75/Printed in U. S. A

AN-700

### DETECTION OF INTERRUPT SOURCE

This section lists the steps the user may follow to detect the different interrupt sources. This includes the six interrupt sources described above plus any external interrupt with the same priority level.

- 1. If nesting of higher level interrupts is desired, set I bit in PSR.
- 2. Read the DMAC's IMSK register. (Address h'FFFF014)
- Test the DIP bit. If it does not match the interrupt level in service, then it is an external interrupt request (this check is redundant if the DMAC's interrupt priority is not due to change, or if there is no external request assigned for that interrupt priority level).
- 4. Read the DMAC's STAT register. (Address h'FFFF610)
- 5. Screen out all masked events. Retain a copy of all the unmasked pending bits in a general purpose register (the rest of this application note refers to this register as the "unmasked-pending word").
- 6. If the Unmasked-Pending word is "0", then it is an external vector. This check is redundant if there is no external request assigned for that level.
- 7. Write the Unmasked-Pending word back to the DMAC status register. This clears all the unmasked pending bits. Note that the masked bits should not be cleared here, since they may be handled by another piece of software which is not called by an interrupt.
- Test all the relevant bits in the Unmasked-Pending word. Perform the service routines for each of the pending events (see the next section). Reinitialize the DMAC channel(s) according to the specific application and return from the interrupt.

Note that if a new pending bit is set in the status register after the DMAC's STAT register is read, then it will not be cleared by writing the Unmasked-Pending word back to the DMAC status register. The pending bit will remain set, and will issue another interrupt immediately after returning from the current interrupt.

#### SERVICE ROUTINES

This section describes the implications that should be considered when handling the interrupt events.

## EOT (End of Transfer) Handling

The transfer is externally terminated by the assertion of  $\overline{\text{EOT}}$  signal. That means that the external condition for the transfer's completion is met, and the channel is free for the next DMAC task. The handler may initialize the channel for its next task and resume its operation.

#### OVR (Channel OVerRun) Handling

Channel Overrun occurs in non-autoinitialize mode when the current transfer is completed, and the parameters for the next transfer are not ready (VLD bit in the CNTL register is zero). The channel is halted.

In single transfer operation, this indicates that the channel's task is over, and the channel is free for another task.

In double buffer operation, this indicates that the DMAC is stopped since the parameters for the next transfer are not ready yet, and the handler has to prepare the parameters, to set the VLD bit and to resume the channel's operation. It may also consider the data of the last transfer as ready, and start processing it.

#### TC (Terminal Count) Handling

TC condition occurs when the BLTC reaches zero. This event does not disable the channel regardless of the value of the corresponding bit in IMSK.

In single transfer operation the TC will always be accompanied by OVR, which will stop the channel's operation. In that case the TC is redundant, and can be masked if OVR is not masked. It indicates that the previous transfer is complete, the current one has started, and that it is time to go ahead and prepare the next buffer in advance, in order to avoid channel overrun. The TC will be accompained by OVR, so if OVR is found set, then the handling of TC may be included in the OVR handling, and the check of TC event may be skipped.

In autoinitialize operation the TC indicates completion of another transfer, and may be used to count number of transfers, and, if required, to stop the channel's operation when a desired number of transfers is reached.

In all cases TC indicates that the data of the last transfer is ready in its destination, and may be further processed.

| code described<br>#      | NOW IT WOI    | KS.                  |                                                                          |
|--------------------------|---------------|----------------------|--------------------------------------------------------------------------|
| # Example of             | ? on-chip     | DMAC interrupt       | s handling                                                               |
| #<br>.set dma_ims        | sk. h'fff     | ff014                |                                                                          |
| .set dma_sta             |               |                      |                                                                          |
| .set dma0_cr             |               |                      |                                                                          |
| .set dmal_cr             | ntl, h'fi     | ffff05c              |                                                                          |
|                          |               |                      |                                                                          |
| int_6:                   |               |                      |                                                                          |
| 11020.                   | bispsrv       | v \$h'0800           | <pre># set I bit in PSR to enable</pre>                                  |
|                          |               |                      | <pre># nesting of higher level interrupt</pre>                           |
|                          | movd<br>cbitb | dma_imsk, r0         | # Store dma interrupt mask.                                              |
|                          | bfs           | \$7, r0<br>ext_int_6 | # Test and clear interrupt priority.<br># If set - this is external int. |
|                          | andd          | dma_stat, r0         | # Record all unmasked pending events.                                    |
|                          | cmpd          | \$0, r0              | # Are there any?                                                         |
|                          | beq           | ext_int_6            |                                                                          |
|                          | movd          | r0, dma_stat         | # clear all unmasked pending events.                                     |
| chk_ovr0:                | tbitb         | \$2, r0              | # Check if DMACO OVR event.                                              |
|                          | bfc           | chk_tc0              |                                                                          |
|                          | jsr           | dma0_ovr             |                                                                          |
| chk_tc0:                 | tbitb<br>bfc  | \$0, ro<br>chk_eot0  | # Check if DMACO TC event.                                               |
|                          | jsr           | dma0_tc              |                                                                          |
| chk_eot0:                | tbitb         | \$1, r0              | # Check if DMACO EOT event.                                              |
|                          | bfc           | chk_ovrl             |                                                                          |
|                          | jsr           | dma0_eot             |                                                                          |
| chk_ovrl:                | tbitb         | \$6, r0              | <pre># Check if DMAC1 OVR event.</pre>                                   |
|                          | bfc<br>jsr    | chk_tcl<br>dmal_ovr  |                                                                          |
| chk_tcl:                 | tbitb         | \$4, r0              | # Check if DMAC1 TC event.                                               |
| CHK_UCI:                 | bfc           | chk_eotl             | # ONCCR II DWACE TO CVCMU.                                               |
|                          | jsr           | dmal_tc              |                                                                          |
| chk_eotl:                | tbitb         | \$5, r0              | # Check if DMACl EOT event.                                              |
|                          | bfc           | chk_out              |                                                                          |
|                          | jsr           | dmal_eot             |                                                                          |
| chk_out:<br>#            | reti          |                      |                                                                          |
|                          | the eve       | ents are guarant     | eed to be masked, the above check                                        |
|                          |               |                      | he non relevant bits.                                                    |
|                          |               |                      | hen OVR implies also TC,                                                 |
|                          |               | owings: (example     | can be used to optimize<br>for ch-O only)                                |
| # chk_tc0:               | tbitb         | \$0, r0              | # Check if DMACO TC event.                                               |
| #                        | bfc           | chk_eot0             | # no TC => no OVR                                                        |
| #<br>#                   | tbitb<br>bfc  | \$2, r0<br>jmp_tc0   | <pre># if TC - is there also OVR? # no =&gt; only TC.</pre>              |
| #<br>#                   | jsr           | dma0_ovr             | # no => only ic.<br># yes - handle OVR. Consider                         |
| #                        | 5             |                      | # TC implied in OVR.                                                     |
| #                        | br            | chk_eot0             | # Skip TC handler.                                                       |
| <pre># jmp_tc0:</pre>    | jsr           | dma0_tc              | " Object to DUAGO TOM second                                             |
| <pre># chk_eot0: #</pre> | tbitb<br>bfc  | \$1, r0<br>chk_tcl   | # Check if DMACO EOT event.                                              |
| #                        | jsr           | dma0_eot             |                                                                          |
|                          |               |                      |                                                                          |
|                          |               |                      |                                                                          |

```
IMPLEMENTATION IN ASSEMBLY (Continued)
dma0_ovr:
# Body of service routine for DMACO over-run.
# Prepare the next buffer parameters.
# To resume channel operation use:
                                     # set channel enable bit and
            movd $3, dma0_ctl
                                     # input data valid bit of dma0
# If handling TC event is implied in handling OVR event, use
# the following to skip the TC check:
                   $chk_eot0, tos # Change the return address in
            movd
                                     \# the stuck to skip the TC check
            ret O
dma0_tc:
#
# Body of service routine for DMACO Terminal Count.
# To resume channel operation use:
            movd
                    $1, dma0_ctl
                                     # set channel enable bit of dma0
            ret
                    0
dma0_eot:
#
# Body of service routine for DMACO external End Of Transfer.
# Initialize channel for next DMAC task.
# To resume channel operation use:
            movd $1, dma0_ctl
                                     # set channel enable bit of dma0
            ret
                    0
dmal_ovr:
# Body of service routine for DMAC1 over-run.
# Prepare the next buffer parameters.
# To resume channel operation use:
            movd $3, dmal_ctl
                                     # set channel enable bit and
                                     # input data valid bit of dmal
# If handling TC event is implied in handling OVR event, use
# the following to skip the TC check:
            movd
                  $chk_eotl, tos # Change the return address in
                                     # the stuck to skip the TC check
            ret O
dmal_tc:
# Body of service routine for DMAC1 Terminal Count.
# to resume channel operation use:
            movd
                  $1, dmal_ctl
                                     # set channel enable bit of dmal
            ret
                    Ö
dmal_eot:
# Body of service routine for DMAC1 external End Of Transfer.
# Initialize channel for next DMAC task.
# to resume channel operation use:
            movd $1, dmal_ctl
                                    # set channel enable bit of dmal
            ret.
                    0
ext_int_6:
# Body of service routine for priority level 6 external interrupt.
#
            reti
```

4

#### LIFE SUPPORT POLICY

NATIONAL'S PRODUCTS ARE NOT AUTHORIZED FOR USE AS CRITICAL COMPONENTS IN LIFE SUPPORT DEVICES OR SYSTEMS WITHOUT THE EXPRESS WRITTEN APPROVAL OF THE PRESIDENT OF NATIONAL SEMICONDUCTOR CORPORATION. As used herein:

- Life support devices or systems are devices or systems which, (a) are intended for surgical implant into the body, or (b) support or sustain life, and whose failure to perform, when properly used in accordance with instructions for use provided in the labeling, can be reasonably expected to result in a significant injury to the user.
- A critical component is any component of a life support device or system whose failure to perform can be reasonably expected to cause the failure of the life support device or system, or to affect its safety or effectiveness.



National does not assume any responsibility for use of any circuitry described, no circuit patent licenses are implied and National reserves the right at any time without notice to change said circuitry and specifications.