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

 
 
> Непонятное поведение __delay_cycles
sevstels
сообщение Jan 27 2010, 04:10
Сообщение #1


Знающий
****

Группа: Участник
Сообщений: 626
Регистрация: 3-12-07
Пользователь №: 32 910



Столкнулся с очень странным поведением __delay_cycles.
Все прерывания запрещены, ничего лишенего не работает.
Но импульс с порта С имеет совершенно разные длительности, причём разница значительна:


//если батарея подключена - можно включить питание DC/DC 3.3v
if(SYSTEM.flag_BatteryPower)
{
PORTC |= (1<<DC3v3);
__delay_cycles(_1ms); //Вот тут задержка строго равна 1ms
PORTC &=~(1<<DC3v3);

if(CHECKBIT(PINF, CameraVolt)) SYSTEM.flag_CameraPower = true;
else
{

PORTC |= (1<<DC3v3);
__delay_cycles(_1ms); //А вот тут уже 20ms
PORTC &=~(1<<DC3v3);

}
}


--------------------
Herz - дятел.
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
sevstels
сообщение Jan 29 2010, 08:21
Сообщение #2


Знающий
****

Группа: Участник
Сообщений: 626
Регистрация: 3-12-07
Пользователь №: 32 910



Цитата
Лог оптимизации ? как вы его себе его представляете ?

Например так:

в блоке: (файл, строка ....)
//-------------------------
1: temp |= (1<<PIN);
2: __delay_cycles(_1ms);
3: temp &=~(1<<PIN);
4: __delay_cycles(_1ms);
5: temp |= (1<<PIN);
6: __delay_cycles(_1ms);
7: temp &=~(1<<PIN);
//--------------------------

оптимизация:
1: temp |= (1<<PIN);
2: delay: циклы
3: temp &=~(1<<PIN);

Разве плохо?
Иногда ввиду работы над большим проектом (или много людей), сложно сразу написать оптимальный код.
Например одна функция сбрасывает бит, а следующая его ставит. Сразу можно увидеть.
Это была бы неплохая подсказка при поиске разных непоняток.

-

Цитата
просто уметь читать листинги

Лучшее - враг хорошего.
С вашим талантом, да до сих пор все бы на асме писали. wink.gif

и пользовались zx-spectrum


--------------------
Herz - дятел.
Go to the top of the page
 
+Quote Post
zltigo
сообщение Jan 29 2010, 09:12
Сообщение #3


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(sevstels @ Jan 29 2010, 11:21) *
Разве плохо?

О господи, представления на уровне детского сада. Вы полагаете компилятор ТЕКСТЫ оптимизирует sad.gif.
Moderator:
Последнее предупреждение - пользуйтесь тэгами для форматирования исходных текстов.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post

Сообщений в этой теме
- sevstels   Непонятное поведение __delay_cycles   Jan 27 2010, 04:10
- - Сергей Борщ   Цитата(sevstels @ Jan 27 2010, 06:10) Все...   Jan 27 2010, 09:04
- - sevstels   Поздно уже смотреть. Вынес включение из встроенног...   Jan 27 2010, 11:21
- - MALLOY2   PORTC должен быть объявлен как volatile, иначе пол...   Jan 27 2010, 13:39
|- - IgorKossak   Цитата(MALLOY2 @ Jan 27 2010, 15:39) PORT...   Jan 28 2010, 07:32
- - sevstels   А вот интересно, компилятор ведёт лог оптимизаций?...   Jan 28 2010, 01:02
|- - demiurg_spb   Цитата(sevstels @ Jan 28 2010, 04:02) У м...   Jan 28 2010, 21:27
- - sevstels   Цитатапрограмму потребуется поздно или рано перепи...   Jan 29 2010, 00:52
|- - sonycman   Цитата(sevstels @ Jan 29 2010, 04:52) Вы ...   Jan 29 2010, 01:44
- - sevstels   Сразу всё "Правильно"?! Не думаю......   Jan 29 2010, 04:15
|- - _Pasha   Цитата(sevstels @ Jan 29 2010, 07:15) пож...   Jan 29 2010, 06:55
|- - zltigo   Цитата(sevstels @ Jan 29 2010, 07:15) Пли...   Jan 29 2010, 08:07
- - MALLOY2   ЦитатаВ заголовочных файлах дивайсов в IAR порты у...   Jan 29 2010, 06:38
- - MALLOY2   ЦитатаНапример так: Упасть и плакать ЦитатаЦита...   Jan 29 2010, 09:06
- - sevstels   ЦитатаЕсли вы не умете писать на ассемблере, брось...   Jan 29 2010, 09:48
|- - Сергей Борщ   Цитата(sevstels @ Jan 29 2010, 11:48) Ну ...   Jan 29 2010, 11:18
- - sevstels   ЦитатаОт незнания. Если бы знал - не спрашивал.Это...   Jan 29 2010, 15:09


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

 


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


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