the_spirit
Dec 7 2011, 15:24
Как заставить LPC2103 работать с массивами int размером 512,1024 точки?
При создании больше одного такого массива в main кристалл виснет.
Программируется в keil.
При просмотре дезассемблера выяснилось, что массив пихается в стек, можно ли как-то повлиять на то, как компилятор интерпретирует массивы? где об этом можно почитат.
kovigor
Dec 7 2011, 15:30
Цитата(the_spirit @ Dec 7 2011, 18:24)

Как заставить LPC2103 работать с массивами int размером 512,1024 точки?
При создании больше одного такого массива в main кристалл виснет.
Программируется в keil.
При просмотре дезассемблера выяснилось, что массив пихается в стек, можно ли как-то повлиять на то, как компилятор интерпретирует массивы? где об этом можно почитат.
Не было такого никогда. Там 32 КБайт ОЗУ. 1024 Int'а - это 4096 байт, всего-то. Посмотрите лучше .map - файл, там указано, куда и что поместил компилятор. Еще вариант - у вас стек слишком маленький, попробуйте его увеличить в Configuration Wizard ...
the_spirit
Dec 7 2011, 15:56
На стек первым делом подумал, увеличил значительно
Но не помогает
map файл прикреплен, можно убедиться
kovigor
Dec 7 2011, 16:02
Цитата(the_spirit @ Dec 7 2011, 19:56)

На стек первым делом подумал, увеличил значительно
Но не помогает
map файл прикреплен, можно убедиться
Просмотрел дважды. Массива на 512 (1024) 32-разрядных слов там нет. Он у вас динамический ?
the_spirit
Dec 7 2011, 16:03
объявлен как volatile
kovigor
Dec 7 2011, 16:09
Цитата(the_spirit @ Dec 7 2011, 20:03)

объявлен как volatile
Какая разница ? Под массив, статический, должна быть выделена память. А она не выделена. Например:
uint8_t EP0Buf[USB_MAX_PACKET0];
даст в map - файле строку:
EP0Buf 0x2000a0f8 Data 64 usbcore.o(.bss)
Есть у вас такая строка для вашего массива ? Нету ...
Или вы массив в обработчике прерывания объявили ?
the_spirit
Dec 7 2011, 16:25
у меня там ни под одну переменную нет такой строчки, возможно я ликер неверно настроил? или я чего-то не понимаю
Не массивы объявил в main
могу скинуть проект, если влезет и если у вас есть время поглядеть
kovigor
Dec 7 2011, 16:28
Цитата(the_spirit @ Dec 7 2011, 20:25)

у меня там ни под одну переменную нет такой строчки, возможно я ликер неверно настроил? или я чего-то не понимаю
Не массивы объявил в main
могу скинуть проект, если влезет и если у вас есть время поглядеть
скиньте, попробую глянуть
kovigor@yahoo.com
P.S. получил пустое письмо, без вложения
the_spirit
Dec 7 2011, 17:11
Пардон)
Переслал по-человечески
RabidRabbit
Dec 7 2011, 18:00
Цитата(the_spirit @ Dec 7 2011, 20:25)

Не массивы объявил в main
А в объявлении массивов есть слово static? Не то ведь точно в стеке окажутся
Цитата(RabidRabbit @ Dec 7 2011, 22:00)

А в объявлении массивов есть слово static? Не то ведь точно в стеке окажутся

Ничего, там стека 12кБайт выделено, если верить map'у. Так что продолжаем следить за развитием интриги.
Ivan Panov
Dec 7 2011, 19:29
Цитата(aaarrr @ Dec 7 2011, 20:06)

Ничего, там стека 12кБайт выделено, если верить map'у. Так что продолжаем следить за развитием интриги.
В заголовке указан микроконтроллер от NXP - LPC2103. У него 8kB ОЗУ и 32kB FLASH, а у вас в обсуждении присутствуют цифры 12kB под стек. Вы обсуждаете какой-то другой чип а я упустил нить обсуждения или у Вас новая ревизия чипа с памятью 32kB RAM?
RabidRabbit
Dec 8 2011, 05:58
Ага, а в мапе вообще написано:
Execution Region RW_IRAM1 (Base: 0x40000000, Size: 0x000030e8, Max: 0x00004000, ABSOLUTE)
Запихать 12 КиБ в область 16 Киб, которая на самом деле размером 8 КиБ, хороший прикол.
the_spirit
Dec 9 2011, 14:00
А, ясно, меня смутила эта строчка в даташите:
2 kB/4 kB/8 kB of on-chip static RAM and 8 kB/16 kB/32 kB of on-chip ßash program
memory.
То есть чтобы работать с большими массивами int на этом критсталле необходимо их размещать во flash памяти? каким образом можно указать на это компилятору?
нужен модификатор static?
Цитата(the_spirit @ Dec 9 2011, 18:00)

То есть чтобы работать с большими массивами int на этом критсталле необходимо их размещать во flash памяти? каким образом можно указать на это компилятору?
нужен модификатор static?
Ваш массив int[1024] занимает 4кБайта, так что должен помещаться в ОЗУ.
Чтобы поместить его во флеш нужен модификатор const и правильный .scat (он по умолчанию такой).
the_spirit
Dec 9 2011, 14:13
Понятно,но мне, к сожалению, нужно 3-4 таких массива.
Вы говорили, что без модификатора static массив пихается в стек, я вас правильно понял?
Можно чуть подробнее о scater файле, или ссылочку на что-нибудь, где можно об этом почитать
спасибо
Цитата(the_spirit @ Dec 9 2011, 18:13)

Вы говорили, что без модификатора static массив пихается в стек, я вас правильно понял?
Это не я говорил, да не важно. Если массив объявлен внутри процедуры, то без модификатора static он будет выделен на стеке.
Цитата(the_spirit @ Dec 9 2011, 18:13)

Можно чуть подробнее о scater файле, или ссылочку на что-нибудь, где можно об этом почитать
Все описано в хелпе на линкер. Но на данном этапе оно Вам не нужно.
the_spirit
Dec 10 2011, 12:15
Спасибо, убрал объявления массивов из main, помогло
впредь буду внимательнее читать описание компилятора
Спасибо за помощь
Для просмотра полной версии этой страницы, пожалуйста,
пройдите по ссылке.