|
Размер стека |
|
|
|
Nov 21 2012, 14:25
|
Местный
  
Группа: Участник
Сообщений: 442
Регистрация: 26-11-10
Пользователь №: 61 199

|
Цитата(_Артём_ @ Nov 21 2012, 18:20)  Размер как правило определяется в каждом проекте, за исключением случая когда стек аппаратный. Тогда два вопроса. 1. В каких устройствах MSP430 стек аппаратный? 2. Как может быть определен размер стека, если я, например, в своем проекте использую рекурсивную функцию? Заранее нельзя сказать сколько раз она будет вызвана и, соответственно, выделить под стек необходимое количество памяти.
|
|
|
|
|
Nov 21 2012, 15:33
|
Гуру
     
Группа: Свой
Сообщений: 2 128
Регистрация: 21-05-06
Пользователь №: 17 322

|
Цитата(d7d1cd @ Nov 21 2012, 16:25)  1. В каких устройствах MSP430 стек аппаратный? ДУмаю, что в MSP430 аппаратный стек не использовался. Такой стек использовался например в PIC-ах. Цитата(d7d1cd @ Nov 21 2012, 16:25)  2. Как может быть определен размер стека, если я, например, в своем проекте использую рекурсивную функцию? Заранее нельзя сказать сколько раз она будет вызвана и, соответственно, выделить под стек необходимое количество памяти. Глубина вызовов не может быть больше, чем размер стека - работать перестанет. Выбирите максимально возможное значение глубины вызовов и задайте стек в соответствии с ним.
|
|
|
|
|
Nov 21 2012, 16:22
|
Местный
  
Группа: Участник
Сообщений: 442
Регистрация: 26-11-10
Пользователь №: 61 199

|
Цитата(_Артём_ @ Nov 21 2012, 19:33)  Глубина вызовов не может быть больше, чем размер стека - работать перестанет.Выбирите максимально возможное значение глубины вызовов и задайте стек в соответствии с ним. Возможно мы не поняли друг друга. Я сам задаю размер стека?
|
|
|
|
|
Nov 21 2012, 16:56
|
Гуру
     
Группа: Свой
Сообщений: 2 128
Регистрация: 21-05-06
Пользователь №: 17 322

|
Цитата(d7d1cd @ Nov 21 2012, 18:22)  Возможно мы не поняли друг друга. Я сам задаю размер стека? Да, задаёте сами. Из slau049c.pdf: Цитата Software Initialization After a system reset, user software must initialize the MSP430 for the application requirements. The following must occur: - Initialize the SP, typically to the top of RAM. - Initialize the watchdog to the requirements of the application. - Configure peripheral modules to the requirements of the application.
|
|
|
|
|
Nov 21 2012, 18:53
|

Знающий
   
Группа: Свой
Сообщений: 723
Регистрация: 29-08-05
Из: Березовский
Пользователь №: 8 065

|
Цитата(d7d1cd @ Nov 21 2012, 19:43)  Привет всем. Подскажите, размер памяти, выделяемой под стек, в устройствах MSP430 всегда одинаков или все зависит от компилятора? Вот тут -- http://zhevak.wordpress.com/2012/11/22/раз...стека-в-msp430/я написал о-очень длинный ответ. Такой длинный, что понял, что помещать его сюда -- лучше не надо.
--------------------
Хочешь рассмешить Бога -- расскажи ему о своих планах!
|
|
|
|
|
Nov 22 2012, 02:46
|
Местный
  
Группа: Участник
Сообщений: 442
Регистрация: 26-11-10
Пользователь №: 61 199

|
Цитата(zhevak @ Nov 21 2012, 22:53)  Вот тут -- http://zhevak.wordpress.com/2012/11/22/раз...стека-в-msp430/я написал о-очень длинный ответ. Такой длинный, что понял, что помещать его сюда -- лучше не надо. Спасибо, почитаю...
Сообщение отредактировал d7d1cd - Nov 22 2012, 02:48
|
|
|
|
|
Nov 22 2012, 15:19
|
Гуру
     
Группа: Свой
Сообщений: 10 920
Регистрация: 5-04-05
Пользователь №: 3 882

