当前位置:首页 > 单片机 > 单片机
[导读]资源使用说明:2410+LINUX、UART(即RS-232串口)全双工通信、RS-485半双工通信局部程序框图及其设计说明:调试记录及调试结果:MODBUS总结: MODBUS协议对比:ASCII模式:用8位表示一

资源使用说明:2410+LINUX、UART(即RS-232串口)全双工通信、RS-485半双工通信

局部程序框图及其设计说明:

调试记录及调试结果:

MODBUS总结:

MODBUS协议

对比:

ASCII模式:用8位表示一个由内容字符转化而来的实际数值,直观;

RTU模式 :用4位表示一个由内容字符转化而来的实际数值,效率高。

其它编程注意点总结:

1、分母或乘数为2的n次方的乘除法用移位运算以提高效率,注意移位运算符的优先级比加减运算符低,别忘了加括号先算移位的;

2、short两个字节,long四个字节,int则与机器字长相关。

3、在使用多个输出函数连续进行多次输出时,有可能发现输出错误。因为下一个数据再上一个数据还没输出完毕,还在输出缓冲区中时,下一个printf就把另一个数据加入输出缓冲区,结果冲掉了原来的数据,出现输出错误。 在 prinf();后加上fflush(stdout); 强制马上输出,避免错误。

4、menset()用法: char arr[20]; memset(arr,'',20);

5、#if 0 code #endif :

(1)code中定义的是一些调试版本的代码,此时code完全被编译器忽略。如果想让code生效,只需把#if 0改成#if 1

(2)#if 0还有一个重要的用途就是用来当成注释,如果你想要注释的程序很长,这个时候#if 0是最好的,保证不会犯错误。(但是林锐的书上说千万不要把#if 0 来当作块注释使用)

#if 1可以让其间的变量成为局部变量。

(3)这个结构表示你先前写好的code,现在用不上了,又不想删除,就用这个方法,比注释方便。

程序代码清单:

/**************************************************************************

// tzdcs.c, need insmod mfix.o & m485.o first.

//

// Data Collect System Ver1.0

//

// base on MODBUS protocol (Mode:ASCII)

// Processor: Arm2410

//

// MODBUS protocol:

// (Mode:ASCII)

// START FLAG ( 0x3A ---- ':' )

// NET ADDRESS HIGH

// NET ADDRESS LOW

// COMMAND HIGH

// COMMAND LOW

// DATA LENGTH ( two char: n like '02')

// DATABUF ( n char: data_0 ~ data_n-1 )

// LRC HIGH

// LRC LOW

// END FLAG ( two char: 0x0D 0x0A ---- 'CRLF' )

//

// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

// START_FLAG AddrHigh AddrLow CmdHigh CmdLow DataLenHigh DataLenLow DataBuf[] LrcHigh LrcLow END_FLAG_1 END_FLAG_2

// 0x3A data_0~data_n-1 0x0D 0x0A

// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

//

// Author: JaneEstrong

// Email: JaneEstrong@gmail.com

// Date: 2012.09.10

//

**************************************************************************/

#include

#include

#include

#include

#include

//#include

#include

////////////////////////////////////////

#define _485_IOCTRL_RE2DE (0x10) //send or receive

#define _485_RE 0 //receive

#define _485_DE 1 //send

//#define BAUDRATE B115200

#define COM1 "/dev/tts/1"//ttyS1 RS232

#define COM2 "/dev/tts/2"// RS485

#define DEV485 "/dev/485/0raw"

////////////////////////////////////////

#define MASTER //主机标志

#define START_FLAG 0x3A // ':'

#define END_FLAG_1 0x0D // CR

#define END_FLAG_2 0x0A // LF

// rx_result

#define NOT_SEND_TO_US 0

#define ERROR_LENGTH 1

#define ERROR_LRC 2

#define ERROR_END_FLAG 3

#define VALID_PACKET 4

//uchStatus

#define MASTER_WAITING_RECEIVE_FROM_PC 1

#define NOT_MASTER_WAITING_RECEIVE_FROM_PC 2

////////////////////////////////////////

typedef unsigned char uchar;

//struct

//{

//static uchar uchStartFlag;

static uchar uchOurAddrHigh='0',uchOurAddrLow='1'; //Local Address

static uchar uchNetAddrHigh,uchNetAddrLow;

static uchar uchCmd;

static uchar uchCmdHigh,uchCmdLow;

static uchar uchDataLen;

static uchar uchDataLenHigh, uchDataLenLow;

static uchar auchDataBuf[222];

