

## FACULTY OF ENGINEERING TECHNOLOGY

**CAMPUS GROUP T LEUVEN** 

# Microcontrollers LAB 3

SPI communication using ASSEMBLY

Coordinator: L. Geurts Cooperator: T. Stas

Academic Year 2019-2020

# Programming in Assembly

While C programming language has the advantage of being readable and easily understandable, it suffers from some shortcomings including slow speed and inefficient implementations. Assembly code, as a low-level language, allows PIC programmers to have more control over how an algorithm is implemented, leading often to faster and more efficient implementations.

# Assembly instructions

Following table gives a brief overview of the instruction set of a PIC18F25k50 microcontroller. More information and examples on every instruction and its operands can be found in the datasheet from the microcontroller under chapter 27.

| Mnemonic,<br>Operands Description                                                                        |                                                                                                                       | Mnemonic,<br>Operands                                                                                                                                                                                                                                                 |                                                                                   | Description                                         |                                                                                                                                                                                                                                                                 |                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                   |
|----------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|-----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BYTE-ORIENTED OPERATIONS                                                                                 |                                                                                                                       |                                                                                                                                                                                                                                                                       | BIT-ORIEN                                                                         | PERATIONS                                           | ≐                                                                                                                                                                                                                                                               |                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                   |
| ADDWF<br>ADDWFC<br>ANDWF<br>CLRF<br>COMF<br>CPFSEQ<br>CPFSGT<br>CPFSLT                                   | f, d, a<br>f, d, a<br>f, d, a<br>f, a<br>f, d, a<br>f, a<br>f, a<br>f, a<br>f, a                                      | Add WREG and f Add WREG and Carry bit to f AND WREG with f Clear f Complement f Compare f with WREG, skip = Compare f with WREG, skip > Compare f with WREG, skip >                                                                                                   | BCF<br>BSF<br>BTFSC<br>BTFSS<br>BTG<br>CONTROL                                    | f, b, a<br>f, b, a<br>f, b, a<br>f, b, a<br>f, d, a | Bit Clear f<br>Bit Set f<br>Bit Test f, Skip if Clear<br>Bit Test f, Skip if Set<br>Bit Toggle f                                                                                                                                                                | Ī                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                   |
| DECF DECFSZ DCFSNZ INCF INCFSZ INFSNZ IORWF MOVF MOVFF MOVWF MULWF NEGF                                  | f, d, a<br>f, d, a<br>f, d, a<br>f, d, a                                                                              | Decrement f Decrement f, Skip if 0 Decrement f, Skip if Not 0 Increment f Increment f, Skip if Not 0 Increment f, Skip if Not 0 Inclusive OR WREG with f Move f Move f (destination) 2nd word Move WREG to f Multiply WREG with f Negate f                            | BN<br>BNC<br>BNN<br>BNOV<br>BNZ<br>BOV<br>BRA<br>BZ<br>CALL<br>CLRWDT<br>DAW      | n n n n n n n n, s —                                | Branch if Negative Branch if Not Carry Branch if Not Negative Branch if Not Overflow Branch if Not Zero Branch if Overflow Branch Unconditionally Branch if Zero Call subroutine 1st word 2nd word Clear Watchdog Timer Decimal Adjust WREG                     | Mnem<br>Open                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Description                                                                                                                                                                                                                                                                       |
| RLCF<br>RLNCF<br>RRCF<br>RRNCF<br>SETF<br>SUBFWB<br>SUBFWB<br>SUBWF<br>SUBWF<br>SWAPF<br>TSTFSZ<br>XORWF | f, d, a<br>f, d, a | Rotate Left f through Carry Rotate Left f (No Carry) Rotate Right f through Carry Rotate Right f (No Carry) Set f Subtract f from WREG with borrow Subtract WREG from f Subtract WREG from f with borrow Swap nibbles in f Test f, skip if 0 Exclusive OR WREG with f | NOP<br>NOP<br>POP<br>PUSH<br>RCALL<br>RESET<br>RETFIE<br>RETLW<br>RETURN<br>SLEEP | n — — n s k s —                                     | Go to address 1st word 2nd word No Operation No Operation Pop top of return stack (TOS) Push top of return stack (TOS) Relative Call Software device Reset Return from interrupt enable Return with literal in WREG Return from Subroutine Go into Standby mode | LITERAL ADDLW ANDLW IORLW LFSR MOVLB MOVLW MULLW RETLW SUBLW XORLW | PERATOR NEW YORK NEW | Add literal and WREG AND literal with WREG Inclusive OR literal with WREG Move literal (12-bit) 2nd word to FSR(f) Move literal to BSR-3:0> Move literal to WREG Multiply literal with WREG Return with literal in WREG Subtract WREG from literal Exclusive OR literal with WREG |

Table 1: PIC18F2550 instruction set

#### Environment

Because in this session, you will use assembly language in MPLABX, you will have to use an assembly compiler.

