亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
国产精品狼人久久影院观看方式| 欧美一区二区在线观看| 精品国产麻豆免费人成网站| 日韩高清不卡一区二区三区| 欧美日产在线观看| 久久精品国产秦先生| 欧美成人艳星乳罩| 国产揄拍国内精品对白| 国产欧美日韩不卡| 色综合久久综合网97色综合| 亚洲日本乱码在线观看| 欧美制服丝袜第一页| 日韩国产精品久久| 精品毛片乱码1区2区3区| 国产成人免费在线观看| 国产精品免费看片| 欧洲另类一二三四区| 午夜av一区二区| 亚洲精品一区二区三区蜜桃下载 | 日韩精品中文字幕在线一区| 麻豆91在线看| 国产精品久久久久久一区二区三区 | 亚洲桃色在线一区| 制服丝袜亚洲色图| 国产精品一二三四| 亚洲一区二区三区在线看 | 精品对白一区国产伦| 成人免费观看av| 五月激情综合婷婷| 亚洲成人动漫一区| 日韩免费视频一区二区| av欧美精品.com| 日本中文一区二区三区| 国产精品久久看| 欧美一区二区啪啪| 91丨九色丨国产丨porny| 麻豆精品精品国产自在97香蕉| 国产日韩欧美不卡| 91.com视频| av电影在线观看一区| 另类欧美日韩国产在线| 亚洲同性gay激情无套| 日韩一级精品视频在线观看| 91网站最新网址| 精品写真视频在线观看| 亚洲成人在线免费| 自拍视频在线观看一区二区| 日韩一区二区免费在线电影| 色综合久久九月婷婷色综合| 久久精品国产久精国产| 亚洲午夜一区二区三区| 国产精品久久久久久久久免费丝袜 | 久久亚洲欧美国产精品乐播| 色噜噜狠狠成人中文综合| 国产精品 日产精品 欧美精品| 天天射综合影视| 亚洲欧美激情一区二区| 国产亚洲精品7777| 日韩欧美国产一二三区| 2022国产精品视频| 91麻豆精品国产91久久久| 91色婷婷久久久久合中文| 国产美女精品一区二区三区| 蜜臀av亚洲一区中文字幕| 亚洲午夜影视影院在线观看| 亚洲欧洲日产国码二区| 国产精品美女久久久久久久久久久| 精品国内二区三区| 欧美一级午夜免费电影| 91麻豆精品国产91久久久| 欧美午夜精品久久久久久超碰| 国产二区国产一区在线观看| 激情亚洲综合在线| 精品在线你懂的| 日本中文字幕一区二区有限公司| 亚洲成人综合在线| 亚洲成人综合网站| 亚洲高清免费视频| 亚洲成av人片在线观看无码| 亚洲综合av网| 亚洲最新视频在线观看| 亚洲制服丝袜av| 亚洲高清免费在线| 日韩电影一二三区| 美女尤物国产一区| 紧缚奴在线一区二区三区| 久久精品国产久精国产爱| 精品一区二区三区在线观看国产| 久久国产三级精品| 国产一区二区中文字幕| 国产精品18久久久久久久网站| 国产一区二区三区在线观看免费视频| 精品亚洲国产成人av制服丝袜| 老汉av免费一区二区三区| 狠狠狠色丁香婷婷综合激情 | 成人av影院在线| 成人毛片视频在线观看| 91亚洲精品久久久蜜桃| 欧洲人成人精品| 欧美一区二区在线观看| 久久久国产精品不卡| 亚洲欧洲av一区二区三区久久| 综合久久综合久久| 日韩精品成人一区二区三区| 欧美bbbbb| 粉嫩av一区二区三区| 色一情一乱一乱一91av| 91精品久久久久久久99蜜桃| 精品久久久久久久久久久久久久久久久 | 成人黄色在线看| 欧美丝袜丝交足nylons| 日韩精品在线网站| 日韩成人精品在线| 国内成人免费视频| 一本到三区不卡视频| 欧美一级精品在线| 国产精品欧美一区喷水| 亚洲成人精品在线观看| 国产精品小仙女| 欧美色偷偷大香| 国产日韩欧美电影| 视频在线观看国产精品| 成人国产亚洲欧美成人综合网| 在线视频一区二区免费| 久久这里只有精品视频网| 一区二区三区在线免费视频 | 亚洲综合久久久| 国产一区在线看| 欧美日本一道本| 成人欧美一区二区三区1314 | 亚洲一区精品在线| 国产福利一区二区三区视频在线| 色婷婷亚洲婷婷| 国产日韩av一区二区| 日韩精品一级中文字幕精品视频免费观看 | 欧美丝袜丝交足nylons图片| 久久久不卡影院| 免费看日韩a级影片| 91碰在线视频| 国产丝袜美腿一区二区三区| 日本不卡一二三| 色久优优欧美色久优优| 久久精品一区二区三区av| 日韩av一区二区三区四区| 99久久精品国产观看| 国产人成一区二区三区影院| 麻豆极品一区二区三区| 欧美午夜一区二区三区免费大片| 国产精品激情偷乱一区二区∴| 国内精品在线播放| 欧美一卡在线观看| 亚洲综合久久久久| 色www精品视频在线观看| 国产欧美va欧美不卡在线| 毛片一区二区三区| 欧美高清你懂得| 丝瓜av网站精品一区二区| 91农村精品一区二区在线| 国产精品美女视频| 国产91精品精华液一区二区三区 | 男人的天堂亚洲一区| 欧美色视频在线观看| 一区二区三区精品视频在线| 9久草视频在线视频精品| 久久精品网站免费观看| 精品无码三级在线观看视频| 69p69国产精品| 日韩成人免费电影| 日韩无一区二区| 日本午夜精品一区二区三区电影| 欧美日韩一区中文字幕| 亚洲国产成人精品视频| 欧美日韩免费不卡视频一区二区三区| 亚洲品质自拍视频网站| 色综合天天综合在线视频| |精品福利一区二区三区| 99久久精品一区二区| 美女视频黄免费的久久| 6080日韩午夜伦伦午夜伦| 日韩av午夜在线观看| 日韩免费电影网站| 国产在线精品一区二区不卡了| 久久一二三国产| 成a人片亚洲日本久久| 中文字幕五月欧美| 一本一道久久a久久精品综合蜜臀| 亚洲色图欧洲色图婷婷| 色婷婷综合久久| 午夜精品爽啪视频| 欧美成人video| 国产精品一区久久久久| 亚洲欧洲精品一区二区精品久久久 | 日韩精品在线看片z| 国产真实乱对白精彩久久| 久久久久久久久久久久久女国产乱| 豆国产96在线|亚洲| 亚洲男人的天堂一区二区| 在线不卡a资源高清| 国产美女av一区二区三区| 成人欧美一区二区三区1314|