搜索
bottom↓
回复: 135

多CPU单线通信原理与实现

  [复制链接]

出0入0汤圆

发表于 2009-2-17 21:32:15 | 显示全部楼层 |阅读模式

原理图 (原文件名:多CPU单线通信原理图.JPG)


  发现所有已发帖子都丢了,用户也注销了,还是重新注册回来的。下面转正题。
  所谓单线通信,其实还是需要两根导线,否则形不成电流回路。这里的意思是,共用CPU电源线完成信号的传递,而不需要单独的信号线。
  两根线,既要给CPU供电,又要传递信号,供电电压需要稳定,信号电压需要交变,看起来是矛盾的。
  解决方法无非是折中:供电电压稳定性做点牺牲,让信号调制上来,再加一个低通滤波器将其消除;信号的调制方法做点让步,尽量减少对
电源的影响,借用电源通道传输,再加一个高通滤波器将信号提取出来。在电力线上传输信号已经是成熟技术,在此我不想讨论,我只想做一
个简单的方案,能够使CPU之间以不太低的速率可靠传输数据即可。
  方案如图所示。

1. DC是供电电源,L1是电感,GND和COM是公用线,既给CPU供电,又供CPU间传递信号。
2. C1是滤波电容,储存电能给CPU供电。
3. D2有两个作用,一是截止作用:当COM线上的电位由高变低时,C1上的电能不会回灌到COM;二是导通作用:当COM线上的电位由低变高时,
L1上会感应出高电压,导致COM线电位高于C1电位,D2起到泄压作用。
4. D1的作用是防止多个CPU 同时发送数据时造成电流短路。

原理:
  没有数据发送时,COM线高电平;有CPU发送数据时,COM线电平随发送CPU的Tx信号高低变化,因为所有Rx(包括发送CPU的)都连在一起,因
此都可以接收到该数据,这样就完成了数据的发送与接收。

通信协议可以自定义,我提出两个例子。
协议1:主从协议
  只有一个CPU做主,其余都是从,所有通信都由主CPU发起,其余只能被动应答。通信过程分三步:1)主CPU发送命令,2)从CPU回应数据,3
)主CPU回应ACK。或,1)主CPU发送命令,2)主CPU发送数据,3)从CPU回应ACK。
命令格式:2字节同步码 + 1字节标记码 + 1字节从CPU地址码 + 1字节命令码 + 2字节参数码 + 1字节CRC校验码
数据格式:2字节同步码 + 1字节标记码 + 1字节数据长度码 + N 字节数据 + 1字节CRC校验码
ACK格式:2字节同步码 + 1字节标记码 + 1字节回应码 (0x55表示接收正确,否则失败) + 1字节CRC校验码
侦错与纠错机制:靠同步码进行帧同步,靠CRC校验码进行帧检错,接收方发现错误丢弃错误帧,发送方等待数据超时重发,连续重发3次失败
放弃发送。

协议2:竞争协议
借用以太网的机制,每个CPU都是平等地位,都可以随时发送数据。步骤如下,当任何一个CPU想发送数据时,
1)探听COM线1ms时间,之内若无数据接收,则转2),否则继续探听。
2)向COM线发送数据,同时接收回来,一旦发现接收数据和发送数据不相同,则转3),否则一直发送数据直到数据发送完毕,返回。
3)停止发送,等待一个随机时间 N ms,转1)。
发送数据格式:2字节同步码 + 1字节源CPU地址码 + 1字节目的CPU地址码 + 1字节数据长度码 + N 字节数据 + 1字节CRC校验码
侦错与纠错机制:靠同步码进行帧同步,靠CRC校验码进行帧检错,靠高层协议进行纠错,高层协议略。

疑问解答:发送数据时Tx变成低电平,电源岂不对地短路啦?
  如果不接电感L1,COM又接地,确实会发生电源对地短路,但是接了L1后就不会了,COM接地相当于此时电源只接了L1一个负载,电源消耗的
