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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? uartsw.c

?? 國(guó)外牛人公開(kāi)的AVR代碼
?? C
字號(hào):
/*! \file uartsw.c \brief Software Interrupt-driven UART Driver. */
//*****************************************************************************
//
// File Name	: 'uartsw.c'
// Title		: Software Interrupt-driven UART Driver
// Author		: Pascal Stang - Copyright (C) 2002-2004
// Created		: 7/20/2002
// Revised		: 4/27/2004
// Version		: 0.1
// Target MCU	: Atmel AVR Series (intended for the ATmega16 and ATmega32)
// Editor Tabs	: 4
//
// This code is distributed under the GNU Public License
//		which can be found at http://www.gnu.org/licenses/gpl.txt
//
//*****************************************************************************

#include <avr/io.h>
#include <avr/interrupt.h>
#include <avr/signal.h>

#include "global.h"
#include "timer.h"
#include "uartsw.h"

// Program ROM constants

// Global variables

// uartsw transmit status and data variables
static volatile u08 UartswTxBusy;
static volatile u08 UartswTxData;
static volatile u08 UartswTxBitNum;

// baud rate common to transmit and receive
static volatile u16 UartswBaudRateDiv;

// uartsw receive status and data variables
static volatile u08 UartswRxBusy;
static volatile u08 UartswRxData;
static volatile u08 UartswRxBitNum;
// receive buffer
static cBuffer uartswRxBuffer;               ///< uartsw receive buffer
// automatically allocate space in ram for each buffer
static char uartswRxData[UARTSW_RX_BUFFER_SIZE];

// functions

//! enable and initialize the software uart
void uartswInit(void)
{
    // initialize the buffers
	uartswInitBuffers();
	// initialize the ports
	sbi(UARTSW_TX_DDR, UARTSW_TX_PIN);
	cbi(UARTSW_RX_DDR, UARTSW_RX_PIN);
	cbi(UARTSW_RX_PORT, UARTSW_RX_PIN);
	// initialize baud rate
	uartswSetBaudRate(9600);

	// setup the transmitter
	UartswTxBusy = FALSE;
	// disable OC1A interrupt
	cbi(TIMSK, OCIE1A);
	// attach TxBit service routine to OC1A
	timerAttach(TIMER1OUTCOMPAREA_INT, uartswTxBitService);

	// setup the receiver
	UartswRxBusy = FALSE;
	// disable OC1B interrupt
	cbi(TIMSK, OCIE1B);
	// attach RxBit service routine to OC1B
	timerAttach(TIMER1OUTCOMPAREB_INT, uartswRxBitService);
	// attach RxBit service routine to ICP
	timerAttach(TIMER1INPUTCAPTURE_INT, uartswRxBitService);
	// trigger on rising edge
	sbi(TCCR1B, ICES1);
	// enable ICP interrupt
	sbi(TIMSK, TICIE1);

	// turn on interrupts
	sei();
}

//! create and initialize the uart buffers
void uartswInitBuffers(void)
{
	// initialize the UART receive buffer
	bufferInit(&uartswRxBuffer, uartswRxData, UARTSW_RX_BUFFER_SIZE);
}

//! turns off software UART
void uartswOff(void)
{
	// disable interrupts
	cbi(TIMSK, OCIE1A);
	cbi(TIMSK, OCIE1B);
	cbi(TIMSK, TICIE1);
	// detach the service routines
	timerDetach(TIMER1OUTCOMPAREA_INT);
	timerDetach(TIMER1OUTCOMPAREB_INT);
	timerDetach(TIMER1INPUTCAPTURE_INT);
}

void uartswSetBaudRate(u32 baudrate)
{
	// set timer prescaler
	timer1SetPrescaler(TIMER_CLK_DIV1);
	// calculate division factor for requested baud rate, and set it
	UartswBaudRateDiv = (u16)((F_CPU+(baudrate/2L))/(baudrate*1L));
}

//! returns the receive buffer structure 
cBuffer* uartswGetRxBuffer(void)
{
	// return rx buffer pointer
	return &uartswRxBuffer;
}

void uartswSendByte(u08 data)
{
	// wait until uart is ready
	while(UartswTxBusy);
	// set busy flag
	UartswTxBusy = TRUE;
	// save data
	UartswTxData = data;
	// set number of bits (+1 for stop bit)
	UartswTxBitNum = 9;
	
	// set the start bit
	#ifdef UARTSW_INVERT
	sbi(UARTSW_TX_PORT, UARTSW_TX_PIN);
	#else
	cbi(UARTSW_TX_PORT, UARTSW_TX_PIN);
	#endif

	// schedule the next bit
	outw(OCR1A, inw(TCNT1) + UartswBaudRateDiv);
	// enable OC1A interrupt
	sbi(TIMSK, OCIE1A);
}

