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

 
 
 
Reply to this topicStart new topic
> STM32F103RB, то ли баг в USARTe?
kan35
сообщение Aug 3 2011, 14:00
Сообщение #1


Знающий
****

Группа: Участник
Сообщений: 537
Регистрация: 22-02-06
Пользователь №: 14 594



Пользую USART.
Разрешено прерывание ТОЛЬКО по флагу RXNE. Все вроде бы работает, но вот если я пытаюсь стопануть проц в какой нибудь точке (поставив точку пока прога крутится), то прога сразу останавливается, но до точки не доходит, отловил - зависает в прерывании USART.
При этом бит ORE выставлен, что в принципе можно считать нормальным в такой ситуации, но именно из за него происходит зацикливание в обработчике прерывания. Добавил холостое считывание USART1_SR и избавился от этой проблемы, но в даташите написано
Цитата
An interrupt is generated on ORE flag in case of Multi Buffer
communication if the EIE bit is set.

У меня EIE не включен, однако в прерывание все равно вваливается.

Что я не учитываю? Помогите понять.
Go to the top of the page
 
+Quote Post
ISK2010
сообщение Aug 4 2011, 05:17
Сообщение #2


Местный
***

Группа: Участник
Сообщений: 205
Регистрация: 21-09-10
Из: г.Зеленоград
Пользователь №: 59 631



Так ты делай считывание USART1_DR, пусть и холостое
Go to the top of the page
 
+Quote Post
kan35
сообщение Aug 4 2011, 06:47
Сообщение #3


Знающий
****

Группа: Участник
Сообщений: 537
Регистрация: 22-02-06
Пользователь №: 14 594



Цитата(ISK2010 @ Aug 4 2011, 09:17) *
Так ты делай считывание USART1_DR, пусть и холостое

не USART1_DR а USART1_SR, но вопрос в том, почему возникает неразрешенное прерывание!?


Сообщение отредактировал kan35 - Aug 4 2011, 06:47
Go to the top of the page
 
+Quote Post
ISK2010
сообщение Aug 4 2011, 07:03
Сообщение #4


Местный
***

Группа: Участник
Сообщений: 205
Регистрация: 21-09-10
Из: г.Зеленоград
Пользователь №: 59 631



Как раз DR. Битик ORE устанавливается из-за того что данные не считываешь. А прерывание у тебя по RXNE, который сбрасывается при чтении DR.

Bit 5 RXNE: Read data register not empty
This bit is set by hardware when the content of the RDR shift register has been transferred to
the USART_DR register. An interrupt is generated if RXNEIE=1 in the USART_CR1 register.
It is cleared by a read to the USART_DR register. The RXNE flag can also be cleared by
writing a zero to it. This clearing sequence is recommended only for multibuffer
communication.
0: Data is not received
1: Received data is ready to be read.
Go to the top of the page
 
+Quote Post
kan35
сообщение Aug 4 2011, 07:08
Сообщение #5


Знающий
****

Группа: Участник
Сообщений: 537
Регистрация: 22-02-06
Пользователь №: 14 594



с RXNE проблем как раз нет, он сбрасывается, проблема то во флаге ORE !!!
а он сбрасывается только чтением регистра _SR.
и из-за ORE проц. зацикливается в прерывании предназначенном только для RXNE
Go to the top of the page
 
+Quote Post
ISK2010
сообщение Aug 4 2011, 07:11
Сообщение #6


Местный
***

Группа: Участник
Сообщений: 205
Регистрация: 21-09-10
Из: г.Зеленоград
Пользователь №: 59 631



Цитата(kan35 @ Aug 4 2011, 11:08) *
с RXNE проблем как раз нет, он сбрасывается, проблема то во флаге ORE !!!
а он сбрасывается только чтением регистра _SR.
и из-за ORE проц. зацикливается в прерывании предназначенном только для RXNE

Ты наличие флага RXNE с помощью чего смотришь? С ним у меня свои счеты, его хрен увидишь через JTAG. Вставь всего одну строчку чтения регистра данных и проверь, а потом говори, помогло или нет.


Go to the top of the page
 
