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

 
 
2 страниц V   1 2 >  
Reply to this topicStart new topic
> Доступ к EEPROM в IAR, ЗАпрещены ли прерывания в программе на момент чтения EEPROM в IAR
Sergio66
сообщение Jan 26 2006, 10:07
Сообщение #1


Местный
***

Группа: Свой
Сообщений: 235
Регистрация: 9-02-05
Пользователь №: 2 526



Подскажите, пожалуйста, на время доступа к переменным в EEPROM IARовский компиллятор запрещает прерывания или нет??? Проблема в том, что в программе, когда работает основной ее цикл, каким то образом портится одна и та же ячейка памяти в EEPROM. При этом, программа только читает EEPROM. В том числе и данную ячейку.
Go to the top of the page
 
+Quote Post
BVU
сообщение Jan 26 2006, 10:43
Сообщение #2


Профессионал
*****

Группа: Свой
Сообщений: 1 301
Регистрация: 30-11-04
Из: Россия, Н.Новгород
Пользователь №: 1 264



Цитата(Sergio66 @ Jan 26 2006, 13:07) *
Подскажите, пожалуйста, на время доступа к переменным в EEPROM IARовский компиллятор запрещает прерывания или нет??? Проблема в том, что в программе, когда работает основной ее цикл, каким то образом портится одна и та же ячейка памяти в EEPROM. При этом, программа только читает EEPROM. В том числе и данную ячейку.

Нет об этом Вы должны заботиться сами:
'C' - __disable_interrupt(); __enable_interrupt();
asm - CLI; SEI


--------------------
Не корысти ради, не в целях наживы, а во исполнение велений души!
Go to the top of the page
 
+Quote Post
Sergio66
сообщение Jan 26 2006, 11:08
Сообщение #3


Местный
***

Группа: Свой
Сообщений: 235
Регистрация: 9-02-05
Пользователь №: 2 526



А есть ли возможность перекомпиллить данные библиотечные функции с запретом прервыаний в них? И где можно взять их исходники?
Go to the top of the page
 
+Quote Post
andk
сообщение Jan 26 2006, 11:26
Сообщение #4


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

Группа: Свой
Сообщений: 199
Регистрация: 17-12-04
Из: Миасс
Пользователь №: 1 519



Эти функции не библиотечные. Они описаны и реализованы в intrinsics.h
Go to the top of the page
 
+Quote Post
miv
сообщение Jan 26 2006, 11:33
Сообщение #5


Участник
*

Группа: Участник
Сообщений: 41
Регистрация: 29-08-05
Из: С-Петербург
Пользователь №: 8 055



Компиллер от IAR при обращении к переменным которые втиснуты в EEPROM всавляет свои процедуры.
т.е. если написать a = 5; он вызовет поппрограмку на асме которая в момент записи запретит прерывания а поосле окончания разрешит их. проверить это можно получив ассемблерный листинг своей программы ! Тоько вот забыл как компиллеру указать что переменная 'а' находится в EEPROM.
Но это можно узнать почитав доку ! wink.gif
Go to the top of the page
 
+Quote Post
GxOST
сообщение Jan 26 2006, 11:34
Сообщение #6


Участник
*

Группа: Свой
Сообщений: 58
Регистрация: 6-12-05
Из: Санкт-Петербург
Пользователь №: 11 878



Во-первых, там все учтено. По крайней мере, в версиях 4.xx. То есть, никаких дополнительных ухищрений с запрещением прерываний делать не нужно.

Во-вторых, все процедуры работы с eeprom можно поменять, подключив к проекту собственный файл, изменив тот, который лежит вот тут: \avr\src\lib\eeprom.s90

И учтите одну вещь: если будете делать как сказал BVU, огребете глюков по полной программе (особенно если есть обращение к EEPROM из обработчиков прерываний).


--------------------
cul8r!
* #ru_embedded - эмбеддерский чат
Go to the top of the page
 
+Quote Post
KRS
сообщение Jan 26 2006, 12:06
Сообщение #7


Профессионал
*****

Группа: Модераторы
Сообщений: 1 951
Регистрация: 27-08-04
Из: Санкт-Петербург
Пользователь №: 555



Так если программа только читает еепром зачем запрещать прерывания?
Go to the top of the page
 
+Quote Post
Sergio66
сообщение Jan 26 2006, 12:16
Сообщение #8


Местный
***

Группа: Свой
Сообщений: 235
Регистрация: 9-02-05
Пользователь №: 2 526



Вопрос возник всвязи с тем, что переменная в EEPROM таки портится!!! Есть подозрение, что если в процессе выполнения функции чтения происходит прерывание, то возможно и переполнение стека, и порча переменных в стеке CSTACK. Вот отсюда и вопрос про запрет прерывания.
Go to the top of the page
 
+Quote Post
miv
сообщение Jan 26 2006, 12:51
Сообщение #9


Участник
*

Группа: Участник
Сообщений: 41
Регистрация: 29-08-05
Из: С-Петербург
Пользователь №: 8 055



Дык каков размер CSTACK, сколько байт ?
Go to the top of the page
 
+Quote Post
Sergio66
сообщение Jan 26 2006, 12:56
Сообщение #10


Местный
***

Группа: Свой
Сообщений: 235
Регистрация: 9-02-05
Пользователь №: 2 526



