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

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

?? sngks32csio.c

?? Vxworks下BSP源碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* sngks32cSio.c - Samsung KS32C serial driver *//* Copyright 1984-2001 Wind River Systems, Inc. */#include "copyright_wrs.h"/*modification history--------------------01c,30nov01,m_h  Save pChan->baudRate when setting baud01b,26apr01,m_h  convert tabs to spaces for readability01a,12apr01,m_h  created from snds100 template.*//*DESCRIPTIONThis is the serial I/O driver for Samsung's KS32C50100 microprocessor which is anARM based processor with several integrated peripherals.  It has an interruptcontroller, two 32-bit timers, one Ethernet controller,two HDLC controllers,one IIC controller, general purpose I/O ports, and a 2 channel DMA controller.The 2 UART channels integrated with the processor are controlled by thisdriver.  Both the UARTs can work in interrupt mode as well as DMA mode.This driver supports only the interrupt mode for the UARTs.All the UART registers are accessible as 32-bit integers from the internalsystem registers.  The macros SNGKS32C_REG_READ and SNGKS32C_REG_WRITE read and write32-bit integers from and to the given addresses.  SNGKS32C_SIO_DEFAULT_BAUD isdefined to 38400 in this file.  This is the default baud rate with which the UART channels will be initialized.  The channels are also initialized with one start bit, one stop bit, 8 bit data and no parity bits.The driver is typically only called only by the BSP. The directly callableroutines in this module are sngks32cDevInit(), sngks32cDevInit2(), sngks32cIntRcv(), sngks32cIntTx(), and sngks32cIntErr().The BSP calls sngks32cDevInit() to initialize or reset the device.It connects the driver's interrupt handlers (sngks32cIntRcv(), sngks32cIntTx(),and sngks32cIntErr()), using intConnect().After connecting the interrupt handlers, the BSP calls sngks32cDevInit2()to inform the driver that interrupt mode operation is now possible.INCLUDES:sngks32cSio.h sioLib.hSEE ALSO:<Samsung KS32C50100 User's Manual>*/#include "vxWorks.h"#include "sioLib.h"#include "intLib.h"#include "errno.h"#include "sngks32cSio.h"#include "ioLib.h"void  myDelay();#define AT91C_BAUD_MIN         1200#define AT91C_BAUD_MAX         230400#define AT91C_SIO_DEFAULT_BAUD 38400/* Hardware abstraction macros *//* local defines  */#ifndef AT91C_SIO_REG_READ#define AT91C_SIO_REG_READ(pChan, reg, result) \    ((result) = (*(volatile UINT32 *)((UINT32)(pChan)->regs + (reg))))#endif    /*AT91C_SIO_REG_READ*/#ifndef AT91C_SIO_REG_WRITE#define AT91C_SIO_REG_WRITE(pChan, reg, data) \    ((*(volatile UINT32 *)((UINT32)(pChan)->regs + (reg))) = (data))#endif    /*AT91C_SIO_REG_WRITE*//* for backward compatibility */#ifndef    SIO_HUP#   define SIO_OPEN    0x100A    /* open channel, raise DTR, RTS */#   define SIO_HUP     0x100B    /* hang-up, lower DTR, RTS */#endif/* forward static declarations */LOCAL int    at91cTxStartup (SIO_CHAN * pSioChan);LOCAL int    at91cCallbackInstall (SIO_CHAN *pSioChan, int callbackType,                                      STATUS (*callback)(), void *callbackArg);LOCAL int    at91cPollOutput (SIO_CHAN *pSioChan, char    outChar);LOCAL int    at91cPollInput (SIO_CHAN *pSioChan, char *thisChar);LOCAL int    at91cIoctl (SIO_CHAN *pSioChan, int request, void *arg);LOCAL STATUS dummyCallback (void);LOCAL void at91cIntRcv(AT91C_CHAN * pChan);LOCAL void at91cIntTx(AT91C_CHAN * pChan);/* local variables */LOCAL    SIO_DRV_FUNCS at91cSioDrvFuncs =    {    at91cIoctl,    at91cTxStartup,    at91cCallbackInstall,    at91cPollInput,    at91cPollOutput    };LOCAL BOOL at91cIntrMode = FALSE;    /* interrupt mode allowed flag */#if 0LOCAL char labRS485;/*RS485的延時*/RS485Delay(){	int i;	for(i=0;i<10000;i++);}#endif/******************************************************************************** at91cDevInit - initialize a AT91C_DUSART** This routine initializes the driver* function pointers and then resets the chip in a quiescent state.* The BSP must have already initialized all the device addresses and the* baudFreq fields in the AT91C_DUSART structure before passing it to* this routine.** RETURNS: N/A*/void at91cDevInit    (    AT91C_CHAN * pChan    )    {    /* initialize each channel's driver function pointers */    pChan->sio.pDrvFuncs    = &at91cSioDrvFuncs;    /* install dummy driver callbacks */    pChan->getTxChar     = dummyCallback;    pChan->putRcvChar    = dummyCallback;        /* reset the chip */    AT91C_SIO_REG_WRITE(pChan,AT91C_US_CR,(AT91C_US_RSTRX | AT91C_US_RSTTX));/*RESET*/    AT91C_SIO_REG_WRITE(pChan,AT91C_US_CR,(AT91C_US_RXEN | AT91C_US_TXEN));	/*TX&RX ENABLE*/    AT91C_SIO_REG_WRITE(pChan,AT91C_US_MR,(AT91C_US_CLKS_CLOCK | AT91C_US_CHRL_8_BITS |								AT91C_US_PAR_NONE | AT91C_US_NBSTOP_1_BIT));/*MODE*/    /* setting polled mode is one way to make the device quiet *//*    at91cIoctl ((SIO_CHAN *)pChan, SIO_MODE_SET, (void *)SIO_MODE_POLL);J*/    at91cIoctl ((SIO_CHAN *)pChan, SIO_BAUD_SET, (void *)AT91C_SIO_DEFAULT_BAUD);    }/******************************************************************************** at91cDevInit2 - initialize a AT91C_DUSART, part 2** This routine is called by the BSP after interrupts have been connected.* The driver can now operate in interrupt mode.  Before this routine is* called only polled mode operations should be allowed.** RETURNS: N/A* ARGSUSED*/void at91cDevInit2    (    AT91C_CHAN * pChan        /* device to initialize */    )    {#if 0    char      outchar = '\0';    UINT32    status;	int i;    AT91C_SIO_REG_WRITE(pChan,AT91C_US_CR,(AT91C_US_RSTRX | AT91C_US_RSTTX));/*RESET*/    AT91C_SIO_REG_WRITE(pChan,AT91C_US_CR,(AT91C_US_RXEN | AT91C_US_TXEN));	/*TX&RX ENABLE*/    AT91C_SIO_REG_WRITE(pChan,AT91C_US_MR,(AT91C_US_CLKS_CLOCK | AT91C_US_CHRL_8_BITS |								AT91C_US_PAR_NONE | AT91C_US_NBSTOP_1_BIT));/*MODE*/    AT91C_SIO_REG_WRITE(pChan,AT91C_US_IER,(AT91C_US_RXRDY |AT91C_US_TXRDY));/*INT ENABLE*/    /*      * Dummy write to TXBUF to start TX empty interrupt     */    AT91C_SIO_REG_WRITE(pChan,AT91C_US_THR,outchar);	    AT91C_SIO_REG_READ(pChan,AT91C_US_CSR, status);  	/*    AT91C_SIO_REG_WRITE(pChan,AT91C_AIC_ICCR,(1<<pChan->intLevel));/*clear pend */    while ((status & AT91C_US_TXREADY) != AT91C_US_TXREADY)/*發送未就緒*/{	*(volatile UINT32 *)0xfffff800 = 0x35;	*(volatile UINT32 *)0xfffff810 = 0x35;		while(1)	{	*(volatile UINT32 *)0xfffff834 = 0x35;/*lit*/		for(i=0;i<1000000;i++);		*(volatile UINT32 *)0xfffff830 = 0x35;		for(i=0;i<1000000;i++);		}}#endif    AT91C_SIO_REG_WRITE(pChan,AT91C_US_IER,AT91C_US_RXRDY |AT91C_US_TXRDY);    at91cIntrMode = TRUE;#if 0	labRS485 = TRUE;/*TRUE:485-PIO默認設置為RX 狀態,FALSE為TX*/#endif    }/******************************************************************************** at91cInt - handle a system  interrupt:DBGU or ST_PIT** RETURNS: N/A*/ void sysIntHandler		(	    AT91C_CHAN *    pChan        /* channel generating the interrupt */	){	UINT32 status;	UINT32 mask;	status = *(volatile UINT32 *)AT91C_ST_SR;	mask = *(volatile UINT32 *)AT91C_ST_IMR;	if((status & mask) == 1)	{		sysClkInt();	}			at91cInt(pChan);	}/******************************************************************************** at91cInt - handle a channel's Tramsmit or receive-character interrupt** RETURNS: N/A*/ void at91cInt		(	    AT91C_CHAN *    pChan        /* channel generating the interrupt */	){    	UINT32        status;	UINT32	    mask;	AT91C_SIO_REG_READ(pChan,AT91C_US_CSR, status);	if((status & AT91C_US_RXREADY ) == AT91C_US_RXREADY )		at91cIntRcv(pChan);	if((status & AT91C_US_TXREADY) == AT91C_US_TXREADY)		at91cIntTx(pChan);}/******************************************************************************** at91cIntRcv - handle a channel's receive-character interrupt** RETURNS: N/A*/ LOCAL void at91cIntRcv    (    AT91C_CHAN *    pChan        /* channel generating the interrupt */    )    {    char            inChar;    /*     * Grab the input character from the chip and hand it off via a     * callback. For chips with input FIFO's it is more efficient     * to empty the entire FIFO here.     */#if 0	if(MODE_RS485 == pChan->UARTmode)	{			logMsg("485 rx int \n",0,0,0,0,0,0);			logMsg("lab = %x\n",labRS485,0,0,0,0,0);		if(labRS485 != TRUE)		{			RS485Delay();			*(volatile UINT32 *)((UINT32)pChan->pioBaseAdrs + AT91C_PIO_CODR) = pChan->pinValue; /*--rx--*/			labRS485 = TRUE;			RS485Delay();		}	}#endif        AT91C_SIO_REG_READ(pChan,AT91C_US_RHR, inChar);        (*pChan->putRcvChar) (pChan->putRcvArg, inChar);/*logMsg("at91cIntRcv,in = %x\n",inChar,0,0,0,0,0);*/    }/******************************************************************************** at91cIntTx - handle a channels transmitter-ready interrupt** RETURNS: N/A*/ LOCAL void at91cIntTx    (    AT91C_CHAN *    pChan        /* channel generating the interrupt */    )    {    char      outChar;	int i;    /*     * If there's a character to transmit then write it out, else reset     * the transmitter. For chips with output FIFO's it is more efficient     * to fill the entire FIFO here.     */    if ((*pChan->getTxChar) (pChan->getTxArg, &outChar) != ERROR)	{    		if (MODE_RS485 == pChan->UARTmode)		{#if 0			logMsg("485 tx int \n",0,0,0,0,0,0);			logMsg("lab = %x \n",labRS485,0,0,0,0,0);			if(labRS485 != FALSE) 			{				RS485Delay();				*(volatile UINT32 *)((UINT32)pChan->pioBaseAdrs + AT91C_PIO_SODR) = pChan->pinValue;/*--tx--*/				RS485Delay();				labRS485 = FALSE;			}#endif#if 0		    AT91C_SIO_REG_WRITE(pChan,AT91C_US_CR,(AT91C_US_RSTRX | AT91C_US_RSTTX));/*RESET*/		    AT91C_SIO_REG_WRITE(pChan,AT91C_US_CR,(AT91C_US_RXEN | AT91C_US_TXEN));	/*TX&RX ENABLE*/		    AT91C_SIO_REG_WRITE(pChan,AT91C_US_MR,(AT91C_US_CLKS_CLOCK | AT91C_US_CHRL_8_BITS |									AT91C_US_PAR_NONE | AT91C_US_NBSTOP_1_BIT));/*MODE*/		    AT91C_SIO_REG_WRITE(pChan,AT91C_US_IER,(AT91C_US_RXRDY |AT91C_US_TXRDY));/*INT ENABLE*/#endif#if 1	for(i=0;i<9000;i++);		/*must*/			*(volatile UINT32 *)((UINT32)pChan->pioBaseAdrs + AT91C_PIO_SODR) = pChan->pinValue;/*--tx--*/	for(i=0;i<9000;i++);		/*maybe*/			AT91C_SIO_REG_WRITE(pChan, AT91C_US_THR, outChar);	for(i=0;i<9000;i++);		 /*must*/			*(volatile UINT32 *)((UINT32)pChan->pioBaseAdrs + AT91C_PIO_CODR) = pChan->pinValue; /*--rx--*/	for(i=0;i<9000;i++);		/*must*/#endif#if 0RS485Delay();	*(volatile UINT32 *)0xFFFFF630 = 1<<14;RS485Delay();		*(volatile UINT32 *)0xfffc001c = outChar;RS485Delay();		*(volatile UINT32 *)0xFFFFF634 = 1<<14;RS485Delay();#endif#if 0		taskDelay(5);			*(volatile UINT32 *)0xFFFFF630 = 1<<14;/*tx*/		taskDelay(5);		*(volatile UINT32 *)0xfffc001c = 0x0c;/*		printf("data send...\n");*/		taskDelay(5);		*(volatile UINT32 *)0xFFFFF634 = 1<<14;		taskDelay(5);#endif		}		else	 if(MODE_RS232 == pChan->UARTmode )		{		AT91C_SIO_REG_WRITE(pChan, AT91C_US_THR, outChar);		}    	}    else        {            AT91C_SIO_REG_WRITE(pChan, AT91C_US_IDR, AT91C_US_TXRDY);/*disable Tx interrupt*/	*(volatile UINT32 *) AT91C_AIC_ICCR= (1 << pChan->intLevel); /*INT pend clear*/        }    }/******************************************************************************** at91cTxStartup - start the interrupt transmitter** RETURNS: OK on success, ENOSYS if the device is polled-only, or* EIO on hardware error.*/LOCAL int at91cTxStartup    (    SIO_CHAN * pSioChan                 /* channel to start */    )    {    AT91C_CHAN * pChan = (AT91C_CHAN *)pSioChan;		char outChar;#if 0    if ((*pChan->getTxChar) (pChan->getTxArg, &outChar) != ERROR)	{    /*printf("TxStartup,outChar = %x\n",outChar);*//*    *(volatile UINT32 *) AT91C_AIC_ICCR= (1 << pChan->intLevel);*/ /*INT pend clear*/    AT91C_SIO_REG_WRITE(pChan, AT91C_US_IER,AT91C_US_TXRDY);/*    intEnable (pChan->intLevel);*/		if(MODE_RS485 == pChan->UARTmode )		{printf("IMR = %x,CSR = %x\n",*(UINT32 *)0XFFFC0010,*(UINT32 *)0XFFFC0014);#if 1logMsg(".\n",0,0,0,0,0,0);			taskDelay(5);			*(volatile UINT32 *)((UINT32)pChan->pioBaseAdrs + AT91C_PIO_SODR) = pChan->pinValue;/*--tx--*/			taskDelay(5);			AT91C_SIO_REG_WRITE(pChan, AT91C_US_THR, outChar);			*(volatile UINT32 *)((UINT32)pChan->pioBaseAdrs + AT91C_PIO_CODR) = pChan->pinValue; /*--rx--*/			taskDelay(5);/*logMsg("out = %c\n",outChar,0,0,0,0,0);*/#endif		}		else	 if(MODE_RS232 == pChan->UARTmode )		{		AT91C_SIO_REG_WRITE(pChan, AT91C_US_THR, outChar);		}	    	}#endif#if 1   *(volatile UINT32 *) AT91C_AIC_ICCR= (1 << pChan->intLevel);    /*INT pend clear*/    AT91C_SIO_REG_WRITE(pChan, AT91C_US_IER,AT91C_US_TXRDY);/*	logMsg("IMR = %x,CSR = %x\n",*(UINT32 *)0XFFFC0010,*(UINT32 *)0XFFFC0014,0,0,0,0);*/#endif    return (OK);    }/******************************************************************************** at91cCallbackInstall - install ISR callbacks to get/put chars** This driver allows interrupt callbacks for transmitting characters* and receiving characters. In general, drivers may support other* types of callbacks too.** RETURNS: OK on success, or ENOSYS for an unsupported callback type.*/ LOCAL int at91cCallbackInstall    (    SIO_CHAN *    pSioChan,               /* channel */    int           callbackType,           /* type of callback */    STATUS        (*callback)(),          /* callback */    void *        callbackArg             /* parameter to callback */    )    {    AT91C_CHAN * pChan = (AT91C_CHAN *)pSioChan;    switch (callbackType)    {    case SIO_CALLBACK_GET_TX_CHAR:        pChan->getTxChar    = callback;        pChan->getTxArg     = callbackArg;        return (OK);    case SIO_CALLBACK_PUT_RCV_CHAR:        pChan->putRcvChar    = callback;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩国产一区二| 亚洲国产一二三| 国产亚洲精品7777| 久久精品视频一区二区三区| 欧美一区二区在线免费播放| 欧美日韩国产一级| 日韩一区二区三区电影在线观看 | 99r国产精品| 成人av免费网站| 欧美日韩一区二区三区在线 | 中文欧美字幕免费| 亚洲人成人一区二区在线观看| 国产精品理论片在线观看| 国产精品少妇自拍| 五月天国产精品| 国产精华液一区二区三区| 色婷婷激情综合| 91小视频在线免费看| 懂色一区二区三区免费观看| 亚洲一区二三区| 久久综合狠狠综合久久激情| 欧美日韩久久久久久| 91精品黄色片免费大全| 91视频xxxx| 欧美日韩一区 二区 三区 久久精品 | 国产精品白丝av| 国产成人免费视频网站高清观看视频| 丁香婷婷综合色啪| 精品少妇一区二区三区日产乱码 | 首页亚洲欧美制服丝腿| 7777女厕盗摄久久久| 美脚の诱脚舐め脚责91 | 亚洲精品网站在线观看| 538在线一区二区精品国产| 看片的网站亚洲| 国产精品久久久一本精品| 欧美剧在线免费观看网站| 国v精品久久久网| 亚洲国产精品麻豆| 久久亚洲精品小早川怜子| 91丨九色丨蝌蚪丨老版| 麻豆成人av在线| 最近日韩中文字幕| 2020国产精品| 欧美另类久久久品| 99这里都是精品| 久久66热re国产| 亚洲小说欧美激情另类| 国产人久久人人人人爽| 欧美久久一区二区| 色综合久久99| 处破女av一区二区| 另类小说视频一区二区| 亚洲制服丝袜在线| 国产精品乱人伦一区二区| 日韩欧美国产系列| 欧美中文字幕一区二区三区| 国产成人午夜视频| 日本不卡的三区四区五区| 亚洲乱码精品一二三四区日韩在线| 欧美videos中文字幕| 欧美日韩在线播| 不卡视频在线观看| 国产精华液一区二区三区| 久久精品国产99久久6| 亚洲福利视频一区| 亚洲免费资源在线播放| 国产精品久久夜| 国产精品久久久久一区二区三区共| 日韩欧美国产三级电影视频| 制服丝袜亚洲网站| 欧美日韩一区二区在线视频| 色欧美日韩亚洲| 91视频在线观看免费| www.欧美.com| av成人动漫在线观看| 高清国产午夜精品久久久久久| 激情五月婷婷综合网| 免费的国产精品| 麻豆精品国产91久久久久久| 视频在线在亚洲| 日韩成人免费电影| 日本欧美一区二区三区乱码| 首页国产欧美日韩丝袜| 日韩电影免费一区| 日韩高清一级片| 美女免费视频一区| 久久精品国产免费| 紧缚捆绑精品一区二区| 黄色成人免费在线| 国产91精品精华液一区二区三区| 精品一区二区三区视频在线观看| 免费观看日韩电影| 久久国产欧美日韩精品| 国产综合久久久久久鬼色| 极品少妇xxxx精品少妇| 国产精品亚洲视频| 波多野结衣中文字幕一区| 成人sese在线| 一本到一区二区三区| 欧美日韩国产综合草草| 欧美一卡二卡在线观看| 久久久www免费人成精品| 国产精品沙发午睡系列990531| 亚洲女同ⅹxx女同tv| 亚洲国产精品一区二区尤物区| 蜜桃av一区二区| 国产成人欧美日韩在线电影| 色综合久久六月婷婷中文字幕| 欧美日韩在线亚洲一区蜜芽| 日韩欧美专区在线| 中文字幕不卡在线观看| 亚洲最大的成人av| 久草这里只有精品视频| 国产黄色精品视频| 91精品福利视频| 91麻豆精品国产91久久久更新时间| 欧美成人一区二区三区片免费 | 欧美经典一区二区三区| 亚洲天堂2014| 麻豆精品在线观看| 91在线视频播放地址| 欧美一区二区三区四区五区 | 日本一区二区三区免费乱视频| 亚洲精品中文字幕在线观看| 蜜桃视频在线观看一区二区| 国产91露脸合集magnet| 在线播放欧美女士性生活| 国产欧美精品一区二区色综合朱莉| 日韩美女精品在线| 国产在线播精品第三| 在线免费观看一区| 久久久不卡影院| 午夜精品久久久久久久久| 国产精品99久久久久久久女警| 欧美性大战久久久久久久蜜臀| 久久综合成人精品亚洲另类欧美| 亚洲国产日韩av| 国产精品一二三区在线| 91精品国产综合久久香蕉麻豆 | 日韩一区二区免费在线电影| 国产精品美女一区二区在线观看| 蜜桃视频在线观看一区| 欧美中文字幕亚洲一区二区va在线 | 亚洲视频一区在线观看| 一区二区三区不卡视频在线观看| 精品无码三级在线观看视频| 欧洲精品视频在线观看| 久久精品无码一区二区三区| 久久疯狂做爰流白浆xx| 91麻豆精品国产综合久久久久久| 伊人性伊人情综合网| 成人激情黄色小说| 国产日韩欧美综合在线| 黄网站免费久久| 欧美不卡在线视频| 蜜臀99久久精品久久久久久软件| 欧美日韩一级片网站| 一区二区三区不卡视频| 91欧美一区二区| 一区二区在线看| 99riav一区二区三区| 中文字幕一区二区三区不卡在线 | 91丨porny丨中文| 中文字幕在线视频一区| 成人综合婷婷国产精品久久| 国产欧美日本一区视频| 国产suv精品一区二区6| 欧美极品aⅴ影院| 成人黄色国产精品网站大全在线免费观看 | 在线免费一区三区| 亚洲高清免费观看高清完整版在线观看| 91麻豆产精品久久久久久| 亚洲桃色在线一区| 欧美在线免费播放| 亚洲成人动漫av| 日韩一区二区中文字幕| 久久不见久久见中文字幕免费| 欧美成人午夜电影| 国产另类ts人妖一区二区| 欧美精品一区二区三区四区| 国产精品自拍三区| 亚洲青青青在线视频| 91久久奴性调教| 日韩黄色小视频| 欧美videofree性高清杂交| 狠狠色丁香婷婷综合| 国产欧美视频一区二区| 91丨porny丨在线| 国产精品毛片高清在线完整版| 国产成人a级片| 国产精品国产三级国产a| a在线欧美一区| 亚洲午夜羞羞片| 精品国产99国产精品| 成人性生交大片免费看中文| 亚洲午夜免费视频| 337p日本欧洲亚洲大胆色噜噜| 成人高清av在线| 亚洲午夜av在线|