亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? gserial.cpp

?? 串口中斷方式通信源程序
?? CPP
字號:

  /*------------------------------------------------------------------*
	  GSERIAL.CPP

	  For asynchronous serial port communications

      ATTENTION: Compile this program with Test Stack Overflow OFF.
				(TC++3: Options/Compiler/Entry
  *------------------------------------------------------------------*/

#include <dos.h>
#include <conio.h>
#include <stdio.h>
#include <string.h>
#include "gserial.h"

#define VERSION 0x0101

#define FALSE				0
#define TRUE				1

#define NO_ERROR			0       /* No error               */
#define BUF_OVFL			1       /* Buffer overflowed      */

#define ESC					0x1B    /* ASCII Escape character */
#define ASCII				0x007F  /* Mask ASCII characters  */
//#define SBUFSIZ			0x4000  /* Serial buffer size     */
#define SBUFSIZ				0x08	/* Serial buffer size     */
#define IBUF_LEN			2048    // Incoming buffer
#define OBUF_LEN			1024    // Outgoing buffer


void           interrupt(*oldvects[2])(...);

/*  get status of the port  */
int read_status_com(int portn)
{
  return(inp(portn+5));
}

/*  send one valid char from the port  */
void send_char_com(int portn,int cc)
{
   while ((read_status_com(portn) & 0x40) == 0);
   outportb(portn,cc);
}

/*  send one string from the port  */
void send_string_com(int portn,int strlen,unsigned char *buf)
{
	int k;	k=0;
   do {
	   send_char_com(portn,*(buf + k));	k++;
	  } while ((k < strlen));
}



void interrupt com_int(...)
{
	int temp;
	disable();
	temp = (inportb(portbase+IIR)) & IIR_MASK;				// why interrupt was called
	switch(temp)
	{
		case 0x00:  // modem status changed
			inportb(portbase+MSR);   // read in useless char
			break;
		case 0x02:  // Request To Send char
			if (outhead != outtail)							// there's a char to send
			{
				outportb(portbase+TXR,outbuf[outhead++]);	// send the character
				if (outhead == OBUF_LEN)
					outhead=0;								// if at end of buffer, reset pointer
			}
			break;
		case 0x04:  // character ready to be read in
			inbuf[inhead++] = inportb(portbase+RXR);// read character into inbuffer
			if (inhead == IBUF_LEN) // if at end of buffer
				inhead=0;           // reset pointer
			break;
		case 0x06:  // line status has changed
			inportb(portbase+LSR);     // read in useless char
			break;
		default:
			break;

	}

	outportb(PIC8259_ICR, PIC8259_EOI);	// Signal end of hardware interrupt
	enable();							// reenable interrupts at the end of the handler

}



// Inserts the character to be outputted into the output buffer, checking
// for an open slot in the output buffer array.  If there is, insert
// the character, or if there isn't, wait until a slot opens up.
serial& serial::operator<<( char ch )
{
	if (ch)								// If this is a valid char
	{
		enable();						// turn on irqs to ensure data output
		//outportb(portbase + MCR,  MCR_INT | MCR_DTR | MCR_RTS);//modem control,
		outportb(portbase + IER,  IER_RX_INT);
		// check buffer, and if full, wait for an available opening

	//	fprintf(stdout,"\n %c is pressed!\n",ch);   //You can use this to verify which key is hit during your test
		while((outhead-1==outtail) ||(outtail==OBUF_LEN-1 && outhead==0));
		disable();						// make sure nothing happens while changing buffer
		outbuf[outtail++] = ch;			// insert character into buffer;
		if (outtail == OBUF_LEN)		// if at end of out buffer
			outtail = 0;				// reset pointer
		if((inportb(portbase+IER)&IER_TX_INT) == 0)
			outportb(portbase+IER,IER_TX_INT | IER_RX_INT);
		enable();                       // re-enable interrupts
	}

	return(*this);
}


serial &serial::operator<<( char *str )
// Outputs a string to the serial port
{
	while (*str)
	{
		(*this) << (*str);
		str++;
	}
	return(*this);
}


serial &serial::operator>>( char &ch )
// Returns either the character to be received from modem if there is one
// waiting in the buffer, or returns a 0 if there is no character waiting.
{
	if (inhead != intail)     // there is a character
	{
		disable();                          // disable irqs while getting char
		ch = inbuf[intail++];               // get character from buffer
		if (intail == IBUF_LEN)				// if at end of in buffer
			intail=0;						// reset pointer
		enable();                           // re-enable interrupt
		return(*this);                      // return the char
	}
	ch = -1;
	return(*this);                          // return nothing
}



