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

 
 
> STM32 Сброс периферии через APB1RSTR, APB2RSTR, Делюсь набитыми шишками
Sergey_Aleksandr...
сообщение Jun 15 2012, 13:38
Сообщение #1


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

Группа: Свой
Сообщений: 168
Регистрация: 8-10-08
Из: РФ Смоленск
Пользователь №: 40 764



Заранее прошу прощения за поток сознания выливаемый на форум уже несколько дней кряду. Новая платформа... новые грабли. Это не вопрос, а опыт-впечатления, полученные за пол-дня потерянного времени.
Пишу загрузчик. Встала задача сбрасывать всю периферию по выходу в основное ПО. Самый простой способ - установка битов регистров APB1RSTR, APB2RSTR, AHBRSTR в '1'. Вот цитата из "Reference Manual RM0008", например, для бита SPI1RST регистра RCC_APB2RSTR
Цитата
Bit 12 SPI1RST: SPI 1 reset
Set and cleared by software.
0: No effect
1: Reset SPI 1

Всё верно, все регистры SPI1 сбрасываются в значения по-умолчанию при установке указанного бита. Однако все последующие манипуляции с SPI1 тщетны. Кто бы мог подумать, что установка бита в '1' держит соответствующий периферийный модуль в состоянии сброса до тех пор, пока этот бит в APB1RSTR или RCC_APB2RSTR не будет сброшен в '0'. Вот тебе и "0: No effect". И что неприятно, в документации про этот момент ни слова. Надеюсь кому-нибудь поможет sm.gif
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов (1 - 4)
maksimp
сообщение Jun 16 2012, 19:45
Сообщение #2


Местный
***

Группа: Участник
Сообщений: 313
Регистрация: 2-07-11
Пользователь №: 66 023



Там же напсиано, цитата из вашей цитаты:
Цитата
Set and cleared by software.

То есть сам он не изменяет своего значения, что записали то в нём и будет.
Поэтому если записали 1 то и будет
Цитата
1: Reset SPI 1

и никуда не денется само.
И нужно записать 0 чтобы не было влияния этого бита на дальнейшую работу:
Цитата
0: No effect

Go to the top of the page
 
+Quote Post
Sergey_Aleksandr...
сообщение Jun 18 2012, 05:29
Сообщение #3


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

Группа: Свой
Сообщений: 168
Регистрация: 8-10-08
Из: РФ Смоленск
Пользователь №: 40 764



Для меня тогда было бы логичным увидеть в документации следующие строки:
Цитата
Bit 12 SPI1RST: SPI 1 reset
Set and cleared by software.
0. Release Reset signal from peripheral module.
1. Move corresponding peripheral module into permanent Reset state.

Либо вставить где-нибудь ремарку, благо что функциональное назначение всех 32 бит регистра одинаково.
Go to the top of the page
 
+Quote Post
maksimp
сообщение Jun 18 2012, 17:00
Сообщение #4


Местный
***

Группа: Участник
Сообщений: 313
Регистрация: 2-07-11
Пользователь №: 66 023



Да, можно было бы как-нибудь так написать.
Go to the top of the page
 
+Quote Post
nx6310
сообщение Nov 30 2012, 06:12
Сообщение #5


Участник
*

Группа: Участник
Сообщений: 72
Регистрация: 28-06-10
Пользователь №: 58 174



Если тактирование периферии отключить например RCC->APB1ENR&=~RCC_APB1ENR_SPI2EN; то после этого записи и чтение регистров периферии не работают. Но при этом содержимое этих регистров сохраняется.
Go to the top of the page
 
+Quote Post

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

 


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


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