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

 
 
> STM32 SPI, не запускается
Alhen
сообщение Jan 23 2012, 11:43
Сообщение #1


Частый гость
**

Группа: Свой
Сообщений: 161
Регистрация: 17-08-04
Из: Караганда
Пользователь №: 516



Второй день пытаюсь вызвать к жизни SPI1 или 2 на STM32VLDISCOVERY.
Перерыл интернет и даташит до тошноты.
Не пойму что не так:
CODE
RCC->APB2ENR |= RCC_APB2ENR_IOPBEN; // Разрешить тактирование порта B.
RCC->APB2ENR |= RCC_APB2ENR_AFIOEN; // Тактирование альтернативных функций GPIO.
//Настройки GPIO
GPIOB->CRH |= GPIO_CRH_MODE15_1; // Выход MOSI PB.15
GPIOB->CRH &= ~GPIO_CRH_MODE15_0; // 2MHz
GPIOB->CRH &= ~GPIO_CRH_CNF15; // Push-Pull

GPIOB->CRH &= ~GPIO_CRH_MODE14; // Вход MISO PB.14
GPIOB->CRH &= ~GPIO_CRH_CNF14_0; //
GPIOB->CRH |= GPIO_CRH_CNF14_1; // Pull-Up
GPIOB->ODR |= GPIO_ODR_ODR14; //

GPIOB->CRH |= GPIO_CRH_MODE13_1; // Выход SCK PB.13
GPIOB->CRH &= ~GPIO_CRH_MODE13_0; // 2MHz
GPIOB->CRH &= ~GPIO_CRH_CNF13; // Push-Pull

GPIOB->CRH &= ~GPIO_CRH_MODE12; // Вход NSS PB.12
GPIOB->CRH &= ~GPIO_CRH_CNF12_0; //
GPIOB->CRH |= GPIO_CRH_CNF12_1; // Pull-Up
GPIOB->ODR |= GPIO_ODR_ODR12;

//Настройки SPI2
RCC->APB1ENR |= RCC_APB1ENR_SPI2EN; //Разрешаем тактирование SPI2

SPI2->CR1 &= ~SPI_CR1_SPE; //Отключаем SPI перед изменением настроек
SPI2->CR1 |= SPI_CR1_BR_0; //Задаем скорость
SPI2->CR1 |= SPI_CR1_BR_1; //
SPI2->CR1 |= SPI_CR1_CPOL; //Задаем режим
SPI2->CR1 |= SPI_CR1_CPHA; //
SPI2->CR1 &= ~SPI_CR1_DFF; //Формат данных 8 бит
SPI2->CR1 &= ~SPI_CR1_CRCEN; //Запрет CRC
SPI2->CR1 &= ~SPI_CR1_CRCNEXT; //Отключение передачи CRC
SPI2->CR1 &= ~SPI_CR1_RXONLY; //и прочих не fullduplex настроек
SPI2->CR1 &= ~SPI_CR1_SSM; //на всякий случай..
SPI2->CR1 &= ~SPI_CR1_SSI; //
SPI2->CR1 &= ~SPI_CR1_LSBFIRST; //MSB вперед
SPI2->CR1 |= SPI_CR1_MSTR; //В режиме Мастер
SPI2->CR1 &= ~SPI_CR1_BIDIMODE;//
SPI2->CR1 &= ~SPI_CR1_BIDIOE; //

SPI2->CR2 &= ~SPI_CR2_SSOE; // Запретить выход SS
// (на входе задан высокий уровень)

SPI2->CR1 |= SPI_CR1_SPE; // Включаем SPI
.....
//Пробная прием-передача
u8 temp;
while (SPI2->SR & SPI_SR_BSY);
while (!(SPI2->SR & SPI_SR_TXE));
SPI2->DR = 0x55; // Передача данных
while (SPI2->SR & SPI_SR_BSY);
while (!(SPI2->SR & SPI_SR_RXNE));
temp = SPI2->DR; // Чтение принятых данных
.......