电能随着L1电流增加变成了储存在L1中的磁能,当COM又变回高电平时,这部分磁场能量会随着D2的泄压作用转移到电容C1中,变成电场能量,
最终被CPU消耗掉,是不是和升压DC-DC有点像?因此可以预期在通信期间,CPU供电电压(即C1电压)会有所升高。

疑问解答:为何选择串口(Tx、Rx)作为数据收发口?
  从原理上看,调制信号占空比应该越大越好,占空比越大,每个周期内低电平时间相对越短,因DC-DC效应对CPU电源电压影响就越小;凡事
不能走极端,占空比也不能太小,否则抗干扰能力就差了。
  另外,通信速率也不宜太低,速率太低,造成发送1bit时COM线电平被拉低时间太长,L1电流过大,会造成L1储能饱和,电源效率降低。
  因此,使用串口不是最好选择,串口信号调制占空比为‘1’100%可以,‘0’0%太小了;串口速率普遍较低,最高才115Kbps。但是,因为单
片机上一般不集成有专门适用于我这个方案的硬件收发器,软件模拟或外挂CPLD又太麻烦,所以干脆用串口算了,硬件简单,成本还低,软件
也不复杂,直接操作串口就行了。

阿莫论坛20周年了!感谢大家的支持与爱护!!

月入3000的是反美的。收入3万是亲美的。收入30万是移民美国的。收入300万是取得绿卡后回国,教唆那些3000来反美的!

出0入0汤圆

发表于 2009-2-17 22:15:41 | 显示全部楼层
强帖
看来电源线传输信号不是不可能啊
LZ这么讲就明白了
值得研究的技术

出0入84汤圆

发表于 2009-2-17 23:30:39 | 显示全部楼层
mark

出0入0汤圆

发表于 2009-2-18 08:48:30 | 显示全部楼层
楼主强人也!

出0入0汤圆

发表于 2009-2-18 08:56:29 | 显示全部楼层
做个实验了吗?

出0入0汤圆

发表于 2009-2-18 09:19:44 | 显示全部楼层
mark

出0入0汤圆

发表于 2009-2-18 09:35:56 | 显示全部楼层
可以查看一个HOMEPLUG的协议。。。电源线可以传到85Mps

出0入0汤圆

发表于 2009-2-18 10:31:49 | 显示全部楼层
MARK

出0入0汤圆

发表于 2009-2-18 10:38:54 | 显示全部楼层
MARK

出0入0汤圆

 楼主| 发表于 2009-2-18 11:34:01 | 显示全部楼层
我初步做过实验,L1取 100uH - 1mH,D1 D2 取1N5819, C1 取220uF 电解电容,速率在 100Kbps - 1Mbps,示波器看 COM 线波形良好。更深一步的编程实验还没做。

出0入0汤圆

发表于 2009-2-18 11:39:00 | 显示全部楼层
很不错,学习了

出0入0汤圆

 楼主| 发表于 2009-2-18 11:39:09 | 显示全部楼层
诚如 6 楼所说,电力 modem 是很成熟的技术了,可以借鉴一下。但又不想把事情搞复杂,所以才有这个方案,如果谁感兴趣可以做一下实验,并把结果反馈共享。

出0入0汤圆

发表于 2009-2-18 11:44:34 | 显示全部楼层
二线对讲机也是利用电源线传输声音信号的。

出0入0汤圆

 楼主| 发表于 2009-2-18 11:52:56 | 显示全部楼层
二线对讲机和电话线一样,既供电,又传递模拟声音信号,若传递数字信号可以先调制再解调,语音信号的带宽(300Hz - 3400Hz)决定调制信号的最大波特率为 56Kbps,就是我们早期的拨号上网速率。

这个方案没有对信号进行调制,线缆带宽也没有限制,线缆特性阻抗也没有匹配,如果进一步完善有很多工作要做,在此仅起一个抛砖引玉的作用。

