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

 
 
 
Reply to this topicStart new topic
> Совместимость CAN и RS485
Axel
сообщение Jun 24 2008, 06:36
Сообщение #1


Местный
***

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



Совместимы ли по уровням драйверы CAN и RS485 (напр SN65HVD230 и SN65HVD10)? К сожалению проверить самому сейчас нет возможности, а ответ нужен... Судя по описаниям, проблем быть не должно, но все же...
Go to the top of the page
 
+Quote Post
MrYuran
сообщение Jun 24 2008, 06:46
Сообщение #2


Беспросветный оптимист
******

Группа: Свой
Сообщений: 4 640
Регистрация: 26-12-07
Из: Н.Новгород
Пользователь №: 33 646



по-моему, CAN и RS-485 это протоколы разного уровня, вернее RS-485 вообще не протокол, а интерфейс.
Поэтому говорить о совместимости уровней некорректно.
Можно говорить о реализации протокола CAN посредством интерфейса RS-485


--------------------
Программирование делится на системное и бессистемное. ©Моё :)
— а для кого-то БГ — это Bill Gilbert =)
Go to the top of the page
 
+Quote Post
Andy Mozzhevilov
сообщение Jun 24 2008, 07:01
Сообщение #3


Знающий
****

Группа: Свой
Сообщений: 877
Регистрация: 26-01-05
Из: Екатеринбург
Пользователь №: 2 206



В протоколе CAN есть требование на доминантные и рецессивные уровни. Логический 0 на выходе контроллера CAN должен преобразовываться в доминантный уровень на физической шине, и этот уровень должен уметь пересилить все рецессивные уровни, которые выдают другие передатчики на эту шину. Интерфейс RS485 под это дело не заточен, насколько я знаю.


--------------------
Пасу котов...
Go to the top of the page
 
+Quote Post
rezident
сообщение Jun 24 2008, 07:07
Сообщение #4


Гуру
******

Группа: Свой
Сообщений: 10 920
Регистрация: 5-04-05
Пользователь №: 3 882



Цитата(Axel @ Jun 24 2008, 12:36) *
Совместимы ли по уровням драйверы CAN и RS485 (напр SN65HVD230 и SN65HVD10)? К сожалению проверить самому сейчас нет возможности, а ответ нужен... Судя по описаниям, проблем быть не должно, но все же...
ИМХО в общем случае нет, драйверы не совместимы. В линиях CAN коллизия это штатная ситуация, в линиях RS-485 это аварийная ситуация.
Цитата(MrYuran @ Jun 24 2008, 12:46) *
по-моему, CAN и RS-485 это протоколы разного уровня, вернее RS-485 вообще не протокол, а интерфейс.
Поэтому говорить о совместимости уровней некорректно.
Можно говорить о реализации протокола CAN посредством интерфейса RS-485
Вопрос про драйверы CAN и RS-485 вообще-то.
Go to the top of the page
 
+Quote Post
Axel
сообщение Jun 24 2008, 07:40
Сообщение #5


Местный
***

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



Видимо необходимо уточнить вопрос. Речь идет об обмене между двумя устройствами: с одной стороны - "закрытый" девайс с RS485, с другой - доступный для перепрограммирования девайс с контроллером и CAN драйвером. Логику обмена можно реализовать, дергая пинами, коллизий в этой ситуации можно избежать, вопрос только в электрической совместимости.
Go to the top of the page
 
+Quote Post
Andy Mozzhevilov
сообщение Jun 24 2008, 07:58
Сообщение #6


Знающий
****

Группа: Свой
Сообщений: 877
Регистрация: 26-01-05
Из: Екатеринбург
Пользователь №: 2 206



Цитата(Axel @ Jun 24 2008, 13:40) *
Видимо необходимо уточнить вопрос. Речь идет об обмене между двумя устройствами: с одной стороны - "закрытый" девайс с RS485, с другой - доступный для перепрограммирования девайс с контроллером и CAN драйвером. Логику обмена можно реализовать, дергая пинами, коллизий в этой ситуации можно избежать, вопрос только в электрической совместимости.

Ваше уточнение внесло ещё большую путаницу.
Что значит "закрытый".
Кто будет дергать пинами? Нужно CAN драйвером сделать эмуляцию протокола для RS485, программно дергая ногами CAN контроллера?


--------------------
Пасу котов...
Go to the top of the page
 
+Quote Post
Axel
сообщение Jun 24 2008, 08:13
Сообщение #7


Местный
***

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



Цитата(Andy Mozzhevilov @ Jun 24 2008, 11:58) *
Что значит "закрытый".


"Закрытый" - доступный только для обмена, но не для модификации (в отличие от другого, программу которого можно модифицировать).

Цитата(Andy Mozzhevilov @ Jun 24 2008, 11:58) *
Нужно CAN драйвером сделать эмуляцию протокола для RS485, программно дергая ногами CAN контроллера?


Именно так.
Go to the top of the page
 
+Quote Post
Andy Mozzhevilov
сообщение Jun 24 2008, 08:18
Сообщение #8


Знающий
****

Группа: Свой
Сообщений: 877
Регистрация: 26-01-05
Из: Екатеринбург
Пользователь №: 2 206



Цитата(Axel @ Jun 24 2008, 14:13) *
Именно так.

Электрически в этом случае наверное должно получиться.


--------------------
Пасу котов...
Go to the top of the page
 
+Quote Post
Axel
сообщение Jun 24 2008, 08:28
Сообщение #9


Местный
***

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



Спасибо всем откликнувшимся, попробую...
Go to the top of the page
 
+Quote Post
navy2000
сообщение Jun 28 2008, 15:28
Сообщение #10


Местный
***

Группа: Свой
Сообщений: 203
Регистрация: 17-07-06
Пользователь №: 18 874



