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

 
 
> Непонятный эффект компилятора (линкера?)
Вячик13
сообщение Jul 30 2015, 05:24
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 71
Регистрация: 17-01-12
Пользователь №: 69 604



Имеется IAR 6.50 для ARM. Проект выполнен для STM32F103VCT6 с использованием scmRTOS V4.00.

В тексте программы имеется объявление константной структуры с инициализацией:
Код
typedef struct {
  char *Name;                             //Отображаемое имя пункта меню
  unsigned char Type;                     //Тип отображения величины пункта меню
  float *Value;                           //Ссылка на величину пункта меню
  unsigned char Precision;                //Точность для чисел с плавающей запятой
  unsigned char Flags;                    //Флаги пункта меню
  unsigned char Access;                   //Уровень доступа к пункту меню
  float MinValue;                         //Минимально допустимая величина
  float MaxValue;                         //Максимально допустимая величина
  float DefaultValue;                     //Величина по умолчанию
  unsigned short UpMenuItem;              //Индекс пункта меню вверх
  unsigned short DownMenuItem;            //Индекс пункта меню вниз
  unsigned short LeftMenuItem;            //Индекс пункта меню влево
  unsigned short RightMenuItem;           //Индекс пункта меню вправо
  TMenuVariable *MenuVar;                 //Указатель на переменные величины меню
  void (*ShowSubroutine)(void *ItemPtr);  //Указатель на программу, которая выполняется при отображении величины (передаётся указатель на пункт меню)
  void (*EditSubroutine)(void *ItemPtr,float NewValue);  //Указатель на программу, которая выполняется при изменении величины (передаётся указатель на пункт меню)
  unsigned char ValueLength;              //Количество позиций, отведённое на величину пункта меню
  unsigned short Index;                   //Индекс пункта внутри меню
} TMenuItem;


const TMenuItem TestMenuItems[] = {
/* Name - Type - Value - Precis - Flags - Access - MinValue - MaxValue - DefValuePtr - UpItem - DownItem - LeftItem - RightItem - Var - ShowSubrout - EditSubrout - ValueLength - GroupItem */

  {"АЦП",mt_WithoutValue,NULL,0,0,al_Operator,0.0,0.0,0.0,NULL,2,428,66,&MenuTestVariable[0],NULL,NULL,0,1}, //Пункт меню "АЦП"
    {"АЦП 1",mt_FloatValue,&ADCChannels[0].Value,3,0,al_Operator,0.0,0.0,0.0,1,NULL,65,3,&MenuTestVariable[1],NULL,NULL,6,2}, //Канал АЦП 1
    {"АЦП 2",mt_FloatValue,&ADCChannels[1].Value,3,0,al_Operator,0.0,0.0,0.0,1,NULL,2,4,&MenuTestVariable[2],NULL,NULL,6,3}, //Канал АЦП 2

...

    {"АЦП 64",mt_FloatValue,&ADCChannels[63].Value,3,0,al_Operator,0.0,0.0,0.0,1,NULL,64,2,&MenuTestVariable[64],NULL,NULL,6,65}, //Канал АЦП 64
};

Оптимизация отключена. Компилируется без ошибок.
В файле *.map упоминание об этой структуре отсутствует.

Но это только часть таблицы. Добавляю остальное. Опять компилирую.
Появляется в файле *.map, но ложится а область ОЗУ (длина таблицы 0x5890 байт).

Пытаюсь поставить перед объявлением и инициализацией прагму:

#pragma location=0x08000800

Теперь ложится в память согласно прагме, но после загрузки при попытке выполнения "улетает".

Что делать и кто виноват?

Сообщение отредактировал Herz - Jul 30 2015, 09:43
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
Сергей Борщ
сообщение Jul 30 2015, 08:05
Сообщение #2


Гуру
******

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



Цитата(Вячик13 @ Jul 30 2015, 08:24) *
Появляется в файле *.map, но ложится а область ОЗУ (длина таблицы 0x5890 байт)
Ненаказуемо. Совсем. По стандарту const только заставляет компилятор запрещать запись в такую переменную. Вы просите переменную - она есть. Попробуйте в нее записать - получите по рукам. Все остальные оптимизации вы запретили компилятору лично. На что же вы обижаетесь? Включите оптимизацию и отлаживайте конечный код, zltigo вам совершенно правильно пишет. Он только не прав по поводу причин, заставляющих размещать константы в ОЗУ. По этому поводу вы его не слушайте, вы сюда слушайте, причины я описал выше. Включите оптимизацию - получите ваш массив во флеше.


--------------------
На любой вопрос даю любой ответ
"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
Вячик13
сообщение Jul 30 2015, 09:37
Сообщение #3


Участник
*

Группа: Участник
Сообщений: 71
Регистрация: 17-01-12
Пользователь №: 69 604



