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

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

?? h8300_sci_serial.c

?? 開放源碼實時操作系統源碼.
?? C
?? 第 1 頁 / 共 2 頁
字號:
//==========================================================================
//
//      h8300_sci_serial.c
//
//      H8/300 Serial SCI I/O Interface Module (interrupt driven)
//
//==========================================================================
//####ECOSGPLCOPYRIGHTBEGIN####
// -------------------------------------------
// This file is part of eCos, the Embedded Configurable Operating System.
// Copyright (C) 1998, 1999, 2000, 2001, 2002 Red Hat, Inc.
//
// eCos is free software; you can redistribute it and/or modify it under
// the terms of the GNU General Public License as published by the Free
// Software Foundation; either version 2 or (at your option) any later version.
//
// eCos is distributed in the hope that it will be useful, but WITHOUT ANY
// WARRANTY; without even the implied warranty of MERCHANTABILITY or
// FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
// for more details.
//
// You should have received a copy of the GNU General Public License along
// with eCos; if not, write to the Free Software Foundation, Inc.,
// 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
//
// As a special exception, if other files instantiate templates or use macros
// or inline functions from this file, or you compile this file and link it
// with other works to produce a work based on this file, this file does not
// by itself cause the resulting work to be covered by the GNU General Public
// License. However the source code for this file must still be made available
// in accordance with section (3) of the GNU General Public License.
//
// This exception does not invalidate any other reasons why a work based on
// this file might be covered by the GNU General Public License.
//
// Alternative licenses for eCos may be arranged by contacting Red Hat, Inc.
// at http://sources.redhat.com/ecos/ecos-license/
// -------------------------------------------
//####ECOSGPLCOPYRIGHTEND####
//==========================================================================
//#####DESCRIPTIONBEGIN####
//
// Author(s):   jskov
// Contributors:gthomas, jskov
// Date:        1999-05-24
// Purpose:     H8/300 Serial I/O module (interrupt driven version)
// Description: 
//
// Note: Since interrupt sources from the same SCI channel share the same
//       interrupt level, there is no risk of races when altering the
//       channel's control register from ISRs and DSRs. However, when 
//       altering the control register from user-level code, interrupts
//       must be disabled while the register is being accessed.
//
// FIXME: Receiving in polled mode prevents duplex transfers from working for
//        some reason.
//####DESCRIPTIONEND####
//==========================================================================

#include <pkgconf/io_serial.h>
#include <pkgconf/io.h>

// FIXME: This is necessary since the SCIF driver may be overriding
// CYGDAT_IO_SERIAL_DEVICE_HEADER. Need a better way to include two
// different drivers.
#include <pkgconf/io_serial_h8300_sci.h>

#include <cyg/io/io.h>
#include <cyg/hal/hal_intr.h>
#include <cyg/io/devtab.h>
#include <cyg/infra/diag.h>
#include <cyg/io/serial.h>

#ifdef CYGDAT_IO_SERIAL_H8300_SCI
// The SCI controller register layout on the SH3/7708.
#define SCI_SCSMR                0      // serial mode register
#define SCI_SCBRR                1      // bit rate register
#define SCI_SCSCR                2      // serial control register
#define SCI_SCTDR                3      // transmit data register
#define SCI_SCSSR                4      // serial status register
#define SCI_SCRDR                5      // receive data register
#define SCI_SCSPTR               -4     // serial port register

static short select_word_length[] = {
    -1,
    -1,
    CYGARC_REG_SCSMR_CHR,               // 7 bits
    0                                   // 8 bits
};

static short select_stop_bits[] = {
    -1,
    0,                                  // 1 stop bit
    -1,
    CYGARC_REG_SCSMR_STOP               // 2 stop bits
};

static short select_parity[] = {
    0,                                  // No parity
    CYGARC_REG_SCSMR_PE,                // Even parity
    CYGARC_REG_SCSMR_PE|CYGARC_REG_SCSMR_OE, // Odd parity
    -1,
    -1
};