Есть еще одна тонкость. В RS-485 линии A и B обе "гуляют" от нуля до питания, а в CAN от половины питания до нуля или питания. Точнее, CANH - Vcc/2 Vcc, CANL Vcc/2 GND. Определение состояния на приеме происходит по разнице (очень упрощенно) данных уровней. Чувствительность у приемников может быть разная, и при большой длинне линий и/или высокой скорости данные могут читаться не корректно.
Имею в виду только Phi-уровень, про CAN-кие прибамбасы в пакетах и скоростях опускаю, так как понял из вопроса там CAN как таковой использоваться не будет.
Go to the top of the page
 
+Quote Post
spf
сообщение Jun 29 2008, 17:15
Сообщение #11


Странник
****

Группа: Свой
Сообщений: 766
Регистрация: 29-08-05
Из: Екатеринбург
Пользователь №: 8 051



Цитата(navy2000 @ Jun 28 2008, 21:28) *
Чувствительность у приемников может быть разная, и при большой длинне линий и/или высокой скорости данные могут читаться не корректно.

Где такое написано и что такое "Чувствительность у приемников"?
Для каждого физического уровня микросхемы делаются по одному документу - уровни у них одинаковые.


--------------------
"Как много есть на свете вещей, которые мне не нужны!" Сократ
Go to the top of the page
 
+Quote Post
navy2000
сообщение Jun 30 2008, 07:04
Сообщение #12


Местный
***

Группа: Свой
Сообщений: 203
Регистрация: 17-07-06
Пользователь №: 18 874



Цитата
Для каждого физического уровня микросхемы делаются по одному документу - уровни у них одинаковые.

Речь шла о физической совместимости CAN и RS485 приемопередатчиков. То есть, будет ли RS-485 приемник стабильно принимать сигнал от CAN-передатчика и наоборот. Так вот, в состоянии, CAN не активен обе линии CANH и CANL будут с потенциалом Vcc/2, а для RS-485 приемника - это нестабильное состояние, поэтому там линии A и B "растягивают" к питанию и земле. Получаем электрический конфликт. Передатчик тянет линии к одному потенциалу, а приемник к другому. Это может привести к получению ложных бит на приеме в отсутствии передачи или установке доминанты на CAN-передатчике (что, в условиях нормального CAN-контроллера привело бы к BusOff).
Цитата
и что такое "Чувствительность у приемников"?

Для приемника RS-485 стандартом описано пороговая характеристика −200мВ до +200мВ
При этом, для передатчика:
|Uвых|=1,5:5,0В (не <1,5В и не >6,0В);
состояние логической «1»: Ua больше Ub (Реально Ua=Vcc, Ub=GND) — MARK, OFF;
состояние логического «0»: Ua меньше Ub (Реально Ub=Vcc, Ua=GND) — SPACE, ON;
Для CAN приемника (например SN65HVD234) типовое значение 100мВ, то есть при этой разнице будет определено доминантное состояние.
Хочу уточнить. Сам, я таких опытов не проводил. В таком соединении не вижу смысла. Я лишь высказываю свои сомнения автору темы. Чтоб не упустил при проектировании и осмыслил.
Go to the top of the page
 
+Quote Post
j2j2j2
сообщение May 18 2012, 05:54
Сообщение #13





Группа: Новичок
Сообщений: 1
Регистрация: 18-05-12
Пользователь №: 71 904



Цитата(navy2000 @ Jun 30 2008, 11:04) *
Речь шла о физической совместимости CAN и RS485 приемопередатчиков. То есть, будет ли RS-485 приемник стабильно принимать сигнал от CAN-передатчика и наоборот.


При небольших линиях будет стабильная связь. Приведу пример такой реализации , а вот и схема адаптации уровней. Проверено, работает со счетчиками Меркурий.

Go to the top of the page
 
+Quote Post
dangiz
сообщение Dec 3 2017, 09:19
Сообщение #14





Группа: Новичок
Сообщений: 4
Регистрация: 10-02-15
Пользователь №: 85 045



Цитата(j2j2j2 @ May 18 2012, 08:54) *
Приведу пример такой реализации [/url], а вот и схема адаптации уровней. Проверено, работает со счетчиками Меркурий.

Схема vlad rusanov, на которую ссылается j2j2j2,

скорее всего работоспособна только для односторонней передачи от прибора с интерфейсом CAN к устройству с интерфейсом RS-485. Действительно, с помощью подтягивающих резисторов можно физический уровень рецессии исказить так, что на входе компаратора RS-485 возникнет разность потенциалов между "А" и "В" порядка 0,25 - 0,27 В, что будет воспринято контроллером RS-485 как "1". Соответственно доминанта даст разность потенциалов -5 В, означающую "0". При необходимости передать что-либо прибору с интерфейсом CAN по линии с интерфейсом RS-485 по способу vlad rusanov уже ничего не получиться. Доминанта, конечно, пройдет, но вот рецессия никак. Отсюда вывод: заманчивая дешевизна использования модемов с интерфейсом RS-485 для удаленного контроля и управления электросчетчиков с интерфейсом CAN не катит. Увы, необходимо использовать квалифицированные модемы, разработанные под этот интерфейс, либо, что более хлопотно, применять конверторы интерфейсов и преобразователи линии, специально созданные под эти задачи.


Go to the top of the page
 
+Quote Post
Velund
сообщение Dec 17 2017, 02:39
Сообщение #15


Знающий
****

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



На самом деле вопросы там есть... CAN трансивер должен уйти в защиту шины, если слишком долго держится доминанта. При низких скоростях с RS485 в эту ситуацию можно попасть на некоторых сочетаниях данных.
Go to the top of the page
 
+Quote Post

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

 


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


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