×
接口总线驱动 > 详情

基于DSP的RS232串口连接设计

发布时间:2024-05-09 发布时间:
|

本科项目上需要DSP通过RS232串口连接四个设备,可供使用的芯片串口只有一个。

方案一:利用手头器件,简单利用FPGA和max232电平转换芯片采用片选方式设计

verilog代码如下:

module demultiplexer1to4 (out0,out1,out2,out3,in,s2,s1,s0);

output out0,out1,out2,out3;

input in;

input s0,s1,s2 ;

reg out0,out1,out2,out3;

always@(s0 or s1 or s2 or in)

case({s2,s1,s0} )

3‘b001: begin out0 《= in; out1 《= 1’bz; out2 《= 1‘bz; out3 《= 1’bz; end

3‘b011: begin out0 《= 1’bz; out1 《= in; out2 《= 1‘bz; out3 《= 1’bz; end

3‘b010: begin out0 《= 1’bz; out1 《= 1‘bz; out2 《= in; out3 《= 1’bz; end

3‘b110: begin out0 《= 1’bz; out1 《= 1‘bz; out2 《= 1’bz; out3 《= in; end

3‘b111: begin out0 《= in; out1 《= in; out2 《= in; out3 《= in; end

default: begin out0 《= 1’bz; out1 《= 1‘bz; out2 《= 1’bz;out3 《= 1‘bz; end

endcase

endmodule

优势:可实现一对一发送和一对多发送;

缺点:需要器件、接线较多,不可靠。

出现问题:使用一段时间后,数据出现乱码,分析是采用劣质max232芯片所导致,改用网申的美信原装芯片,没有继续出现问题。但劣质max232芯片单独使用电平转换没有问题。

方案二、接着我开始寻找集成芯片用以替代方案一,然后找到了成都国腾微电子有限公司的GM8125一扩五串口芯片。原理图如下:

此芯片缺陷是不能够一对多发送数据,只能一对一,倒也能满足我使用需求。

经过了一个寒假回来,事情变的奇怪了,采用此转换芯片发送的第一组数据出现乱码,后续数据正常。

解决办法,上电后先发送一组无用数据,跳过乱码。当时因为时间关系没有继续查明原因。

简单自制转换电路(此电路不适用与全双工工作):

RS232高电平: -3~ -15V

RS232低电平: +3~ +15V

RS232传输数据时空闲位为高电平,即-3~ -15V

发送数据时,USART_TXD(TTL或CMOS电平)为高电平,Q1截止,RS232_RXD电平为(0.7V(二极管压降)+RS232_TXD),因RS232_TXD空闲时为高电平,则RS232_RXD也为高电平。

USART_TXD(TTL或CMOS电平)为低电平,Q1导通,RS232_RXD电平近似为VCC,表现在RS232电平上为低电平。

接收数据时,RS232_TXD为高电平,Q2截止,USART_RXD近似为VCC,表现在TTL或CMOS电平上为高电平。

RS232_TXD为低电平,Q2导通,USART_RXD电平接近为0,为低电平。


『本文转载自网络,版权归原作者所有,如有侵权请联系删除』

热门文章 更多
计算机总线故障的维修原则有哪些