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

 
 
 
Reply to this topicStart new topic
> IAR сходит с ума на High оптимизации
Jenya7
сообщение Aug 10 2017, 13:38
Сообщение #1


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

Группа: Участник
Сообщений: 1 778
Регистрация: 29-03-12
Пользователь №: 71 075



функция
Код
void AT25_Write(uint32_t address, uint8_t *data, uint32_t lenght);

на любой оптимизации кроме High
Код
uint32_t addr = 128;
AT25_Write(addr, at45_data_tx, 200);

останавливаю брекпойнт в функции - address = 128 - все честно
на оптимизации High - address = 536889328 - они не охренели там случайно?
Go to the top of the page
 
+Quote Post
Непомнящий Евген...
сообщение Aug 10 2017, 13:43
Сообщение #2


Знающий
****

Группа: Свой
Сообщений: 771
Регистрация: 16-07-07
Из: Волгодонск
Пользователь №: 29 153



Отладчик не всегда показывает правильные значения локальных переменных. Можете так попробовать

Код
volatile uint32_t g_address;
void AT25_Write(uint32_t address, uint8_t *data, uint32_t lenght) {
  g_address = address; // и дальше смотрите адрес в g_address
//...
}
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Aug 10 2017, 13:45
Сообщение #3


Гуру
******

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



QUOTE (Jenya7 @ Aug 10 2017, 16:38) *
на оптимизации High - address = 536889328 - они не охренели там случайно?
Может на high-оптимизации он находится в регистре или уже в другом регистре, а на выделенном ему месте в стеке или в первоначальном регистре уже давно другие данные. Шагайте в окне дизассемблера и внимательно следите за путешествием address. Сколько я себя помню - "они охреневали" всего два раза и это было на довольно ранних версиях компилятора под конкретную платформу.


--------------------
На любой вопрос даю любой ответ
"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
Jenya7
сообщение Aug 10 2017, 13:50
Сообщение #4


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

Группа: Участник
Сообщений: 1 778
Регистрация: 29-03-12
Пользователь №: 71 075



Цитата(Непомнящий Евгений @ Aug 10 2017, 19:43) *
Отладчик не всегда показывает правильные значения локальных переменных. Можете так попробовать

Код
volatile uint32_t g_address;
void AT25_Write(uint32_t address, uint8_t *data, uint32_t lenght) {
  g_address = address; // и дальше смотрите адрес в g_address
//...
}

о спасибо. так работает. проблема в том что функция не работала. адрес вычислялся неправильно.
Go to the top of the page
 
+Quote Post
scifi
сообщение Aug 10 2017, 19:44
Сообщение #5


Гуру
******

Группа: Свой
Сообщений: 3 020
Регистрация: 7-02-07
Пользователь №: 25 136



Яры разные бывают. Например, яр для Coldfire точно генерит неправильный код даже на низком уровне оптимизации.
А вообще на высоком уровне оптимизации трудно отличить свою ошибку от глюка компилятора (второе случается гораздо реже, конечно). В результате оптимизации код вывернут наизнанку, отладчик едва ли показывает что-то вменяемое. Нужно копаться в дизассемблере и соотносить с исходным кодом, а для нетривиальных алгоритмов это адский труд.
Go to the top of the page
 
+Quote Post
Непомнящий Евген...
сообщение Aug 11 2017, 06:18
Сообщение #6


Знающий
****

Группа: Свой
Сообщений: 771
Регистрация: 16-07-07
Из: Волгодонск
Пользователь №: 29 153



Цитата(Jenya7 @ Aug 10 2017, 16:50) *
о спасибо. так работает. проблема в том что функция не работала. адрес вычислялся неправильно.


А вот это странно и тут я бы разобрался. Конечно может быть косяк компилятора, но более вероятно что вы где-то заходите в зону UB (неопределенного поведения).

Скажем обращение по нулевому указателю запрещено

Код
void f(char *addr) {
  if (addr)  // этот if на высокой оптимизации будет выкинут, так как
    doSomething();

  *addr = '1'; // эта строка говорит компилятору, что addr точно не 0
}
Go to the top of the page
 
+Quote Post

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

 


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


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