出0入0汤圆

发表于 2009-2-18 13:37:33 | 显示全部楼层
关注这个主题,我接触过欧洲的EIB协议,并且使用过法国海格的eib产品,它就是用双线,进行电源与信号的供应与传送

出0入0汤圆

发表于 2009-2-18 13:52:27 | 显示全部楼层
不错,值得学习

出0入4汤圆

发表于 2009-2-18 14:08:28 | 显示全部楼层
不错,有新意.

估计通信不稳定, 电感余振,会是个问题,

出0入0汤圆

发表于 2009-2-18 14:20:47 | 显示全部楼层
我们有款产品基本上就是类似的原理,不是用的电感而是电阻,外围也要增加很多

出0入0汤圆

发表于 2009-2-18 14:27:43 | 显示全部楼层
mark

出0入0汤圆

发表于 2009-2-18 20:57:03 | 显示全部楼层
有创意,但觉得用1-wire类似的通信更可靠些。

出0入0汤圆

发表于 2009-2-19 04:03:58 | 显示全部楼层
可以看看电视机的天线放大器的供电和信号传输!
一根屏蔽线就可以传上G的频率信号!
还是模拟信号啊!
要是数字信号基本不用考虑损耗!
还有双线可以实现双向传输的!
我是修家电的!天线放大器做过一些!
还有那个供电的可以用稳压!
有空大家来考虑一下!
天线架放大器的电路原理就是一个空心线圈电感隔离信号来提取用电!
然后用一个电容接出信号!
下面是一个自制电视天线放大器的帖子链接!
http://www.dzdiy.com/html/200712/31/20071231065351.htm

出0入0汤圆

发表于 2009-2-20 15:45:19 | 显示全部楼层
记号

出0入0汤圆

发表于 2009-2-20 16:37:20 | 显示全部楼层
mark

出0入0汤圆

发表于 2009-2-20 18:36:10 | 显示全部楼层
类似的 达拉斯 1-wire 。。。

出0入0汤圆

发表于 2009-2-20 22:01:34 | 显示全部楼层
冲突怎么办?如果用硬件通讯的方法,那么只有一个字节发送完成后才可以检查到,这时候所有的发送数据都会错的。硬件不能做到按位检查。

出0入0汤圆

发表于 2009-2-20 22:09:19 | 显示全部楼层
【25楼】 ssyniuej
积分:1410
派别:
等级:------
来自:山东济宁
冲突怎么办?如果用硬件通讯的方法,那么只有一个字节发送完成后才可以检查到,这时候所有的发送数据都会错的。硬件不能做到按位检查。  
__________________________
   冲突了只是数据会乱,可以通过协议解决,不会烧电路。

出0入50汤圆

发表于 2009-2-20 22:18:13 | 显示全部楼层
厉害,以后试试这种总线用到机器里。

出0入0汤圆

发表于 2009-2-22 16:36:47 | 显示全部楼层
focus 总线报警主机好像就采用此方式,好像工作电流不大。

出0入0汤圆

发表于 2009-2-22 21:00:09 | 显示全部楼层
加一楼

出0入0汤圆

发表于 2009-2-22 21:00:09 | 显示全部楼层
加一楼

出0入0汤圆

发表于 2009-2-22 21:00:10 | 显示全部楼层
加一楼

出0入0汤圆

发表于 2009-2-22 21:17:35 | 显示全部楼层
加一楼

出0入0汤圆

发表于 2009-2-22 23:46:13 | 显示全部楼层
支持下

出0入147汤圆

发表于 2009-10-1 21:38:55 | 显示全部楼层
mark

出0入0汤圆

发表于 2009-10-1 23:09:41 | 显示全部楼层
MAKR

出0入0汤圆

发表于 2009-10-2 00:04:14 | 显示全部楼层
看看

