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

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

?? sngks32csio.c

?? 三星公司S3C4510B的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"#define SNGKS32C_BAUD_MIN         1200#define SNGKS32C_BAUD_MAX         460860#define SNGKS32C_SIO_DEFAULT_BAUD 38400/* Hardware abstraction macros *//* local defines  */#ifndef SNGKS32C_SIO_REG_READ#define SNGKS32C_SIO_REG_READ(pChan, reg, result) \    ((result) = (*(volatile UINT32 *)((UINT32)(pChan)->regs + (reg))))#endif    /*SNGKS32C_SIO_REG_READ*/#ifndef SNGKS32C_SIO_REG_WRITE#define SNGKS32C_SIO_REG_WRITE(pChan, reg, data) \    ((*(volatile UINT32 *)((UINT32)(pChan)->regs + (reg))) = (data))#endif    /*SNGKS32C_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    sngks32cTxStartup (SIO_CHAN * pSioChan);LOCAL int    sngks32cCallbackInstall (SIO_CHAN *pSioChan, int callbackType,                                      STATUS (*callback)(), void *callbackArg);LOCAL int    sngks32cPollOutput (SIO_CHAN *pSioChan, char    outChar);LOCAL int    sngks32cPollInput (SIO_CHAN *pSioChan, char *thisChar);LOCAL int    sngks32cIoctl (SIO_CHAN *pSioChan, int request, void *arg);LOCAL STATUS dummyCallback (void);/* local variables */LOCAL    SIO_DRV_FUNCS sngks32cSioDrvFuncs =    {    sngks32cIoctl,    sngks32cTxStartup,    sngks32cCallbackInstall,    sngks32cPollInput,    sngks32cPollOutput    };LOCAL BOOL sngks32cIntrMode = FALSE;    /* interrupt mode allowed flag *//******************************************************************************** sngks32cDevInit - initialize a SNGKS32C_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 SNGKS32C_DUSART structure before passing it to* this routine.** RETURNS: N/A*/void sngks32cDevInit    (    SNGKS32C_CHAN * pChan    )    {    /* initialize each channel's driver function pointers */    pChan->sio.pDrvFuncs    = &sngks32cSioDrvFuncs;    /* install dummy driver callbacks */    pChan->getTxChar     = dummyCallback;    pChan->putRcvChar    = dummyCallback;        /* reset the chip */    SNGKS32C_SIO_REG_WRITE(pChan,SNGKS32C_ULCON,(INT_CLK | PARITY_NONE | ONE_STOP | WORD_LEN));    /* setting polled mode is one way to make the device quiet */    sngks32cIoctl ((SIO_CHAN *)pChan, SIO_MODE_SET, (void *)SIO_MODE_POLL);    sngks32cIoctl ((SIO_CHAN *)pChan, SIO_BAUD_SET, (void *)SNGKS32C_SIO_DEFAULT_BAUD);    }/******************************************************************************** sngks32cDevInit2 - initialize a SNGKS32C_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 sngks32cDevInit2    (    SNGKS32C_CHAN * pChan        /* device to initialize */    )    {    char      outchar = '\0';    UINT32    status;    /*      * Dummy write to TXBUF to start TX empty interrupt     */    SNGKS32C_SIO_REG_WRITE(pChan,SNGKS32C_UTXBUF,outchar);    /* Interrupt mode is allowed */    SNGKS32C_SIO_REG_WRITE(pChan,SNGKS32C_UCON,UCON_RX|UCON_TX|UCON_BREAK);    SNGKS32C_SIO_REG_READ(pChan,SNGKS32C_USTAT, status);        while ((status & USTAT_TX_READY) != USTAT_TX_READY)        ;    SNGKS32C_SIO_REG_WRITE(pChan,SNGKS32C_UCON,UCON_RX|UCON_TX);    sngks32cIntrMode = TRUE;    }/******************************************************************************** sngks32cIntRcv - handle a channel's receive-character interrupt** RETURNS: N/A*/ void sngks32cIntRcv    (    SNGKS32C_CHAN *    pChan        /* channel generating the interrupt */    )    {    char            inChar;    UINT32        status;    /*     * 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.     */    SNGKS32C_SIO_REG_READ(pChan,SNGKS32C_USTAT, status);    if((status & USTAT_RX_READY) == USTAT_RX_READY)        {        SNGKS32C_SIO_REG_READ(pChan,SNGKS32C_URXBUF, inChar);        (*pChan->putRcvChar) (pChan->putRcvArg, inChar);        }    }/******************************************************************************** sngks32cIntTx - handle a channels transmitter-ready interrupt** RETURNS: N/A*/ void sngks32cIntTx    (    SNGKS32C_CHAN *    pChan        /* channel generating the interrupt */    )    {    char      outChar;    UINT32    status;    /*     * 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.     */    SNGKS32C_SIO_REG_READ(pChan,SNGKS32C_USTAT, status);        if((status & USTAT_TX_READY) != USTAT_TX_READY)            return;    if ((*pChan->getTxChar) (pChan->getTxArg, &outChar) != ERROR)        SNGKS32C_SIO_REG_WRITE(pChan, SNGKS32C_UTXBUF, outChar);    else        {            intDisable (pChan->intLevelTx);        *(UINT32 *) SNGKS32C_INTPEND = (1 << pChan->intLevelTx);        }    }/******************************************************************************** sngks32cTxStartup - start the interrupt transmitter** RETURNS: OK on success, ENOSYS if the device is polled-only, or* EIO on hardware error.*/LOCAL int sngks32cTxStartup    (    SIO_CHAN * pSioChan                 /* channel to start */    )    {    SNGKS32C_CHAN * pChan = (SNGKS32C_CHAN *)pSioChan;    *(UINT32 *) SNGKS32C_INTPENDTST |= (1 << pChan->intLevelTx);    intEnable (pChan->intLevelTx);    return (OK);    }/******************************************************************************** sngks32cCallbackInstall - 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 sngks32cCallbackInstall    (    SIO_CHAN *    pSioChan,               /* channel */    int           callbackType,           /* type of callback */    STATUS        (*callback)(),          /* callback */    void *        callbackArg             /* parameter to callback */    )    {    SNGKS32C_CHAN * pChan = (SNGKS32C_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;        pChan->putRcvArg     = callbackArg;        return (OK);    default:        return (ENOSYS);    }    }/********************************************************************************* sngks32cPollOutput - output a character in polled mode** RETURNS: OK if a character arrived, EIO on device error, EAGAIN* if the output buffer if full. ENOSYS if the device is* interrupt-only.*/LOCAL int sngks32cPollOutput    (    SIO_CHAN *pSioChan,    char      outChar    )    {    SNGKS32C_CHAN * pChan = (SNGKS32C_CHAN *)pSioChan;    UINT32    status;    /* is the transmitter ready to accept a character? */    SNGKS32C_SIO_REG_READ (pChan, SNGKS32C_USTAT, status);    if ((status & USTAT_TX_READY) == 0x00)        return (EAGAIN);    /* write out the character */    SNGKS32C_SIO_REG_WRITE(pChan, SNGKS32C_UTXBUF, outChar);    return (OK);    }/******************************************************************************** sngks32cPollInput - poll the device for input** RETURNS: OK if a character arrived, EIO on device error, EAGAIN* if the input buffer if empty, ENOSYS if the device is* interrupt-only.*/LOCAL int sngks32cPollInput    (    SIO_CHAN *    pSioChan,    char *        thisChar    )    {    SNGKS32C_CHAN * pChan = (SNGKS32C_CHAN *)pSioChan;    UINT32    status;    SNGKS32C_SIO_REG_READ (pChan,SNGKS32C_USTAT, status);    if ((status & USTAT_RX_AVAIL) == 0x00)        return (EAGAIN);    /* no input available at this time */    /* got a character */    SNGKS32C_SIO_REG_READ(pChan, SNGKS32C_URXBUF, *thisChar);    return (OK);    }/******************************************************************************** sngks32cModeSet - toggle between interrupt and polled mode** RETURNS: OK on success, EIO on unsupported mode.*/LOCAL int sngks32cModeSet    (    SNGKS32C_CHAN * pChan,        /* channel */    uint_t          newMode       /* new mode */    )    {    UINT32    temp;    if ((newMode != SIO_MODE_POLL) && (newMode != SIO_MODE_INT))        return (EIO);    /* Don't enter interrupt mode unless it is allowed. */    if ((newMode == SIO_MODE_INT) && (!sngks32cIntrMode))    return (EIO);    /* set the new mode */    pChan->mode = newMode;    if (pChan->mode == SIO_MODE_INT)        {                SNGKS32C_SIO_REG_READ(pChan, SNGKS32C_UCON, temp);        temp &=UCON_RX_TX_RESET;    /**Reset RX and TX mode bits*/        temp |= (UCON_RX|UCON_TX);        SNGKS32C_SIO_REG_WRITE(pChan,SNGKS32C_UCON, temp);        intEnable(pChan->intLevelRx);        }    else        {        SNGKS32C_SIO_REG_READ(pChan, SNGKS32C_UCON, temp);        temp &=UCON_RX_TX_RESET;    /**Reset RX and TX mode bits*/        temp |= (UCON_RX|UCON_TX);        SNGKS32C_SIO_REG_WRITE(pChan,SNGKS32C_UCON, temp);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99久久综合色| 不卡高清视频专区| 中文字幕免费不卡| 欧美日韩欧美一区二区| 国产精品自拍毛片| 偷拍日韩校园综合在线| **欧美大码日韩| 欧美成人精品3d动漫h| 一本一道综合狠狠老| 国产一区视频网站| 亚洲成人激情av| 亚洲天堂久久久久久久| 久久久一区二区三区捆绑**| 欧美日韩精品免费观看视频 | 天天影视涩香欲综合网| 亚洲国产激情av| 精品欧美黑人一区二区三区| 欧美羞羞免费网站| 91尤物视频在线观看| 国产成人精品免费视频网站| 日本麻豆一区二区三区视频| 亚洲男人的天堂av| 国产精品久线观看视频| 久久精品亚洲麻豆av一区二区 | 欧美成人艳星乳罩| 欧美高清视频不卡网| 欧美这里有精品| 欧美videos中文字幕| 精品视频在线视频| 在线精品视频小说1| jvid福利写真一区二区三区| 国产美女精品一区二区三区| 久久精品久久综合| 青青草视频一区| 亚洲第一av色| 天天av天天翘天天综合网| 亚洲精品第1页| 一片黄亚洲嫩模| 一区二区成人在线| 亚洲国产cao| 亚洲成人av一区二区| 亚洲成人av一区| 水野朝阳av一区二区三区| 午夜精品一区在线观看| 天堂午夜影视日韩欧美一区二区| 亚洲成av人片在线观看| 亚洲成av人在线观看| 三级亚洲高清视频| 麻豆国产91在线播放| 久久精品99久久久| 国产成人精品亚洲日本在线桃色| 91在线免费视频观看| 成人精品gif动图一区| 大胆亚洲人体视频| 99久久精品情趣| 91麻豆福利精品推荐| 在线免费亚洲电影| 欧美日韩国产综合一区二区| 91精品婷婷国产综合久久| 日韩久久久精品| 国产三级欧美三级日产三级99| 国产欧美日韩亚州综合| 日韩一区日韩二区| 亚洲丰满少妇videoshd| 美女在线观看视频一区二区| 国产精品91一区二区| 在线不卡中文字幕| 久久久影视传媒| 亚洲天堂久久久久久久| 午夜精品视频在线观看| 国内外精品视频| 91麻豆自制传媒国产之光| 欧美区视频在线观看| 国产精品美女久久久久久久网站| 国产香蕉久久精品综合网| 最新成人av在线| 午夜国产不卡在线观看视频| 国产在线精品一区在线观看麻豆| 成人手机电影网| 欧美三级欧美一级| 久久香蕉国产线看观看99| 专区另类欧美日韩| 麻豆成人久久精品二区三区红| 国产成人综合在线播放| 91黄色激情网站| 久久品道一品道久久精品| 亚洲欧美一区二区三区国产精品 | 欧美性大战xxxxx久久久| 欧美一区二区三区思思人| 中文字幕成人在线观看| 首页国产欧美久久| 成人午夜精品一区二区三区| 欧美日韩不卡一区二区| 国产欧美精品一区二区色综合| 亚洲成人自拍偷拍| 成人激情午夜影院| 99国内精品久久| 午夜精品福利视频网站| 国产乱子伦一区二区三区国色天香| 色综合久久久久久久| 精品国精品国产尤物美女| 亚洲久草在线视频| 国产一区二区三区不卡在线观看 | 欧美精品在线观看播放| 国产精品女主播av| 久久精品国产亚洲高清剧情介绍| 91网址在线看| 国产三区在线成人av| 日韩专区中文字幕一区二区| 色综合久久六月婷婷中文字幕| 精品久久久久香蕉网| 五月开心婷婷久久| 91国产丝袜在线播放| 中文字幕欧美日韩一区| 精品亚洲porn| 欧美一卡在线观看| 亚洲丶国产丶欧美一区二区三区| 成人va在线观看| 国产日韩欧美a| 国模无码大尺度一区二区三区| 欧美久久久久久蜜桃| 一区二区三区国产| 97久久精品人人做人人爽50路| 久久精品视频在线看| 蜜臀精品久久久久久蜜臀| 欧美久久久久久久久中文字幕| 亚洲女同ⅹxx女同tv| 99re这里只有精品视频首页| 国产精品美女久久久久久久| 国产成人午夜视频| 亚洲国产成人午夜在线一区| 国产精品1区二区.| 久久久精品黄色| 国产馆精品极品| 国产欧美综合在线| 成人午夜在线播放| 国产精品美女一区二区在线观看| 成人免费看片app下载| 国产精品色哟哟网站| av一区二区三区黑人| 一色桃子久久精品亚洲| 91网站最新网址| 亚洲欧美日韩中文字幕一区二区三区 | 91精品国产欧美一区二区成人| 亚洲小少妇裸体bbw| 欧美另类一区二区三区| 日韩中文字幕亚洲一区二区va在线| 欧美日本精品一区二区三区| 亚洲va欧美va人人爽| 欧美精品在欧美一区二区少妇| 日韩黄色免费网站| 欧美mv日韩mv国产| 国产精品18久久久久久久久 | 久久久噜噜噜久久中文字幕色伊伊| 紧缚捆绑精品一区二区| 久久精品在这里| 99久久久精品免费观看国产蜜| 亚洲人成网站影音先锋播放| 欧美午夜免费电影| 欧美aaaaaa午夜精品| 久久精品夜色噜噜亚洲aⅴ| www.av精品| 午夜影视日本亚洲欧洲精品| 日韩亚洲欧美一区| 国产成人精品免费视频网站| 亚洲欧美日韩国产一区二区三区| 欧美系列在线观看| 久久成人羞羞网站| 国产精品毛片无遮挡高清| 在线观看成人小视频| 秋霞av亚洲一区二区三| 国产女同性恋一区二区| 欧美亚洲禁片免费| 九九精品一区二区| 亚洲视频免费看| 日韩免费高清av| 色综合网色综合| 另类人妖一区二区av| 自拍偷拍国产精品| 欧美一级爆毛片| 99re热视频精品| 久久69国产一区二区蜜臀| 最新欧美精品一区二区三区| 欧美一级理论片| 91网站在线观看视频| 久久97超碰国产精品超碰| 亚洲综合精品久久| 久久久www免费人成精品| 欧美日韩一区视频| 成人黄色综合网站| 免播放器亚洲一区| 一区二区三区中文在线| 久久久亚洲高清| 欧美巨大另类极品videosbest| 国产精品影视天天线| 亚洲成人av在线电影| 久久超碰97人人做人人爱| 日韩理论电影院| 国产日产欧产精品推荐色| 在线播放日韩导航|