Start the environment, then click on File >> New Project to create a new project. Unlike when using C language, you need to choose MPASM as compiler.

There is no need to configure the properties of the project any more, unlike the XC8 complier, the MPASM compile is quite handy.

The next step is to create an .asm file in your project. There is an assembly template on Toledo. This template shows you how to include header files, initialize registers, and handle interrupts. You may download this and add it to your project folder.

### **Building and Debugging**

After importing an assembly file into your project, you may run or debug the code (no need for linker file). The building and debugging procedures are the same as that of a C project. You may use the same debug tools (*Variables* and *Stimulus*) as well.

NOTE: When using debug tools, your reset, interrupt, and start vectors should point to 0x000, 0x008, 0x018, and 0x020 respectively. Before building a HEX file to download onto the board, do not forget to change the reset, interrupt, and start vectors back to 0x1000, 0x1008, 0x1018, and 0x1020. This ensures that your code skips the bootloader and that all parts are executed properly.

#### File Register

Unlike the declaration of a variable and it's data type in C, when you want to use a variable in assembly code you need to give an address location to the File Register of your microcontroller. When in simulation mode, you can have a look at the values stored in the File Register.

 $\mathsf{Select}\;\mathsf{Window}\to\mathsf{Simulator}\to\overline{\qquad}\mathsf{File}\;\mathsf{Registers}$ 

#### **Assignment:**

Have a look at the template program on toledo "AsmTemplate.asm". This example shows an 8-bit linear feedback shift register (LFSR) using EXOR functions. This can be done using the following algorithm:



RCO is used as enable signal, the result will be displayed on PORTB.

Try to predict the first 3 values the LFSR will generate. Try to simulate the template program and check if your prediction was correct.

Try to download the template program. Test the functionality on your microcontroller board. If the program runs at full speed, it is not possible for human eye to see the LED change. Create and call the delay function in your assembly program:

CALL delay1 ; call the delay loop

The Serial Peripheral Interface (SPI) is a three-pin, synchronous communication protocol that allows a master device to initiate communication with and transfer data to and from a slave device. It is implemented in the PIC by a hardware module called the Synchronous Serial Port or the Master Synchronous Serial Port (MSSP). It allows for serial communication between two or more devices at a high speed and is reasonably easy to implement.

To understand the concept of SPI, you will connect two PIC boards together and communicate between them using this protocol.



Figure 1: SPI Master/Slave connection with two PIC microcontrollers

The MSSP module consists of a transmit/receive shift register (SSPSR) and a buffer register (SSP1BUF). The SSPSR shifts the data in and out of the device, MSB first. The SSPBUF holds the data that was written to the SSPSR until the received data is ready. Once the eight bits of data have been received, the byte is moved to SSP1BUF register. Then, the Buffer Full detect bit, BF (SSP1STAT<0>) and the interrupt flag bit, SSPIF, are set.

The SPI Master clock should be driven by TMR2, with Timer2 period register PR2 set to 0xFF. When TMR2 is equal to PR2, it will generate a clock pulse for the master SPI.

For more information on the MSSP module, it's configuration and example code, have a look in the PIC18F25k50 data sheet chapter 16!



#### Assignment "COUNTER over SPI":

| IABLE 10  |                                       | TENO ACC      | 0017112    |             |        |        |        |        |                  |
|-----------|---------------------------------------|---------------|------------|-------------|--------|--------|--------|--------|------------------|
| Name      | Bit 7                                 | Bit 6         | Bit 5      | Bit 4       | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Register on page |
| ANSELA    | _                                     | _             | ANSA5      | _           | ANSA3  | ANSA2  | ANSA1  | ANSA0  | 147              |
| ANSELB    | _                                     | _             | ANSB5      | ANSB4       | ANSB3  | ANSB2  | ANSB1  | ANSB0  | 148              |
| INTCON    | GIE/GIEH                              | PEIE/GIEL     | TMR0IE     | INT0IE      | IOCIE  | TMR0IF | INT0IF | IOCIF  | 114              |
| IPR1      | ACTIP                                 | ADIP          | RCIP       | TXIP        | SSPIP  | CCP1IP | TMR2IP | TMR1IP | 123              |
| PIE1      | ACTIE                                 | ADIE          | RCIE       | TXIE        | SSPIE  | CCP1IE | TMR2IE | TMR1IE | 120              |
| PIR1      | ACTIF                                 | ADIF          | RCIF       | TXIF        | SSPIF  | CCP1IF | TMR2IF | TMR1IF | 117              |
| PMD1      | _                                     | MSSPMD        | CTMUMD     | CMP2MD      | CMP1MD | ADCMD  | CCP2MD | CCP1MD | 62               |
| SSP1BUF   | SSP1 Receive Buffer/Transmit Register |               |            |             |        |        |        |        | _                |
| SSP1CON1  | WCOL                                  | SSPOV         | SSPEN      | CKP         |        | 252    |        |        |                  |
| SSP1CON3  | ACKTIM                                | PCIE          | SCIE       | BOEN        | SDAHT  | SBCDE  | AHEN   | DHEN   | 255              |
| SSP1STAT  | SMP                                   | CKE           | D/Ā        | Р           | S      | R/W    | UA     | BF     | 251              |
| TRISA     | TRISA7                                | TRISA6        | TRISA5     | TRISA4      | TRISA3 | TRISA2 | TRISA1 | TRISA0 | 149              |
| TRISB     | TRISB7                                | TRISB6        | TRISB5     | TRISB4      | TRISB3 | TRISB2 | TRISB1 | TRISB0 | 149              |
| TRISC     | TRISC7                                | TRISC6        | _          | _           | _      | TRISC2 | TRISC1 | TRISC0 | 149              |
| Legend: S | haded bits an                         | e not used by | the MSSP i | n SPI mode. |        |        |        |        |                  |

