|
Пару вопросов по Си для MCS51, от начинающего... |
|
|
|
 |
Ответов
|
Dec 10 2008, 14:18
|
Знающий
   
Группа: Свой
Сообщений: 540
Регистрация: 16-08-07
Из: Владивосток
Пользователь №: 29 831

|
Цитата(AndreyS @ Dec 10 2008, 18:56)  Суть проблеммы В рабочем режиме иногда прошивка виснет. Выяснил, что зависает (зацикливается) она по причине того что локальные переменные процедуры кто-то запорол. Нашел в карте памяти что данные ячейки относятся еще к двум процедурам (причем там эти переменные тоже локальные). Одна из которых вызывается в прерывании. Как мне теперь заставить Keil убрать из перекрестных ссылок эти переменные (чтобы они лежали в разных адресах DATA)? Делать их глобальными внутри одного файла желания нет.
Пока я проверил только локальные переменные в области DATA, быть может такая петрушка есть еще с переменными в области XDATA. Почему Keil их так расположил? Ведь при компиляции он знает какие процедуры попадают в прерывание и по идее должен этим процедурам для локальных переменных выдилять свои адреса. Может нужно что-то указать??
Спасибо. Как я понял, у Вас есть функция которая вызывается из функции обработки прерывания? Если так, то это очень не гуд  . Для этого нужны очень веские основания. Только в том случае, если Вы эту функцию вызываете еще из другого места. Но эту ситуацию линкер возможно и не отслеживает и нужно в этой функции переменные объявить static, хотя это равносильно глобальной переменной. Да и тем более возможен повторный вход в функцию со всеми вытекающими. Этот вариант отметаем  Если же вызов только из прерывания, тогда лучше вобще обойтись без дополнительной функции, все стащить в одно место, в функцию-обработчик. Вы же наверняка пользуетесь using-ами, может быть линкер эти переменные через регистры протащит, будет маленькое счастье  . А нельзя вобще обойтись в прерывании без обработки, выставив соответствующий флажок и обработать в другом месте?
|
|
|
|
|
Dec 10 2008, 16:08
|

Местный
  
Группа: Участник
Сообщений: 235
Регистрация: 28-01-05
Из: Санкт-Петербург
Пользователь №: 2 276

|
Цитата(barabek @ Dec 10 2008, 17:18)  Как я понял, у Вас есть функция которая вызывается из функции обработки прерывания? Если так, то это очень не гуд  . Для этого нужны очень веские основания. Только в том случае, если Вы эту функцию вызываете еще из другого места. Но эту ситуацию линкер возможно и не отслеживает и нужно в этой функции переменные объявить static, хотя это равносильно глобальной переменной. Да и тем более возможен повторный вход в функцию со всеми вытекающими. Этот вариант отметаем  Если же вызов только из прерывания, тогда лучше вобще обойтись без дополнительной функции, все стащить в одно место, в функцию-обработчик. Вы же наверняка пользуетесь using-ами, может быть линкер эти переменные через регистры протащит, будет маленькое счастье  . А нельзя вобще обойтись в прерывании без обработки, выставив соответствующий флажок и обработать в другом месте? Огромное спасибо за содержательный ответ. В прерывании использую процедуру которая вызывается еще и по коду. Суть процедуры сформировать (подготовить запрос на SPI шину и поставить его в очередь). Т.е. по сути - это и флажок и короткий обработчик этого флажка. Да. Переосмыслил сейчас еще раз свой код и чую буду переделывать обработчик прерывания.  Да, тут я упустил из внимания возможность повторного вызова процедуры в неблагоприятный момент. Вы подняли мне веки  Правда это не отменяет объединения (отображения части переменных по одним и тем же адресам) локальных переменных двух разных процедур (я пока просто перебросил переменные в одной процедуре в XRAM и таким образом развязал эти процедуры). Буду переписывать обработчик.
Сообщение отредактировал AndreyS - Dec 10 2008, 16:21
--------------------
Удачи.
|
|
|
|
Сообщений в этой теме
Lotor Пару вопросов по Си для MCS51 Jul 8 2007, 15:32 alcosar Цитата(Lotor @ Jul 8 2007, 18:32) Доброе ... Jul 8 2007, 19:51 Lotor Цитата(alcosar @ Jul 8 2007, 23:51) const... Jul 9 2007, 16:18  msn Цитата(Lotor @ Jul 9 2007, 19:18) Это-то ... Jul 10 2007, 21:25   zltigo Цитата(msn @ Jul 11 2007, 00:25) пишем...... Jul 10 2007, 22:57  Sir Jon Цитата(Lotor @ Jul 9 2007, 19:18) Это-то ... Sep 7 2007, 10:51   kolobok0 Цитата(Sir Jon @ Sep 7 2007, 14:51) ..Хор... Sep 7 2007, 11:18 SALOME Цитата(Lotor @ Jul 8 2007, 22:32) Доброе ... Jul 9 2007, 03:46 oran-be ЦитатаЭто-то понятно, но есть вагон и маленькая те... Jul 9 2007, 18:17 Lotor Цитата(oran-be @ Jul 9 2007, 22:17) ... Jul 9 2007, 19:21  Sergu Цитата(Lotor @ Jul 9 2007, 22:21) Еще воз... Jul 10 2007, 03:51   Lotor Цитата(Sergu @ Jul 10 2007, 07:51) удобно... Jul 10 2007, 16:53 silc alcosar: const и не должен помещать в ОЗУ. Вам нуж... Aug 10 2007, 14:57 Василий_Безкатегорийный Насчет побитового обращения к портам. Я пытаюсь ра... Sep 25 2007, 08:45    tag Цитата(barabek @ Dec 11 2008, 04:31) В эт... Dec 11 2008, 10:05     barabek Цитата(tag @ Dec 11 2008, 20:05) Уверяю в... Dec 11 2008, 10:53    AndreyS Цитата(barabek @ Dec 11 2008, 03:31) Если... Dec 11 2008, 12:00     barabek Цитата(AndreyS @ Dec 11 2008, 22:00) Комп... Dec 11 2008, 14:00      AndreyS Цитата(barabek @ Dec 11 2008, 17:00) Здес... Dec 11 2008, 14:37 AndreyS Люди!!! Помогите. Пока перебросил пере... Dec 10 2008, 10:57 Axel Если функция не написана, как реентерабельная (сло... Dec 10 2008, 17:37 AndreyS Добрый день.
Написал для прерывания специальную ф... Dec 12 2008, 10:38 Сергей Борщ Цитата(AndreyS @ Dec 12 2008, 12:38) И пе... Dec 12 2008, 12:03  c8051 Цитата(Сергей Борщ @ Dec 12 2008, 15:03) ... Dec 12 2008, 16:52   Сергей Борщ Цитата(c8051 @ Dec 12 2008, 18:52) c51.pd... Dec 12 2008, 18:37    AndreyS Цитата(Сергей Борщ @ Dec 12 2008, 21:37) ... Dec 13 2008, 20:34
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|