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

 
 
5 страниц V  « < 2 3 4 5 >  
Reply to this topicStart new topic
> void const *argument, Что это?
GetSmart
сообщение Jan 10 2014, 19:22
Сообщение #46


.
******

Группа: Участник
Сообщений: 4 005
Регистрация: 3-05-06
Из: Россия
Пользователь №: 16 753



Цитата(Tarbal @ Jan 9 2014, 08:47) *
В процессорах с Гарвардской архитектурой AVR, PIC, 8051 константы размещаются во флеше.
...
Для этого и используется слово const. Pic использует слово flash кажется, но это в микрочиповском компиляторе. С другими не работал не знаю.

Стандартный прототип memcpy:
void *memcpy(void *s1, const void *s2, size_t n);
копирует из ОЗУ в ОЗУ.

Цитата(Tarbal @ Jan 10 2014, 00:55) *
К сожалению давно не программирую на этих процессорах. У кого есть IAR AVR?

IAR AVR именно так и интерпретирует const. Как не меняющий адресное пространство.


--------------------
Заблуждаться - Ваше законное право :-)
Go to the top of the page
 
+Quote Post
Tarbal
сообщение Jan 10 2014, 22:35
Сообщение #47


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

Группа: Свой
Сообщений: 1 351
Регистрация: 21-05-10
Пользователь №: 57 439



Цитата(andrewlekar @ Jan 10 2014, 21:30) *
Может уже хватит переливать из пустого в порожнее? То народ указатель на структуру от самой структуры отличить не может, то указатель на массив от самого массива, то общее адресное пространство от раздельного.


Ничего не понял. Может попробуете еще раз выразить свою мысль?
Go to the top of the page
 
+Quote Post
andrewlekar
сообщение Jan 11 2014, 06:32
Сообщение #48


Знающий
****

Группа: Участник
Сообщений: 837
Регистрация: 8-02-07
Пользователь №: 25 163



Цитата
Ничего не понял. Может попробуете еще раз выразить свою мысль?


В вашем коде для AVR все переменные будут размещены в ОЗУ. Хотите их размещать во флэш - пишите __flash. У Viko константы были размещены во флэш потому что он пользовался компилятором для ARM.
Go to the top of the page
 
+Quote Post
Tarbal
сообщение Jan 11 2014, 18:22
Сообщение #49


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

Группа: Свой
Сообщений: 1 351
Регистрация: 21-05-10
Пользователь №: 57 439



Цитата(andrewlekar @ Jan 11 2014, 10:32) *
В вашем коде для AVR все переменные будут размещены в ОЗУ. Хотите их размещать во флэш - пишите __flash. У Viko константы были размещены во флэш потому что он пользовался компилятором для ARM.


Я вам не верю. Когда я в конце 90х работал с ним константы были размещены во флэш.
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Jan 11 2014, 19:33
Сообщение #50


Гуру
******

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



Цитата(Tarbal @ Jan 11 2014, 20:22) *
Я вам не верю.
Ваше право. Но убеждать остальных на основании только лишь вашей веры как-то неразумно.


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
Tarbal
сообщение Jan 13 2014, 12:28
Сообщение #51


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

Группа: Свой
Сообщений: 1 351
Регистрация: 21-05-10
Пользователь №: 57 439



Цитата(Сергей Борщ @ Jan 11 2014, 22:33) *
Ваше право. Но убеждать остальных на основании только лишь вашей веры как-то неразумно.


Напротив. Я не убеждаю никого. Меня убеждают на основе веры. Я высказал предположение и привел простую процедуру проверить его. Меня как раз начали убеждать, что неправильно предположил. Я сказал, что не верю на слово, а проверить сам не могу. Заставлять проверить моё предположение я естественно никого не могу. Хотел помочь, но если вам уже всё ясно, то откланиваюсь.

Сообщение отредактировал Tarbal - Jan 13 2014, 12:31
Go to the top of the page
 
+Quote Post
Tarbal
сообщение Jan 14 2014, 13:10
Сообщение #52


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

Группа: Свой
Сообщений: 1 351
Регистрация: 21-05-10
Пользователь №: 57 439



Вот документ.
На странице 5 есть информация о размещении констант в памяти.
http://netstorage.iar.com/SuppDB/Public/SU...memoryusage.pdf

Константы могут находиться в програмной памяти, оперативной памяти и внешней ЕПРОМ.

А здесь на странице 6 утверждают:
CONST Holds variables declared as const
.......
The CONST and CSTR should only be included in the XLINK file if there is an external
PROM in the system.

http://www.atmel.ca/Images/doc1079.pdf

Я уже не помню, а копаться лень. Для доступа ко внешней ЕПРОМ и для доступа ко внутренней ОЗУ используются одинаковые команды на ассемблере? Если разные, то это может объяснить многое в декларации функции с константным параметром.

Примечание: Я прекрасно знаю стандартное объяснение константного указателя как параметра функции, однако это всем известно. Разные способы адресации же это довольно неочевидное свойство.


