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

 
 
> STM32F105 и SPI, Добавьте ясности, пожалуйста
Still Enemy
сообщение Apr 14 2015, 12:25
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 66
Регистрация: 29-01-15
Из: Нижний Новгород
Пользователь №: 84 817



Стоит задача работать с FlashMemory M25P128 по SPI1 с помощью STM32. Под SPI1 выделено только три пина: MOSI,MISO,SCK, которые висят PB с 3 по 5 пин(Remap запилен). Платой(разработка фирмы) не предусмотрен NSS, пин PA14 забит другим устройством, зато под NSS заведён пин PB6. Как необходимо настроить ноги SPI, чтобы всё работало?
Я представляю, что и с текущей конфигурацией платы можно сделать, но как?
Как я рассуждаю, читая Reference Manual: нужно заделать SSM=1 и SSI=1 в SPI_CR1 и SSOE = 0 в SPI_CR2. Запилить PB6 как обычный GPIO на выход и подавать на него лог ноль при обмене.
После этого начинаю углубляться в Reference Manual. Возникло дохера вопросов(некоторые не по теме, но всё же хотелось знать):
Цитата
NSS: Slave select. This is an optional pin to select a slave device. This pin acts as a ‘chip select’ to let the SPI master communicate with slaves individually and to avoid contention on the data lines.

Как с помощью одного пина то можно управлять индивидуально одним из нескольких слейвов?
Дальше интереснее:
Цитата
Software NSS management (SSM = 1)
The slave select information is driven internally by the value of the SSI bit in the SPI_CR1 register. The external NSS pin remains free for other application uses.

Прочитав пару десятков раз мануал и еще посмотрев вот сюда рассудил про себя, что всё же 2 варианта работы в режиме программного управления ногой NSS:
1) SSOE = 0, SSM = 1, SSI = 1. Тут включается режим "какбэ" мультимастер. Выставить SSI в ноль - значит вылет ошибки MODF с последующим понижением в рабы) Выдержка из мануала по этому поводу:
Цитата
25.3.10 Error flags
Master mode fault (MODF)
Master mode fault occurs when the master device has its NSS pin pulled low (in NSS hardware mode) or SSI bit low (in NSS software mode), this automatically sets the MODF bit.

2) SSOE = 0, SSM = 1, SSI = ?(SSI в этом случае видимо нахрен не нужен). Подтягиваем NSS мастера к питанию, а CS слейва к земле(это я увидел по картинке 238 в том же мануале). Тут не понятно, что делать с SSI.
Вот тут я уже не понимаю как в 1 варианте работать с слейвом, без подтягивания к земле CS слейва. И опять же вопрос по работе с несколькими слейвами тоже актуален.
Как же нужно настроить регистры SPI в моём случае? Это вообще реально?
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
Still Enemy
сообщение Apr 17 2015, 10:15
Сообщение #2


Участник
*

Группа: Участник
Сообщений: 66
Регистрация: 29-01-15
Из: Нижний Новгород
Пользователь №: 84 817



Кароч ребят, вы не поверите. Дело оказалось в новых дровах, которые генерирует Куб, там нашелся касяк очень и очень старый: у меня МК шьётся через SW/JTAG. Я использую SW, он под себя выделает 2 пина PA13,PA14. В коде вызывалась команда, которая делает ремап, чтобы освободить остальные пины(в том числе и злосчастный PB3!!!), кроме тех что под SW, но на деле ремап никакой не происходил по одной простой причине: чтобы делать ремап, надо сначала включить тактирование на порт(в моём случае на B ). Вот только в таком случае оно начинает работать, а не сначала ремап, а потом включить тактирование.

Сообщение отредактировал Still Enemy - Apr 17 2015, 10:16
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Apr 17 2015, 14:53
Сообщение #3


Гуру
******

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



Цитата(Still Enemy @ Apr 17 2015, 13:15) *
чтобы делать ремап, надо сначала включить тактирование на порт(в моём случае на B ).
Только наверное не тактирование порта, а тактирование AFIO. Я - то библиотеками не пользуюсь, первым делом инициализирую тактирование всех нужных блоков записью всех трех регистров RCC_xxxENR целиком, но логика подсказывает, что раз регистр MAPR находится в группе AFIO, то и за его тактирование отвечает тактирование AFIO.


--------------------
На любой вопрос даю любой ответ
"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

Сообщений в этой теме
- Still Enemy   STM32F105 и SPI   Apr 14 2015, 12:25
- - mcheb   Совершенно очевидно,что МК-мастер,флэш-слэйв. Поэт...   Apr 14 2015, 13:57
- - Сергей Борщ   Управляйте сигналом выборки памяти ногодрыгом. Апп...   Apr 14 2015, 13:58
|- - A. Fig Lee   Цитата(Сергей Борщ @ Apr 14 2015, 09:58) ...   Apr 14 2015, 15:08
- - Still Enemy   mcheb, спасибо, кэп, я спрашивал не про то. Серге...   Apr 14 2015, 17:56
- - uriy   ЦитатаA разве NSS работает не только на инпут в сл...   Apr 15 2015, 04:20
|- - Still Enemy   Цитата(uriy @ Apr 15 2015, 08:20) Тоже вс...   Apr 15 2015, 04:56
|- - Сергей Борщ   Цитата(uriy @ Apr 15 2015, 06:20) Тоже вс...   Apr 15 2015, 05:14
- - A. Fig Lee   A как вы тогда предлагаете угадывать, когда дергат...   Apr 15 2015, 10:20
- - Still Enemy   Что-то у меня никак не работает. Взял осциллограф,...   Apr 15 2015, 12:42
- - A. Fig Lee   Посмотреть регистры, убедится, что они меняются. Е...   Apr 15 2015, 13:57
|- - Still Enemy   Цитата(A. Fig Lee @ Apr 15 2015, 17:57) П...   Apr 15 2015, 16:25
- - Still Enemy   В итоге оказалось, что не работала нога PB3. Сдела...   Apr 16 2015, 06:07


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

 


RSS Текстовая версия Сейчас: 21st August 2025 - 23:02
Рейтинг@Mail.ru


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