## $\mu C$ controls digital potentiometer

## LUKASZ SLIWCZYNSKI, UNIVERSITY OF MINING AND METALLURGY, KRAKOW, POLAND

Many digitally controlled potentiometers (for example, the LM1971/2/3 from National Semiconductor, www. national.com) incorporate a three-wire serial digital interface, using data, clock, and enable lines. In **Figure 1**, the potentiometer's nomenclature for these lines is Data-In, Clk, and Load/Shift, respectively. The assembler program in **Listing 1** provides an interface to an SAB80535  $\mu$ C. The main idea of the method is to use the capture/compare capability of Timer 2 in the  $\mu$ C to provide the timing relationship between the Data-In and Clk signals. The principal control of the interface comes from subroutine S16BIT in **Listing 1**.

To program the potentiometer, the  $\mu$ C must send 2 bytes to it—the "channel address," followed by the attenuation value with its most significant bit first. Sending a byte starts

by loading the number of bits to send into the  $\mu$ C's BCOUNT register and initiating the P1 lines (setting P1.0 through P1.3 to a low state). Next, Timer 2 starts with overload enabled. The routine sets two digital compare/capture units (CC1 and



The rising edge of the clock signal validates data loading into the Data-In and Load/Shift pins of the potentiometer.

## www.ednmag.com



CC3 in the  $\mu$ C) to the "compare" mode by writing 88H into the CCEN register. The contents of the register decrease after each interrupt. In this way, eight consecutive interrupts occur, each to send 1 bit of data. The interrupt subroutine at address 006BH manages the transmission of the data bits via P1.2.

The CC1 unit generates the Clk signal on pin P1.1 when the contents of the Timer 2 count register (composed of TH2 and TL2 8-bit registers) equal the values set in registers CCL1 and CCH1. This value depends on the length of the interrupt subroutine. After transmission of the last bit, the routine stops Timer 2 by setting the value 0ECH in register T2CON. During data transmission, the main program spends its time waiting in the loop, as long as the bit FLAGS.0 is at logic 1. This bit clears in the last pass of the subroutine and sets just before Timer 2 starts. Transmission of the second byte of data occurs in exactly the same way after the routine reprograms the related registers. The Channel and Volume registers hold the 2 bytes to send.

**Figures 2** and **3** show the timing relationships of the interface. In **Figure 2**, the 2 bytes Channel and Volume are 05AH and 081H, respectively. Data is valid on the rising edge of the Clk signal. **Figure 3** shows the time dependence in the interrupt-routine calls and the Clk rising edges. In this design, it takes approximately 740 µsec to program 2 bytes into the potentiometer with an 8-MHz clock frequency (a 1.5-µsec machine-cycle time). (DI #2256).

To Vote For This Design, Circle No. 400



The rising edge of the clock signal appears approximately 32  $\mu$ sec after the CC3 compare/capture unit in the  $\mu$ C generates an interrupt.



The subroutine in Listing 1 provides a simple serial digital interface to National's (and others') digital potentiometers.

| LISTING 1—S16BIT SUBROUTINE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                   |                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| EQU FLAGS.002FH<br>EQU CHANKE.004FH<br>EQU CHANKE.004FH<br>EQU CHANKE.004FH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                   | ;<br>;THIS COMM<br>THE MAIN ;PF<br>N<br>N | ANDS SHOULD BE PLACED SOMEWHERE IN THE BEGINING OF<br>XOGRAMM<br>AOV SP.406H; SET THE STACK POINTER<br>AOV IP0,4020H; SET THE INTERUPT PRIORITY LEVEL OF CC3<br>AOV FLAGS.#00H; CLEAR ALL BITS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
| INTERRUPT SUBR<br>HANDLER<br>HANDLER<br>(THE NUMBER OF MACHINE CYCLES TO EXECUTE<br>GIVEN AT THE ;RIGHT-HAND SIDE. THREE ADDITIONAL<br>FOR THE RESPONSE TO ,THE INTERRUPT REQUEST<br>.ORG 0006BH<br>CLR IEND 7; DISABLE ALL INTERRUPTS<br>PUSH PSW;<br>MOV ABCOUNT;<br>JZ ALL BY; TEST IF THE LAST BIT TO SEND<br>DEC A;<br>MOV BCOUNT;<br>RIC A;<br>MOV CHANNEL;<br>RIC A;<br>MOV CHANNEL;<br>POP PSW;<br>POP ACC;<br>RETI;<br>ALL_BY; MOV A,CHANNEL; THE LAST BIT TO SEND<br>RIC A;<br>MOV P1.2,C; SEND THE BIT<br>CLR FLAGS, INFORM SIGBIT FUNCTION<br>POP PSW;<br>POP ACC;<br>RIC A;<br>MOV P1.2,C; SEND THE BIT<br>CLR FLAGS, INFORM SIGBIT FUNCTION<br>POP PSW;<br>POP ACC;<br>RIC A;<br>MOV P1.2,C; SEND THE BIT<br>CLR FLAGS, INFORM SIGBIT FUNCTION<br>POP PSW;<br>POP ACC;<br>ANL 72CON,#DECH: STOP TIMER 2<br>SET BIEND 7; PAGE INTO FUNCTION | OUTINE<br>THE COMMAND ARE<br>CYCLES ARE ADDED<br>1<br>2 -> 8 + 3 = 11<br>2 -> 14 + 3 = 17<br>2 -> 22 + 3 = 25<br>2 -> 12 + 3 = 15 | S16BiT:<br>S16_1:<br>S16_2:<br>S_END;     | LM1972 INTERFACE CONTROLLING<br>FUNCTION<br>MOV TL2,#(255 - 25);SET TIMER 2 COUNT REGISTER<br>MOV CRCL,#(255 - 25);SET TIMER 2 RELOAD REGISTER<br>MOV CRCL,#(255 - 25);SET TIMER 2 RELOAD REGISTER<br>MOV CCL3,#(255 - 25);SET THE BEGINING OF INTERRUPT<br>MOV CCL3,#(255 - 25); SET THE BEGINING OF INTERRUPT<br>MOV CCL3,#(256 - 25); SET THE BEGINING OF INTERRUPT<br>MOV CCL3,#(256 - 25); SET THE BEGINING OF INTERRUPT<br>MOV CL3,#(256 - 25); SET THE BEGINING OF INTERRUPT<br>MOV CL3,#(256 - 25); SET THE BEGINING OF INTERRUPT<br>MOV TL2,#(256 - 25); SET THE BEGINING OF INTERRUPT<br>MOV CL3,#(256 - 25); SET THE BEGINING OF INTERRUPT<br>MOV CL3,#(256 - 25); SET THE BEGINING OF INTERRUPT<br>MOV CL3,#(256 - 25); SET THE RUPT<br>MOV CL3,#(256 - 25); SET THE BEGINING OF INTERRUPT<br>MOV CL3,#(256 - 256); SET MAIT UNTER WITH OVERLOAD ENABLED<br>JB FLAGS, 0,516 - 1; WANT UNTER NUMBER OF BITS TO SEND<br>MOV CHANNEL, A<br>SETB FLAGS, 0,516 - 2; WANT UNDER AND CHANNEL CONTENTS<br>MOV CHANNEL, A<br>SETB FLAGS, 0,516 - 2; WITH INTE THER 2 WITH OVERLOAD ENABLED<br>JB FLAGS, 0,516 - 2; WANT UNTERRUPT<br>OR LP1,#(074, SET OUTPUT PINS TO THE HIGH STATE<br>NET |  |