出0入0汤圆

发表于 2009-10-2 00:50:51 | 显示全部楼层
mark

出0入0汤圆

发表于 2009-10-2 01:23:50 | 显示全部楼层
记号记号!

出0入0汤圆

发表于 2009-10-2 01:36:30 | 显示全部楼层
在这种通讯模式下,一台机器出错,所有机器全死

个人认为,这并不是一种安全和稳定的通讯方式,只在极少数情况下有意义

出0入0汤圆

发表于 2009-10-2 07:21:22 | 显示全部楼层
mark.

出0入0汤圆

发表于 2009-10-2 07:32:01 | 显示全部楼层
mark

出0入0汤圆

发表于 2009-10-2 07:40:52 | 显示全部楼层
mark

出0入0汤圆

发表于 2009-10-2 17:07:26 | 显示全部楼层
用CAN总线的原理接线能实现硬件防冲突

出0入0汤圆

发表于 2009-10-2 17:54:37 | 显示全部楼层
mark

出0入0汤圆

发表于 2009-10-2 18:11:14 | 显示全部楼层
jh

出0入309汤圆

发表于 2009-10-2 18:21:30 | 显示全部楼层
mark

出0入0汤圆

发表于 2009-10-4 09:13:57 | 显示全部楼层
MARK

出0入0汤圆

发表于 2009-10-5 01:12:40 | 显示全部楼层
好办法

出0入0汤圆

发表于 2009-10-5 14:43:36 | 显示全部楼层
记号

出0入0汤圆

发表于 2009-10-5 16:19:12 | 显示全部楼层
顶一下,先

出0入0汤圆

发表于 2009-10-5 21:50:45 | 显示全部楼层
消防报警系统中供电和数据就是共线啊,就两根线搞定的!稳定也不是问题啊,人命关天嘛。

出0入0汤圆

发表于 2009-10-6 11:22:18 | 显示全部楼层
mark

出0入0汤圆

发表于 2009-10-6 14:12:56 | 显示全部楼层
【15楼】 gzrascal
终于看到有接触过EIB的兄弟了。。。呵呵
------
LZ的这种多机通讯方式,在协议制定上一定要注意信号碰撞,和单个通讯模块故障导致整个系统崩溃。参考相关EIB的技术,在这两方面是做得非常好的。。。
另外,使用直流电+信号线的这种方式,不仅仅是LZ所想,EIB、大金空调等很多厂商都有使用这种通讯方式的。。。可这项技术10多年前就有了。。。
有兴趣我们大家一起研究一下,制定一个相关可实施的协议或标准。。。

出0入0汤圆

发表于 2009-10-6 14:54:01 | 显示全部楼层
有意思,有具体的例子参考一下就好了。

出0入0汤圆

发表于 2009-10-6 15:43:20 | 显示全部楼层
 楼顶图是个很不错的构思,但也正如39楼水猫所说,危险潜伏其中。

 打个比方,一组潜水员被一根共用的氧气管连接起来,他们之间的通信手段就靠捏几下氧气管传递信息。如果其中有个人出了意外神志不清,他在昏迷中老捏着氧气管不放手的话,就把别人也憋死了。

 不过其实是有改进办法的,比如各节点的TX不要直接短路电源,改用串电容用交流调制的办法通信,就安全了。

出0入0汤圆

发表于 2009-10-6 15:49:40 | 显示全部楼层
不错,供电很象电话总机的模式

出20入22汤圆

发表于 2009-10-6 16:56:43 | 显示全部楼层
串电阻电容很简单的

出0入0汤圆

发表于 2010-9-25 15:49:05 | 显示全部楼层
mark

出0入0汤圆

发表于 2010-9-28 15:16:51 | 显示全部楼层
支持,学习了,理论上是可以的!
实际应该也是可以的,呵呵!!!

出0入0汤圆