static unsigned short select_baud[] = {
    0,    // Unused
    CYGARC_SCBRR_CKSx(50)<<8 | CYGARC_SCBRR_N(50),
    CYGARC_SCBRR_CKSx(75)<<8 | CYGARC_SCBRR_N(75),
    CYGARC_SCBRR_CKSx(110)<<8 | CYGARC_SCBRR_N(110),
    CYGARC_SCBRR_CKSx(134)<<8 | CYGARC_SCBRR_N(134),
    CYGARC_SCBRR_CKSx(150)<<8 | CYGARC_SCBRR_N(150),
    CYGARC_SCBRR_CKSx(200)<<8 | CYGARC_SCBRR_N(200),
    CYGARC_SCBRR_CKSx(300)<<8 | CYGARC_SCBRR_N(300),
    CYGARC_SCBRR_CKSx(600)<<8 | CYGARC_SCBRR_N(600),
    CYGARC_SCBRR_CKSx(1200)<<8 | CYGARC_SCBRR_N(1200),
    CYGARC_SCBRR_CKSx(1800)<<8 | CYGARC_SCBRR_N(1800),
    CYGARC_SCBRR_CKSx(2400)<<8 | CYGARC_SCBRR_N(2400),
    CYGARC_SCBRR_CKSx(3600)<<8 | CYGARC_SCBRR_N(3600),
    CYGARC_SCBRR_CKSx(4800)<<8 | CYGARC_SCBRR_N(4800),
    CYGARC_SCBRR_CKSx(7200)<<8 | CYGARC_SCBRR_N(7200),
    CYGARC_SCBRR_CKSx(9600)<<8 | CYGARC_SCBRR_N(9600),
    CYGARC_SCBRR_CKSx(14400)<<8 | CYGARC_SCBRR_N(14400),
    CYGARC_SCBRR_CKSx(19200)<<8 | CYGARC_SCBRR_N(19200),
    CYGARC_SCBRR_CKSx(38400)<<8 | CYGARC_SCBRR_N(38400),
    CYGARC_SCBRR_CKSx(57600)<<8 | CYGARC_SCBRR_N(57600),
    CYGARC_SCBRR_CKSx(115200)<<8 | CYGARC_SCBRR_N(115200),
    CYGARC_SCBRR_CKSx(230400)<<8 | CYGARC_SCBRR_N(230400)
};


typedef struct h8300_sci_info {
    CYG_ADDRWORD   data;                // Pointer to data register
    
    CYG_WORD       er_int_num,          // Error interrupt number
                   rx_int_num,          // Receive interrupt number
                   tx_int_num;          // Transmit interrupt number

    CYG_ADDRWORD   ctrl_base;           // Base address of SCI controller

    cyg_interrupt  serial_er_interrupt, 
                   serial_rx_interrupt, 
                   serial_tx_interrupt;
    cyg_handle_t   serial_er_interrupt_handle, 
                   serial_rx_interrupt_handle, 
                   serial_tx_interrupt_handle;

    bool           tx_enabled;
} sh_sci_info;

static bool h8300_serial_init(struct cyg_devtab_entry *tab);
static bool h8300_serial_putc(serial_channel *chan, unsigned char c);
static Cyg_ErrNo h8300_serial_lookup(struct cyg_devtab_entry **tab, 
                                   struct cyg_devtab_entry *sub_tab,
                                   const char *name);
static unsigned char h8300_serial_getc(serial_channel *chan);
static Cyg_ErrNo h8300_serial_set_config(serial_channel *chan, cyg_uint32 key,
                                      const void *xbuf, cyg_uint32 *len);
static void h8300_serial_start_xmit(serial_channel *chan);
static void h8300_serial_stop_xmit(serial_channel *chan);

static cyg_uint32 h8300_serial_tx_ISR(cyg_vector_t vector, cyg_addrword_t data);
static void       h8300_serial_tx_DSR(cyg_vector_t vector, cyg_ucount32 count, 
                                   cyg_addrword_t data);
static cyg_uint32 h8300_serial_rx_ISR(cyg_vector_t vector, cyg_addrword_t data);
static void       h8300_serial_rx_DSR(cyg_vector_t vector, cyg_ucount32 count, 
                                   cyg_addrword_t data);
