|
проблема со стеком в IAR |
|
|
|
Apr 23 2007, 14:41
|
Частый гость
 
Группа: Новичок
Сообщений: 75
Регистрация: 17-08-06
Из: Минск
Пользователь №: 19 630

|
Доброго всем дня ! Подскажите пожалуйста, что делаю не так. Имеется IAR 4.40A. На вкладке Options/ Linker/Config указываю в качестве Linker Command File свой файл, в котором инициализирую стек следующим образом :
//************************************************************************* // Stack and heap segments. //*************************************************************************
-D_CSTACK_SIZE=2000 // -D_SVC_STACK_SIZE=10 -D_IRQ_STACK_SIZE=100 -D_HEAP_SIZE=2000
-Z(DATA)CSTACK+_CSTACK_SIZE=RAMSTART-RAMEND // -Z(DATA)SVC_STACK+_SVC_STACK_SIZE=RAMSTART-RAMEND -Z(DATA)IRQ_STACK+_IRQ_STACK_SIZE,HEAP+_HEAP_SIZE=RAMSTART-RAMEND
При отладке с самых первых шагов выскакивает предупреждение:
Mon Apr 23 14:16:34 2007: The stack 'CSTACK' is filled to 97% (7964 bytes used out of 8192). The warning threshold is set to 90%.
Откуда на 'CSTACK' берется 8192 байта, если в файле указано 2000? И почему так быстро забивается стек? Возможно я чего-то не понимаю. Обьясните пожалуйста идиоту.....
Стал копаться в опция линкера, и на той же вкладке нашел Comand file configuration tools. В выскочившем окошке в качестве адресного диапазона INTERNAL ROM указан диапазон 8000-FFFFF, а в качестве диапазона INTERNAL RAM -100000-7FFFFF - это при том, что используется МК LPC2214 ( ROM - 00000000 - 0003FFFF, RAM - 3FFFFFFF-40003FFF ), хотя в качестве таблицы векторов указаны адреса 0x0 - 0x3f, что соответствует действительности... . На следующей вкладке этого окна в качестве HEEP SIZE указан объем 8000,а не 2000 , как в вышеупомянутом файле....
Возможно вопросы глупые, но все же обьясните пожалуйста, что используется для распределения памяти, и почему в Comand file configuration tools такое распределение адресов? Спасибо...
|
|
|
|
|
 |
Ответов
|
Aug 26 2007, 16:23
|
Местный
  
Группа: Участник*
Сообщений: 418
Регистрация: 20-08-07
Пользователь №: 29 930

|
Цитата(Sarez @ Apr 24 2007, 15:47)  to cf7k и IgorKossak : Да, действительно, Вы оказались правы. В main были размещены локальные буфера - работали на прием данных из стека Wiznet...
Большое всем спасибо! Добавлю свои три копейки: Для анализа размеров получившегося бинарника - вообще-то можно после линковки посмотреть в файл *.map - мне что-то подсказывает, что IAR его тоже делает... Наверное интуиция...
Сообщение отредактировал Николай Z - Aug 26 2007, 17:02
|
|
|
|
Сообщений в этой теме
Sarez проблема со стеком в IAR Apr 23 2007, 14:41 amw 0x2000 = 8192 (десятичное).
Может тут собака порыл... Apr 23 2007, 14:47 Sarez Пожалуй фраза про идиота и не такая уж и смешная..... Apr 23 2007, 15:15 scifi Действительно, линкер вомпринимает числа в опциях ... Apr 24 2007, 06:51 amw А еще, на сколько я помню, 0x2000 + 0x2000 равно о... Apr 24 2007, 09:49 cf7k Цитата(amw @ Apr 24 2007, 10:49) Может эт... Apr 24 2007, 10:10 IgorKossak Похоже, что инициализация указателя стека была нев... Apr 24 2007, 10:15 Panych Цитата(IgorKossak @ Apr 24 2007, 14:15) В... Aug 24 2007, 14:16  zltigo Цитата(Panych @ Aug 24 2007, 17:16) И что... Aug 24 2007, 14:38 _Sam_ потому что для линкёра вы всё значения в 16ричной ... Apr 24 2007, 11:18 Ден У меня наблюдалось странное переполнение R стека п... Aug 29 2007, 11:43
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|