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

 
 
> Формирование задержки
aspID
сообщение Sep 11 2007, 10:47
Сообщение #1


Местный
***

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



На данном этапе некритично, но интересно, как можно формировать задержки длительностью в единицы мкс.

На данный момент используется:
Код
#define _delay_us(x) __delay_cycles(x*F_CPU/1000000)


на частоте
Код
#define F_CPU 3686400UL
просто исполняю следующий код и смотрю за сигналом
Код
  DDRD |= (1 << PD6);
  while (1)
  {
    PORTD |= ( 1 << PD6 );
    _delay_us(5);
    PORTD &= ~( 1 << PD6 );
    _delay_us(1);
  }

на уровне десятков мкс работает нормально, 5 мкс растягиваются до 5,4 мкс а 1 мкс - до 1,85 мкс

Если работать через прерывания таймера - думается мне, обработка не даст большей выгоды. Или я не прав? Как вариант, конечно, увеличивать частоту кварца...
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
aspID
сообщение Sep 11 2007, 16:36
Сообщение #2


Местный
***

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



Цитата
Мораль - измерение малых величин некорректно

Хотите сказать, что наны вообще нереально использовать? Или кварца в 3,6864МГц для микросекунд мало??

Цитата
Прерывание при малых задержках бред.

Это все-таки к чему? К тому, что следует перейти на таймер или все же оставаться на макросе?

Просто с конкретным случаем - "использование макроса" я проверил работу, а со случаем "использование таймера" не заморачивался. Наверняка не я первый, не я последний задался этим вопросом...
Go to the top of the page
 
+Quote Post



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

 


RSS Текстовая версия Сейчас: 23rd July 2025 - 01:07
Рейтинг@Mail.ru


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