//! gets a byte (if available) from the uart receive buffer
u08 uartswReceiveByte(u08* rxData)
{
	// make sure we have a receive buffer
	if(uartswRxBuffer.size)
	{
		// make sure we have data
		if(uartswRxBuffer.datalength)
		{
			// get byte from beginning of buffer
			*rxData = bufferGetFromFront(&uartswRxBuffer);
			return TRUE;
		}
		else
		{
			// no data
			return FALSE;
		}
	}
	else
	{
		// no buffer
		return FALSE;
	}
}

void uartswTxBitService(void)
{
	if(UartswTxBitNum)
	{
		// there are bits still waiting to be transmitted
		if(UartswTxBitNum > 1)
		{
			// transmit data bits (inverted, LSB first)
			#ifdef UARTSW_INVERT
			if( !(UartswTxData & 0x01) )
			#else
			if( (UartswTxData & 0x01) )
			#endif
				sbi(UARTSW_TX_PORT, UARTSW_TX_PIN);
			else
				cbi(UARTSW_TX_PORT, UARTSW_TX_PIN);
			// shift bits down
			UartswTxData = UartswTxData>>1;
		}
		else
		{
			// transmit stop bit
			#ifdef UARTSW_INVERT
			cbi(UARTSW_TX_PORT, UARTSW_TX_PIN);
			#else
			sbi(UARTSW_TX_PORT, UARTSW_TX_PIN);
			#endif
		}
		// schedule the next bit
		outw(OCR1A, inw(OCR1A) + UartswBaudRateDiv);
		// count down
		UartswTxBitNum--;
	}
	else
	{
		// transmission is done
		// clear busy flag
		UartswTxBusy = FALSE;
	}
}

void uartswRxBitService(void)
{
	// this function runs on either:
	// - a rising edge interrupt
	// - OC1B
	if(!UartswRxBusy)
	{
		// this is a start bit
		// disable ICP interrupt
		cbi(TIMSK, TICIE1);
		// schedule data bit sampling 1.5 bit periods from now
		outw(OCR1B, inw(TCNT1) + UartswBaudRateDiv + UartswBaudRateDiv/2);
		// clear OC1B interrupt flag
		sbi(TIFR, OCF1B);
		// enable OC1B interrupt
		sbi(TIMSK, OCIE1B);
		// set start bit flag
		UartswRxBusy = TRUE;
		// reset bit counter
		UartswRxBitNum = 0;
		// reset data
		UartswRxData = 0;
	}
	else
	{
		// start bit has already been received
		// we're in the data bits
		
		// shift data byte to make room for new bit
		UartswRxData = UartswRxData>>1;

		// sample the data line
		#ifdef UARTSW_INVERT
		if( !(inb(UARTSW_RX_PORTIN) & (1<<UARTSW_RX_PIN)) )
		#else
		if( !(inb(UARTSW_RX_PORTIN) & (1<<UARTSW_RX_PIN)) )
		#endif
		{
			// serial line is marking
			// record '1' bit
			UartswRxData |= 0x80;
		}

		// increment bit counter
		UartswRxBitNum++;
		// schedule next bit sample
		outw(OCR1B, inw(OCR1B) + UartswBaudRateDiv);

		// check if we have a full byte
		if(UartswRxBitNum >= 8)
		{
			// save data in receive buffer
			bufferAddToEnd(&uartswRxBuffer, UartswRxData);
			// disable OC1B interrupt
			cbi(TIMSK, OCIE1B);
			// clear ICP interrupt flag
			sbi(TIFR, ICF1);
			// enable ICP interrupt
			sbi(TIMSK, TICIE1);
			// clear start bit flag
			UartswRxBusy = FALSE;
		}
	}
}