/* Install our functions to handle communications */
void setvects(void)
{
    oldvects[0] = getvect(0x0B);
	oldvects[1] = getvect(0x0C);
    setvect(0x0B, com_int);
	setvect(0x0C, com_int);
}

/* Uninstall our vectors before exiting the program */
void resvects(void)
{
    setvect(0x0B, oldvects[0]);
    setvect(0x0C, oldvects[1]);
}



/* Tell modem that we're ready to go */
void serial::comm_on(void)
{
    int temp, pnum;


	disable();
	temp = inportb(portbase + MCR) | 0x0f;//MCR_INT;
	outportb(portbase + MCR, temp);
	temp = (inportb(portbase + IER)) | IER_RX_INT;//|IER_TX_INT;
	outportb(portbase + IER, temp);
	pnum = (portbase == COM1BASE ? COM1 : COM2);
	temp = inportb(PIC8259_IMR) & (pnum == COM1 ? IRQ4 : IRQ3);
	outportb(PIC8259_IMR, temp);

 //	temp = inportb(portbase + MCR) | MCR_DTR | MCR_RTS;
 //	outportb(portbase + MCR, temp);
	enable();
}

/* Go off-line */
void serial::comm_off(void)
{
     int  temp;

    disable();
	temp = inportb(PIC8259_IMR) | ~IRQ3 | ~IRQ4;
    outportb(PIC8259_IMR, temp);
    outportb(portbase + IER, 0);
	outportb(portbase + MCR, 0);
	enable();
}

void serial::init_serial(void)
{
    endbuf = startbuf = 0;
	setvects();
	comm_on();
}

serial::~serial()
{
    comm_off();
    resvects();
}

/* Set the port number to use */
int serial::SetPort(int Port)
{
    int  Offset, far *RS232_Addr;

    switch (Port)
	{ /* Sort out the base address */
      case COM1 : 
		  Offset = 0x0000;
          break;
      case COM2 : 
		  Offset = 0x0002;
		  break;
      default   :
		  printf("\ncannot find the serial port.\n");
		  return (-1);
    }

	RS232_Addr = (int far *)MK_FP(0x0040, Offset);  /* Find out where the port is. */
	if (*RS232_Addr == NULL)
	{
		printf("\ncannot find the serial port.\n");
		return (-1);                     /* If NULL then port not used. */
	}
    portbase = *RS232_Addr;              /* Otherwise set portbase      */

	return (0);
}

/* This routine sets the speed; will accept funny baud rates. */
/* Setting the speed requires that the DLAB be set on.        */
int serial::SetSpeed(int Speed)
{
	char	c;
    int		divisor;

    if (Speed == 0)            /* Avoid divide by zero */
        return (-1);
	else
        divisor = (int) (115200L/Speed);

    if (portbase == 0)
        return (-1);

    disable();
	c = inportb(portbase + LCR);
    outportb(portbase + LCR, (c | 0x80)); /* Set DLAB */
    outportb(portbase + DLL, (divisor & 0x00FF));
    outportb(portbase + DLH, ((divisor >> 8) & 0x00FF));
    outportb(portbase + LCR, c);          /* Reset DLAB */
	enable();

	return (0);
}

/* Set other communications parameters */
int serial::SetOthers(int Parity, int Bits, int StopBit)
{
	int  setting;

	if (portbase == 0)
		return (-1);
	if (Bits < 5 || Bits > 8)
		return (-1);
    if (StopBit != 1 && StopBit != 2)			
		return (-1);
    if (Parity != LCR_NO_PARITY && Parity != LCR_ODD_PARITY && Parity != LCR_EVEN_PARITY)
		return (-1);

    setting  = Bits-5;
    setting |= ((StopBit == 1) ? 0x00 : 0x04);
	setting |= Parity;

	disable();
	outportb(portbase + LCR, setting);
    enable();

    return (0);
}

/* Set up the port */
serial::serial(int Port, int Speed, int Parity, int Bits, int StopBit)
{
	flag = 0;
	if (SetPort(Port))
	  flag = -1;
	if (SetSpeed(Speed))
	  flag = -1;
	if (SetOthers(Parity, Bits, StopBit))
	  flag = -1;

	if (!flag)
	   init_serial();
}