发表于 2010-9-28 16:53:39 | 显示全部楼层
用过CMBUS-CMT100芯片,可以实现跟lz一样的功能,不过成本要高一些

出0入0汤圆

发表于 2010-9-28 17:13:41 | 显示全部楼层
MARK

出0入0汤圆

发表于 2010-9-28 17:21:23 | 显示全部楼层
受教了!!感谢楼主!!!!

出0入0汤圆

发表于 2010-9-29 15:58:06 | 显示全部楼层
加一楼!
MARK!

出0入0汤圆

发表于 2010-10-4 08:18:31 | 显示全部楼层
MARK!

出0入0汤圆

发表于 2010-10-4 09:47:40 | 显示全部楼层
很好!

出0入0汤圆

发表于 2010-10-4 10:06:54 | 显示全部楼层
好想法 值得一试

出0入0汤圆

发表于 2010-10-4 11:02:58 | 显示全部楼层
多谢楼主!

出0入0汤圆

发表于 2010-10-4 11:22:27 | 显示全部楼层
很好的想法,有空可以研究下。

出0入0汤圆

发表于 2010-11-5 16:41:24 | 显示全部楼层
呵呵
【15楼】 gzrascal  
终于看到有接触过EIB的兄弟了。。。呵呵
------
LZ的这种多机通讯方式,在协议制定上一定要注意信号碰撞,和单个通讯模块故障导致整个系统崩溃。参考相关EIB的技术,在这两方面是做得非常好的。。。
另外,使用直流电+信号线的这种方式,不仅仅是LZ所想,EIB、大金空调等很多厂商都有使用这种通讯方式的。。。可这项技术10多年前就有了。。。
有兴趣我们大家一起研究一下,制定一个相关可实施的协议或标准。。。

目前国内搞基于EIB通讯产品的兄弟太少啦。这个贴我关注好久拉!

海格的总线电源 ,驱动器,调光模块都有接触过,他们的信号调整解调电路都是分立元件搭的。
西门子的信号调整解调电路是用的专用芯片。
不过都是在30V的总线电源上叠加交流信号。
这类产品都是用的低功耗的单片机,海格用的是TI 的M430低功耗系列。

出0入0汤圆

发表于 2010-11-5 16:46:30 | 显示全部楼层
想上传一个EIB协议中文版 现在我还没有审核通过呢
EIB 产品就是多主 竞争协议
有几个优先等级

出0入0汤圆

发表于 2010-11-5 18:49:35 | 显示全部楼层
TO 【70楼】 Aaronli

是的,搞EIB的兄弟是太少了。。。。就我知道的在上海,有过培训认证的,能独立完成整个系统调试的,也就那二十几个人。

你也用过海格的东西吗?我是从西门子Install BUS开始接触的,随后ABB的i bus、海格的tebis、莫顿、威琅、WDL、吉萊,伟麦、永诺等等多少都有接触过,最近在看becker的DD,起始都差不多。。。呵呵

EIB是个标准协议,全称翻译过来就是欧洲安装总线,而且已经成为了我国的一个暂行标准。。。唉

西门子发起的时候已经有个KNX系统(欧洲标准的),貌似是弥补BA系统低端的应用,不过用来做规模大点的应用也是可以的。上海的烟草大厦,浦东国际机场,世博场馆,等都有应用。

现在我主要是用EIB系统来完成一些别墅和豪宅的家居智能化系统。当然,还同时要整合安防,监控,音视频一体化,空调,地暖啥的控制的。

这ID是马甲号,需要的话留个联系方式,交流一下。。。呵呵

出0入0汤圆

发表于 2010-11-6 08:03:58 | 显示全部楼层
TO hetiger
加群28343506,我们群里聊吧!

出0入0汤圆

发表于 2010-11-6 08:09:54 | 显示全部楼层
NBA

出0入0汤圆

发表于 2010-11-6 22:05:28 | 显示全部楼层
是个好思路,虽然实际使用会有些麻烦!