При отладке видно, что все настройки устанавливаются как прописано в коде,
а в регистр DR данные 0x55 так и не записывается. На ногах процессора молчок.
Тоже самое делал и для SPI1 с учетом бита альтернативной распиновки.
Наверное, если взять библиотеку с функциями инициализации все бы заработало,
но хочу вот так через "stm32f10x.h".
Помогите пожалуйста разобраться.

Сообщение отредактировал IgorKossak - Jun 18 2012, 17:20
Причина редактирования: [codebox]
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
ChipKiller
сообщение Jan 23 2012, 16:29
Сообщение #2


Участник
*

Группа: Участник
Сообщений: 31
Регистрация: 26-12-11
Пользователь №: 69 097



Цитата("Alhen")
Это от безисходности и злобы ...
... надеюсь все теперь все ОК ... код из рабочего примера
Цитата("Acvarif")
Как переназначить GPIO SPI1 на другие ноги?
1 - посмотреть в datasheet sm.gif .. на других ногах "висит" JTAG, так что помимо установки AFIO_MAPR->SPI1_REMAP нужно позаботиться о JTAG

Сообщение отредактировал ChipKiller - Jan 23 2012, 16:31
Go to the top of the page
 
+Quote Post
Alhen
сообщение Jan 24 2012, 04:26
Сообщение #3


Частый гость
**

Группа: Свой
Сообщений: 161
Регистрация: 17-08-04
Из: Караганда
Пользователь №: 516



Цитата(ChipKiller @ Jan 23 2012, 20:29) *
... надеюсь все теперь все ОК ... код из рабочего примера

Благодарю за рабочий код, действительно все заработало, с меня пиво beer.gif
Я разобрался в чем была промашка, надо было назначить выходы в режиме альтернативной функции.
Код
   GPIOA->CRL   |=  GPIO_CRL_MODE7;     // Выход MOSI PA.7 (50 MHz)
   GPIOA->CRL   &= ~GPIO_CRL_CNF7_0;    // Push-Pull
   GPIOA->CRL   |=  GPIO_CRL_CNF7_1;    // с альтернативной функцией !!!!!!

Позволю себе выложить весь код тестовой программы в том же стиле.
Такой "долбеж" по регистрам неизбежен на начальном этапе освоения камня,
есть ощущение проникновения в сакральный смысл регистров biggrin.gif
CODE
#include "stm32f10x.h"
u8 temp;

void main()
{
RCC->APB2ENR |= RCC_APB2ENR_IOPAEN; // Разрешить тактирование порта A.
RCC->APB2ENR |= RCC_APB2ENR_AFIOEN; // Тактирование альтернативных функций GPIO.
GPIOA->CRL |= GPIO_CRL_MODE7; // Выход MOSI PA.7 (50 MHz)
GPIOA->CRL &= ~GPIO_CRL_CNF7_0; // Push-Pull
GPIOA->CRL |= GPIO_CRL_CNF7_1; // с альтернативной функцией !!!!!!

GPIOA->CRL &= ~GPIO_CRL_MODE6; // Вход MISO PA.6
GPIOA->CRL &= ~GPIO_CRL_CNF6_0; //
GPIOA->CRL |= GPIO_CRL_CNF6_1; // with Pull-Up

GPIOA->CRL |= GPIO_CRL_MODE5; // Выход SCK PA.5 (50 MHz)
GPIOA->CRL &= ~GPIO_CRL_CNF5_0; // Push-Pull
GPIOA->CRL |= GPIO_CRL_CNF5_1; // с альтернативной функцией !!!!

GPIOA->CRL |= GPIO_CRL_MODE4; // Выход NSS PA.4 (50 MHz)
GPIOA->CRL &= ~GPIO_CRL_CNF4; // Push-Pull General Purpose
GPIOA->BSRR = GPIO_BSRR_BS4; //

AFIO->MAPR &= ~AFIO_MAPR_SPI1_REMAP; //Сбрасываем REMAP для SPI на PA4-7
RCC->APB2ENR |= RCC_APB2ENR_SPI1EN;

SPI1->CR1 &= ~SPI_CR1_SPE; //Запрещаем SPI перед изменениями настроек
SPI1->CR1 |= SPI_CR1_BR_0; //Задаем скорость
SPI1->CR1 |= SPI_CR1_BR_1;
SPI1->CR1 |= SPI_CR1_CPOL; //Задаем режим
SPI1->CR1 |= SPI_CR1_CPHA; //
SPI1->CR1 &= ~SPI_CR1_DFF; //Формат данных 8 бит
SPI1->CR1 &= ~SPI_CR1_CRCEN; //Запрет CRC
SPI1->CR1 &= ~SPI_CR1_CRCNEXT; //Отключение передачи CRC
SPI1->CR1 &= ~SPI_CR1_RXONLY; //и прочих не fullduplex настроек
SPI1->CR1 &= ~SPI_CR1_SSM; //на всякий случай..
SPI1->CR1 &= ~SPI_CR1_SSI;
SPI1->CR1 &= ~SPI_CR1_LSBFIRST; //MSB вперед
SPI1->CR1 |= SPI_CR1_MSTR; //В режиме Мастер
SPI1->CR1 &= ~SPI_CR1_BIDIMODE;
SPI1->CR1 &= ~SPI_CR1_BIDIOE;

SPI1->CR1 |= SPI_CR1_SPE; // Включаем SPI

while(1)
{
while (SPI1->SR & SPI_SR_BSY);
while (!(SPI1->SR & SPI_SR_TXE));
SPI1->DR = 0x55; // Передача данных
while (SPI1->SR & SPI_SR_BSY);
while (!(SPI1->SR & SPI_SR_RXNE));
temp = SPI1->DR; // Чтение принятых данных
}
}