/*
void uartswRxBitService(void)
{
	u16 thisBitTime;
	u08 bitperiods;
	u08 i;

	// bit transition was detected
	// record bit's edge time
	thisBitTime = inw(ICR1);

	cbi(PORTB, 0);

	if(!UartswRxStartBit)
	{
		// this is a start bit
		// switch to falling-edge trigger
		cbi(TCCR1B, ICES1);
		// record bit time
		UartswRxBitTime = thisBitTime;
		// set start bit flag
		UartswRxStartBit = TRUE;
		// reset bit counter
		UartswRxBitNum = 0;
		// reset data
		UartswRxData = 0;
	}
	else
	{
		// start bit has already been received
		// we're in the data bits
		
		// how many bit periods since last edge?
		bitperiods = (thisBitTime - UartswRxBitTime + UartswBaudRateDiv/2)/UartswBaudRateDiv;
		// set last edge time
		UartswRxBitTime = thisBitTime;

		if(bitperiods > 10)
		{
			// switch to trigger on rising edge
			sbi(TCCR1B, ICES1);
			// clear start bit flag
			UartswRxStartBit = FALSE;
		}
		else
		{


		if( inb(TCCR1B) & (1<<ICES1) )
		{
			// just triggered on a rising edge
			// previous bits were zero
			// shift in the data (data bits are inverted)
			for(i=0; i<bitperiods; i++)
			{
				UartswRxData = UartswRxData<<1;
				UartswRxData |= 0x01;
			}
			// switch to trigger on falling edge
			cbi(TCCR1B, ICES1);
		}
		else
		{
			// just triggered on a falling edge
			// previous bits were one
			// shift in the data (data bits are inverted)
			for(i=0; i<bitperiods; i++)
			{
				UartswRxData = UartswRxData<<1;
			}
			// switch to trigger on rising edge
			sbi(TCCR1B, ICES1);
		}
		
		// increment bit counter
		UartswRxBitNum += bitperiods;
		
		// check if we have a full byte + start bit
		if(bitperiods > 8)
		{
			// save data in receive buffer
			bufferAddToEnd(&uartswRxBuffer, UartswRxData);
			// switch to trigger on rising edge
			sbi(TCCR1B, ICES1);
			// clear start bit flag
			UartswRxStartBit = FALSE;
		}
		}
	}

	// turn off debug LEDs
	delay(10);
	sbi(PORTB, 0);
	sbi(PORTB, 1);
}
*/

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人午夜在线播放| 成人午夜激情在线| 国产精品久久久久久久久免费樱桃 | 亚洲一级二级在线| 精品美女一区二区三区| 欧美亚洲高清一区二区三区不卡| 国产一区二区三区精品欧美日韩一区二区三区| 亚洲精品免费一二三区| 久久看人人爽人人| 欧美高清激情brazzers| 一本一本大道香蕉久在线精品 | 成人污污视频在线观看| 91高清在线观看| 懂色av中文一区二区三区| 美女性感视频久久| 亚洲成人你懂的| 亚洲色图清纯唯美| 欧美国产一区二区在线观看| 欧美一区二区在线播放| 欧美色中文字幕| 一本大道av一区二区在线播放| 国产精品综合视频| 久草精品在线观看| 蜜桃一区二区三区在线| 丝袜美腿亚洲综合| 性做久久久久久免费观看欧美| 最新国产成人在线观看| 国产精品久久久久影视| 国产日产欧美一区二区三区| 久久综合色8888| 欧美大白屁股肥臀xxxxxx| 欧美男男青年gay1069videost| 91丨国产丨九色丨pron| 成人av电影免费在线播放| 国产成人超碰人人澡人人澡| 精彩视频一区二区| 激情深爱一区二区| 久久激情五月激情| 韩国av一区二区三区| 久久99国产精品久久99| 久久9热精品视频| 老汉av免费一区二区三区 | 国内精品久久久久影院薰衣草 | 欧美日韩亚洲综合一区二区三区| 色94色欧美sute亚洲线路一久| a级精品国产片在线观看| 91丨九色丨尤物| 日本精品一级二级| 欧美羞羞免费网站| 欧美美女一区二区| 日韩一区二区三区精品视频| 日韩免费观看2025年上映的电影| 精品免费视频一区二区| 天天色 色综合| 日韩精品免费专区| 久久91精品国产91久久小草| 国产福利一区二区三区视频在线 | 国产·精品毛片| 成人av集中营| 欧美日韩在线综合| 日韩欧美国产综合| 国产农村妇女精品| 亚洲精品免费一二三区| 日韩精品一二三| 高清成人免费视频| 在线视频一区二区免费| 91精品综合久久久久久| 久久久www免费人成精品| 亚洲天堂成人在线观看| 五月激情丁香一区二区三区| 国产激情一区二区三区| 91久久久免费一区二区| 精品欧美一区二区久久| 日韩一区欧美小说| 日韩av高清在线观看| 国产suv精品一区二区883| 日本精品视频一区二区三区| 欧美不卡一二三| 日韩理论片一区二区| 奇米影视7777精品一区二区| 丰满放荡岳乱妇91ww| 欧美高清性hdvideosex| 欧美国产一区二区| 日韩国产精品久久久| 成人a免费在线看| 欧美一区二区三区视频免费| 国产日韩三级在线| 日韩vs国产vs欧美| 成a人片国产精品| 欧美sm极限捆绑bd| 一区二区三区国产精华| 高清国产一区二区| 91精品蜜臀在线一区尤物| 亚洲同性同志一二三专区| 蜜桃精品视频在线| 欧美色精品天天在线观看视频| 欧美高清在线精品一区| 日韩国产欧美在线播放| 色哟哟一区二区在线观看| 久久亚洲私人国产精品va媚药| 亚洲成人免费在线| 一本色道久久加勒比精品| 久久精品一二三| 免费一级欧美片在线观看| 91免费看片在线观看| 国产精品无码永久免费888| 麻豆国产91在线播放| 欧洲视频一区二区| 亚洲欧洲在线观看av| 国产成人午夜视频| 日韩亚洲欧美在线| 婷婷中文字幕一区三区| 欧美性色黄大片| 最新欧美精品一区二区三区| 国产成人午夜片在线观看高清观看| 91麻豆精品国产91久久久| 亚洲国产成人av好男人在线观看| 99免费精品在线观看| 国产精品三级久久久久三级| 久久电影国产免费久久电影| 宅男噜噜噜66一区二区66| 香蕉久久一区二区不卡无毒影院| 91蜜桃网址入口| 日韩毛片精品高清免费| 99久久免费视频.com| 国产精品欧美一区喷水| 床上的激情91.| 中文字幕欧美三区| www.亚洲国产| 亚洲精品亚洲人成人网在线播放| 91欧美激情一区二区三区成人| 成人免费一区二区三区在线观看| 99久久er热在这里只有精品15 | 91国偷自产一区二区开放时间 | 91精品麻豆日日躁夜夜躁| 亚洲高清视频中文字幕| 欧美日韩国产综合一区二区 | 奇米影视在线99精品| 日韩视频永久免费| 久久国产成人午夜av影院| xfplay精品久久| 成人一区二区三区中文字幕| 中文字幕一区二区三区视频| 色婷婷综合五月| 亚洲午夜免费视频| 91精品蜜臀在线一区尤物| 久久成人免费网| 欧美激情一区二区三区不卡| www.亚洲国产| 亚洲成a人v欧美综合天堂下载| 欧美美女一区二区三区| 美女视频黄 久久| 久久这里都是精品| 成人午夜激情在线| 亚洲精品高清在线| 日韩一区二区在线观看视频 | 91理论电影在线观看| 亚洲国产裸拍裸体视频在线观看乱了 | 亚洲精品写真福利| 欧美精品123区| 国产精品一区二区久久不卡| 中文字幕免费不卡| 欧美无砖砖区免费| 国产综合色视频| 亚洲欧洲日韩av| 91精品视频网| 懂色av一区二区三区蜜臀| 亚洲欧美精品午睡沙发| 日韩一区二区在线观看视频播放| 国产风韵犹存在线视精品| 一区二区三区在线观看国产| 日韩一区二区三区观看| 成人国产精品免费观看动漫| 亚洲午夜激情av| 久久精品欧美一区二区三区麻豆 | 制服丝袜国产精品| 大白屁股一区二区视频| 日日夜夜精品免费视频| 国产精品久久毛片av大全日韩| 精品视频一区二区不卡| 成人午夜碰碰视频| 日韩精品久久久久久| 日韩美女精品在线| 精品国产乱码久久久久久老虎| 色婷婷av一区二区三区大白胸| 开心九九激情九九欧美日韩精美视频电影 | 一区二区三区波多野结衣在线观看| 日韩一区二区三区电影| 91女厕偷拍女厕偷拍高清| 激情五月婷婷综合| 亚洲高清在线视频| 中文字幕日本不卡| 日韩精品最新网址| 欧美亚洲免费在线一区| jlzzjlzz国产精品久久| 久久国产尿小便嘘嘘尿| 午夜视频一区二区| 一区二区三区在线免费播放| 日本一区二区三级电影在线观看 | 精品国产免费久久|