


版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、#include"main.h/字地址0-255促取低8位)位地址0-255促取低8位)/*CRC高位字节值表*/constuint8codeauchCRCHi=(0x00,0xC1,0x81,0x40,0x01,0xC0,0x80,0x41,0x01,0xC0,0x80,0x41,0x00,0xC1,0x81,0x40,0x01,0xC0,0x80,0x41,0x00,0xC1,0x81,0x40,0x00,0xC1,0x81,0x40,0x01,0xC0,0x80,0x41,0x01,0xC0,0x80,0x41,0x00,0xC1,0x81,0x40,0x00,0xC1,0x8
2、1,0x40,0x01,0xC0,0x80,0x41,0x00,0xC1,0x81,0x40,0x01,0xC0,0x80,0x41,0x01,0xC0,0x80,0x41,0x00,0xC1,0x81,0x40,0x01,0xC0,0x80,0x41,0x00,0xC1,0x81,0x40,0x00,0xC1,0x81,0x40,0x01,0xC0,0x80,0x41,0x00,0xC1,0x81,0x40,0x01,0xC0,0x80,0x41,0x01,0xC0,0x80,0x41,0x00,0xC1,0x81,0x40,0x00,0xC1,0x81,0x40,0x01,0xC0,0x8
3、0,0x41,0x01,0xC0,0x80,0x41,0x00,0xC1,0x81,0x40,0x01,0xC0,0x80,0x41,0x00,0xC1,0x81,0x40,0x00,0xC1,0x81,0x40,0x01,0xC0,0x80,0x41,0x01,0xC0,0x80,0x41,0x00,0xC1,0x81,0x40,0x00,0xC1,0x81,0x40,0x01,0xC0,0x80,0x41,0x00,0xC1,0x81,0x40,0x01,0xC0,0x80,0x41,0x01,0xC0,0x80,0x41,0x00,0xC1,0x81,0x40,0x00,0xC1,0x8
4、1,0x40,0x01,0xC0,0x80,0x41,0x01,0xC0,0x80,0x41,0x00,0xC1,0x81,0x40,0x01,0xC0,0x80,0x41,0x00,0xC1,0x81,0x40,0x00,0xC1,0x81,0x40,0x01,0xC0,0x80,0x41,0x00,0xC1,0x81,0x40,0x01,0xC0,0x80,0x41,0x01,0xC0,0x80,0x41,0x00,0xC1,0x81,0x40,0x01,0xC0,0x80,0x41,0x00,0xC1,0x81,0x40,0x00,0xC1,0x81,0x40,0x01,0xC0,0x8
5、0,0x41,0x01,0xC0,0x80,0x41,0x00,0xC1,0x81,0x40,0x00,0xC1,0x81,0x40,0x01,0xC0,0x80,0x41,0x00,0xC1,0x81,0x40,0x01,0xC0,0x80,0x41,0x01,0xC0,0x80,0x41,0x00,0xC1,0x81,0x40;/*CRC低位字节值表*/constuint8codeauchCRCLo=(0x00,0xC0,0xC1,0x01,0xC3,0x03,0x02,0xC2,0xC6,0x06,0x07,0xC7,0x05,0xC5,0xC4,0x04,0xCC,0x0C,0x0D,
6、0xCD,0x0F,0xCF,0xCE,0x0E,0x0A,0xCA,0xCB,0x0B,0xC9,0x09,0x08,0xC8,0xD8,0x18,0x19,0xD9,0x1B,0xDB,0xDA,0x1A,0x1E,0xDE,0xDF,0x1F,0xDD,0x1D,0x1C,0xDC,0x14,0xD4,0xD5,0x15,0xD7,0x17,0x16,0xD6,0xD2,0x12,0x13,0xD3,0x11,0xD1,0xD0,0x10,0xF0,0x30,0x31,0xF1,0x33,0xF3,0xF2,0x32,0x36,0xF6,0xF7,0x37,0xF5,0x35,0x34,
7、0xF4,0x3C,0xFC,0xFD,0x3D,0xFF,0x3F,0x3E,0xFE,0xFA,0x3A,0x3B,0xFB,0x39,0xF9,0xF8,0x38,0x28,0xE8,0xE9,0x29,0xEB,0x2B,0x2A,0xEA,0xEE,0x2E,0x2F,0xEF,0x2D,0xED,0xEC,0x2C,0xE4,0x24,0x25,0xE5,0x27,0xE7,0xE6,0x26,0x22,0xE2,0xE3,0x23,0xE1,0x21,0x20,0xE0,0xA0,0x60,0x61,0xA1,0x63,0xA3,0xA2,0x62,0x66,0xA6,0xA7,
8、0x67,0xA5,0x65,0x64,0xA4,0x6C,0xAC,0xAD,0x6D,0xAF,0x6F,0x6E,0xAE,0xAA,0x6A,0x6B,0xAB,0x69,0xA9,0xA8,0x68,0x78,0xB8,0xB9,0x79,0xBB,0x7B,0x7A,0xBA,0xBE,0x7E,0x7F,0xBF,0x7D,0xBD,0xBC,0x7C,0xB4,0x74,0x75,0xB5,0x77,0xB7,0xB6,0x76,0x72,0xB2,0xB3,0x73,0xB1,0x71,0x70,0xB0,0x50,0x90,0x91,0x51,0x93,0x53,0x52,
9、0x92,0x96,0x56,0x57,0x97,0x55,0x95,0x94,0x54,0x9C,0x5C,0x5D,0x9D,0x5F,0x9F,0x9E,0x5E,0x5A,0x9A,0x9B,0x5B,0x99,0x59,0x58,0x98,0x88,0x48,0x49,0x89,0x4B,0x8B,0x8A,0x4A,0x4E,0x8E,0x8F,0x4F,0x8D,0x4D,0x4C,0x8C,0x44,0x84,0x85,0x45,0x87,0x47,0x46,0x86,0x82,0x42,0x43,0x83,0x41,0x81,0x80,0x40;uint8testCoil;/
10、用于测试位地址1uint16testRegister;用于测试字址址16uint8localAddr=1;单片机控制板的地址uint8sendCount;/发送字节个数uint8receCount;/接收到的字节个数uint8sendPosi;/发送位置uint16crc16(uint8*puchMsg,uint16usDataLen)uint8uchCRCHi=0xFF;/*高CRC字节初始化*/uint8uchCRCLo=0xFF;/*(氐CRC字节初始化*/uint32ulndex;/*CRC循环中的索引*/while(usDataLen-)/*传输消息缓冲区*/ulndex=uchCR
11、CHiA*puchMsg+;/*计算CRC*/uchCRCHi=uchCRCLoaauchCRCHiuIndex;uchCRCLo=auchCRCLouIndex;return(uchCRCHi<<8|uchCRCLo);/uint16crc16(uint8*puchMsg,uint16usDataLen)/开始发送voidbeginSend(void)(b485Send=1;设为发送sendPosi=0;if(sendCount>1)sendCount-;ACC=sendBuf0;TB8=P;SBUF=sendBuf0;/voidbeginSend(void)读线圈状态vo
12、idreadCoil(void)(uint8addr;uint8tempAddr;uint8byteCount;uint8bitCount;uint16crcData;uint8position;uint8i,k;uint8result;uint16tempData;uint8exit=0;/addr=(receBuf2<<8)+receBuf3;/tempAddr=addr&0xfff;addr=receBuf3;tempAddr=addr;/bitCount=(receBuf4<<8)+receBuf5;/读取的位个数bitCount=receBuf5;by
13、teCount=bitCount/8;/字节个数if(bitCount%8!=0)byteCount+;for(k=0;k<byteCount;k+)(/字节位置position=k+3;sendBufposition=0;for(i=0;i<8;i+)(getCoilVal(tempAddr,&tempData);sendBufposition|=tempData<<i;tempAddr+;if(tempAddr>=addr+bitCount)if(tempAddr>=addr+bitCount)读完exit=1;break;if(exit=1)b
14、reak;sendBuf0=localAddr;sendBuf1=0x01;sendBuf2=byteCount;byteCount+=3;crcData=crc16(sendBuf,byteCount);sendBufbyteCount=crcData>>8;byteCount+;sendBufbyteCount=crcData&0xff;sendCount=byteCount+1;beginSend();/voidreadCoil(void)/读寄存器voidreadRegisters(void)uint8addr;uint8tempAddr;uint16result;
15、uint16crcData;uint8readCount;uint8byteCount;uint8finsh;/1完成0出错uint16i;uint16tempData=0;/addr=(receBuf2<<8)+receBuf3;/tempAddr=addr&0xfff;addr=receBuf3;tempAddr=addr;/readCount=(receBuf4<<8)+receBuf5;要读的个数readCount=receBuf5;byteCount=readCount*2;for(i=0;i<byteCount;i+=2,tempAddr+)(
16、getRegisterVal(tempAddr,&tempData);sendBufi+3=tempData>>8;sendBufi+4=tempData&Oxff;sendBuf0=localAddr;sendBuf1=3;sendBuf2=byteCount;byteCount+=3;crcData=crc16(sendBuf,byteCount);sendBufbyteCount=crcData>>8;byteCount+;sendBufbyteCount=crcData&Oxff;sendCount=byteCount+1;beginSe
17、nd();/voidreadRegisters(void)强制单个线圈voidforceSingleCoil(void)(uint8addr;uint8tempAddr;uint16tempData;uint8onOff;uint8i;/addr=(receBuf2<<8)+receBuf3;/tempAddr=addr&Oxfff;addr=receBuf3;tempAddr=addr;/onOff=(receBuf4<<8)+receBuf5;onOff=receBuf4;/if(onOff=0xff00)if(onOff=0xff)(设为ONtempDat
18、a=1;/elseif(onOff=0x0000)elseif(onOff=0x00)(/设为OFFtempData=0;setCoilVal(tempAddr,tempData);for(i=0;i<receCount;i+)(sendBufi=receBufi;sendCount=receCount;beginSend();/voidforceSingleCoil(void)/设置多个寄存器voidpresetMultipleRegisters(void)(uint8addr;uint8tempAddr;uint8byteCount;uint8setCount;uint16crcDa
19、ta;uint16tempData;uint8finsh;/为1时完成为0时出错uint8i;/addr=(receBuf2<<8)+receBuf3;/tempAddr=addr&0xfff;addr=receBuf3;tempAddr=addr&0xff;/setCount=(receBuf4<<8)+receBuf5;setCount=receBuf5;byteCount=receBuf6;for(i=0;i<setCount;i+,tempAddr+)(tempData=(receBufi*2+7<<8)+receBufi*2+
20、8;setRegisterVal(tempAddr,tempData);sendBuf0=localAddr;sendBuf1=16;sendBuf2=addr>>8;sendBuf3=addr&0xff;sendBuf4=setCount>>8;sendBuf5=setCount&0xff;crcData=crc16(sendBuf,6);sendBuf6=crcData>>8;sendBuf7=crcData&0xff;sendCount=8;beginSend();/voidpresetMultipleRegisters(voi
21、d)/检查uart0数据voidcheckComm0Modbus(void)uint16crcData;uint16tempData;if(receCount>4)switch(receBuf1)case1:/读取线圈状态(读取点16位以内)case3:/读取保持寄存器(一个或多个)case5:/强制单个线圈case6:/设置单个寄存器if(receCount>=8)/接收完成一组数据/应该关闭接收中断if(receBuf0=localAddr&&checkoutError=0)crcData=crc16(receBuf,6);if(crcData=receBuf7
22、+(receBuf6<<8)/校验正确if(receBuf1=1)/读取线圈状态(读取点16位以内)readCoil();elseif(receBuf1=3)读取保持寄存器(一个或多个)readRegisters();elseif(receBuf1=5)/强制单个线圈forceSingleCoil();elseif(receBuf1=6)/presetSingleRegister();receCount=0;checkoutError=0;break;case15:/设置多个线圈tempData=receBuf6;tempData+=9;数据个数if(receCount>=t
23、empData)if(receBuf0=localAddr&&checkoutError=0)crcData=crc16(receBuf,tempData-2);if(crcData=(receBuftempData-2<<8)+receBuftempData-1)/forceMultipleCoils();receCount=0;checkoutError=0;break;case16:/设置多个寄存器tempData=(receBuf4<<8)+receBuf5;tempData=tempData*2;数据个数tempData+=9;if(receC
24、ount>=tempData)if(receBuf0=localAddr&&checkoutError=0)(crcData=crc16(receBuf,tempData-2);if(crcData=(receBuftempData-2<<8)+receBuftempData-1)(presetMultipleRegisters();receCount=0;checkoutError=0;break;default:break;/voidcheckComm0(void)/取线圈状态返回0表示成功uint16getCoilVal(uint16addr,uint1
25、6*tempData)(uint16result=0;uint16tempAddr;tempAddr=addr&0xfff;/只取低8位地址switch(tempAddr&0xff)(case0:break;case1:*tempData=testCoil;break;case2:break;case3:break;case4:break;case5:break;case6:break;case7:break;case8:break;case9:break;case10:break;case11:break;case12:break;case13:break;case14:br
26、eak;case15:break;case16:break;default:break;returnresult;/uint16getCoilVal(uint16addr,uint16*data)/设定线圈状态返回0表示成功uint16setCoilVal(uint16addr,uint16tempData)uint16result=0;uint16tempAddr;tempAddr=addr&0xfff;switch(tempAddr&0xff)case0:break;case1:testCoil=tempData;break;case2:break;case3:break;case4:break;case5:break;case6:break;case7:break;case8:break;case9:break;case10:break;case11:break;case12:break;case13:break;case14:break;case15:break;case16:break;default:break;returnresult;/uint16setCoilVal(uint16addr,uint16data)
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025福建泉州市洛江区总商会招聘编外工作人员1人考前自测高频考点模拟试题及答案详解(考点梳理)
- 2025广东省事业单位集中招聘高校毕业生广州市中级人民法院岗位笔试模拟试卷带答案详解
- 贵州国企招聘2025贵州惠信餐饮管理有限责任公司招聘笔试历年参考题库附带答案详解
- 浙江国企招聘2025绍兴鉴湖酿酒有限公司公开招聘劳务派遣外包人员16人笔试历年参考题库附带答案详解
- 225四川长虹电子控股集团有限公司招聘宣传策划经理等岗位2人笔试历年参考题库附带答案详解
- 2025陕西西安建工物流设备集团3月招聘笔试历年参考题库附带答案详解
- 2025陕西榆林府谷能源投资集团有限公司选聘24人笔试历年参考题库附带答案详解
- 2025辽控集团所属国合集团招聘1人笔试历年参考题库附带答案详解
- 2025贵州黔南州都匀市农旅集团诚聘驻场生猪养殖技术人员6人笔试历年参考题库附带答案详解
- 2025贵州水投水库运营管理黔东南有限公司面向社会招聘笔试笔试历年参考题库附带答案详解
- 2025国企竞聘上岗与干部竞聘上岗笔试题及答案
- 人工智能与建筑产业体系智能化升级研究报告
- 武科大大学生手册考试内容及答案
- 集装箱吊装专项施工方案
- 2025年中国家用WiFi路由器行业市场全景分析及前景机遇研判报告
- 2025年领导干部任前廉政法规知识考试题库(含答案)
- 2025年山东省济宁市邹城市第十一中学中考二模数学试题
- 信息技术基础教程(WPS版)课件 第3章 Windows 10 操作系统的使用
- 小鹿斑比题目及答案
- 2024超声法检测混凝土缺陷技术规程
- 2025-2030中国建筑行业供应链金融发展现状与前景分析
评论
0/150
提交评论