/pic18f47q10-cnano-spi-slave-int-bare

The PIC18F47Q10 features two MSSP modules, which can be configured in SPI mode. In this demo, the SPI is configured as slave and it is used to exchange data. The data transfer is triggered by interrupts. The repository contains the bare metal code for the application.

Primary LanguageC

MCHP

PIC18F47Q10 Exchanging Data as a Slave SPI Device Using Interrupts

Objective

This repository contains an example of bare-metal source code for SPI as described in TB3265 - Getting Started with SPI using MSSP on PIC18 document from Microchip.
In this demo, the SPI will be configured as slave and it will be used to exchange data. The data transfer is triggered by interrupts.

Related Documentation

Software Used

Hardware Used

Setup

The PIC18F47Q10 Curiosity Nano Development Board is used as the test platform.


The following configurations must be made for this project:

  • Clock

    • Oscillator Select: HFINTOSC
    • HF Internal Clock: 64 MHz
    • Clock Divider: 1
  • MSSP1:

    • MSSP1 Enabled
    • MSSP1 Interrupts Enabled
    • Serial Protocol: SPI
    • Mode: Slave
    • Data Mode: 0
  • Watchdog Timer: disabled

  • Low-voltage Programming: enabled

Pin Configuration
RA5 (SS) Digital Input
RC3 (SCK) Digital Input
RC4 (SDI) Digital Input
RC5 (SDO) Digital Output

Operation

  1. Connect the board to the PC.

  2. Open the pic18f47q10-cnano-spi-slave-int-bare.X project in MPLAB® X IDE.

  3. Set pic18f47q10-cnano-spi-slave-int-bare.X project as main project. Right click on the project in the Projects tab and click Set as Main Project.

  4. Select the PIC18F47Q10 Curiosity Nano in the Hardware Tool section of the project settings:

  • Right click on the project and click Properties;
  • Select the PIC18F47Q10 Curiosity Nano (click on the SN) in the Hardware Tool tab and then click OK:
  1. Program the project to the board: right click on the project and click Make and Program Device.

Result:

  • Channel 0 -> SCK
  • Channel 1 -> Slave SDI/Master SDO
  • Channel 2 -> Slave SDO/Master SDI
  • Channel 3 -> SS1
  • Channel 4 -> SS2 (for other slave device)

Summary

This project is an illustration for a basic use case based around MSSP1 in SPI mode.