|
|
  |
Помогите разобраться |
|
|
|
Dec 22 2008, 11:26
|
Участник

Группа: Участник
Сообщений: 40
Регистрация: 22-12-08
Пользователь №: 42 664

|
Доброго времени суток, всем! Взялся разбираться с AVR на AVRStudio. Проблема такая. Необходимо матрицу 800 элементов (контстанты) объявить в памяти программ, чтобы они не занимали места в ОЗУ! Все перепробовал - бесполезно. После компиляции все 800 штук указаны в DATA. Объявляю как const - тоже самое!!! Хотя в книгах пишут, что если объявлено как const, то должны храниться в памяти программ. Что делать?
|
|
|
|
|
Dec 22 2008, 11:46
|

Гуру
     
Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095

|
AVRStudio - оболочка/симулятор. В комплекте с ней идет ассемблер AVRasm (AVRasm2). Упоминание компиляции наталкивает на мысль, что в качестве компилятора вы используете avr-gcc (WinAVR). Цитата(LoLo @ Dec 22 2008, 13:26)  Хотя в книгах пишут, что если объявлено как const, то должны храниться в памяти программ. Выкинуть такие книги. const означает, что компилятор не позволит изменить это, т.е. данные с атрибутом const являются read-only. Куда размещать такие данные - отдано на усмотрение компилятору. Цитата(LoLo @ Dec 22 2008, 13:26)  Что делать? Как всегда - читать документацию. Начать с Winavr/doc/avr-libc/faq.html. Читать от начала до конца, обратить внимание на атрибут PROGMEM.
--------------------
На любой вопрос даю любой ответ"Write code that is guaranteed to work, not code that doesn’t seem to break" ( C++ FAQ)
|
|
|
|
|
Dec 22 2008, 11:56
|

Профессионал
    
Группа: Свой
Сообщений: 1 001
Регистрация: 27-06-06
Пользователь №: 18 409

|
Цитата(LoLo @ Dec 22 2008, 15:26)  Доброго времени суток, всем! Взялся разбираться с AVR на AVRStudio. Проблема такая. Необходимо матрицу 800 элементов (контстанты) объявить в памяти программ, чтобы они не занимали места в ОЗУ! Все перепробовал - бесполезно. После компиляции все 800 штук указаны в DATA. Объявляю как const - тоже самое!!! Хотя в книгах пишут, что если объявлено как const, то должны храниться в памяти программ. Что делать? Давно писал на ассемблере но кажется надо делать так: .CSEG loop: .DB 10, 151, 898 p.s. сорри не дочитал до конца и подумал что речь идёт об ассемблере в С нужно использовать ключевое слово: __flash char var[800] // для iar flash char var[800] //для cvavr для других компиляторов не знаю
Сообщение отредактировал mempfis_ - Dec 22 2008, 12:00
|
|
|
|
|
Dec 22 2008, 12:01
|

Профессионал
    
Группа: Участник
Сообщений: 1 091
Регистрация: 25-07-07
Из: Саратов
Пользователь №: 29 357

|
Цитата(Сергей Борщ @ Dec 22 2008, 14:46)  Выкинуть такие книги. Ну, это уж слишком. Правильно там написано, и хороший компилятор мог бы догодаться, что const нужно помещать в памяти программ. Но gcc - универсальный компилятор, т.е. предназначем для работы на платформах, где нет программной памяти, поэтому приходится пользоваться не только такими извращениями как PROGMEM, но и pgm_read_word_near и т.п., вместо того чтобы просто разыменовывать указатель, а компилятор по его типу догадывался бы, в какую память обращаться.
|
|
|
|
|
Dec 22 2008, 12:24
|
Участник

Группа: Участник
Сообщений: 40
Регистрация: 22-12-08
Пользователь №: 42 664

|
Цитата(Сергей Борщ @ Dec 22 2008, 14:46)  AVRStudio - оболочка/симулятор. В комплекте с ней идет ассемблер AVRasm (AVRasm2). Упоминание компиляции наталкивает на мысль, что в качестве компилятора вы используете avr-gcc (WinAVR).Выкинуть такие книги. const означает, что компилятор не позволит изменить это, т.е. данные с атрибутом const являются read-only. Куда размещать такие данные - отдано на усмотрение компилятору. Как всегда - читать документацию. Начать с Winavr/doc/avr-libc/faq.html. Читать от начала до конца, обратить внимание на атрибут PROGMEM. Спасибо. Память данных уменьшилась. Но появились warning: initialization makes pointer from integer without a cast. Очень много... Цитата(mempfis_ @ Dec 22 2008, 14:56)  Давно писал на ассемблере но кажется надо делать так: .CSEG loop: .DB 10, 151, 898 p.s. сорри не дочитал до конца и подумал что речь идёт об ассемблере в С нужно использовать ключевое слово: __flash char var[800] // для iar flash char var[800] //для cvavr для других компиляторов не знаю  Надо для WinAVR
|
|
|
|
|
Dec 22 2008, 13:04
|
Участник

Группа: Участник
Сообщений: 15
Регистрация: 11-09-05
Из: Московская обл.
Пользователь №: 8 448

|
Цитата(LoLo @ Dec 22 2008, 16:24)  Спасибо. Память данных уменьшилась. Но появились warning: initialization makes pointer from integer without a cast. Очень много... Надо для WinAVR В WinAVR попробуйте сделать примерно так: uint8_t Data[800]PROGMEM = {0x81, 0x42, 0x24, 0x18, ....};
|
|
|
|
|
Dec 22 2008, 13:40
|

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

|
Цитата(777777 @ Dec 22 2008, 15:01)  Ну, это уж слишком. Правильно там написано, и хороший компилятор мог бы догодаться, что const нужно помещать в памяти программ. Но gcc - универсальный компилятор, т.е. предназначем для работы на платформах, где нет программной памяти, поэтому приходится пользоваться не только такими извращениями как PROGMEM, но и pgm_read_word_near и т.п., вместо того чтобы просто разыменовывать указатель, а компилятор по его типу догадывался бы, в какую память обращаться. Любой стандартный компилятор C создаёт код из предположения что у нас одно адресное пространство (Архитектура фон Неймана), ну а если это не так (у AVR гарвардская архитектура + ещё eeprom) приходится так или иначе указывать в какой памяти располагать те или иные данные. И это не извращения, а необходимость. А платформ где нет программной памяти не существует, т.к. программа есть всегда и она гдето располагается пусть даже в виде отверстий в перфокарте
--------------------
“Будьте внимательны к своим мыслям - они начало поступков” (Лао-Цзы)
|
|
|
|
|
  |
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|