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

 
 
> Проблема с SPI., STM32F303VC
Jenya7
сообщение Mar 27 2018, 06:53
Сообщение #1


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

Группа: Участник
Сообщений: 1 778
Регистрация: 29-03-12
Пользователь №: 71 075



Камень STM32F303VC
Настроил SPI
Код
/*!< SPI Config */
  SPI_InitStructure.SPI_Direction = SPI_Direction_2Lines_FullDuplex;
  SPI_InitStructure.SPI_Mode = SPI_Mode_Master;
  SPI_InitStructure.SPI_DataSize = SPI_DataSize_8b;
  SPI_InitStructure.SPI_CPOL = SPI_CPOL_Low;
  SPI_InitStructure.SPI_CPHA = SPI_CPHA_1Edge;
  SPI_InitStructure.SPI_NSS = SPI_NSS_Soft;
  SPI_InitStructure.SPI_BaudRatePrescaler = SPI_BaudRatePrescaler_32;  //APB1=36Mhz => ~1Mhz //APB2=72Mhz                                                                  
  SPI_InitStructure.SPI_FirstBit = SPI_FirstBit_MSB;
  SPI_InitStructure.SPI_CRCPolynomial = 7;
  SPI_Init(SPIx, &SPI_InitStructure);

Размер задан - байт - SPI_DataSize_8b
На скопе на клоке вижу 16 бит - после передачи 8 бит посылает еще 8.
Я что то недонастроил?

Передача байта такая
Код
uint32_t SPI_TransferByte(SPI_TypeDef *SPIx, uint8_t data)
{
    uint32_t timeout;

    // All data transmitted/received but SPI may be busy so wait until done.
    timeout = SPI_DELAY;
    while (SPIx->SR & SPI_I2S_FLAG_BSY) { if(!timeout--) return SPI_ERR; }

    // Setting the Data Register (DR) transmits the byte of data on MOSI.
    SPIx->DR = data;

    //  Wait for any data on MISO pin to be received.
    timeout = SPI_DELAY;
    while (!(SPIx->SR & SPI_I2S_FLAG_RXNE)) { if(!timeout--) return SPI_ERR; }

    //  Return the data received on MISO pin.
    return (uint8_t)(SPIx->DR);
}


Сообщение отредактировал Jenya7 - Mar 27 2018, 06:56
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
Сергей Борщ
сообщение Mar 27 2018, 10:31
Сообщение #2


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



QUOTE (Jenya7 @ Mar 27 2018, 11:23) *
а что в нем не так? на будущее. чтобы знать.
Поехали по буквам:
CODE
uint32_t spixbase = 0x00;
1)Придуманный специально для этого uintptr_t? Не, не слышали.
CODE
  spixbase = (uint32_t)SPIx;
  spixbase += 0x0C;
2)Магические числа. Ну хоть стандартный макрос offsetof() можно было использовать вместо магичесого числа? Не, не слышали.
3)Почему не смогли взять сразу адрес SPIx->DR? Адресная арифметика, которую компилятор делает лучше криворукого программиста, тут делается вручную.
4)Переменная называется spixbase, хотя хранит совсем не base.
CODE
  *(__IO uint8_t *) spixbase = Data;
Ну наконец-то! Полэкрана кода ради одного-единственного явного приведения типа.

А что мешало вместо всего этого "шедевра" написать один макрос
CODE
#define SPI_SendData8(SPIx, data)   *(__IO uint8_t *)&SPIx->DR = data


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
jcxz
сообщение Mar 27 2018, 11:13
Сообщение #3


Гуру
******

Группа: Свой
Сообщений: 5 228
Регистрация: 3-07-08
Из: Омск
Пользователь №: 38 713



Цитата(Сергей Борщ @ Mar 27 2018, 13:31) *
А что мешало вместо всего этого "шедевра" написать один макрос
Код
#define SPI_SendData8(SPIx, data)   *(__IO uint8_t *)&SPIx->DR = data

Полностью поддерживаю! Та функция - ну просто вырви-глаз какой-то! laughing.gif
Ещё лучше регистр DR описать как union 16-битного и 8-битного. Тогда будет выглядеть ещё лучше. Я обычно так делаю.

Честно говоря - мне всегда противно смотреть на портянки типа:
Код
  SPI_InitStructure.SPI_Direction = SPI_Direction_2Lines_FullDuplex;
  SPI_InitStructure.SPI_Mode = SPI_Mode_Master;
...

всегда пролистываю такие сообщения не глядя.
И это вместо, того чтобы задать блоки периферийных регистров в виде структур, а формировать битовые поля в них макросами (ну или просто номерами битов), что было бы красиво и эффективно.
Go to the top of the page
 
+Quote Post

Сообщений в этой теме
- Jenya7   Проблема с SPI.   Mar 27 2018, 06:53
- - adnega   Цитата(Jenya7 @ Mar 27 2018, 09:53) Разме...   Mar 27 2018, 07:36
|- - Jenya7   Цитата(adnega @ Mar 27 2018, 12:36) Есть ...   Mar 27 2018, 07:49
|- - Сергей Борщ   QUOTE (adnega @ Mar 27 2018, 09:36) Добав...   Mar 27 2018, 09:00
|- - Jenya7   Цитата(Сергей Борщ @ Mar 27 2018, 14:00) ...   Mar 27 2018, 09:23
|- - adnega   Цитата(Сергей Борщ @ Mar 27 2018, 12:00) ...   Mar 27 2018, 09:24
|- - Obam   Цитата(jcxz @ Mar 27 2018, 15:13) ...блок...   Mar 28 2018, 15:18
|- - jcxz   Цитата(Obam @ Mar 28 2018, 18:18) Символи...   Mar 30 2018, 08:47
- - serglg   и куда ж такому "программисту" как я под...   Mar 28 2018, 05:06
|- - adnega   Цитата(serglg @ Mar 28 2018, 08:06) и куд...   Mar 28 2018, 05:38
|- - serglg   Цитата(adnega @ Mar 28 2018, 11:38) Научи...   Mar 28 2018, 10:43
- - MrYuran   Чтобы не плодить тем, добавлю здесь. Вчера у меня ...   Mar 30 2018, 06:26
|- - adnega   Цитата(MrYuran @ Mar 30 2018, 09:26) Чтоб...   Mar 30 2018, 06:49
|- - MrYuran   Цитата(adnega @ Mar 30 2018, 09:49) Вчера...   Mar 30 2018, 07:26
- - Obam   Хозян, как всем известно - барин... да и речь в то...   Mar 30 2018, 14:55
- - jcxz   Цитата(Obam @ Mar 30 2018, 17:55) В коман...   Mar 30 2018, 19:43


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

 


RSS Текстовая версия Сейчас: 16th July 2025 - 13:24
Рейтинг@Mail.ru


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