реклама на сайте
подробности

 
 
> LPC1111, тормоза SPI
esaulenka
сообщение Dec 1 2011, 15:50
Сообщение #1


Профессионал
*****

Группа: Свой
Сообщений: 1 032
Регистрация: 13-03-08
Из: Маськва
Пользователь №: 35 877



Копаюсь с модулем SSP0 на контроллере LPC1111.


Частота камня - 48 МГц, частота SPI - 12 МГц, задержки между байтами 1,17 мкс.
Прикрепленное изображение



Частота камня - 36 МГц, частота SPI - 18 МГц, задержки между байтами 1,23 мкс.
Прикрепленное изображение




код простейший, никаких прерываний:
Код
uint8_t SendByteSPI( uint8_t data)
{
    LPC_SSP0->DR = data;
    while( LPC_SSP0->SR & BIT(4) )    // SPI0 busy
    ;
    return LPC_SSP0->DR;
}

#define SPI_WriteByte(data)        SendByteSPI(data)
#define SPI_ReadByte()            SendByteSPI(0x00)

uint8_t Mem_ReadByte( uint32_t aunMemAddr )
{
    uint8_t        ucByteReadMem;
    ACTIVE_SPI();
    SPI_WriteByte( 0x03 );            // Read Data Bytes
    SPI_WriteByte( (uint8_t)(aunMemAddr >> 16 ) );
    SPI_WriteByte( (uint8_t)(aunMemAddr >> 8 ) );
    SPI_WriteByte( (uint8_t)(aunMemAddr ) );
    ucByteReadMem    = SPI_ReadByte();
    DEACTIVE_SPI();    
    return ucByteReadMem;
}


Сталкивался кто-нибудь?..


--------------------
Тут обсуждается творческий порыв, а не соответствие каким-либо стандартам ©
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
esaulenka
сообщение Dec 2 2011, 16:28
Сообщение #2


Профессионал
*****

Группа: Свой
Сообщений: 1 032
Регистрация: 13-03-08
Из: Маськва
Пользователь №: 35 877



Не взлетит sad.gif
Запихать в FIFO 5 байт получается быстрее, чем он их передаёт. Соответственно, переходим к циклу выгребания, и возвращаем какой-то неверный байт.

Но за идею спасибо, в итоге закончилось следующим:
Код
uint8_t Mem_ReadByte( uint32_t aunMemAddr )
{
    ACTIVE_SPI();
    LPC_SSP0->DR = 0x03;
    LPC_SSP0->DR = aunMemAddr >> 16;
    LPC_SSP0->DR = aunMemAddr >> 8;
    LPC_SSP0->DR = aunMemAddr;
    LPC_SSP0->DR = 0;
    while (LPC_SSP0->SR & BIT(4));
    DEACTIVE_SPI();    
    LPC_SSP0->DR;
    LPC_SSP0->DR;
    LPC_SSP0->DR;
    LPC_SSP0->DR;
    return     LPC_SSP0->DR;
}


При попытке свернуть чтение в цикл получаем неплохие тормоза...


--------------------
Тут обсуждается творческий порыв, а не соответствие каким-либо стандартам ©
Go to the top of the page
 
+Quote Post



Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 4th August 2025 - 19:40
Рейтинг@Mail.ru


Страница сгенерированна за 0.01371 секунд с 7
ELECTRONIX ©2004-2016