出0入0汤圆

发表于 2010-11-6 22:20:10 | 显示全部楼层
mark

出0入0汤圆

发表于 2010-12-31 21:40:22 | 显示全部楼层
好用吗?

出0入0汤圆

发表于 2010-12-31 21:43:44 | 显示全部楼层
mark

出0入0汤圆

发表于 2010-12-31 23:44:45 | 显示全部楼层
这种电路好像有专用芯片,hetlk有介绍过他的专用芯片,听说爱普生打印机的打印头是单总线架构,通过电源线进来的,速度还很快

出0入0汤圆

发表于 2011-1-1 10:48:57 | 显示全部楼层
好像用红外线类似的高频传输也可以。不过距离是问题

出0入0汤圆

发表于 2011-11-8 15:54:29 | 显示全部楼层
能给个实现该功能的IC或者成熟电路吗?

我们用3V供电,用两根线连接到另外一块板子,即供电又传输信号!双向通信!

单线通信和总线供电吧!

QQ:52157293

出0入0汤圆

发表于 2011-11-8 16:06:08 | 显示全部楼层
g00d

出0入0汤圆

发表于 2012-2-9 10:12:59 | 显示全部楼层
mark

出200入2554汤圆

发表于 2012-2-9 15:49:08 | 显示全部楼层
学习一下

出0入0汤圆

发表于 2012-2-10 13:18:14 | 显示全部楼层
hao 高深,学习

出0入4汤圆

发表于 2013-1-26 00:42:07 来自手机 | 显示全部楼层
如果电压高,要好搞得多

出0入0汤圆

发表于 2013-1-26 01:32:33 | 显示全部楼层
强帖,留个印。

出0入0汤圆

发表于 2013-1-30 12:28:37 | 显示全部楼层
很有意思的帖子,学习了。

出0入0汤圆

发表于 2013-2-28 14:55:16 | 显示全部楼层
先做个记号,回头仔细看看。

出0入4汤圆

发表于 2013-2-28 15:01:36 | 显示全部楼层
消防总线就是二线制的,既做供电又把信号调制上面进行通信,总线上可以挂200多个设备,但现在可以提供的电流比较小,设备要求低功耗,但更改设计,以提供更大电流也是可能的。

出0入10汤圆

发表于 2013-2-28 17:32:45 | 显示全部楼层
干扰会不会很大~

出0入0汤圆

发表于 2013-2-28 18:12:17 | 显示全部楼层
既做供电又把信号调制上面进行通信,学习一下

出0入0汤圆

发表于 2013-7-14 13:31:53 | 显示全部楼层
嗯,这个方案的话,
各个CPU怎么区分?
例如他们实现相同的功能,用的是相同的程序,怎样给每个CPU赋值不同的地址?

出0入0汤圆

发表于 2013-7-16 07:18:25 | 显示全部楼层
帮顶 看看  

出0入0汤圆

发表于 2013-7-31 20:59:42 | 显示全部楼层
现在已经有啦仪表总线

出0入0汤圆

发表于 2013-7-31 21:06:46 | 显示全部楼层
楼主  此方案商用了吗?

出0入0汤圆

 楼主| 发表于 2013-8-2 12:38:54 | 显示全部楼层
没有商用,只是几年前我的一个想法,还不成熟

出0入0汤圆

发表于 2013-8-2 13:01:18 | 显示全部楼层
值得一看,下面的恢复更好看,eib不错,研究一下

出0入0汤圆

发表于 2013-8-2 13:11:56 | 显示全部楼层
思路明晰,值得研究!LZ强人

出0入0汤圆

发表于 2014-6-24 17:40:18 | 显示全部楼层
mark      

出0入0汤圆

发表于 2014-6-25 08:49:31 | 显示全部楼层
这么好的帖子怎么让它沉了呢!!
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-4-26 13:34

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表