我想使用微控制器通过SPI进行数据通信。因此,我首先选择了具有PIC32MX470F512L的Microchip USB入门工具包III模块。我尝试了几种编码SPI的方法,但在示波器上只能看到时钟信号SCK。
然后,我使用带有PIC32MX360F512L的Microchip入门工具包I尝试了相同的代码(只是将一些代码行调整到新的PIC)。一切都运行得很好。所以,我不明白为什么USB入门套件III不能用于SPI通信?
我给你用来测试SPI SDO&的代码。 / SS
#define _SUPPRESS_PLIB_WARNING
#include <stdio.h>
#include <stdlib.h>
#include <plib.h>
#include <p32xxxx.h>
#include <xc.h>
#include <peripheral/spi.h>
// DEVCFG2
#pragma config FPLLIDIV = DIV_2 // PLL Input Divider (12x Divider)
#pragma config FPLLMUL = MUL_20 // PLL Multiplier (24x Multiplier)
#pragma config FPLLODIV = DIV_1 // System PLL Output Clock Divider (PLL Divide by 256)
// DEVCFG1
#pragma config FNOSC = PRIPLL // Oscillator Selection Bits (Primary Osc w/PLL (XT+,HS+,EC+PLL))
#pragma config FSOSCEN = OFF // Secondary Oscillator Enable (Disabled)
#pragma config IESO = ON // Internal/External Switch Over (Enabled)
#pragma config POSCMOD = HS // Primary Oscillator Configuration (HS osc mode)
#pragma config OSCIOFNC = OFF // CLKO Output Signal Active on the OSCO Pin (Disabled)
#pragma config FPBDIV = DIV_1 // Peripheral Clock Divisor (Pb_Clk is Sys_Clk/8)
#pragma config FCKSM = CSDCMD // Clock Switching and Monitor Selection (Clock Switch Disable, FSCM Disabled)
#pragma config WDTPS = PS1048576 // Watchdog Timer Postscaler (1:1048576)
#pragma config FWDTEN = OFF // Watchdog Timer Enable (WDT Disabled (SWDTEN Bit Controls))
// DEVCFG0
#pragma config DEBUG = OFF // Background Debugger Enable (Debugger is Enabled)
#pragma config ICESEL = ICS_PGx2 // ICE/ICD Comm Channel Select (Communicate on PGEC1/PGED1)
#pragma config PWP = OFF // Program Flash Write Protect (Disable)
#pragma config BWP = OFF // Boot Flash Write Protect bit (Protection Disabled)
#pragma config CP = OFF // Code Protect (Protection Disabled)
int main(void) {
TRISGbits.TRISG6=0; //SCK2
TRISGbits.TRISG7=1; //SDI2
TRISGbits.TRISG8=0; //SDO2
TRISGbits.TRISG9=0; //SS2
OpenSPI2(SPI_MODE16_ON|SPI_SMP_ON|MASTER_ENABLE_ON|SEC_PRESCAL_5_1|PRI_PRESCAL_16_1, SPI_ENABLE);
int data;
PORTGbits.RG9 = 1;
while(1)
{
PORTGbits.RG9 = 0;
putcSPI2(0xaaaa);
data=getcSPI2();
PORTGbits.RG9 = 1;
}
return 0;
}
由于
答案 0 :(得分:0)
引脚映射
你做引脚映射吗?它不会出现在您发布的代码中。
您需要使用PPS(外设引脚选择)将引脚分配给SPI模块。
OpenSPI是一个库函数,但它也需要使用引脚外设选择(PPS)进行引脚映射
第12.3.1点http://ww1.microchip.com/downloads/en/DeviceDoc/60001120F.pdf
引脚状态(模拟/数字)
检查您的引脚是否处于(默认)模拟状态。如果引脚也具有模拟(AN)功能,则默认状态为模拟状态,您无法控制该引脚。您需要设置寄存器ANSELx(或AD1PCFG)来设置引脚。
在芯片PIC32MX470F512L中,您使用的引脚(RG6-9)也具有模拟功能(AN):
10 AN16/C1IND/RPG6/SCK2/PMA5/RG6
11 AN17/C1INC/RPG7/PMA4/RG7
12 AN18/C2IND/RPG8/PMA3/RG8
14 AN19/C2INC/RPG9/PMA2/RG9
{7}}
模拟引脚第12.2.5节http://ww1.microchip.com/downloads/en/DeviceDoc/60001185F.pdf
答案 1 :(得分:0)
大家好,感谢您的回复!
感谢您的帮助,我发现了这个问题。引脚配置是必要的。在我为代码配置添加的代码下面。
// Mapping SPI1 & SPI2
SDI1Rbits.SDI1R = 0xa; // SDI1 to C4
RPD0Rbits.RPD0R = 0x8; // SDO1 to D0
RPB2Rbits.RPB2R = 0x7; // SS1 to B2
SDI2Rbits.SDI2R = 0x1; // SDI2 to G7
RPG8Rbits.RPG8R = 0x6; // SDO2 to G8
RPG9Rbits.RPG9R = 0x6; // SS2 to G9