|
Цитата(d7d1cd @ Nov 21 2012, 21:22)  Возможно мы не поняли друг друга. Я сам задаю размер стека? Размер стека это абстрактная величина, определяемая программистом для компилятора. Потому, что в MSP430 аппаратный лишь сам указатель стека. Размер стека никак аппаратно не задается и не контролируется. "Наползание" стека на область статических/глобальных данных это самая трудновыявляемая ошибка в программировании. Компилятор может немного помочь в определении этого момента, но не всегда и с вероятностью, сильно отличающейся от 100%. Тем более он этого не может, когда идут рекурсивные вызовы в прерываниях, которые компилятор спрогнозировать вообще не в силах. Используйте программные ухищрения, типа счетчика рекурсии. Код #define MAX_NESTED_VALUE 5 //максимальное значение уровня вложенности прерываний #pragma vector=TIMERB0_VECTOR #pragma type_attribute=__interrupt void TIMERB0_ISR(void) { static unsigned int cntr_nested=0; cntr_nested++; //инкремент счетчика вложенности прерываний if (cntr_nested < MAX_NESTED_VALUE) //проверяем уровень вложенности, если он меньше допустимого, то выполняем какие-то действия {
... //выполняем какие-то действия, необходимые до вложенных прерываний
__enable_interrupt(); //разрешаем прерывания, в т.ч. вложенные
... //выполняем какие-то действия
} --cntr_nested; //декремент счетчика вложенности прерываний }
|
|
|
|
|
Nov 22 2012, 19:46
|
Гуру
     
Группа: Свой
Сообщений: 10 920
Регистрация: 5-04-05
Пользователь №: 3 882

|
Цитата(_Артём_ @ Nov 22 2012, 20:33)  Зачем cntr_nested объявлена как static, а не как глобальная? Чтобы зря не "засирать" namespace  Цитата(_Артём_ @ Nov 22 2012, 20:33)  Это подсчёт вложенности одного и того же прерывания? Конечно. Ведь переменная имеет область видимости и изменяется только внутри данной конкретной функции обработки прерывания. Цитата(_Артём_ @ Nov 22 2012, 20:33)  Не лучше ли на входе прерывания делать запрет вызова, а на выходе опять разрешать? Данный вопрос свидетельствует о том, что вы слабо знакомы с системой прерываний MSP430. При переходе по вектору прерывания сохраняется состояние регистра SR (на стеке), затем флаг GIE (Global Interrupt Enable - глобальное разрешение маскируемых прерываний), входящий в состав этого регистра, сбрасывается (точнее сбрасывается состояние всего статусного регистра SR) и таким образом вложенные прерывания автоматически запрещаются. Так что отдельно запрещать прерывания непосредственно в функции обработки прерывания не требуется. Если вам нужны вложенные прерывания, то в обработчике прерывания их можно разрешить (установив бит GIE). Естественно, что при выходе из прерывания состояние регистра SR (и бита GIE) восстанавливается.
|
|
|
|
|
Nov 22 2012, 20:35
|
Гуру
     
Группа: Свой
Сообщений: 2 128
Регистрация: 21-05-06
Пользователь №: 17 322

|
Цитата(rezident @ Nov 22 2012, 21:46)  Чтобы зря не "засирать" namespace  Ну если так...то понятно. Цитата(rezident @ Nov 22 2012, 21:46)  Конечно. Ведь переменная имеет область видимости и изменяется только внутри данной конкретной функции обработки прерывания. Мне как-то трудно представить, зачем допускать ситуацию, когда вложенность одного и того же прерывания больше 1. Разрешить работать другим прерываниям - понятно, а так - не очень. Цитата(rezident @ Nov 22 2012, 21:46)  Данный вопрос свидетельствует о том, что вы слабо знакомы с системой прерываний MSP430. Я их даже не видел ни разу.  Цитата(rezident @ Nov 22 2012, 21:46)  Если вам нужны вложенные прерывания, то в обработчике прерывания их можно разрешить (установив бит GIE). Обычно так и делаю (на АВР правда, но какая разница). Но перед этим запрещаю тот обработчик, который выполняется в текущий момент.
|
|
|
|
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|