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

 
 
> Проблема с inline в EWAVR, Оптимизация Function inlining режет код
Makki
сообщение Sep 24 2013, 17:45
Сообщение #1


Участник
*

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



Такая ситуация: имеем несколько вложенных друг в друга функций: main( level1 (level2 ())), полная оптимизация по скорости.
При компиляции код функций уровня вложенности больше 2 просто исчезает (в дизассемблере смотрел), хоть просто возвращай переменную, хоть что угодно.
Выполняется main( level1 ()) без вызова level2 ()
Убил часа 4 на поиск причины. Пока не добрался до function inlining.
Отключил function inlining, все остальное так и оставил - помогло.

Кто-нибудь знает, что это такое было???

И таки да, у меня Kickstart на 4 кб.
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
aaarrr
сообщение Sep 25 2013, 12:23
Сообщение #2


Гуру
******

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



А как объявлен usart_count?
Go to the top of the page
 
+Quote Post
Makki
сообщение Sep 25 2013, 12:39
Сообщение #3


Участник
*

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



Как глобальная переменная (это видно по коду modbus_slave_routine()).
unsigned char usart_count=0;

А, я понял, к чему вы клоните.
Тогда, похоже, компилятор даже не предполагает, что в modbus_slave_routine() между
usart_count=0;
и
modbus_frame_check()
переменная usart_count может быть изменена прерыванием.

Но тогда при чем здесь Function inlining???
Go to the top of the page
 
+Quote Post
aaarrr
сообщение Sep 25 2013, 13:08
Сообщение #4


Гуру
******

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



Цитата(Makki @ Sep 25 2013, 16:39) *
Но тогда при чем здесь Function inlining???

Потому что после включения modbus_frame_check() в состав modbus_slave_routine() компилятор и обнаружил, что usart_count в modbus_frame_check() всегда равен нулю.
Go to the top of the page
 
+Quote Post
Makki
сообщение Sep 25 2013, 13:28
Сообщение #5


Участник
*

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



Всё, теперь мне все стало понятно. Жалко, что компилятор даже не думает о том, что глобальная переменная может быть изменена прерыванием...
Не, погодите, а как тогда семафоры передавать? И ждать их изменения? Тут что-то не так все равно.

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

?
Go to the top of the page
 
+Quote Post
aaarrr
сообщение Sep 25 2013, 13:47
Сообщение #6


Гуру
******

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



Цитата(Makki @ Sep 25 2013, 17:28) *
Жалко, что компилятор даже не думает о том, что глобальная переменная может быть изменена прерыванием...
Не, погодите, а как тогда семафоры передавать? И ждать их изменения? Тут что-то не так все равно.

Об этом должен думать программист. Ключевое слово volatile.
Go to the top of the page
 
+Quote Post
Makki
сообщение Sep 25 2013, 14:05
Сообщение #7


Участник
*

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



Ага. Все понял, как только в раздел Type qualifiers заглянул. Спасибо за наводку! Пошел читать руководство...
Go to the top of the page
 
+Quote Post



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

 


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


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