Сообщение отредактировал Tarbal - Jan 14 2014, 13:38
Go to the top of the page
 
+Quote Post
demiurg_spb
сообщение Jan 14 2014, 15:42
Сообщение #53


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

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



Цитата(Tarbal @ Jan 14 2014, 17:10) *
Вот документ.
А теперь замените iar на avr-gcc...


--------------------
“Будьте внимательны к своим мыслям - они начало поступков” (Лао-Цзы)
Go to the top of the page
 
+Quote Post
Tarbal
сообщение Jan 14 2014, 16:09
Сообщение #54


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

Группа: Свой
Сообщений: 1 351
Регистрация: 21-05-10
Пользователь №: 57 439



Цитата(demiurg_spb @ Jan 14 2014, 19:42) *
А теперь замените iar на avr-gcc...


Простите, что вы имели ввиду?
Go to the top of the page
 
+Quote Post
demiurg_spb
сообщение Jan 14 2014, 16:34
Сообщение #55


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

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



Цитата(Tarbal @ Jan 14 2014, 20:09) *
Простите, что вы имели ввиду?
К тому что ваши ссылки, как собственно и измышления, исключительно для IAR. Но ведь есть и другие, более распространённые компиляторы, где const не гарантирует размещения данных в ПЗУ, что никак не противоречит стандарту. Об этом вам Сергей пытался намекнуть...


--------------------
“Будьте внимательны к своим мыслям - они начало поступков” (Лао-Цзы)
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Jan 14 2014, 18:09
Сообщение #56


Гуру
******

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



Цитата(Tarbal @ Jan 14 2014, 15:10) *
Вот документ.
Опустим тот факт, что это документ лохматого года, когда ИАР знал только 6 моделей AVR.
Цитата(Tarbal @ Jan 14 2014, 15:10) *
А здесь на странице 6 утверждают:CONST Holds variables declared as const
Ненаказуемо.
Цитата(Tarbal @ Jan 14 2014, 15:10) *
.......
The CONST and CSTR should only be included in the XLINK file if there is an external
PROM in the system.
Я уже не помню, а копаться лень. Для доступа ко внешней ЕПРОМ и для доступа ко внутренней ОЗУ используются одинаковые команды на ассемблере? Если разные, то это может объяснить многое в декларации функции с константным параметром.
Если повесите свою параллельную ПЗУ на внешнюю шину как память данных - команды будут одинаковые. Но опять же, это не компилятор положит во флеш, а вы запихнете ПЗУ в адресное пространство ОЗУ, этакое чесание левого уха правой ногой. Обе эти памяти будут находиться в одном адресном пространстве.

Обратите внимание на свой же документ:
Цитата
Table comments:
(*) Each combination of processor option and memory model has a default memory type, and also one or more additionally available memory types. All constant and variable data which are put into the segments CCSTR, ECSTR, CSTR, CONST and CSTACK are always implicitly belonging to the default memory type.


Также обратите внимание, что в этой таблице все константы, не имеющие спецификатора flash имеют сноску номер 2, которая гласит:
Цитата
The initialized information is copied from program to data memory at startup. This is done in the ?C_STARTUP function in CSTARTUP.S90. The application accesses the variable in the data space. The used program space is never accessed after startup is fulfilled


Дальше будете спорить?


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
Tarbal
сообщение Jan 14 2014, 18:46
Сообщение #57


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

Группа: Свой
Сообщений: 1 351
Регистрация: 21-05-10
Пользователь №: 57 439



Цитата(demiurg_spb @ Jan 14 2014, 20:34) *
К тому что ваши ссылки, как собственно и измышления, исключительно для IAR. Но ведь есть и другие, более распространённые компиляторы, где const не гарантирует размещения данных в ПЗУ, что никак не противоречит стандарту. Об этом вам Сергей пытался намекнуть...


Я допускаю, что вы невнимательно читали то что я писал. Опять же ваши замечания о GCC мимо кассы, поскольку стартовый постинг был про Кейл.
О стандарте: Сколько я знаю компиляторов, у каждого есть свои особенности.

Цитата(Сергей Борщ @ Jan 14 2014, 22:09) *
Если повесите свою параллельную ПЗУ на внешнюю шину как память данных - команды будут одинаковые. Но опять же, это не компилятор положит во флеш, а вы запихнете ПЗУ в адресное пространство ОЗУ, этакое чесание левого уха правой ногой. Обе эти памяти будут находиться в одном адресном пространстве.


Я это допускал, поэтому в предпоследнем постинге и написал:
"Я уже не помню, а копаться лень. Для доступа ко внешней ЕПРОМ и для доступа ко внутренней ОЗУ используются одинаковые команды на ассемблере? Если разные, то это может объяснить многое в декларации функции с константным параметром."

Цитата(Сергей Борщ @ Jan 14 2014, 22:09) *
Обратите внимание на свой же документ:
Table comments:
(*) Each combination of processor option and memory model has a default memory type, and also one or more additionally available memory types. All constant and variable data which are put into the segments CCSTR, ECSTR, CSTR, CONST and CSTACK are always implicitly belonging to the default memory type.

