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

 
 
 
Reply to this topicStart new topic
> Эмуляция оптимизированного и не оптимизированного кода, AVRSTUDIO+AVRDRAGON+ATMEGA16
MiklPolikov
сообщение Aug 14 2010, 20:19
Сообщение #1


Гуру
******

Группа: Свой
Сообщений: 2 015
Регистрация: 23-01-07
Из: Москва
Пользователь №: 24 702



AVRSTUDIO + AVRDRAGON + ATMEGA16

Помогите понять вот какие вещи :

1)В опциях проекта можно выбрать оптимизацию кода. Если поставить максимальную оптимизацию, под отладкой происходит совсем не пойми что :
программа не останавливается на точках останова, во многих местах точки останова вообще не получается поставить,
программа не выходит из циклов for(i=0;j<128;i++) .
Без JTAG программа в МК работает как надо, я это вижу на осциллографе.
Совсем без оптимизации программа под отладкой выполняется нормально.

2)В любом случае под отладкой не работает АЦП . Выставляю бит ADSC в ADCSRA , он сразу же сбрасывается. В регистре результата всё время 0
Опять же без JTAG ацп работает нормально...
Прикрепленные файлы
Прикрепленный файл  Motor_Control.txt ( 8.46 килобайт ) Кол-во скачиваний: 97
 


--------------------
Если у Вас нет практического опыта в данной теме- не вступайте в дискуссию и не пишите никаких теоретических рассуждений! Заранее спасибо !
Go to the top of the page
 
+Quote Post
Savrik
сообщение Aug 14 2010, 20:27
Сообщение #2


наблюдаю..
***

Группа: Свой
Сообщений: 291
Регистрация: 11-12-06
Из: Украина
Пользователь №: 23 369



Раз Вы включили оптимизацию, почитайте о модификаторе volatile.

Кроме того, использовать глобальную переменную i для цикла не есть хорошо... Лучше для этого использовать локальные переменные
Go to the top of the page
 
+Quote Post
MiklPolikov
сообщение Aug 14 2010, 21:12
Сообщение #3


Гуру
******

Группа: Свой
Сообщений: 2 015
Регистрация: 23-01-07
Из: Москва
Пользователь №: 24 702



Цитата(Savrik @ Aug 15 2010, 00:27) *
Раз Вы включили оптимизацию, почитайте о модификаторе volatile.

Кроме того, использовать глобальную переменную i для цикла не есть хорошо... Лучше для этого использовать локальные переменные


Оптимизация отключил .
Почему же ацп под отладкой не работает ?

Под отладкой не выставляется бит ADSC в ADCSRA , почему ?


--------------------
Если у Вас нет практического опыта в данной теме- не вступайте в дискуссию и не пишите никаких теоретических рассуждений! Заранее спасибо !
Go to the top of the page
 
+Quote Post
Savrik
сообщение Aug 14 2010, 21:50
Сообщение #4


наблюдаю..
***

Группа: Свой
Сообщений: 291
Регистрация: 11-12-06
Из: Украина
Пользователь №: 23 369



В ADSC записуется единица для начала преобразования. После преобразования в ADSC будет ноль. У Вас как АЦП работает? от таймера?
Как без отладчика Вы знаете, что АЦП работает? Пишете в терминал?

Цитата
Оптимизация отключил .

Зачем так радикально?smile.gif Просто надо переписать правильно код и все, к примеру, переменная result , в которой, подозреваю, записуется значение АЦП в перывании, без volatile
Go to the top of the page
 
+Quote Post
MiklPolikov
сообщение Aug 14 2010, 22:11
Сообщение #5


Гуру
******

Группа: Свой
Сообщений: 2 015
Регистрация: 23-01-07
Из: Москва
Пользователь №: 24 702



Цитата(Savrik @ Aug 15 2010, 01:50) *
В ADSC записуется единица для начала преобразования. После преобразования в ADSC будет ноль. У Вас как АЦП работает? от таймера?
Как без отладчика Вы знаете, что АЦП работает? Пишете в терминал?



Ацп работает просто в цикле

while(1)
{
while ( (ADCSRA & (1<<ADSC))!=0 ) {}; //ждём когда закончится преобразование
result=ADCH;
ADCSRA|=(1<<ADSC);//запускаем преобразование

.............

}

То что ацп работает без отладки я знаю потому что МК выводит результат на порт , и я вижу что он правильный.

Мне не понятно, почему если выполнять программу под отладкой пошагово, ADCSRA|=(1<<ADSC); ни к чему не приводит, в ADCSRA ничего не записывается.








--------------------
Если у Вас нет практического опыта в данной теме- не вступайте в дискуссию и не пишите никаких теоретических рассуждений! Заранее спасибо !
Go to the top of the page
 
+Quote Post
DpInRock
сообщение Aug 15 2010, 13:05
Сообщение #6


Гуру
******

Группа: Участник
Сообщений: 2 254
Регистрация: 4-05-07
Из: Moscow
Пользователь №: 27 515



Цитата
for(i=0;j<128;i++)

Из такого цикла выходят только вперед ногами.


--------------------
On the road again (Canned Heat)
Go to the top of the page
 
+Quote Post
sigmaN
сообщение Aug 16 2010, 00:42
Сообщение #7


I WANT TO BELIEVE
******

Группа: Свой
Сообщений: 2 617
Регистрация: 9-03-08
Пользователь №: 35 751



