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

 
 
2 страниц V   1 2 >  
Reply to this topicStart new topic
> LPC2103 работа с большими массивами int
the_spirit
сообщение Dec 7 2011, 15:24
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 42
Регистрация: 25-11-10
Из: Красногорск
Пользователь №: 61 170



Как заставить LPC2103 работать с массивами int размером 512,1024 точки?
При создании больше одного такого массива в main кристалл виснет.
Программируется в keil.
При просмотре дезассемблера выяснилось, что массив пихается в стек, можно ли как-то повлиять на то, как компилятор интерпретирует массивы? где об этом можно почитат.
Go to the top of the page
 
+Quote Post
kovigor
сообщение Dec 7 2011, 15:30
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 5 273
Регистрация: 30-03-10
Пользователь №: 56 295



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



Не было такого никогда. Там 32 КБайт ОЗУ. 1024 Int'а - это 4096 байт, всего-то. Посмотрите лучше .map - файл, там указано, куда и что поместил компилятор. Еще вариант - у вас стек слишком маленький, попробуйте его увеличить в Configuration Wizard ...
Go to the top of the page
 
+Quote Post
the_spirit
сообщение Dec 7 2011, 15:56
Сообщение #3


Участник
*

Группа: Участник
Сообщений: 42
Регистрация: 25-11-10
Из: Красногорск
Пользователь №: 61 170



На стек первым делом подумал, увеличил значительно
Но не помогает
map файл прикреплен, можно убедиться
Прикрепленные файлы
Прикрепленный файл  Furier_Arm.txt ( 51.38 килобайт ) Кол-во скачиваний: 684
 
Go to the top of the page
 
+Quote Post
kovigor
сообщение Dec 7 2011, 16:02
Сообщение #4


Гуру
******

Группа: Свой
Сообщений: 5 273
Регистрация: 30-03-10
Пользователь №: 56 295



Цитата(the_spirit @ Dec 7 2011, 19:56) *
На стек первым делом подумал, увеличил значительно
Но не помогает
map файл прикреплен, можно убедиться

Просмотрел дважды. Массива на 512 (1024) 32-разрядных слов там нет. Он у вас динамический ?
Go to the top of the page
 
+Quote Post
the_spirit
сообщение Dec 7 2011, 16:03
Сообщение #5


Участник
*

Группа: Участник
Сообщений: 42
Регистрация: 25-11-10
Из: Красногорск
Пользователь №: 61 170



объявлен как volatile
Go to the top of the page
 
+Quote Post
kovigor
сообщение Dec 7 2011, 16:09
Сообщение #6


Гуру
******

Группа: Свой
Сообщений: 5 273
Регистрация: 30-03-10
Пользователь №: 56 295



Цитата(the_spirit @ Dec 7 2011, 20:03) *
объявлен как volatile


Какая разница ? Под массив, статический, должна быть выделена память. А она не выделена. Например:

uint8_t EP0Buf[USB_MAX_PACKET0];

даст в map - файле строку:

EP0Buf 0x2000a0f8 Data 64 usbcore.o(.bss)

Есть у вас такая строка для вашего массива ? Нету ...

Или вы массив в обработчике прерывания объявили ? sm.gif
Go to the top of the page
 
+Quote Post
the_spirit
сообщение Dec 7 2011, 16:25
Сообщение #7


Участник
*

Группа: Участник
Сообщений: 42
Регистрация: 25-11-10
Из: Красногорск
Пользователь №: 61 170



у меня там ни под одну переменную нет такой строчки, возможно я ликер неверно настроил? или я чего-то не понимаю


Не массивы объявил в main
могу скинуть проект, если влезет и если у вас есть время поглядеть
Go to the top of the page
 
+Quote Post
kovigor
сообщение Dec 7 2011, 16:28
Сообщение #8


Гуру
******

Группа: Свой
Сообщений: 5 273
Регистрация: 30-03-10
Пользователь №: 56 295



Цитата(the_spirit @ Dec 7 2011, 20:25) *
у меня там ни под одну переменную нет такой строчки, возможно я ликер неверно настроил? или я чего-то не понимаю


Не массивы объявил в main
могу скинуть проект, если влезет и если у вас есть время поглядеть


скиньте, попробую глянуть

kovigor@yahoo.com

P.S. получил пустое письмо, без вложения
Go to the top of the page
 
+Quote Post
the_spirit
сообщение Dec 7 2011, 17:11
Сообщение #9


Участник
*

Группа: Участник
Сообщений: 42
Регистрация: 25-11-10
Из: Красногорск
Пользователь №: 61 170



Пардон)
Переслал по-человечески
Go to the top of the page
 
+Quote Post
RabidRabbit
сообщение Dec 7 2011, 18:00
Сообщение #10


Местный
***

Группа: Свой
Сообщений: 397
Регистрация: 3-12-09
Из: Россия, Москва
Пользователь №: 54 040



Цитата(the_spirit @ Dec 7 2011, 20:25) *
Не массивы объявил в main

А в объявлении массивов есть слово static? Не то ведь точно в стеке окажутся sm.gif
Go to the top of the page
 
+Quote Post
aaarrr
сообщение Dec 7 2011, 18:06
Сообщение #11


Гуру
******

Группа: Свой
Сообщений: 10 713
Регистрация: 11-12-04
Пользователь №: 1 448



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

Ничего, там стека 12кБайт выделено, если верить map'у. Так что продолжаем следить за развитием интриги.
Go to the top of the page
 
+Quote Post
Ivan Panov
сообщение Dec 7 2011, 19:29
Сообщение #12


Участник
*

Группа: Участник
Сообщений: 26
Регистрация: 23-02-09
Из: Одесская обл.
Пользователь №: 45 249



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


В заголовке указан микроконтроллер от NXP - LPC2103. У него 8kB ОЗУ и 32kB FLASH, а у вас в обсуждении присутствуют цифры 12kB под стек. Вы обсуждаете какой-то другой чип а я упустил нить обсуждения или у Вас новая ревизия чипа с памятью 32kB RAM?
Go to the top of the page
 
+Quote Post
RabidRabbit
сообщение Dec 8 2011, 05:58
Сообщение #13


Местный
***

Группа: Свой
Сообщений: 397
Регистрация: 3-12-09
Из: Россия, Москва
Пользователь №: 54 040



Ага, а в мапе вообще написано:
Execution Region RW_IRAM1 (Base: 0x40000000, Size: 0x000030e8, Max: 0x00004000, ABSOLUTE)
Запихать 12 КиБ в область 16 Киб, которая на самом деле размером 8 КиБ, хороший прикол.
Go to the top of the page
 
+Quote Post
the_spirit
сообщение Dec 9 2011, 14:00
Сообщение #14


Участник
*

Группа: Участник
Сообщений: 42
Регистрация: 25-11-10
Из: Красногорск
Пользователь №: 61 170



А, ясно, меня смутила эта строчка в даташите:
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?
Go to the top of the page
 
+Quote Post
aaarrr
сообщение Dec 9 2011, 14:04
Сообщение #15


Гуру
******

Группа: Свой
Сообщений: 10 713
Регистрация: 11-12-04
Пользователь №: 1 448



Цитата(the_spirit @ Dec 9 2011, 18:00) *
То есть чтобы работать с большими массивами int на этом критсталле необходимо их размещать во flash памяти? каким образом можно указать на это компилятору?
нужен модификатор static?

Ваш массив int[1024] занимает 4кБайта, так что должен помещаться в ОЗУ.
Чтобы поместить его во флеш нужен модификатор const и правильный .scat (он по умолчанию такой).
Go to the top of the page
 
+Quote Post

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

 


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


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