static cyg_uint32 h8300_serial_er_ISR(cyg_vector_t vector, cyg_addrword_t data);
static void       h8300_serial_er_DSR(cyg_vector_t vector, cyg_ucount32 count, 
                                   cyg_addrword_t data);

static SERIAL_FUNS(h8300_serial_funs, 
                   h8300_serial_putc, 
                   h8300_serial_getc,
                   h8300_serial_set_config,
                   h8300_serial_start_xmit,
                   h8300_serial_stop_xmit
    );


static h8300_sci_info h8300_serial_info =
{
    NULL,
    CYGNUM_HAL_INTERRUPT_ERI0,
    CYGNUM_HAL_INTERRUPT_RXI0,
    CYGNUM_HAL_INTERRUPT_TXI0,
    CYGARC_REG_SMR0
};

#if CYGNUM_IO_SERIAL_H8300_H8300H_SERIAL1_BUFSIZE > 0
static unsigned char h8300_serial_out_buf[CYGNUM_IO_SERIAL_H8300_CQ7708_SERIAL1_BUFSIZE];
static unsigned char h8300_serial_in_buf[CYGNUM_IO_SERIAL_H8300_CQ7708_SERIAL1_BUFSIZE];

static SERIAL_CHANNEL_USING_INTERRUPTS(h8300_serial_channel,
                                       h8300_serial_funs, 
                                       h8300_serial_info,
                                       CYG_SERIAL_BAUD_RATE(CYGNUM_IO_SERIAL_H8300_H8300H_SERIAL1_BAUD),
                                       CYG_SERIAL_STOP_DEFAULT,
                                       CYG_SERIAL_PARITY_DEFAULT,
                                       CYG_SERIAL_WORD_LENGTH_DEFAULT,
                                       CYG_SERIAL_FLAGS_DEFAULT,
                                       &h8300_serial_out_buf[0], 
                                       sizeof(h8300_serial_out_buf),
                                       &h8300_serial_in_buf[0],  
                                       sizeof(h8300_serial_in_buf)
    );
#else
static SERIAL_CHANNEL(h8300_serial_channel,
                      h8300_serial_funs, 
                      h8300_serial_info,
                      CYG_SERIAL_BAUD_RATE(CYGNUM_IO_SERIAL_H8300_H8300H_SERIAL1_BAUD),
                      CYG_SERIAL_STOP_DEFAULT,
                      CYG_SERIAL_PARITY_DEFAULT,
                      CYG_SERIAL_WORD_LENGTH_DEFAULT,
                      CYG_SERIAL_FLAGS_DEFAULT
    );
#endif

DEVTAB_ENTRY(h8300_serial_io,
             CYGDAT_IO_SERIAL_H8300_H8300H_SERIAL1_NAME,
             0,                 // Does not depend on a lower level interface
             &cyg_io_serial_devio, 
             h8300_serial_init, 
             h8300_serial_lookup,          // Serial driver may need initializing
             &h8300_serial_channel
    );