/*  Control-Break interrupt handler */
int c_break(void)
{
	int temp;
	disable();
	temp = inportb(PIC8259_IMR) | ~IRQ3 | ~IRQ4;
	outportb(PIC8259_IMR, temp);
	outportb(portbase + IER, 0);
	outportb(portbase + MCR, 0);
	enable();
	fprintf(stderr, "\nStill online.\n");
	return(0);
}

main()
{
	/* Communications parameters */
	int        port     = COM1;
	int        speed    = 9600;
	int        parity   = LCR_NO_PARITY;
	int        bits     = 8;
	int        stopbits = 1;
	int        done  = FALSE;
	char       c;
	int temp,i=0,j=0;

	serial comport(port, speed, parity, bits, stopbits);

	ctrlbrk(c_break);
	//for(i=0;i<OBUF_LEN;i++)
	//{
	//	outbuf[i] = 'a'+i;
	//}
	//static   char  outbuf[OBUF_LEN];		// out buffer

	fprintf(stdout, "TURBO C TERMINAL\n"
			"...You're now in terminal mode, "
			"press [ESC] to quit...\n\n");

	/*
	   The main loop aMSR_CTS as a dumb terminal. We repeatedly
	   check the keyboard buffer, and communications buffer.
	*/
	do {
		if (kbhit())
		{
			c=getch();
			/* Look for an Escape key */
			switch (c)
			{
				case ESC:
					done = TRUE;  /* Exit program */
					break;

			//You may want to handle other keys here
			}
			if (!done)   comport<<c;
			//send_char_com(portbase,c); //This is another send function,I add this function because some people (esp. older) don't like c++(they use c)
		}
		delay(50);
		comport >> c;
		if (c != -1)     //'-1' is the END signal of a string
		{
			//fputc(c & ASCII, stdout);
			fprintf(stdout,"%c",c);
		}

	} while (!done && !SError);

	/* Check for errors */
	switch (SError)
	{
		case NO_ERROR: fprintf(stderr, "\nbye.\n");
					  return (0);

		case BUF_OVFL: fprintf(stderr, "\nBuffer Overflow.\n");
					  return (99);

		default:      fprintf(stderr, "\nUnknown Error, SError = %d\n",
							  SError);
					  return (99);
	}
}


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人免费在线视频观看| 日韩精品最新网址| 国产精品综合一区二区三区| 亚洲欧美日韩国产综合在线| 欧美一区二区三区四区五区| 91女神在线视频| 极品少妇xxxx精品少妇| 亚洲黄色小视频| 日本一区二区视频在线观看| 欧美一卡二卡三卡| 欧美伊人久久久久久久久影院| 国产精品性做久久久久久| 天天av天天翘天天综合网| 国产精品久久久久久亚洲毛片 | 91女神在线视频| 国内精品伊人久久久久av影院| 亚洲综合男人的天堂| 国产精品国产自产拍高清av王其 | 久久九九久久九九| 欧美一区二区三区在线看| 欧美在线视频全部完| av在线播放不卡| 国v精品久久久网| 国产乱人伦偷精品视频免下载| 另类综合日韩欧美亚洲| 日欧美一区二区| 午夜欧美在线一二页| 夜夜嗨av一区二区三区中文字幕| 国产精品理伦片| 国产精品伦理一区二区| 日本一区二区三区在线观看| 国产亚洲美州欧州综合国| 日韩欧美www| 欧美一级一级性生活免费录像| 欧美色精品天天在线观看视频| 欧美亚洲高清一区二区三区不卡| 91性感美女视频| 日本高清免费不卡视频| 色综合久久99| 在线观看av不卡| 欧美午夜精品久久久久久超碰| 欧洲国产伦久久久久久久| 欧洲一区二区三区免费视频| 欧美亚洲国产一区在线观看网站| 欧美唯美清纯偷拍| 欧美日韩高清一区二区三区| 欧美日韩国产123区| 日韩欧美综合在线| 日韩精品一区在线观看| 精品福利av导航| 国产调教视频一区| 国产精品免费丝袜| 亚洲欧洲av在线| 亚洲综合免费观看高清完整版| 天天综合网天天综合色| 麻豆精品久久精品色综合| 极品美女销魂一区二区三区免费| 国产成人午夜视频| jlzzjlzz国产精品久久| 欧美系列在线观看| 91精品国产91综合久久蜜臀| 精品99久久久久久| 国产精品午夜春色av| 亚洲综合丝袜美腿| 老司机免费视频一区二区| 国产成人午夜精品影院观看视频| 99国产精品国产精品久久| 欧美三区在线观看| 精品久久免费看| 亚洲色图.com| 麻豆91在线播放免费| 成人激情视频网站| 欧美日韩一区国产| 久久欧美中文字幕| 一区二区在线观看免费 | 亚洲高清久久久| 老司机精品视频导航| 成年人午夜久久久| 69久久夜色精品国产69蝌蚪网| 久久久一区二区| 亚洲国产美女搞黄色| 国产在线精品不卡| 91久久免费观看| 久久精品亚洲乱码伦伦中文| 亚洲一区二区欧美激情| 国产一区二区三区在线看麻豆| 色拍拍在线精品视频8848| 精品国产1区2区3区| 亚洲图片自拍偷拍| 丰满亚洲少妇av| 欧美一区二区黄| 综合在线观看色| 国产真实乱偷精品视频免| 99久久久久免费精品国产 | 欧美午夜在线一二页| 日韩欧美中文一区| 亚洲精品高清在线| 国产一区二区成人久久免费影院| 欧美日韩激情在线| 国产精品国产三级国产普通话三级| 日韩在线a电影| 色综合久久天天| 国产精品久久夜| 国产一区二区三区久久悠悠色av| 欧美日韩大陆一区二区| 亚洲欧洲成人自拍| 国产精品亚洲人在线观看| 欧美一激情一区二区三区| 一区二区久久久久久| 丰满白嫩尤物一区二区| 日韩三级.com| 日本午夜精品一区二区三区电影| 色先锋aa成人| 国产精品国产三级国产普通话99 | 成人永久免费视频| 精品国产乱码91久久久久久网站| 午夜精品一区二区三区免费视频| 91亚洲国产成人精品一区二三 | 日韩欧美久久久| 青青草视频一区| 欧美日韩二区三区| 亚洲精品一卡二卡| 97精品超碰一区二区三区| 国产午夜精品久久久久久免费视 | 色综合视频一区二区三区高清| 亚洲欧美激情在线| 色偷偷成人一区二区三区91| 婷婷开心激情综合| 欧美亚洲另类激情小说| 中文字幕亚洲在| 国产精品99久久久久久似苏梦涵| 精品国产乱码久久久久久久| 青青草精品视频| 日韩欧美一区二区久久婷婷| 亚洲大型综合色站| 色噜噜偷拍精品综合在线| 亚洲免费av观看| 日本道在线观看一区二区| 亚洲美女区一区| 99re在线精品| 一区二区三区欧美视频| 91成人免费电影| 亚洲国产乱码最新视频| 欧美日韩高清一区二区三区| 三级欧美韩日大片在线看| 欧美精选一区二区| 亚洲成av人片| 欧美电影影音先锋| 奇米777欧美一区二区| 日韩免费观看2025年上映的电影 | 亚洲成人av一区二区| 337p亚洲精品色噜噜| 日本不卡123| 欧美精品一区二区三区高清aⅴ | 韩国精品免费视频| 国产香蕉久久精品综合网| 国产成人精品免费看| 中文字幕av一区二区三区| 99re视频精品| 日本不卡高清视频| 久久免费电影网| 色丁香久综合在线久综合在线观看| 国产传媒一区在线| 国产精品久久久久久亚洲伦| 在线观看www91| 另类小说图片综合网| 国产欧美精品区一区二区三区| 91麻豆精东视频| 日韩不卡一二三区| 久久久久久久久久看片| 91丨九色丨国产丨porny| 午夜国产不卡在线观看视频| 精品国产乱码久久久久久夜甘婷婷 | 欧美亚洲综合在线| 麻豆精品在线播放| 国产精品―色哟哟| 欧美高清视频一二三区 | 日韩精品影音先锋| 99精品1区2区| 麻豆精品新av中文字幕| 欧美激情一区二区三区在线| 欧美日韩一区二区三区视频| 激情久久五月天| 亚洲综合视频网| 久久久精品国产免费观看同学| 欧美亚洲禁片免费| 国产精品亚洲а∨天堂免在线| 亚洲午夜视频在线| 国产午夜精品久久久久久久| 欧美肥大bbwbbw高潮| 成人免费高清视频在线观看| 日韩电影在线观看网站| 亚洲欧洲三级电影| 精品国产一区二区三区忘忧草| 欧美亚洲国产怡红院影院| 国产凹凸在线观看一区二区| 日韩国产精品大片| 一区二区三区电影在线播| 日本一区二区免费在线观看视频| 欧美一区二区观看视频|