版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、一个 c 语言的串口通信程序范例标签:分类: 技术笔记c 语言串口通信通信程序it最近接触一个项目, 用 HL-C1C激光位移传感器 +易控组态软件完成生产线高度跳变检测,好久没有接触 c c# ,一些资料,找来做个记录,也许大家用的着#include <stdio.h>#include <dos.h>#include <conio.h>#include <string.h>#define COM2320x2f8#define COMINT0x0b#define MaxBufLen500#define Port82590x20#define Eo
2、fInt0x20static intcomportaddr;static char intvectnum;static unsigned char maskb;static unsigned char BufferMaxBufLen;static intCharsInBuf,CircIn,CircOut;static void (interrupt far *OldAsyncInt)();static void interrupt far AsyncInt(void);void Init_COM(int ComPortAddr, unsigned char IntVectNum, int Ba
3、ud,unsigned char Data, unsigned char Stop, unsigned charParity)unsigned char High,Low;int f;comportaddr=ComPortAddr;intvectnum=IntVectNum;CharsInBuf=0;CircIn=0;CircOut=0;f=(Baud/100);f=1152/f; High=f/256;Low=f-High*256;outp(ComPortAddr+3,0x80);outp(ComPortAddr,Low);outp(ComPortAddr+1,High);Data=(Dat
4、a-5)|(Stop-1)*4);if(Parity=2) Data=Data|0x18;else if(Parity=1) Data=Data|0x8;outp(ComPortAddr+3,Data);outp(ComPortAddr+4,0x0a);outp(ComPortAddr+1,0x01);disable();OldAsyncInt=getvect( IntVectNum );setvect( IntVectNum, AsyncInt );enable();maskb=inp(Port8259+1);if(IntVectNum=0x0c)outp(Port8259+1,maskb&
5、amp;0xef);else outp(Port8259+1,maskb&0xf7);static void interrupt far AsyncInt(void)disable();if(CharsInBuf<MaxBufLen)BufferCircIn=inp(comportaddr);if(CircIn<MaxBufLen-1) CircIn+;else CircIn=0;if(CircIn=CircOut) CircOut+;else CharsInBuf+;enable();outp(Port8259,EofInt);void Restore(void)setv
6、ect(intvectnum,OldAsyncInt);outp(Port8259+1,maskb);int GetCharInBuf(unsigned char *Char)int Flag;Flag=-1;if(CharsInBuf>0)(*Char)=BufferCircOut;if(CircOut<MaxBufLen-1)CircOut+;else CircOut=0;CharsInBuf-;Flag=0;return Flag;int SendChar(unsigned char Char)if(inp(comportaddr+5)&0x20)=0) return
7、 -1;outp(comportaddr,Char);return 0;main()int i,c;unsigned char InChar;Init_COM(COM232,COMINT,1200,8,1,0);while(1)if(kbhit()if(InChar=getch()=27)break;else while(SendChar(InChar);if(GetCharInBuf(&InChar)=0)printf("%c",InChar);Restore();接收程序:#include <dos.h>#include <fstream.h&
8、gt;#include <conio.h>#include <stdio.h>#include <stdlib.h>#include <math.h>#define RXD 0 / 接收#define TXD 0 / 发送#define LSB 0 / 波特率调节低8 位#define MSB 1 / 波特率调节高8 位#define IER 1 /中断起用寄存器#define IIR 2 / 中断标识寄存器#define LCR 3 / 线路控制寄存器#define MCR 4 / 调制解调器控制寄存器#define LSR 5 / 线路状态寄
9、存器#define MSR 6 / 调制解调器状态寄存器#define IERV 1#define OUT2 0x08#define ERTS 2#define EDTR 1#define EMPTY 0X20#define READY 0X30#define ICREG 0X20#define IMASKREG 0X21#define EOI 0X20#define WAITCOUNT 5000#define BUFFLEN 2048 / 用于存储字符的数组的界#define ALTE 0X12#define ALTQ 0X10#define SER_BAUD_1200 96#define
10、SER_BAUD_2400 48#define SER_BAUD_9600 0x0C#define SER_BAUD_19200 6#define SER_STOP_1 0 /*/ 1 stop bit per character*/#define SER_STOP_2 4 /*/ 2 stop bits per character*/#define SER_BITS_5 0 /*/ send 5 bit characters*/#define SER_BITS_6 1 /*/ send 6 bit characters*/#define SER_BITS_7 2 /*/ send 7 bit
11、 characters*/#define SER_BITS_8 3 /*/ send 8 bit characters*/#define SER_PARITY_NONE 0 /*/ no parity*/#define SER_PARITY_ODD 8 /*/ odd parity*/#define SER_PARITY_EVEN 24 /*/ even parity*/int port;int ComNum;unsigned portaddr;unsigned portf;unsigned int baudtable=0x180,0xc0,0x60,0x30,0x18,0x0c,0x06;
12、unsigned char paritytable=0x08,0x18,0x00,0x28,0x38; unsigned char bufferBUFFLEN;/recv buf int buffin=0;int buffout=0;int incount=0;int outcount=0;void interrupt(*vect_com)(.);void putb(unsigned char ch)/write a char to the recvbuf将中断得到的数据写到缓冲区int temp;temp=buffin;if(+buffin=BUFFLEN)buffin=0;if(buffi
13、n!=buffout)bufferbuffin=ch;/ printf("bufferin%d=%c",bufferbuffin);/ getch();elsebuffin=temp;unsigned char getb()/read a char from the recvbufif(buffout!=buffin)if(+buffout=BUFFLEN)buffout=0;/printf("bufferout%d=%c",buffout,bufferbuffout);return(bufferbuffout);elsereturn(0xff);/*u
14、nsigned char sender( unsigned char ch)outportb(portaddr2+TXD,ch);printf("nsender outportdata=%cn",ch);outcount+;return(1);*/void interrupt receiver(.)unsigned char ch;ch=inportb(portaddr+RXD);putb(ch);incount+; / 记录接收了多少个数据。outportb(ICREG,EOI);void SerInit(int baud,int configuration)disabl
15、e();outportb(portaddr+LCR,0x80);outportb(portaddr+LSB,baud);outportb(portaddr+MSB,0x00);outportb(portaddr+LCR,configuration);enable();void SerOpen(void)vect_com=getvect(portf+8);disable();inportb(portaddr+RXD);inportb(portaddr+MSR);inportb(portaddr+LSR);inportb(portaddr+IIR);outportb(portaddr+IER,IE
16、RV);outportb(portaddr+MCR,OUT2|ERTS|EDTR);outportb(IMASKREG,inportb(IMASKREG)&(1<<portf);setvect(portf+8,receiver);enable();void SerClose(void)disable();outportb(portaddr+IER,0);outportb(portaddr+MCR,0);outportb(IMASKREG,inportb(IMASKREG)|(1<<portf);enable();setvect(portf+8,vect_com)
17、;void Getportaddr(int port)switch (port)case 0: portaddr=0x3F8; break;case 1: portaddr=0x2F8; break;case 2: portaddr=0x3E8; break;case 3: portaddr=0x2E8; break;portf=(port=0)?4:3;void Int()unsigned char key,key2;port=ComNum-1;if(peek(0x40,port*2)=0)printf("have no special com .n");exit(1);
18、elseprintf("The used port is :COM%dn",ComNum);Getportaddr(port); /得到串口地址SerInit(SER_BAUD_9600,SER_PARITY_EVEN|SER_BITS_8 | SER_STOP_1); /初始化串口,设置波特率等SerOpen();doif(kbhit()key2=getch();if(key2=27) break;key=getb();if(key!=0xff)printf("%xt",key);FILE *fp;fp=fopen("C:Receivedat
19、a.dat","ab"); / 可选择接收数据的存放文件路径和文件名 if(fp=NULL) printf("File open error!");/ fputc(key,fp); fwrite(&key,sizeof(unsigned char),1,fp); fclose(fp);while (key2!=27);SerClose();/ printf("%d char has been receivedn",incount);/ printf("%d char has been sendedn&quo
20、t;,outcount);/ printf("nsum=%d n",sum);void main()/com1 receiveprintf("Please input the receive COMnum:(14)n");cin>>ComNum;printf("the current com set is:9600,even, data bits 8, stop 1,");Int();printf("nnOVERn");exit(0);发送文件程序#include <dos.h>#inclu
21、de <bios.h>#include <stdio.h>#include <math.h>#include <conio.h>#include <graphics.h>#ifdef _cplusplus#define _CPPARGS .#else#define _CPPARGS#endif#define SER_RBF 0#define SER_THR 0#define SER_IER 1#define SER_IIR 2#define SER_LCR 3#define SER_MCR 4#define SER_LSR 5#def
22、ine SER_MSR 6#define SER_DLL 0#define SER_DLH 1#define SER_BAUD_1200 96#define SER_BAUD_2400 48#define SER_BAUD_9600 12#define SER_BAUD_19200 6#define SER_GP02 8#define COM_1 0x3F8#define COM_2 0x2F8 /*/ base port address of port 1*/#define COM_3 0x3E8#define COM_4 0x2E8#define SER_STOP_1 0 /*/ 1 st
23、op bit per character*/#define SER_STOP_2 4 /*/ 2 stop bits per character*/#define SER_BITS_5 0 /*/ send 5 bit characters*/#define SER_BITS_6 1 /*/ send 6 bit characters*/#define SER_BITS_7 2 /*/ send 7 bit characters*/#define SER_BITS_8 3 /*/ send 8 bit characters*/#define SER_PARITY_NONE 0 /*/ no p
24、arity*/#define SER_PARITY_ODD 8 /*/ odd parity*/#define SER_PARITY_EVEN 24 /*/ even parity*/#define SER_DIV_LATCH_ON 128 /*/ used to turn reg 0,1 into divisor latch*/ #define PIC_IMR 0x21 /*/ pic's interrupt mask reg.*/ #define PIC_ICR 0x20 /*/ pic's interupt control reg.*/#define INT_SER_PO
25、RT_0 0x0C /*/ port 0 interrupt com 1 & 3*/ #define INT_SER_PORT_1 0x0B /*/ port 0 interrupt com 2 & 4*/#define SERIAL_BUFF_SIZE 128 /*/ current size of circulating receive buffer*/ void interrupt far (*Old_Isr)(_CPPARGS); /*/ holds old com port interrupt handler*/ char ser_bufferSERIAL_BUFF_
26、SIZE; /*/ the receive buffer*/int ser_end = -1,ser_start=-1; /*/ indexes into receive buffer*/ int ser_ch, char_ready=0; /*/ current character and ready flag*/ int old_int_mask; /*/ the old interrupt mask on the PIC*/ int open_port; /*/ the currently open port*/int serial_lock = 0; /*/ serial ISR se
27、maphore so the buffer*/*/ isn't altered will it is being written*/*/ to by the ISR*/*- 写串口 -*/void interrupt far Serial_Isr(_CPPARGS)serial_lock = 1;ser_ch = inp(open_port + SER_RBF);if (+ser_end > SERIAL_BUFF_SIZE-1)ser_end = 0;ser_bufferser_end = ser_ch;+char_ready;outp(PIC_ICR,0x20);serial
28、_lock = 0;int Ready_Serial()return(char_ready);/*-读串口 -*/int Serial_Read()int ch;while(serial_lock)if (ser_end != ser_start)if (+ser_start > SERIAL_BUFF_SIZE-1)ser_start = 0;ch = ser_bufferser_start;printf("%x",ch);if (char_ready > 0)-char_ready;return(ch);elsereturn(0);/*-写串口 -*/Ser
29、ial_Write(char ch)while(!(inp(open_port + SER_LSR) & 0x20)asm clioutp(open_port + SER_THR, ch);asm sti/*- 初始化串口 -*/Open_Serial(int port_base, int baud, int configuration)open_port = port_base;disable();outp(port_base + SER_LCR, SER_DIV_LATCH_ON);outp(port_base + SER_DLL, baud);outp(port_base + S
30、ER_DLH, 0);outp(port_base + SER_LCR, configuration);outp(port_base + SER_MCR, SER_GP02);outp(port_base + SER_IER, 1);if (port_base = COM_1 | port_base=COM_3)Old_Isr = _dos_getvect(INT_SER_PORT_0);_dos_setvect(INT_SER_PORT_0, Serial_Isr);printf("nOpening Communications Channel Com Port #1/3.n&qu
31、ot;);elseOld_Isr = _dos_getvect(INT_SER_PORT_1);_dos_setvect(INT_SER_PORT_1, Serial_Isr);printf("nOpening Communications Channel Com Port #2/4.n");old_int_mask = inp(PIC_IMR);outp(PIC_IMR, (port_base=COM_1) ? (old_int_mask & 0xEF) : (old_int_mask & 0xF7 );enable();/*- 关闭串口 -*/Close
32、_Serial(int port_base)outp(port_base + SER_MCR, 0);outp(port_base + SER_IER, 0);outp(PIC_IMR, old_int_mask );if (port_base = COM_1)_dos_setvect(INT_SER_PORT_0, Old_Isr);printf("nClosing Communications Channel Com Port #1.n");else_dos_setvect(INT_SER_PORT_1, Old_Isr);printf("nClosing C
33、ommunications Channel Com Port #2.n");/*- 发送应用 -*/void main(int argc,char *argv)char ch,press;int done=0;FILE *fp;argc=2;/argv1="c:comfile.c"if(argc<2)printf("nUsage:display filename.wav!");/ exit(1);if(fp=fopen(argv1,"r+b")=NULL)printf("cannot open the filen");/ exit(0);fseek(fp, 0, SEEK_SET);Open_Serial(COM_1,SER_BAUD_9600,SER_PARITY_EVEN|SER_BITS_8|SER_STOP_1);printf(&quo
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2026年潮玩品牌运营策略培训
- 2026年水利工程中的智能化监测技术
- 2025年财务副职竞聘笔试题及答案
- 2025年延长石油秋招笔试及答案
- 2025年大学竞选干部笔试题目及答案
- 2025年网易3d角色制作笔试及答案
- 2026新疆中闽(哈密)能源有限公司招聘3人考试备考试题及答案解析
- 2025年永州网人事考试及答案
- 2025年幼教笔试重点归纳知识点及答案
- 2026湖南智谷投资发展集团有限公司招聘补充笔试备考题库及答案解析
- 2025年普外副高考试试题及答案
- 餐饮执法办案课件
- 铁路安全管理条例课件
- 2025年大唐杯试题题库及答案
- 政务新媒体运营培训课件
- 山东省济南市2025届中考英语真题(含部分答案无音频及听力原文)
- 合作平台管理办法
- 人工智能赋能基础教育应用蓝皮书 2025
- 惠州一中钱学森班数学试卷
- 辅助生殖实验室技术课件
- (高清版)DB14∕T 3449-2025 危险化学品道路运输事故液态污染物应急收集系统技术指南
评论
0/150
提交评论