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

 
 
 
Reply to this topicStart new topic
> altera max2 - как управлять подтягивающим резстором?
yantux
сообщение Jun 12 2012, 19:13
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 15
Регистрация: 10-03-10
Пользователь №: 55 894



Есть altera max2, которая подключена к ПЗС матрице, при чём подтягивающий резистор уже есть на плате. Т.е. предполагается, сто внутренний подтягивающий резистор altera max2 я использовать не должен.

Если я правильно понял по даташиту и i2c, я должен в max2 управлять подтягивающим резистором, чтобы в нужный момент принимать ACK или non-ACK бит от ПЗС? Как на vhdl реализовать управление внутренним подтягивающим резистором в altera max2?
Go to the top of the page
 
+Quote Post
Zwerg_nase
сообщение Jun 13 2012, 07:07
Сообщение #2


Местный
***

Группа: Свой
Сообщений: 204
Регистрация: 14-10-05
Из: г. Москва
Пользователь №: 9 641



Цитата(yantux @ Jun 12 2012, 23:13) *
Есть altera max2, которая подключена к ПЗС матрице, при чём подтягивающий резистор уже есть на плате. Т.е. предполагается, сто внутренний подтягивающий резистор altera max2 я использовать не должен.

Если я правильно понял по даташиту и i2c, я должен в max2 управлять подтягивающим резистором, чтобы в нужный момент принимать ACK или non-ACK бит от ПЗС? Как на vhdl реализовать управление внутренним подтягивающим резистором в altera max2?


В стандарте на I2C написано: "The transmitter releases the SDA line (HIGH) during the acknowledgeclock pulse.." Т.е. надо не подтягивающим резистором управлять, а переключать пин SDA в третье состояние. В ПЛИСе для этого надо объявить пин SDA, как bidirectional и, когда надо принимать ACK, переключить этот пин на вход, т.е. release the SDA line, а внешний подтягивающий резистор уже подтянет SDA вверх. Кстати, подтягивающий резистор нужен не абы какой, а достаточный для обеспечения требуемой длительности положительного фронта (1000 нс для 100 кГц и 300 нс для 400 кГц). Поэтому внутренний подтягивающий резистор мах2 для этих целей (5-25 кОм) может оказаться слишком большим для этой цели.
Go to the top of the page
 
+Quote Post
yantux
сообщение Jun 13 2012, 17:55
Сообщение #3


Участник
*

Группа: Участник
Сообщений: 15
Регистрация: 10-03-10
Пользователь №: 55 894



Цитата(Zwerg_nase @ Jun 13 2012, 11:07) *
В ПЛИСе для этого надо объявить пин SDA, как bidirectional и, когда надо принимать ACK, переключить этот пин на вход, т.е. release the SDA line, а внешний подтягивающий резистор уже подтянет SDA вверх.


В Квартусе он объявлен как bidirectional. Как в программе vhdl изменять режим приём/передача? Надо использовать мегафункцию? Если да, тогда какую? Как то не вериться, что пин будет переключаться автоматически.
Go to the top of the page
 
+Quote Post
sazh
сообщение Jun 13 2012, 18:25
Сообщение #4


Гуру
******

Группа: Свой
Сообщений: 2 435
Регистрация: 6-10-04
Из: Петербург
Пользователь №: 804



Цитата(yantux @ Jun 13 2012, 20:55) *
В Квартусе он объявлен как bidirectional. Как в программе vhdl изменять режим приём/передача? Надо использовать мегафункцию? Если да, тогда какую? Как то не вериться, что пин будет переключаться автоматически.


Пин объявленный как двунаправленный всегда идет в связке с буфером по z состоянию.
Вам нужно на этом буфере симитировать буфер с открытым стоком, так как на плате у вас есть внешний резистор.
все это есть в любом учебнике.
Код
module opndr
(
input  clk,
input  in_data,
output out_data,
inout  in_out_data
);

reg out_data_rg;

assign in_out_data = (in_data == 1'b0) ? 1'b0 : 1'bz;

always @(posedge clk)
begin
out_data_rg <= in_out_data;
end

assign out_data = out_data_rg;

endmodule

Go to the top of the page
 
+Quote Post
Zwerg_nase
сообщение Jun 14 2012, 07:03
Сообщение #5


Местный
***

Группа: Свой
Сообщений: 204
Регистрация: 14-10-05
Из: г. Москва
Пользователь №: 9 641



Цитата(yantux @ Jun 13 2012, 21:55) *
В Квартусе он объявлен как bidirectional. Как в программе vhdl изменять режим приём/передача? Надо использовать мегафункцию? Если да, тогда какую? Как то не вериться, что пин будет переключаться автоматически.

Пример на VHDL в атаче.
Прикрепленные файлы
Прикрепленный файл  Trireg_VHDL..pdf ( 36.16 килобайт ) Кол-во скачиваний: 100
 
Go to the top of the page
 
+Quote Post

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

 


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


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