Мне это ничего не говорит в контексте нашей дискуссии.

Цитата(Сергей Борщ @ Jan 14 2014, 22:09) *
Дальше будете спорить?

Я не спорю, а ищу ответы.
Go to the top of the page
 
+Quote Post
andrewlekar
сообщение Jan 15 2014, 04:53
Сообщение #58


Знающий
****

Группа: Участник
Сообщений: 837
Регистрация: 8-02-07
Пользователь №: 25 163



Ну вот я собрал ваш код при помощи IAR AVR 5.3. Вот MAP файл:

Код
  FILE NAME : D:\projects\avr\just_test\Debug\Obj\main.r90
  PROGRAM MODULE, NAME : main

  SEGMENTS IN THE MODULE
  ======================
NEAR_I
  Relative segment, address: DATA 000000A0 - 000000A5 (0x6 bytes), align: 0
  Segment part 7.             Intra module refs:   main
           ENTRY                   ADDRESS         REF BY
           =====                   =======         ======
           str1                    000000A0
    -------------------------------------------------------------------------
NEAR_I
  Relative segment, address: DATA 000000A6 - 000000AB (0x6 bytes), align: 0
  Segment part 10.            Intra module refs:   main
           ENTRY                   ADDRESS         REF BY
           =====                   =======         ======
           str2                    000000A6
    -------------------------------------------------------------------------
NEAR_Z
  Relative segment, address: DATA 000000AC - 000000AD (0x2 bytes), align: 0
  Segment part 12.            Intra module refs:   main
           ENTRY                   ADDRESS         REF BY
           =====                   =======         ======
           ptr                     000000AC
    -------------------------------------------------------------------------
CODE
  Relative segment, address: CODE 00000054 - 000000A3 (0x50 bytes), align: 1
  Segment part 14.
           ENTRY                   ADDRESS         REF BY
           =====                   =======         ======
           main                    00000054        ?cstartup_call_main (?C_STARTUP)
               RSTACK = 00000000 ( 00000002 )
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Jan 15 2014, 07:37
Сообщение #59


Гуру
******

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



Цитата(Tarbal @ Jan 14 2014, 20:46) *
О стандарте: Сколько я знаю компиляторов, у каждого есть свои особенности.
Да, особенности есть. Но вам уже третью страницу объясняют, что к const это не относится. Требование стандарта к const одно - компилятор должен выдавать ошибку при попытке записи в такую переменную. Все. В остальном эта обычная переменная. Далее ход мыслей у всех компиляторописателей обычно одинаков: разместить переменные с похожими свойствами (обнуляемые, инициализируемые и т.д.) рядом, чтобы при старте (если нужно) подготовить каждую группу к работе одним махом в цикле. Отсюда группирование переменных в сегменты. Никаких требований на размещение во флеш/ОЗУ для const стандарт на компилятор не накладывает, но и не запрещает, если это не мешает выполнению остальных требований стандарта.
В случае разных адресных пространств (AVR) размещение констант в программной памяти (флеше) нарушает требование быть обычной переменной. Поэтому для размещения в других адресных пространствах (одно из которых - память кода) вводятся расширения - ключевые слова типа __flash, __eeprom, idata, xdata, far, huge и подобные. const совершенно перпендикулярен к этому.
Если же архитектура имеет только одно адресное пространство, то появляется возможность работать с константами прямо во флеш не нарушая требования стандарта без всяких дополнительных ключевых слов, сэкономив таким образом ОЗУ и немножко времени на копировании при старте. И тут уже все в руках программиста - использовать такую возможность или нет. const снова никоим образом на это не влияет. Я показывал, что изменением положения одной строки в скрипте линкера можно получить вариант с константами в ОЗУ и константами во флеше. Оба варианта будут работать. И оба не нарушают стандарт.

Цитата(Tarbal @ Jan 14 2014, 20:46) *
Мне это ничего не говорит в контексте нашей дискуссии.
default memory - ОЗУ. Содержимое всех указанных сегментов по умолчанию попадает в адресное прстранство ОЗУ. В том числе и сегмент CONST. Если это вам ни о чем не говорит - я не вижу смысла в дальнейшей дискуссии.


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
Tarbal
сообщение Jan 15 2014, 13:13
Сообщение #60


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

Группа: Свой
Сообщений: 1 351
Регистрация: 21-05-10
Пользователь №: 57 439



Цитата(andrewlekar @ Jan 15 2014, 08:53) *
Ну вот я собрал ваш код при помощи IAR AVR 5.3. Вот MAP файл:


Спасибо. Убедили. Практика критерий истины sm.gif


Цитата(Сергей Борщ @ Jan 15 2014, 11:37) *
default memory - ОЗУ.


И как это следует из вашей цитаты?
ОЗУ насколько мне известно называется ОЗУ, а не default memory.
Почему не написано ОЗУ если это одно и то же?
С какой стати множить понятия?

Сообщение отредактировал Tarbal - Jan 15 2014, 13:14
Go to the top of the page
 
+Quote Post

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

 


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


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