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

 
 
> Затык с i2c
Putnik
сообщение Jun 17 2010, 10:14
Сообщение #1


Местный
***

Группа: Свой
Сообщений: 214
Регистрация: 4-09-07
Из: Зеленоград
Пользователь №: 30 272



Здравствуйте!

В общем, все просто - есть модуль i2c_contr, его назначение - запись по i2c в АЦП и ЦАП-е регистры и затем их чтение во внутреннюю память (модуль RAM55B),
Выкладываю последний вариант в котором в железке стабильно работает запись в АЦП, остальное не работает..

В предыдущих вариациях иногда получал запись в ЦАП как требуется

Чтение не работало ни разу, приходит NACK(SDAT == 1) после отправки адреса устройства с 8-м битом в 1(READ),

прикладываю простенький тестбенч, для просмотра линий SCLK и SDAT надо смотреть внутренние sclk и sdat в i2c_contr,
отображающие их поведение на линии, в реальности они собираются в верхнем модуле как
assign sdat = sda_en ? sda_o : 1'bz,
sda_i = sdat;
assign sclk = scl_en ? scl_o : 1'bz,
scl_i = sclk;
(ибо open drain у третьего спартана нет)


подскажите где лажаю, вроде все делал по стандарту I2C и даташитамПрикрепленный файл  src.rar ( 3.44 килобайт ) Кол-во скачиваний: 91


--------------------
за Навального!
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
iosifk
сообщение Jun 17 2010, 10:56
Сообщение #2


Гуру
******

Группа: Модераторы
Сообщений: 4 011
Регистрация: 8-09-05
Из: спб
Пользователь №: 8 369



Для начала надо посмотреть аппликухи ксайлинкса. Там I2C рассмотрен подробно и даны исходники...
А потом рекомендую на входе клока поставить цифровой фильтр, чтобы убрать возможный дребезг из-за пологих фронтов.
Удачи!


--------------------
www.iosifk.narod.ru
Go to the top of the page
 
+Quote Post
Putnik
сообщение Jun 17 2010, 11:13
Сообщение #3


Местный
***

Группа: Свой
Сообщений: 214
Регистрация: 4-09-07
Из: Зеленоград
Пользователь №: 30 272



Цитата(iosifk @ Jun 17 2010, 14:56) *
Для начала надо посмотреть аппликухи ксайлинкса. Там I2C рассмотрен подробно и даны исходники...
А потом рекомендую на входе клока поставить цифровой фильтр, чтобы убрать возможный дребезг из-за пологих фронтов.
Удачи!

В верхнем модуле клок clk для i2c_contr идет от входного пина ПЛИС по цеп-ке IBUFG -> DCM(x2) -> BUFG

аппликухи - это application? их на сайте ксайлинкса искать? Спасибо
UPS - нашел application I2C у хилых на сайте


--------------------
за Навального!
Go to the top of the page
 
+Quote Post
Maverick
сообщение Jun 17 2010, 11:24
Сообщение #4


я только учусь...
******

Группа: Модераторы
Сообщений: 3 447
Регистрация: 29-01-07
Из: Украина
Пользователь №: 24 839



Цитата(Putnik @ Jun 17 2010, 14:13) *
UPS - нашел application I2C у хилых на сайте

И произошло чудо! smile.gif


--------------------
If it doesn't work in simulation, it won't work on the board.

"Ты живешь в своих поступках, а не в теле. Ты — это твои действия, и нет другого тебя" Антуан де Сент-Экзюпери повесть "Маленький принц"
Go to the top of the page
 
+Quote Post
Putnik
сообщение Jun 17 2010, 11:38
Сообщение #5


Местный
***

Группа: Свой
Сообщений: 214
Регистрация: 4-09-07
Из: Зеленоград
Пользователь №: 30 272



Цитата(Maverick @ Jun 17 2010, 15:24) *
И произошло чудо! smile.gif

очень смешно cranky.gif , по делу лучше бы что-то подсказали


--------------------
за Навального!
Go to the top of the page
 
+Quote Post

Сообщений в этой теме
- Putnik   Затык с i2c   Jun 17 2010, 10:14
- - sazh   Цитата(Putnik @ Jun 17 2010, 13:14) assig...   Jun 17 2010, 11:39
|- - Putnik   Цитата(sazh @ Jun 17 2010, 15:39) Если вн...   Jun 17 2010, 11:44
- - Putnik   Скажите, времянки то хоть правильные? Диаграммы з...   Jun 18 2010, 07:14
|- - DmitryR   Цитата(Putnik @ Jun 18 2010, 11:14) нет а...   Jun 18 2010, 07:20
|- - Putnik   Цитата(DmitryR @ Jun 18 2010, 11:20) Для ...   Jun 18 2010, 11:49
|- - DmitryR   Тогда вероятно у вас pullup неправильно смоделиров...   Jun 18 2010, 12:02
- - Putnik   Собираю sdat и sclk так - assign sdat = sda_en ...   Jun 18 2010, 12:34
|- - DmitryR   Это все понятно, как pullup-то моделируется? И ещ...   Jun 18 2010, 12:59
- - Putnik   на sda_i имитируется входное воздействие по линии ...   Jun 18 2010, 13:28
|- - DmitryR   На sda_i ничего имитировать нельзя - он внутри UUT...   Jun 18 2010, 16:25
|- - Putnik   Цитата(DmitryR @ Jun 18 2010, 20:25) На s...   Jun 18 2010, 20:10
|- - DmitryR   pullup(sda);   Jun 21 2010, 05:20
- - Putnik   У ЦАП не заметил внешнего сброса сначала, на запис...   Jun 22 2010, 09:01
- - DmitryR   Цитата(Putnik @ Jun 22 2010, 13:01) ЦАП -...   Jun 22 2010, 09:06
- - aaarrr   Цитата(Putnik @ Jun 22 2010, 13:01) видим...   Jun 22 2010, 09:07


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

 


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


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