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

 
 
> EP9302: как работает GPIO?, тайминги, синхронизация...
AVR
сообщение Mar 1 2008, 01:47
Сообщение #1


фанат Linux'а
*****

Группа: Свой
Сообщений: 1 353
Регистрация: 23-10-05
Из: SPB.RU
Пользователь №: 10 008



Здравствуйте!
Прошу прощения за возможно глупый вопрос... (по сайту искал, гуглил...)
В документации на EP93XX пишется что GPIO тактируется частотой 14 с чем-то МГц, а сам контроллер работает на 200 МГц. Искал в документации ответ на такой вопрос, но так и не нашел: если состояние выводов обновляется с частотой 14 МГц, а контроллер работает на 200 МГц, то как осуществляется синхронизация чтобы можно было быстро вываливать следующее значение на порт как только будет выдано старое значение на выводы?..
Провел маленький эксперимент, но не могу самому себе объяснить результаты:
CS-EP9302 подключена к Altera-DE1 через шлейфик к портам A, B и F. В Cyclone II прошивка, которая считает число фронтов на одном из выводов порта A и выводит это число на светодиоды. На ARM'е крутится linux, работа с GPIO осуществляется из драйвера, в старотовый код которого вставлен такой фрагмент:
Код
__raw_writeb(0xFF, GPIO_PADDR);
for(i = 0; i < 16; i++)
{
    __raw_writeb(0xFF, GPIO_PADR);
    __raw_writeb(0x00, GPIO_PADR);
    __raw_writeb(0xFF, GPIO_PADR);
    __raw_writeb(0x00, GPIO_PADR);
    __raw_writeb(0xFF, GPIO_PADR);
    __raw_writeb(0x00, GPIO_PADR);
    asm("nop");
    asm("nop");
    asm("nop");
    __raw_writeb(0xFF, GPIO_PADR);
    __raw_writeb(0x00, GPIO_PADR);
}
Код генерирует ровно 64 такта, и что удивительно, ПЛИСка исправно ловит ровно 64 такта. Если добавить немного nop'ов чтобы привнести мешающую задержку, то все равно ловится 64 такта... Возможно nop'ы выбрасываются, но всё равно ведь для операция записи константы в порт потребуется тактов меньше чем имеется в запасе до следующего обновления состояния портов... или не так?

1) Почему получается такой результат? Процессор приостанавливается на момент вывода в порт и ждет пока он обновится?
2) Как заставить GCC вывести ассемблерный листинг (чтобы посмотреть что там нагенерировалось) если сборка драйвера осуществляется таким способом: make -C $KDIR SUBDIRS=$DIR modules ?


--------------------
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
sensor_ua
сообщение Mar 1 2008, 22:08
Сообщение #2


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

Группа: Свой
Сообщений: 1 266
Регистрация: 22-04-05
Из: Киев
Пользователь №: 4 387



Цитата
я не припоминаю привязки к 14МГц. Где это упоминалось?

Не имею радости использования EP9302, но имею документ EPЗ9302_PP3.pdf


--------------------
aka Vit
Go to the top of the page
 
+Quote Post
aaarrr
сообщение Mar 1 2008, 22:19
Сообщение #3


Гуру
******

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



Цитата(sensor_ua @ Mar 2 2008, 01:08) *
Не имею радости использования EP9302, но имею документ EPЗ9302_PP3.pdf

Рад за Вас. И на какой же странице упоминается тактирование GPIO?
Go to the top of the page
 
+Quote Post
AVR
сообщение Mar 1 2008, 23:51
Сообщение #4


фанат Linux'а
*****

Группа: Свой
Сообщений: 1 353
Регистрация: 23-10-05
Из: SPB.RU
Пользователь №: 10 008



Цитата(aaarrr @ Mar 2 2008, 01:19) *
Рад за Вас. И на какой же странице упоминается тактирование GPIO?
Действительно, в EP93xx_Users_Guide_UM1.pdf нашел картинку 5-3 Bus Clock Generation, там показано что Pripheral Clock может быть MAX = 50 MHz... smile.gif
С толку сбивает то что картинке в даташите GPIO висит на одной шине с остальными периферийными штуковинами, а максимум тактовой для них судя по таблице 5-3 исходные 14 МГц, правда сам GPIO там не упоминается... smile.gif


--------------------
Go to the top of the page
 
+Quote Post

Сообщений в этой теме


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

 


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


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