Кстати, пошагово в отладчике программа не проходит проверку на RXNE и попадает в бесконечный цикл.
Видать, где-то, RXNE успевает сброситься.
Сам кусок кода с записью и чтением я взял на форуме ST здесь
Автор утверждает, что у него код работает только в этом порядке, хотя в мануале RM0041 не рекомендуют проверять
BSY при каждой посылке и приеме.

Цитата
Note: Do not use the BSY flag to handle each data transmission or reception. It is better to use the
TXE and RXNE flags instead.


Сообщение отредактировал IgorKossak - Jan 24 2012, 09:50
Причина редактирования: [codebox]
Go to the top of the page
 
+Quote Post

Сообщений в этой теме
- Alhen   STM32 SPI   Jan 23 2012, 11:43
- - ChipKiller   зачем же так "долбить" SPI2->CR1 ? .....   Jan 23 2012, 12:07
|- - Acvarif   Делал так (под новуб библиотеку периферии). Для ра...   Jan 23 2012, 12:46
|- - Alhen   QUOTE (ChipKiller @ Jan 23 2012, 15:07) з...   Jan 23 2012, 14:41
- - dfyz.s   Добрый вечер. Тоже разбираюсь с SPI. Вроде все д...   Jun 13 2012, 13:15
- - Genadi Zawidowski   Цитата// MISO: выход push-pull PC11 Master Input S...   Jun 13 2012, 19:55
- - dfyz.s   Обновил библиотеки - заработало MOSI, CS и SCLK Се...   Jun 14 2012, 08:54
- - Genadi Zawidowski   в приведённом коде miso программировался на вывод....   Jun 14 2012, 09:25
- - dfyz.s   На отладчик забил Понял, в чем был косяк. Кодuint...   Jun 14 2012, 10:03
- - Genadi Zawidowski   Нет, именно входом. А как это делается на NXP я по...   Jun 14 2012, 18:48
|- - Impartial   Цитата(Genadi Zawidowski @ Jun 14 2012, 21...   Jun 14 2012, 19:18
- - dfyz.s   ЦитатаКод GPIOB->CRH &= ~(GPIO_CRH_CN...   Jun 18 2012, 15:12
- - ВитГо   хочу подключить к STM32F4 DISCOVERY дисплей LCD NO...   Oct 21 2012, 06:14
- - HHIMERA   Цитата(ВитГо @ Oct 21 2012, 09:14) и собс...   Oct 21 2012, 08:36


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

 


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


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