// Internal function to actually configure the hardware to desired baud rate,
// etc.
static bool
h8300_serial_config_port(serial_channel *chan, cyg_serial_info_t *new_config, 
                      bool init)
{
    cyg_uint16 baud_divisor = select_baud[new_config->baud];
    h8300_sci_info *h8300_chan = (h8300_sci_info *)chan->dev_priv;
    cyg_uint8 _scr, _smr;

    // Check configuration request
    if ((-1 == select_word_length[(new_config->word_length -
                                  CYGNUM_SERIAL_WORD_LENGTH_5)])
        || -1 == select_stop_bits[new_config->stop]
        || -1 == select_parity[new_config->parity]
        || baud_divisor == 0)
        return false;

    // Disable SCI interrupts while changing hardware
    HAL_READ_UINT8(h8300_chan->ctrl_base+SCI_SCSCR, _scr);
    HAL_WRITE_UINT8(h8300_chan->ctrl_base+SCI_SCSCR, 0);

    // Set databits, stopbits and parity.
    _smr = select_word_length[(new_config->word_length -
                               CYGNUM_SERIAL_WORD_LENGTH_5)] | 
        select_stop_bits[new_config->stop] |
        select_parity[new_config->parity];
    HAL_WRITE_UINT8(h8300_chan->ctrl_base+SCI_SCSMR, _smr);

    // Set baud rate.
    _smr &= ~CYGARC_REG_SCSMR_CKSx_MASK;
    _smr |= baud_divisor >> 8;
    HAL_WRITE_UINT8(h8300_chan->ctrl_base+SCI_SCSMR, _smr);
    HAL_WRITE_UINT8(h8300_chan->ctrl_base+SCI_SCBRR, baud_divisor & 0xff);

    // Clear the status register.
    HAL_WRITE_UINT8(h8300_chan->ctrl_base+SCI_SCSSR, 0);

    if (init) {
        // Always enable transmitter and receiver.
        _scr = CYGARC_REG_SCSCR_TE | CYGARC_REG_SCSCR_RE;

        if (chan->out_cbuf.len != 0)
            _scr |= CYGARC_REG_SCSCR_TIE; // enable tx interrupts

        if (chan->in_cbuf.len != 0)
            _scr |= CYGARC_REG_SCSCR_RIE; // enable rx interrupts
    }
     
    HAL_WRITE_UINT8(h8300_chan->ctrl_base+SCI_SCSCR, _scr);

    if (new_config != &chan->config) {
        chan->config = *new_config;
    }
    return true;
}