+Quote Post
Flexz
сообщение Aug 4 2011, 07:17
Сообщение #7


Местный
***

Группа: Свой
Сообщений: 252
Регистрация: 9-10-08
Из: Московская обл.
Пользователь №: 40 797



Флаг ORE вызывает прерывание RXNE.
Go to the top of the page
 
+Quote Post
ISK2010
сообщение Aug 4 2011, 07:19
Сообщение #8


Местный
***

Группа: Участник
Сообщений: 205
Регистрация: 21-09-10
Из: г.Зеленоград
Пользователь №: 59 631



А чтобы не устанавливался ORE, нужно до прихода следующих данных прочитать DR. Или так и будем дальше спорить, что появилось раньше, курица или яйцо.
Go to the top of the page
 
+Quote Post
Flexz
сообщение Aug 4 2011, 07:29
Сообщение #9


Местный
***

Группа: Свой
Сообщений: 252
Регистрация: 9-10-08
Из: Московская обл.
Пользователь №: 40 797



Последнее предложение не осилил, вы к чему это вообще?

типовая последовательность обработки прерывания -
1. считать регистр статуса
2. обработать статус(ы) (в данном случае считать DR)
При этом ORE тоже сбросится. Это ошибка которую просто нужно обработать.

ТС видимо только читает DR, не глядя на статус, вот прерывание и виснет.
Go to the top of the page
 
+Quote Post
ISK2010
сообщение Aug 4 2011, 07:34
Сообщение #10


Местный
***

Группа: Участник
Сообщений: 205
Регистрация: 21-09-10
Из: г.Зеленоград
Пользователь №: 59 631



С последовательностью не спорю, сам так делаю. Но мне кажется, ТС наоборот DR не читает. Ведь сам по себе ORE не появляется. вот к чему мое сложное предложение.
Go to the top of the page
 
+Quote Post
Flexz
сообщение Aug 4 2011, 07:48
Сообщение #11


Местный
***

Группа: Свой
Сообщений: 252
Регистрация: 9-10-08
Из: Московская обл.
Пользователь №: 40 797



Возможно и так, сам возникновение ORE встречал только в тяжелом проекте - много прерываний+кривая расстановка приоритетов, в итоге иногда RXNE не успевал обработаться.
Go to the top of the page
 
+Quote Post
kan35
сообщение Aug 4 2011, 16:10
Сообщение #12


Знающий
****

Группа: Участник
Сообщений: 537
Регистрация: 22-02-06
Пользователь №: 14 594



Цитата(Flexz @ Aug 4 2011, 11:29) *
Последнее предложение не осилил, вы к чему это вообще?

типовая последовательность обработки прерывания -
1. считать регистр статуса
2. обработать статус(ы) (в данном случае считать DR)
При этом ORE тоже сбросится. Это ошибка которую просто нужно обработать.

ТС видимо только читает DR, не глядя на статус, вот прерывание и виснет.

ну вот я раньше просто считывал _DR, сбрасывал ...PendingBit и не было проблем. Да в принципе так то не страшно, если не допускать возникновение ORE. Но самый то вопрос в том - почему прерывание от ORE не разрешено, а оно возникает...
Go to the top of the page
 
+Quote Post
ISK2010
сообщение Aug 4 2011, 17:46
Сообщение #13


Местный
***

Группа: Участник
Сообщений: 205
Регистрация: 21-09-10
Из: г.Зеленоград
Пользователь №: 59 631



Цитата(kan35 @ Aug 4 2011, 20:10) *
Но самый то вопрос в том - почему прерывание от ORE не разрешено, а оно возникает...


Смотри "Reference manual RM0008 Rev 13" стр.786 таб.196 строчка 5. Или рисунок 300.

Т.е. в твоем случае возникает не прерывание "Error interrupt", которое включается битом EIE, а прерывание "RXNE interrupt".

Вот кстати из описания регистра USART_CR1 :

Bit 5 RXNEIE: RXNE interrupt enable
This bit is set and cleared by software.
0: Interrupt is inhibited
1: A USART interrupt is generated whenever ORE=1 or RXNE=1 in the USART_SR register


Go to the top of the page
 
+Quote Post

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

 


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


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