



**Discrete Logic Replacement** 

# **Decimal Adjust Routines**

Author: Eduardo H. Sigal Buenos Aires Argentina email: esigal@feedback.net.ar

## **APPLICATION OPERATION**

When implementing packed BCD logic with PICmicros<sup>™</sup> it may be necessary to perform additions or increments. In this case, it is necessary to execute a decimal adjustment to ensure a valid result.

I've included two routines.

### Routine #1

This routine emulates the 'decimal adjust after addition' which is part of the instruction set of some microprocessor families. Of course, it works only after additions, but remember that a packed BCD number can be decremented by adding '99'.

| ROM words:      | 16                          |
|-----------------|-----------------------------|
| Additional RAM: | 1 byte (1 bit used)         |
| Execution time: | 15 to 17 instruction cycles |

## Routine #2

This routine is to be used when only an increment is necessary (i.e., up counters, clocks, etc.). It increments the 'number' register and performs the decimal adjust. In fact, this routine will work with additions of up to '6' in any or both of the packed BCD digits.

| ROM words:      | 12                          |
|-----------------|-----------------------------|
| Additional RAM: | none                        |
| Execution time: | 10 to 13 instruction cycles |

Both routines return W = 0, if the result is '99' or less and W = 1, if the result is '100' or more. This allows for multiple precision packed BCD numbers manipulation.

## **MICROCHIP TOOLS USED**

## Assembler/Compiler version

MPASM V01.50, MPLAB V3.22.02

Microchip Technology Incorporated, has been granted a nonexclusive, worldwide license to reproduce, publish and distribute all submitted materials, in either original or edited form. The author has affirmed that this work is an original, unpublished work and that he/she owns all rights to such work. All property rights, such as patents, copyrights and trademarks remain with author.

# **GRAPHICAL REPRESENTATION**



# **Discrete Logic Replacement**



## APPENDIX A: SOURCE CODE

## A.1 Routine #1:Decimal Adjust After Addition

Note: 'daa' must be called immediately after the addition if performed, which result must be in 'number' register.

07h ; Register for flag storing (only bit 0 is used) flag equ 08h ; Register for number storing number equ ; daa BCF flag, 0 BTFSC STATUS, C flag, 0 BSF MOVLW 06h BTFSC STATUS, DC ADDWF number, F ; ADDWF number, F BTFSS STATUS, DC SUBWF number, F MOVLW 60h ADDWF number, F BTFSS STATUS, C BTFSC flag, 0 RETLW 01h SUBWF number, F RETLW 00h

#### A.2 Routine #2: Increment and Perform Decimal Adjust to the 'Number' Register

| number<br>; | equ                                                         | 07h                                                           |             | ; | Register | for | number | storing |
|-------------|-------------------------------------------------------------|---------------------------------------------------------------|-------------|---|----------|-----|--------|---------|
| incdaa      | MOVLW<br>ADDWF<br>BTFSC<br>GOTO<br>MOVLW                    | 07h<br>number,<br>STATUS,<br>test_c<br>06h                    | F<br>DC     |   |          |     |        |         |
| test_c      | SUBWF<br>MOVLW<br>ADDWF<br>BTFSC<br>RETLW<br>SUBWF<br>RETLW | number,<br>60h<br>number,<br>STATUS,<br>01h<br>number,<br>00h | F<br>C<br>F |   |          |     |        |         |