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

 
 
> STM32L151 RTC, Какое-то неудобство использования
MiklPolikov
сообщение Dec 6 2013, 16:15
Сообщение #1


Гуру
******

Группа: Свой
Сообщений: 2 015
Регистрация: 23-01-07
Из: Москва
Пользователь №: 24 702



Я чего-то недопонял, или действительно так :


Допустим в программе во многих местах нужно знать время. Время хранится в какой-то глобальной переменной.
Очевидно что каждую секунду нужно читать из RTC новое время . Но вот-тут загвоздка.
Никакого прерывания происходящего точно в момент изменения секунды в RTC нет.
Остаётся читать время из RTC в прерываниях RTC_Wakup или в прерываниях любого другого таймера.
Но тогда изменения секунд в переменной будут не синхронизированы с тиканьем реальных секунд в RTC , или нужно читать RTC очень часто.

Читать непосредственно в момент когда время понадобилось то же неудобно, потому как что бы прочитать время нужно сбросить флаг RTC_ISR_RSF того что дата и время скопированы в буферный регистр, и ждать пока он выставится.

Явное неудобство


--------------------
Если у Вас нет практического опыта в данной теме- не вступайте в дискуссию и не пишите никаких теоретических рассуждений! Заранее спасибо !
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
smk
сообщение Dec 6 2013, 16:49
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 2 246
Регистрация: 17-03-05
Из: Украина, Киев
Пользователь №: 3 446



А будильника там тоже нет?


--------------------
Живи днем так, чтобы ночью ты спал спокойно.
Go to the top of the page
 
+Quote Post
MiklPolikov
сообщение Dec 6 2013, 17:04
Сообщение #3


Гуру
******

Группа: Свой
Сообщений: 2 015
Регистрация: 23-01-07
Из: Москва
Пользователь №: 24 702



Цитата(smk @ Dec 6 2013, 20:49) *
А будильника там тоже нет?

Есть

Цитата(jcxz @ Dec 6 2013, 20:38) *
Решение навскидку:
Читать значение RTC в прерывании какого-то таймера (частоту прерывания выставить в соответствии с необходимой точностью обнаружения момента изменения RTC).
По обнаружению изменения значения RTC, перепрограммировать частоту на период немного меньше секунды.
После получения этого прерывания, опять установить большую частоту прерывания до изменения RTC. и так далее. Надеюсь идея ясна.


Замечательно . На мой взгляд сканировать состояние RTC с большой частотой не непрерывно а изредка, видимо ради экономии ресурсов процессора - это способ
сделать глюк который будет происходить в момент нехватки ресурсов более редким и потому более сложноотлавливаемым sm.gif
Ещё можно просверлить в процессоре дырочку, и через неё смотреть не изменилась ли секунда в RTC.


--------------------
Если у Вас нет практического опыта в данной теме- не вступайте в дискуссию и не пишите никаких теоретических рассуждений! Заранее спасибо !
Go to the top of the page
 
+Quote Post
jcxz
сообщение Dec 6 2013, 17:47
Сообщение #4


Гуру
******

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



Цитата(MiklPolikov @ Dec 6 2013, 23:04) *
Замечательно . На мой взгляд сканировать состояние RTC с большой частотой не непрерывно а изредка, видимо ради экономии ресурсов процессора - это способ
сделать глюк который будет происходить в момент нехватки ресурсов более редким и потому более сложноотлавливаемым sm.gif

Нехватки каких ресурсов?
Go to the top of the page
 
+Quote Post



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

 


RSS Текстовая версия Сейчас: 22nd August 2025 - 11:42
Рейтинг@Mail.ru


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