Цитата(Сергей Борщ @ Jul 30 2015, 11:05) *
Ненаказуемо. Совсем. По стандарту const только заставляет компилятор запрещать запись в такую переменную. Вы просите переменную - она есть. Попробуйте в нее записать - получите по рукам. Все остальные оптимизации вы запретили компилятору лично. На что же вы обижаетесь? Включите оптимизацию и отлаживайте конечный код, zltigo вам совершенно правильно пишет. Он только не прав по поводу причин, заставляющих размещать константы в ОЗУ. По этому поводу вы его не слушайте, вы сюда слушайте, причины я описал выше. Включите оптимизацию - получите ваш массив во флеше.


Включил оптимизацию (пробовал и средний уровень и высокий). Не помогло.

Цитата(shreck @ Jul 30 2015, 12:21) *
Не-а. Вот так:
char const* const Name;
Хотя нет. Можно и без второго const.

Сдается мне, что проблема в указателях на функцию. Скорее всего реализации функций в другом файле или ниже по тексту. Соответственно компилятор на момент заполнения структуры не знает их адреса.


Так я же объявил их равными NULL.
Go to the top of the page
 
+Quote Post
shreck
сообщение Jul 30 2015, 09:44
Сообщение #4


Местный
***

Группа: Свой
Сообщений: 327
Регистрация: 24-06-06
Из: Томск
Пользователь №: 18 328



Цитата(Вячик13 @ Jul 30 2015, 15:37) *
Так я же объявил их равными NULL.


А ADCChannels, MenuTestVariable определены в этом же файле?
Go to the top of the page
 
+Quote Post
Вячик13
сообщение Jul 30 2015, 10:23
Сообщение #5


Участник
*

Группа: Участник
Сообщений: 71
Регистрация: 17-01-12
Пользователь №: 69 604



Цитата(shreck @ Jul 30 2015, 12:44) *
А ADCChannels, MenuTestVariable определены в этом же файле?


MenuTestVariable в том же файле прямо перед таблицей, а ADCChannels в main.cpp, но по команде оболочки "Go to Definition" переходит к определению правильно.
Go to the top of the page
 
+Quote Post
shreck
сообщение Jul 30 2015, 10:32
Сообщение #6


Местный
***

Группа: Свой
Сообщений: 327
Регистрация: 24-06-06
Из: Томск
Пользователь №: 18 328



Цитата(Вячик13 @ Jul 30 2015, 16:23) *
... а ADCChannels в main.cpp, но по команде оболочки "Go to Definition" переходит к определению правильно.

Ну вот и ответ на вопрос почему не во флешь, а в ОЗУ находится объект. А возможности навигации по коду у редактора здесь вообще не причем.
Go to the top of the page
 
+Quote Post
Вячик13
сообщение Jul 30 2015, 10:52
Сообщение #7


Участник
*

Группа: Участник
Сообщений: 71
Регистрация: 17-01-12
Пользователь №: 69 604



Цитата(shreck @ Jul 30 2015, 13:32) *
Ну вот и ответ на вопрос почему не во флешь, а в ОЗУ находится объект. А возможности навигации по коду у редактора здесь вообще не причем.


Перенёс и ADCChannels в тот же файл - не помогло.
Go to the top of the page
 
+Quote Post

Сообщений в этой теме
- Вячик13   Непонятный эффект компилятора (линкера?)   Jul 30 2015, 05:24
- - zltigo   QUOTE (Вячик13 @ Jul 30 2015, 08:24) Опти...   Jul 30 2015, 06:17
|- - Вячик13   Ну хорошо, "структура не может быть проинициа...   Jul 30 2015, 06:38
|- - zltigo   QUOTE (Вячик13 @ Jul 30 2015, 09:38) Каки...   Jul 30 2015, 06:45
|- - zltigo   QUOTE (Сергей Борщ @ Jul 30 2015, 11:05) ...   Jul 30 2015, 08:30
|- - zltigo   QUOTE (shreck @ Jul 30 2015, 12:44) А ADC...   Jul 30 2015, 11:44
|- - shreck   Цитата(zltigo @ Jul 30 2015, 17:44) По ба...   Jul 31 2015, 02:44
- - AHTOXA   Я бы в первую очередь заменил char *Name; ...   Jul 30 2015, 08:40
|- - shreck   Цитата(AHTOXA @ Jul 30 2015, 14:40) Я бы ...   Jul 30 2015, 09:21
- - shreck   Значит есть что-то еще, о чем не знает компилятор ...   Jul 30 2015, 10:58
|- - Вячик13   Цитата(shreck @ Jul 30 2015, 13:58) Значи...   Jul 30 2015, 11:19
|- - megajohn   Цитата(Вячик13 @ Jul 30 2015, 14:19) Поня...   Jul 30 2015, 11:27
- - jcxz   Цитата(Вячик13 @ Jul 30 2015, 11:24) В фа...   Jul 31 2015, 02:23
- - Вячик13   Ура! Нашёл причину. В структуре должны быть т...   Jul 31 2015, 05:12


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

 


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


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