Размер CSTACK = 0х170 байт. Взял я этот размер из map файла:
Вот что там прописано


SEGMENT SPACE START ADDRESS END ADDRESS SIZE TYPE ALIGN
======= ===== ============= =========== ==== ==== =====
INTVEC CODE 00000000 - 0000004F 50 com 1
?FILL1 CODE 00000050 - 00000057 8 rel 0
NEAR_F CODE 00000058 - 00001A29 19D2 rel 0
SWITCH CODE 00001A2A - 00001A9B 72 rel 1
CODE CODE 00001A9C - 00006263 47C8 rel 1
INITTAB CODE 00006264 - 0000626F C rel 0
NEAR_ID CODE 00006270 - 000062ED 7E rel 0
ABSOLUTE DATA 0000001C rel 0
DATA 0000001D
DATA 0000001E
DATA 0000001F
DATA 00000020 - 00000027 8
DATA 00000029 - 0000002C 4
DATA 00000030 - 0000003B C
DATA 00000040 - 00000042 3
DATA 00000045 - 00000045 1
DATA 00000048 - 0000004B 4
DATA 0000004E - 0000004F 2
DATA 00000053 - 00000056 4
DATA 00000059 - 00000059 1
DATA 0000005B - 0000005C 2
CSTACK DATA 00000060 - 000001CF 170 dse 0
RSTACK DATA 000001D0 - 0000020F 40 dse 0
NEAR_I DATA 00000210 - 0000028D 7E rel 0
NEAR_Z DATA 0000028E - 000004B8 22B rel 0
EEPROM_I XDATA 00000001 - 0000012D 12D rel 0
Go to the top of the page
 
+Quote Post
miv
сообщение Jan 26 2006, 13:06
Сообщение #11


Участник
*

Группа: Участник
Сообщений: 41
Регистрация: 29-08-05
Из: С-Петербург
Пользователь №: 8 055



Если вложенных прерываний не городили ! То такого размера должно хватить !
Кстати ! Если при чтении или записи в EEPROM не запрещать прерывания, а впрерываниях
есть ещё место где есть обращение к EEPROM или FLASH то данные в EEPROM могут слететь, даже
если идёт только чтение !

Ко FLASH есно по записи ! biggrin.gif
Go to the top of the page
 
+Quote Post
Sergio66
сообщение Jan 26 2006, 13:10
Сообщение #12


Местный
***

Группа: Свой
Сообщений: 235
Регистрация: 9-02-05
Пользователь №: 2 526



В том то и дело, что проект очень сложный и большой. Прерываний наверчено немеряно - все три таймера работают асинхронно с прерываниями, UART, TWI, INT0, INT1, INT2, и все это исключительно асинхронно.
Go to the top of the page
 
+Quote Post
Sergio66
сообщение Jan 26 2006, 13:25
Сообщение #13


Местный
***

Группа: Свой
Сообщений: 235
Регистрация: 9-02-05
Пользователь №: 2 526



Да, у меня в программе есть место, где в функции обработки прерывания идет чтение из EEPROM. Так это и может явиться причиной сбоя данных в EEPROM? Следует учесть, что, насколько я смог оценить последствия такого сбоя, сбивается всегда одна и та же ячейка.
Go to the top of the page
 
+Quote Post
miv
сообщение Jan 26 2006, 13:41
Сообщение #14


Участник
*

Группа: Участник
Сообщений: 41
Регистрация: 29-08-05
Из: С-Петербург
Пользователь №: 8 055



Тогда нужно быть уверенным наверняка что в момент чтения или записи в EEPROM прерывания запрещены. 1 самому разрешать и запрешать, или дать на откуп компиллеру т.е. сказать ему что эти переменные находяться в EEPROM. (вот как это делается в IAR я не помню) cranky.gif
Go to the top of the page
 
+Quote Post
BVU
сообщение Jan 26 2006, 14:01
Сообщение #15


Профессионал
*****

Группа: Свой
Сообщений: 1 301
Регистрация: 30-11-04
Из: Россия, Н.Новгород
Пользователь №: 1 264



Цитата(GxOST @ Jan 26 2006, 14:34) *
Во-первых, там все учтено. По крайней мере, в версиях 4.xx. То есть, никаких дополнительных ухищрений с запрещением прерываний делать не нужно.

Во-вторых, все процедуры работы с eeprom можно поменять, подключив к проекту собственный файл, изменив тот, который лежит вот тут: \avr\src\lib\eeprom.s90

И учтите одну вещь: если будете делать как сказал BVU, огребете глюков по полной программе (особенно если есть обращение к EEPROM из обработчиков прерываний).

Сколько времени работаю с 'IAR Embedded Workbench 4.10B' и никаких проблем не возникало... Незнаю, как Вы работаете с EEPROM, а я предпочитаю не мудрить и использовать чтение/запись, как к обычным переменным объявленные в EEPROM. Просто посмотрите свой ассемблерный код после компиляции и все станет ясно, что на 'автомате' запрещение и разрешение прерываний там не генерируется. А в прерываниях на которые Вы сетуете необходимо учитывать автоматическое запрещение при входе в прерывание.


--------------------
Не корысти ради, не в целях наживы, а во исполнение велений души!
Go to the top of the page
 
+Quote Post

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

 


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


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