// Function to initialize the device.  Called at bootstrap time.
static bool 
h8300_serial_init(struct cyg_devtab_entry *tab)
{
    serial_channel *chan = (serial_channel *)tab->priv;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品久久久久久久久久免费看 | 色网站国产精品| 色婷婷av一区| 久久综合色播五月| 亚洲一区二区三区美女| 开心九九激情九九欧美日韩精美视频电影 | 91啪在线观看| 丝袜美腿亚洲色图| 一区二区三区鲁丝不卡| 国产精品一区二区果冻传媒| 欧美日韩视频在线一区二区| 久久久99精品久久| 美国毛片一区二区三区| 欧美私人免费视频| 国产精品久久国产精麻豆99网站| 青青青爽久久午夜综合久久午夜| 欧美在线观看视频在线| 1000精品久久久久久久久| 国产在线观看一区二区| 在线不卡免费av| 一级女性全黄久久生活片免费| 国产成人综合在线播放| 欧美一区二区播放| 午夜激情久久久| 欧美三级中文字| 亚洲精品美腿丝袜| 一本色道久久综合亚洲aⅴ蜜桃| 国产免费成人在线视频| 国产精品一区二区在线播放 | 午夜一区二区三区视频| 91视频.com| 亚洲欧美经典视频| 色婷婷av一区| 一二三四区精品视频| 欧美日韩一区在线观看| 亚洲一二三专区| 欧美日韩专区在线| 日本不卡一区二区三区高清视频| 欧美日韩亚洲综合在线| 偷窥国产亚洲免费视频| 91精品国产手机| 麻豆91精品视频| 亚洲一级电影视频| 黄色成人免费在线| 久久久亚洲欧洲日产国码αv| 国产在线精品免费av| 久久日一线二线三线suv| 国产成人精品网址| 国产精品不卡在线| 在线观看免费视频综合| 日本午夜一本久久久综合| 精品国产乱码久久久久久牛牛| 国产一区二区三区电影在线观看| 国产精品污www在线观看| 色综合一区二区三区| 亚洲成人资源在线| 精品理论电影在线观看| 99久久99久久久精品齐齐| 亚洲国产裸拍裸体视频在线观看乱了 | 日日嗨av一区二区三区四区| 欧美大片国产精品| 成人免费高清在线| 午夜久久福利影院| 国产情人综合久久777777| 91免费观看国产| 免费成人av资源网| 椎名由奈av一区二区三区| 欧美三级电影一区| 国产一区二区三区四 | 久久夜色精品国产欧美乱极品| 国产麻豆午夜三级精品| 亚洲精品福利视频网站| 日韩三级高清在线| 成人一区二区视频| 欧美aa在线视频| 又紧又大又爽精品一区二区| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 国产精品久久久久毛片软件| 欧美一区二区三区四区五区| 国产激情一区二区三区桃花岛亚洲| **网站欧美大片在线观看| 精品国产乱码久久久久久久| 色综合久久九月婷婷色综合| 精品亚洲成a人| 亚洲国产美女搞黄色| 国产精品午夜电影| 精品日韩一区二区三区免费视频| 91一区二区在线| 国产成人在线观看| 麻豆精品一区二区av白丝在线| 亚洲色图欧洲色图| 国产精品区一区二区三区| 日韩欧美精品在线视频| 欧美视频在线观看一区| 91在线观看地址| 成人亚洲一区二区一| 久久av中文字幕片| 日本不卡一区二区三区| 亚洲va在线va天堂| 国产精品视频免费看| 亚洲精品一区二区精华| 一区二区三区鲁丝不卡| 欧美在线视频全部完| 成人精品视频一区二区三区尤物| 免费在线欧美视频| 五月天精品一区二区三区| 亚洲国产精品麻豆| 亚洲最色的网站| 亚洲精品视频一区| 一区二区三区在线播放| 亚洲日本在线观看| 成人欧美一区二区三区1314| 国产偷v国产偷v亚洲高清| 久久久不卡网国产精品二区| 日韩亚洲欧美成人一区| 日韩免费看的电影| 精品国产制服丝袜高跟| 久久久久成人黄色影片| 日本一区二区三区在线观看| 国产亚洲自拍一区| 国产精品久久综合| 一区二区三区高清不卡| 亚洲二区在线视频| 五月天欧美精品| 久久精品99久久久| 国产aⅴ综合色| 91丨九色丨蝌蚪富婆spa| 色欧美片视频在线观看在线视频| 色呦呦国产精品| 91精品国产入口在线| 欧美精品一区二区精品网| 国产日本欧美一区二区| 亚洲人成在线观看一区二区| 亚洲午夜久久久久中文字幕久| 亚洲国产sm捆绑调教视频 | 亚洲精品乱码久久久久| 午夜视频在线观看一区二区三区| 蜜桃av噜噜一区| 成人av免费在线观看| 欧美艳星brazzers| 日韩欧美国产午夜精品| 亚洲欧洲三级电影| 亚洲成人免费在线观看| 国产精品88888| 欧美精选在线播放| 欧美精品一区二区三区四区| 中文字幕亚洲不卡| 日韩激情一二三区| 国产精品亚洲第一区在线暖暖韩国| 成人性生交大片免费看中文| 欧美私人免费视频| 久久日韩粉嫩一区二区三区| 一区二区三区欧美激情| 香蕉乱码成人久久天堂爱免费| 国产在线国偷精品免费看| 色8久久精品久久久久久蜜| 精品国产91乱码一区二区三区| 国产精品久久久久久福利一牛影视| 亚洲成人av一区二区三区| 国产在线视频精品一区| 在线观看亚洲a| 国产欧美日韩精品a在线观看| 亚洲精品va在线观看| 国产精品亚洲一区二区三区在线| 欧美日韩亚洲综合一区二区三区| 欧美国产激情二区三区| 日本美女一区二区三区视频| 菠萝蜜视频在线观看一区| 欧美一区二区三区日韩| 亚洲欧美日韩中文播放| 精品一区二区免费在线观看| 欧美三级欧美一级| 日本一区二区免费在线| 日日夜夜免费精品| 欧美中文字幕久久| 国产精品卡一卡二| 国产成人综合在线| 精品欧美一区二区久久| 午夜婷婷国产麻豆精品| 91成人国产精品| 中文字幕一区二区在线观看| 卡一卡二国产精品 | 久久久久久综合| 全部av―极品视觉盛宴亚洲| 亚洲图片欧美色图| 三级在线观看一区二区| 一本久久a久久免费精品不卡| 国产网站一区二区| 精品一区二区三区欧美| 欧美精品久久99| 亚洲成av人片一区二区三区| 日本久久一区二区三区| 亚洲欧美一区二区三区孕妇| 成人av先锋影音| 国产精品丝袜黑色高跟| 国产伦精一区二区三区| 久久伊人中文字幕| 国产麻豆视频一区二区| 国产亚洲成aⅴ人片在线观看 | 精品国产一二三|