static uchar uchCalcLrcCode;

static uchar uchCalcLrcHigh, uchCalcLrcLow;

static uchar uchRxLrcCode;

static uchar uchRxLrcHigh, uchRxLrcLow;

//static uchar uchEndFlag1,uchEndFlag2;

static uchar uchStatus=0;

//} Modbus_Protocol;

/************************** Functions Declare **************************/

uchar Ascii_To_Num(uchar a);

uchar Num_To_Ascii(uchar n);

void Float16_To_String(float f, uchar *str);

void Send_Char(int fdcom, uchar ch);

void Receive_Char(int fdcom, uchar *ch);

void Modbus_Send_Packet(int fdcom);

uchar Modbus_Receive_Decode(int fdcom);

void Report_Rx_Result(uchar result);

void Reply(int fdcom, uchar rx_result);

static void Help_Menu(void);

static int Get_Baudrate(char** argv);

/**********************************************************************

* 函数名称 : main

* 函数功能 : 程序主入口函数

* 入口参数 : 无

* 出口参数 : 无

**********************************************************************/

int main(int argc, char **argv)

{

int fd485, fdcom1, fdcom2;

struct termios oldtio1,newtio1,oldstdtio1,newstdtio1;

struct termios oldtio2,newtio2,oldstdtio2,newstdtio2;

int baud;

/////////////////////////

uchar rx_result;

/////////////////////////

if((argc > 3 ) "|(argc == 1)){

Help_Menu();

exit(0);

}

fd485 = open(DEV485,O_RDWR);

if(fd485 < 0)

{

printf("####s3c2410 485 device open fail###

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

平时使用串口打印出现乱码的,绝大部分原因是串口波特率没对。那么,我们怎么测量实际的波特率呢?在这之前,顺便一起回顾一下波特率的概念。什么是波特率、比特率?比特率(Bitrate)表示每秒钟传输的二进制位数,单位为比特每秒...

关键字: 串口通讯

USR-N580是有人物联网新开发的一款工业级8串口服务器,8串口独立工作、互不影响;双网口设计,支持交换机功能,可级联,有效扩展串口数量;采用Arm Cortex-M7方案,数据传输速度快且稳定可靠;内部集成TCP/I...

关键字: 物联网 RS485 串口通讯 串口 串口服务器 交换机

摘要:针对变频器通信应用,介绍了MODBUS协议的特点及其组成;设计了RS485电路接口;并以ARMCortex-M3微控制器为核心,设计了MODBUS协议的实现方案。针对变频器F2000-G开

关键字: modbus协议

引言   现场总线作为生产过程自动化发展的重点,对推动自动化技术起到巨大的推动作用,是现代化工业的标志。MODBUS作为现场总线的一种通信协议,它实现了PLC控制器、工控仪表与设备间的通

关键字: avr单片机 智能控制系统 modbus协议

  Modbus是由Modicon(现为施耐德电气公司的一个品牌)在1979年发明的,是全球第一个真正用于工业现场的总线协议。为更好地普及和推动Modbus在基于以太网上的分布式应用,目前施耐德

关键字: modbus协议 总线协议

  Modbus协议最初由Modicon公司开发出来,是针对PLC设备设计的基于串行总线的主从模式的应用层总线设备协议。ModbusTCP是封装在TCP包内的Modbus协议,虽然有一些变化,但

关键字: modbus协议

  Modbus协议最初由Modicon公司开发出来,是针对PLC设备设计的基于串行总线的主从模式的应用层总线设备协议。ModbusTCP是封装在TCP包内的Modbus协议,虽然有一些变化,但

关键字: plc modbus协议

点击上方嵌入式开发圈 记得关注我们哦! 【134.1   应用层的“半双工”和“全双工”。】        应用层的“半双工”。主机与从机在程序应用层采用“一问一答”的查询模式,主机是主动方,从机是被动方,主机问一句从机...

关键字: 应用层 串口通讯 双机

在工业控制、电力通讯、智能仪表等领域,通常情况下是采用串口通信的方式进行数据交换。最初采用的方式是RS232接口,由于工业现场比较复杂,各种电气设备会在环境中产生比较多的电磁干扰,会导致信号传输

关键字: modbus协议 rs485通信

本文在遵循Modbus协议的基础上,阐述了Modbus的两种传输模式和串口通讯程序的设计实例,并给出了VB语言的程序清单。 基于Modbus协议的串口通讯程序----Modbus协议简介

关键字: modbus协议 rs485
关闭
关闭