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

 
 
> Вопрос начинающего по PLL, Детали программирования AT91SAM7S32
Genadi Zawidowsk...
сообщение Mar 25 2009, 10:18
Сообщение #1


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

Группа: Участник
Сообщений: 1 620
Регистрация: 22-06-07
Из: Санкт-Петербург, Россия
Пользователь №: 28 634



Начал я использовать AT91SAM7S32 - получил, при исполнении программы "ножкодрыгательства" из SRAM при тактовой частоте 48 МГц минимальное время между переключениями состояния вывода около 53 наносекунд.

Нормально ли это?

дело в том, что не смотря на упоминание в даташите того факта, что умножитель PLL записанный в соответствующий регистор используется увеличенный на единицу, 90% всех увиденных мною примеров в Интернете игнорируют это. Соответственно, у меня вопрос - кто-нибудь проверял, как оно на самом деле?

Проект (использовал yagarto, слегка доработал crt.s и скрипты линкера для поддержки ramfunc и инициализированных переменных) в аттачменте.
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
aaarrr
сообщение Mar 25 2009, 21:26
Сообщение #2


Гуру
******

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



Цитата(Genadi Zawidowski @ Mar 25 2009, 13:18) *
Начал я использовать AT91SAM7S32 - получил, при исполнении программы "ножкодрыгательства" из SRAM при тактовой частоте 48 МГц минимальное время между переключениями состояния вывода около 53 наносекунд.

Нормально ли это?

Это слишком быстро. Минимальное время переключения - 3 такта MCLK, или 62.5нс. Для проверки правильности установки PLL лучше использовать программируемый выход.

Цитата(Genadi Zawidowski @ Mar 25 2009, 13:18) *
дело в том, что не смотря на упоминание в даташите того факта, что умножитель PLL записанный в соответствующий регистор используется увеличенный на единицу, 90% всех увиденных мною примеров в Интернете игнорируют это. Соответственно, у меня вопрос - кто-нибудь проверял, как оно на самом деле?

В действительности все соответствует даташиту. Примеры лучше брать у Атмела (тоже дрянь, но хотя бы без диких ляпов).
Go to the top of the page
 
+Quote Post
Genadi Zawidowsk...
сообщение Mar 25 2009, 21:54
Сообщение #3


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

Группа: Участник
Сообщений: 1 620
Регистрация: 22-06-07
Из: Санкт-Петербург, Россия
Пользователь №: 28 634



Цитата(aaarrr @ Mar 26 2009, 00:26) *
Это слишком быстро. Минимальное время переключения - 3 такта MCLK, или 62.5нс. Для проверки правильности установки PLL лучше использовать программируемый выход.


В действительности все соответствует даташиту. Примеры лучше брать у Атмела (тоже дрянь, но хотя бы без диких ляпов).


Про три такта - это где написано? Из чего это время складывается? Не, про такты и время на инструкции я понимаю. Может, работа через set/reset на середине такта на выводы попадает?

Я, в общем-то, тоже ожидал увидеть что-то, кратное тактовой частоте с периодом примерно 21 наносекунда. А у меня получилось 2.5 такта...

Я делал так:
Код
// пример функции, для скорости помещаемой в SRAM
void RAMFUNC_NONILINE fast_clock_test(void)
{
    for (;;)
    {
        AT91C_BASE_PIOA->PIO_CODR = mask;
        AT91C_BASE_PIOA->PIO_SODR = mask;
    }
}


Вот в "короткой" части этого цикла (между сбросом и установкой бита) осцилограф TDS-1012 показывает около 52 наносекунд.

Сообщение отредактировал Genadi Zawidowski - Mar 25 2009, 22:00
Go to the top of the page
 
+Quote Post
aaarrr
сообщение Mar 25 2009, 22:14
Сообщение #4


Гуру
******

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



Цитата(Genadi Zawidowski @ Mar 26 2009, 00:54) *
Про три такта - это где написано? Из чего это время складывается? Не, про такты и время на инструкции я понимаю. Может, работа через set/reset на середине такта на выводы попадает?

Прямым текстом нигде не написано. Команда STR занимает 2 такта + дополнительный такт при доступе через APB.
Но я измерял скорость выполнения кода, а не времена между переключениями пина. Попробуйте в одном цикле последовательно
выполнить несколько операций set/reset, посмотрите скважность.
Go to the top of the page
 
+Quote Post
Genadi Zawidowsk...
сообщение Mar 25 2009, 23:03
Сообщение #5


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

Группа: Участник
Сообщений: 1 620
Регистрация: 22-06-07
Из: Санкт-Петербург, Россия
Пользователь №: 28 634



Интересно! Первый нулевой импульс имеет около 80 нан в нуле. Остальные в последовательности формирубт строгий меандр с периодом около 125 наносекунд - тоесть, по те самые 62 наносекунды.
Короче, теперь я уверен, что тактовая точно 48 мегагерц! Пока впечетления самые приятные.
Go to the top of the page
 
+Quote Post



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

 


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


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