PIC32 неправильно SPI MOSI

Я пытаюсь разработать интерфейс SPI, и я начал с простой конфигурации. Вопрос в том, что SCK работает нормально, но MOSI не работает. Вот мой код и мой тестовый логический тестер.

#include <stdlib.h>   

#include <plib.h>   

// example functions prototypes   
int     SpiDoMasterSlaveExample(int nCycles);   

void    SpiInitDevice(int chn, int isMaster, int frmEn, int frmMaster);   


// some definitions   

#define MIN_SPI_TXFER_SIZE      8       // min number of words per transfer   
#define MAX_SPI_TXFER_SIZE      512     // max number of words per transfer   


// configuration settings   
#pragma config FNOSC = PRIPLL, POSCMOD = HS, FPLLMUL = MUL_18, FPLLIDIV = DIV_2, FPBDIV = DIV_2, FPLLODIV = DIV_1   
#pragma config FWDTEN = OFF   

int main(void)   
{   

    SYSTEMConfigPerformance(72000000L);   


    srand(ReadCoreTimer());     // seed the pseudo random generator   

    if(!SpiDoMasterSlaveExample(100))   
    {   
        return 0;   // our example failed   
    }   

    return 1;   

}   

int SpiDoMasterSlaveExample(int nCycles)   
{   
    int fail=0;     // overall result   

    SpiInitDevice(1, 1, 1, 1);  // initialize the SPI channel 1 as master, frame master   
    SpiInitDevice(2, 0, 1, 0);  // initialize the SPI channel 2 as slave, frame slave   

    while(nCycles-- && !fail)   
    {   
        unsigned int    txferSize;   
        unsigned short* pTxBuff;   
        unsigned short* pRxBuff;   

        txferSize=MIN_SPI_TXFER_SIZE+rand()%(MAX_SPI_TXFER_SIZE-MIN_SPI_TXFER_SIZE+1);  // get a random transfer size   

        pTxBuff=(unsigned short*)malloc(txferSize*sizeof(short));   
        pRxBuff=(unsigned short*)malloc(txferSize*sizeof(short));       // we'll transfer 16 bits words   

        if(pTxBuff && pRxBuff)   
        {   
            unsigned short* pSrc=pTxBuff;   
            unsigned short* pDst=pRxBuff;   
            int             ix;   
            int             rdData;   

            for(ix=0; ix<txferSize; ix++)   
            {   
                pTxBuff[ix]='A'; // fill buffer with some random data   
            }   

            ix=txferSize+1;             // transfer one extra word to give the slave the possibility to reply back the last sent word   
            while(ix--)   
            {   
                SpiChnPutC(1, *pSrc++);     // send data on the master channel, SPI1   
                rdData=SpiChnGetC(1);       // get the received data   
                if(ix!=txferSize)   
                {   // skip the first received character, it's garbage   
                    *pDst++=rdData;         // store the received data   
                }   
                rdData=SpiChnGetC(2);           // receive data on the slave channel, SPI2   
                SpiChnPutC(2, rdData);          // relay back data   
            }   

            // now let's check that the data was received ok   
            pSrc=pTxBuff;   
            pDst=pRxBuff;   
            for(ix=0; ix<txferSize; ix++)   
            {   
                if(*pDst++!=*pSrc++)   
                {   
                    fail=1;     // data mismatch   
                    break;   
                }   
            }   
        }   
        else   
        {   // memory allocation failed   
            fail=1;   
        }   

        free(pRxBuff);   
        free(pTxBuff);  // free the allocated buffers   
    }   


    return !fail;   
}   

void SpiInitDevice(int chn, int isMaster, int frmEn, int frmMaster)   
{   
    unsigned int    config=SPI_CON_MODE16|SPI_CON_SMP|SPI_CON_ON;   // SPI configuration word   
    if(isMaster)   
    {   
        config|=SPI_CON_MSTEN;   
    }   
    if(frmEn)   
    {   
        config|=SPI_CON_FRMEN;   
        if(!frmMaster)   
        {   
            config|=SPI_CON_FRMSYNC;   
        }   
    }   


    SpiChnOpen(chn, config, 4); // divide fpb by 4, configure the I/O ports. Not using SS in this example   

}   

Извините, я не могу опубликовать изображение логического анализатора для очков своей репутации.

Я пытаюсь отправить "А" все время (заполнить буфер передачи). Вот и пошли данные в SPI1.

Я читаю SPI1 с моего ввода / вывода платы расширения Microchip, где SPI1 находится на контактах 41 и 43 (41 SCK и 43 SDO). В SPI2, контакт 23 и 25, очевидно, у меня нет трафика.

Кто-нибудь имеет представление об этой ошибке?

большое спасибо

2 ответа

Серия PIC32MX имеет отображаемые входные и выходные контакты для некоторых периферийных устройств, включая SPI. Это означает, что MOSI и MISO могут быть сопоставлены с различными выводами, в зависимости от ваших конкретных потребностей.

Вам нужно указать это в коде перед тем, как вы начнете использовать SPI, иначе PIC не будет знать, какие контакты использовать.

Ниже приведен только пример того, как настроить контакты (выбор периферийных контактов). Вы должны посмотреть в таблице данных вашего PIC для сопоставлений. Первый параметр в вызовах - это индекс таблицы из таблицы.

/* inputs */
PPSInput(2, SDI1, RPF2);    // F2, MEMORY MISO -> SPI1SDI
PPSInput(2, SDI2, RPG7);    // G7, ZB MISO -> SPI2SDI

/* outputs */
PPSOutput(4, RPF3, SDO1);   // F3, MEMORY MOSI -> SPI1SDO
PPSOutput(1, RPG8, SDO2);   // G8, ZB MOSI -> SPI2SDO

Как описано выше, проверьте ваш периферийный контакт выбора. Дополнительно вы должны установить направление вашего порта на Выход (PDx-Register). MISO должен быть установлен на вход.

Другие вопросы по тегам