Цитата
Из такого цикла выходят только вперед ногами.
Отличное выражение. Надо взять на вооружение ))


--------------------
The truth is out there...
Go to the top of the page
 
+Quote Post
MiklPolikov
сообщение Aug 16 2010, 06:36
Сообщение #8


Гуру
******

Группа: Свой
Сообщений: 2 015
Регистрация: 23-01-07
Из: Москва
Пользователь №: 24 702



Цитата(DpInRock @ Aug 15 2010, 17:05) *
Из такого цикла выходят только вперед ногами.


Я разумеется здесь ошибся, и в программе у меня цикл for(i=0:i<128;i++)

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

Установка оптимизации, которая называется -02 решает проблему. Скорость работы снижается на 15% , но зато всё работает так как должно.


--------------------
Если у Вас нет практического опыта в данной теме- не вступайте в дискуссию и не пишите никаких теоретических рассуждений! Заранее спасибо !
Go to the top of the page
 
+Quote Post
MrYuran
сообщение Aug 16 2010, 06:46
Сообщение #9


Беспросветный оптимист
******

Группа: Свой
Сообщений: 4 640
Регистрация: 26-12-07
Из: Н.Новгород
Пользователь №: 33 646



Цитата(MiklPolikov @ Aug 16 2010, 10:36) *
С максимальной оптимизацией действительно всё глючит. Во многих случаях компилятор решает, что переменная " не нужна" , видимо как в этом цикле, и выбрасывает действия с ней.

volatile, однозначно!
Если выкидывает константы, которые вы, например, хотели уложить в флешь или еепром, есть например, в GCC аттрибут used, а в ИАРе - специальная прагма.


--------------------
Программирование делится на системное и бессистемное. ©Моё :)
— а для кого-то БГ — это Bill Gilbert =)
Go to the top of the page
 
+Quote Post
MiklPolikov
сообщение Aug 16 2010, 07:11
Сообщение #10


Гуру
******

Группа: Свой
Сообщений: 2 015
Регистрация: 23-01-07
Из: Москва
Пользователь №: 24 702



Цитата(MrYuran @ Aug 16 2010, 10:46) *
volatile, однозначно!
Если выкидывает константы, которые вы, например, хотели уложить в флешь или еепром, есть например, в GCC аттрибут used, а в ИАРе - специальная прагма.


В том то и дело что у меня нет ничего такого, и volatile ни как не помогает.
Грустить по поводу оптимизации -02 вместо -03 , с которой работало бы на 15% быстрее не стоит : Эти лишние 15% берутся от того что программа делает не всё что должна : )


--------------------
Если у Вас нет практического опыта в данной теме- не вступайте в дискуссию и не пишите никаких теоретических рассуждений! Заранее спасибо !
Go to the top of the page
 
+Quote Post
sigmaN
сообщение Aug 18 2010, 20:17
Сообщение #11


I WANT TO BELIEVE
******

Группа: Свой
Сообщений: 2 617
Регистрация: 9-03-08
Пользователь №: 35 751



Нормально написанная программа не начинает глючить после включения оптимизации.
Ну, в 99% случаев. Исключения, конечно, бывают. Но нарваться на глюк оптимизатора всё таки достаточно сложно.
На много проще самому натупить, а потом обвинять компилятор.
И volatile нужен только там, где действительно нужен.
Если компилятор выбрасывает i - это абсолютно нормально. Объявить i как volatile конечно же можно. И вы даже сможете прошагать по циклу отладчиком, но скорость просесть может конкретно.


--------------------
The truth is out there...
Go to the top of the page
 
+Quote Post
XVR
сообщение Aug 19 2010, 06:38
Сообщение #12


Гуру
******

Группа: Свой
Сообщений: 3 123
Регистрация: 7-04-07
Из: Химки
Пользователь №: 26 847



Цитата
С максимальной оптимизацией действительно всё глючит. Во многих случаях компилятор решает, что переменная " не нужна" , видимо как в этом цикле, и выбрасывает действия с ней.
И он прав (компилятор). Все присваивания нулей в DATA_init компилятор имеет право выбросить (все глобальные не инициализированные переменные прописываются 0 при старте программы, и до единственного вызова DATA_init не меняются). Так что и циклы пропадут, вместе с переменными i и j
Go to the top of the page
 
+Quote Post
AlterPferd
сообщение Aug 19 2010, 07:31
Сообщение #13





Группа: Новичок
Сообщений: 3
Регистрация: 30-08-06
Пользователь №: 19 941



Цитата(MiklPolikov @ Aug 16 2010, 10:36) *
Я разумеется здесь ошибся, и в программе у меня цикл for(i=0:i<128;i++)

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

Установка оптимизации, которая называется -02 решает проблему. Скорость работы снижается на 15% , но зато всё работает так как должно.


Голубчик, (unsigned char i;) ВСЕГДА меньше 128
Go to the top of the page
 
+Quote Post
XVR
сообщение Aug 19 2010, 08:01
Сообщение #14


Гуру
******

Группа: Свой
Сообщений: 3 123
Регистрация: 7-04-07
Из: Химки
Пользователь №: 26 847



Цитата(AlterPferd @ Aug 19 2010, 11:31) *
Голубчик, (unsigned char i;) ВСЕГДА меньше 128
Не всегда. Всегда она меньше 256

Go to the top of the page
 
+Quote Post

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

 


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


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