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

 
 
 
Reply to this topicStart new topic
> Стек переходит в область переменных, Стек
LSerg
сообщение Apr 6 2011, 07:35
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 41
Регистрация: 1-06-08
Пользователь №: 37 967



Помогите решить данную проблему.
Проект на мега128, компилятор winavr 20100110

Device: atmega128

Program: 64760 bytes (49.4% Full)
(.text + .data + .bootloader)

Data: 3966 bytes (96.8% Full)
(.data + .bss + .noinit)

В программе есть структура

Код
struct {
  unsigned char State_Code_Num; //
  
  unsigned char hours; //
  unsigned char minutes; //
  unsigned char seconds; //

  unsigned char years; //
  unsigned char mounses;
  unsigned char days;
} State_System;


Во время работы программы переменная State_System.days чюдесным образом изменяется. Пересмотрел программу, видимых наложений не нашел. Запусти внутрисхемную отладку в студии. Поставил точку останова на адрес 0х107С это адрес выше указанной переменной. Когда программа остановилась в не понятном месте гляжу Syack Pointer 0х107B и в переменной соответ. левые данные.
Почему winavr не ругается на этапе компиляции и как выловить после чего происходит переполнение?
Не хотелось бы верить в глючность winavr и просто изза этого переходить на ИАР.

Заранее спасибо!

Go to the top of the page
 
+Quote Post
MrYuran
сообщение Apr 6 2011, 07:46
Сообщение #2


Беспросветный оптимист
******

Группа: Свой
Сообщений: 4 640
Регистрация: 26-12-07
Из: Н.Новгород
Пользователь №: 33 646



Цитата(LSerg @ Apr 6 2011, 11:35) *
Почему winavr не ругается на этапе компиляции и как выловить после чего происходит переполнение?
Не хотелось бы верить в глючность winavr и просто изза этого переходить на ИАР.

А как вы предлагаете это отлавливать на этапе компиляции?
Стек в GCC двигается навстречу данным, так что если они встретились - всё, аллес, надо урезать осетра.
Уменьшать уровень вложенности, инлайнить, следить за локальными переменными итд.
Для таких случаев есть профайлер.
Цитата
Data: 3966 bytes (96.8% Full)

Может, что-нибудь выкинуть можно?


--------------------
Программирование делится на системное и бессистемное. ©Моё :)
— а для кого-то БГ — это Bill Gilbert =)
Go to the top of the page
 
+Quote Post
klen
сообщение Apr 6 2011, 08:59
Сообщение #3


бессмертным стать можно тремя способами
*****

Группа: Свой
Сообщений: 1 405
Регистрация: 9-05-06
Из: Москва
Пользователь №: 16 912



ну допустим мы поймали момент что стек кончиля(в FreeRTOS это делается на уровне стека потока проверкой по маркру ) .... и что стого, если это произошдо то фисЁ, ложимся накрываемся белой простынкой и медленно чтоб не создавать паники вперед ногами ползем в сторну кладби.. ресета. если это произошло то лошадь пошла поперек еще до кода - причина то не вкоде а алгоритмах и входных данных - нада профилактика а не лечение.

система должна быть сдизайнена чтоб этого "небыло".
Go to the top of the page
 
+Quote Post
demiurg_spb
сообщение Apr 7 2011, 05:06
Сообщение #4


неотягощённый злом
******

Группа: Свой
Сообщений: 2 746
Регистрация: 31-01-08
Из: Санкт-Петербург
Пользователь №: 34 643



У Вас константные строки, массивы или структуры используются?
Они размещены во флеше?
hint:
PSTR
PROGMEM


--------------------
“Будьте внимательны к своим мыслям - они начало поступков” (Лао-Цзы)
Go to the top of the page
 
+Quote Post
SysRq
сообщение Apr 7 2011, 14:18
Сообщение #5


Чайник, 1 литр
****

Группа: Свой
Сообщений: 655
Регистрация: 17-05-06
Из: Moscow
Пользователь №: 17 168



Цитата(LSerg @ Apr 6 2011, 11:35) *
Пересмотрел программу, видимых наложений не нашел.
Прологи\эпилоги функций и прерываний посмотрите. Зло именно там.
Go to the top of the page
 
+Quote Post
sergeeff
сообщение Apr 7 2011, 15:43
Сообщение #6


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

Группа: Свой
Сообщений: 1 481
Регистрация: 10-04-05
Пользователь №: 4 007



Цитата(klen @ Apr 6 2011, 11:59) *
система должна быть сдизайнена чтоб этого "небыло".


Встречался я как-то с программой статического анализатора исходного кода с оценкой необходимого стека и прочего. Цена под 18 тыс. долларов. Так может дешевле голову включить?
Go to the top of the page
 
+Quote Post
LSerg
сообщение Apr 8 2011, 15:22
Сообщение #7


Участник
*

Группа: Участник
Сообщений: 41
Регистрация: 1-06-08
Пользователь №: 37 967



Спасибо, откликнувшимся.
На данной стадии решил, стрелять из пушки по воробьям (поставил mega1281)

Главную идею понял буду заматься программной оптимизацией кода!!!
Go to the top of the page
 
+Quote Post
sergeeff
сообщение Apr 8 2011, 15:30
Сообщение #8


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

Группа: Свой
Сообщений: 1 481
Регистрация: 10-04-05
Пользователь №: 4 007



Цитата(LSerg @ Apr 8 2011, 18:22) *
Спасибо, откликнувшимся.
Главную идею понял буду заматься программной оптимизацией кода!!!


Главную идею не понял. Не оптимизацией кода надо заняться, а оптимизацией используемого стека (т.е. локальных переменнных).
Go to the top of the page
 
+Quote Post

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

 


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


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