TABLE 16-1: REGISTERS ASSOCIATED WITH SPI OPERATION

#### 1. Counter implementation

Start by implementing a simple 8-bit binary counter on PORTB. Use RA4 to toggle UP/DOWN mode. If the counter program runs at full speed, it is not possible for human eye to see the LED change. Create and call the delay function in your assembly program:

#### CALL ; call the delay loop delay1

#### 2. One PIC board

Configure your PIC as a Master SPI. Transmit the counter values via the SPI Master. Connect SDO directly to SDI of the same board. Display the received 8-bit result on 8 LED's. Display the SPI data line on an oscilloscope. Pay attention to the pinout of your microcontroller (SDI and SDO).

#### 3. Two PIC board

Connect your master PIC to another PIC that is configured as an SPI slave. The master is generating the counter values, the slave receives those and shows them on 8 LED's connected to PORTB.

## Assignment "Master as AD convertor":

In the previous lab session we configured the AD convertor to take samples on an analog input. Try to implement this code in assembly instructions. Connect a potentiometer to the analog input of the SPI master, sample this input and send the result to the SPI slave. The slave displays the received value on PORTB.

# Assignment "Master as AD convertor – Slave as PWM generator":

In the previous lab session we configured the CCP module to generate a PWM signal. Try to implement this code in assembly instructions on the SPI slave. Use the AD result that you receive from the SPI slave from previous assignment to make an adjustable Duty Cycle.

| TARI F 16-1. | REGISTERS | ASSOCIATED WITH SPI OPERATION |
|--------------|-----------|-------------------------------|

| Name     | Bit 7                          | Bit 6         | Bit 5        | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Register on page |
|----------|--------------------------------|---------------|--------------|--------|--------|--------|--------|--------|------------------|
| ANSELA   | _                              | _             | ANSA5        | _      | ANSA3  | ANSA2  | ANSA1  | ANSA0  | 147              |
| ANSELB   | _                              | _             | ANSB5        | ANSB4  | ANSB3  | ANSB2  | ANSB1  | ANSB0  | 148              |
| INTCON   | GIE/GIEH                       | PEIE/GIEL     | TMR0IE       | INT0IE | IOCIE  | TMR0IF | INT0IF | IOCIF  | 114              |
| IPR1     | ACTIP                          | ADIP          | RCIP         | TXIP   | SSPIP  | CCP1IP | TMR2IP | TMR1IP | 123              |
| PIE1     | ACTIE                          | ADIE          | RCIE         | TXIE   | SSPIE  | CCP1IE | TMR2IE | TMR1IE | 120              |
| PIR1     | ACTIF                          | ADIF          | RCIF         | TXIF   | SSPIF  | CCP1IF | TMR2IF | TMR1IF | 117              |
| PMD1     | _                              | MSSPMD        | CTMUMD       | CMP2MD | CMP1MD | ADCMD  | CCP2MD | CCP1MD | 62               |
| SSP1BUF  | SSP1 Recei                     | ve Buffer/Tra | nsmit Regist | er     |        |        |        |        | _                |
| SSP1CON1 | WCOL SSPOV SSPEN CKP SSPM<3:0> |               |              |        |        |        |        | 252    |                  |
| SSP1CON3 | ACKTIM                         | PCIE          | SCIE         | BOEN   | SDAHT  | SBCDE  | AHEN   | DHEN   | 255              |
| SSP1STAT | SMP                            | CKE           | D/Ā          | Р      | S      | R/W    | UA     | BF     | 251              |
| TRISA    | TRISA7                         | TRISA6        | TRISA5       | TRISA4 | TRISA3 | TRISA2 | TRISA1 | TRISA0 | 149              |
| TRISB    | TRISB7                         | TRISB6        | TRISB5       | TRISB4 | TRISB3 | TRISB2 | TRISB1 | TRISB0 | 149              |
| TRISC    | TRISC7                         | TRISC6        | _            | _      | _      | TRISC2 | TRISC1 | TRISC0 | 149              |