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

 
 
 
Reply to this topicStart new topic
> Вопрос начинающего по 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
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
aaarrr
сообщение Mar 25 2009, 23:08
Сообщение #6


Гуру
******

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



Цитата(Genadi Zawidowski @ Mar 26 2009, 02:03) *
Короче, теперь я уверен, что тактовая точно 48 мегагерц!

Рад за Вас, хотя лучше проверять частоту на выводах PCKx. А то вдруг я соврал? smile.gif
Go to the top of the page
 
+Quote Post
Genadi Zawidowsk...
сообщение Mar 25 2009, 23:31
Сообщение #7


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

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



Цитата(aaarrr @ Mar 26 2009, 02:08) *
Рад за Вас, хотя лучше проверять частоту на выводах PCKx. А то вдруг я соврал? smile.gif

Я еще не научился программировать таймеры... да, внмательно просмотрел тот пример от атмела, в котором программируется генератор на 96-с-копейками для работы с USB при использовании кварца на 18.4312 - там как рвз учитывается, что писать в регистр умножителя pll надо уменьшенное число - оно просто используется, 72, без комментария, что в расчетах будет 73...
Go to the top of the page
 
+Quote Post
aaarrr
сообщение Mar 25 2009, 23:35
Сообщение #8


Гуру
******

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



PCK - это не выход таймера, а просто вывод системного клока на пин через прескалер. Удобно, только прескалер кривой немного.
Go to the top of the page
 
+Quote Post
Genadi Zawidowsk...
сообщение Mar 26 2009, 00:10
Сообщение #9


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

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



Цитата(aaarrr @ Mar 26 2009, 02:35) *
PCK - это не выход таймера, а просто вывод системного клока на пин через прескалер. Удобно, только прескалер кривой немного.


Проверил - всё точно, не ошибся я с программированием pll. Спасибо большое за подсказки.

зы: что-то не удается фотографию тестовой платы приатачить. Експлорер уходит в себя, иногда bad gateway пишет.

Сообщение отредактировал Genadi Zawidowski - Mar 26 2009, 00:15
Go to the top of the page
 
+Quote Post
_4afc_
сообщение Mar 26 2009, 08:03
Сообщение #10


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

Группа: Свой
Сообщений: 1 262
Регистрация: 13-10-05
Из: Санкт-Петербург
Пользователь №: 9 565



Цитата(Genadi Zawidowski @ Mar 26 2009, 02:31) *
Я еще не научился программировать таймеры... да, внмательно просмотрел тот пример от атмела, в котором программируется генератор на 96-с-копейками для работы с USB при использовании кварца на 18.4312 - там как рвз учитывается, что писать в регистр умножителя pll надо уменьшенное число - оно просто используется, 72, без комментария, что в расчетах будет 73...


Общеизвестная ошибка в примерах.

(18432/14*73)/2=48054857 а не 47923200.
Go to the top of the page
 
+Quote Post

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

 


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


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