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

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

?? 21555drv.c

?? vxworks的BSP開發配置文件
?? C
字號:
/* 21555drv.c - Intel 21555 Non-Transparent Bridge Driver *//* Copyright 2000 Intel Corp. *//*modification history--------------------01b,17jul01,jdg  Allow variable bridge configurations01a,20dec00,jdg  Created*//*DESCRIPTIONThis library provides support for the Intel 21555 Non-transparent Bridge.*//* includes */#include "vxWorks.h"#include "config.h"#include "dllLib.h"#include "pciIomapLib.h"#include "21555drv.h"/* defines */#define MASK_4K  (~(4 * 1024 - 1))#define MASK_8K  (~(8 * 1024 - 1))#define MASK_1M  (~(1 * 1024 * 1024 -1))#define MASK_2M  (~(2 * 1024 * 1024 -1))#define PREFETCHABLE (1<<3)/* * At present, we only use bit 15, later we'll also use bit 14 for the * second 1200 */#define DOORBELL_BITS (1 << 15)#define REG_READ16(a) (*(volatile UINT16*)(a))#define REG_WRITE16(a,val) (*(volatile UINT16*)(a)) = (val)/* imports *//* typedefs */typedef struct ntbInfo         /* Non transparent bridge info */{    UINT32 ioBase;} NTB_INFO;/* globals */NTB_INFO ntbInfo;/* locals *//* forward declarations *//********************************************************************************* sysIntel21555PreInit - Initialize 21555 NTB** This routine finds the bridge and initializes it's CSRs.* It should be called after pciIomapLibInit is called, and before* PCI addresses are assigned (sysPciAssignAddrs).** RETURNS: OK, or ERROR*/STATUS sysIntel21555PreInit    (    UINT32 upstreamSize   /* Size of upstream window: 16K - 2G */    ){    UINT32 pciBus;      /* PCI bus number */    UINT32 pciDevice;   /* PCI device number */    UINT32 pciFunc;     /* PCI Function number */    UINT16 data0, data1;    UINT32 size;    for (size = 31; size >= 14; size--) {        if (upstreamSize == (UINT32)(1 << size))            break;    }    if (size < 14)      {        return ERROR;      }    if (OK != pciFindDevice(INT21555_VEND_ID, INT21555_DEVICE_ID,                            0, &pciBus, &pciDevice, &pciFunc))    {        return ERROR;    }    /*     * Set up Secondary BAR masks and address mapping     *     * ADDR REG                  TYPE SIZE   PURPOSE     * 10   Sec CSR Mem          Mem  N/A    not used     * 14   Sec CSR              IO   N/A    21555 CSRs     * 18   Upstream IOM Bar 0   Mem  4K     not used     * 1C   Upstream Mem Bar 1   Mem  4K     not used     * 20   Upstream Mem Bar 2   Mem  var    General Primary Access     */    pciConfigOutLong(pciBus, pciDevice, pciFunc,                     PCI_US_IOMEM_0_SETUP, MASK_4K);    pciConfigOutLong(pciBus, pciDevice, pciFunc,                     PCI_US_MEM_1_SETUP, MASK_4K);    /* Program up Upstream Mem 2 size */    pciConfigInWord(pciBus, pciDevice, pciFunc,                    PCI_CHIP_CTRL_0,                    &data0);    pciConfigInWord(pciBus, pciDevice, pciFunc,                    PCI_CHIP_CTRL_1,                    &data1);    data1 &= ~0x0F00;    if (size >= 29) {        data0 |= 0x1000;        data1 |= (size - 28) << 8;    } else {        data0 &= ~0x1000;        data1 |= (size - 13) << 8;    }    pciConfigOutWord(pciBus, pciDevice, pciFunc,                     PCI_CHIP_CTRL_0,                     data0);    pciConfigOutWord(pciBus, pciDevice, pciFunc,                     PCI_CHIP_CTRL_1,                     data1);    return OK;}/********************************************************************************* readCsrIoBase - Reads the CSR IO Base after PCI address assignments** This routine finds the bridge and reads the CSR IO Base** RETURNS: OK, or ERROR*/STATUS readCsrIoBase    (    ){    UINT32 pciBus;      /* PCI bus number */    UINT32 pciDevice;   /* PCI device number */    UINT32 pciFunc;     /* PCI Function number */    if (OK != pciFindDevice(INT21555_VEND_ID, INT21555_DEVICE_ID,                            0, &pciBus, &pciDevice, &pciFunc))    {        return ERROR;    }    /* Read CSR IO Base */    pciConfigInLong(pciBus, pciDevice, pciFunc, PCI_CFG_BASE_ADDRESS_1,                    &ntbInfo.ioBase); /* CSR IO Base */    ntbInfo.ioBase &= ~PCI_HEADER_TYPE_MASK;    ntbInfo.ioBase |= PCI_IO_BASE;	return OK;}	/********************************************************************************* sysIntel21555PostInit - Initialize 21555 NTB after PCI address assignments** This routine finds the bridge and does any initialization that needs to* occur after PCI addresses are assigned (sysPciAssignAddrs).** RETURNS: OK, or ERROR*/STATUS sysIntel21555PostInit    (    short vendId,             /* Subsystem Vendor ID */    short sysId,              /* Subsystem ID */    UINT32 sdramWindowSize,   /* Size of SDRAM Window in Pri PCI */    UINT32 sdramWindowOffset  /* Offset of window from start of SDram */    ){    UINT32 pciBus;      /* PCI bus number */    UINT32 pciDevice;   /* PCI device number */    UINT32 pciFunc;     /* PCI Function number */    UINT32 addr;    UINT16 data;    if (OK != pciFindDevice(INT21555_VEND_ID, INT21555_DEVICE_ID,                            0, &pciBus, &pciDevice, &pciFunc))    {        return ERROR;    }    /* Read CSR IO Base */    pciConfigInLong(pciBus, pciDevice, pciFunc, PCI_CFG_BASE_ADDRESS_1,                    &ntbInfo.ioBase); /* CSR IO Base */    ntbInfo.ioBase &= ~PCI_HEADER_TYPE_MASK;    ntbInfo.ioBase |= PCI_IO_BASE;    /* Set Subsystem ID */    pciConfigOutWord(pciBus, pciDevice, pciFunc, PCI_CFG_SUB_VENDER_ID,                     vendId);    pciConfigOutWord(pciBus, pciDevice, pciFunc, PCI_CFG_SUB_SYSTEM_ID,                     sysId);    /*     * Set up primary BAR masks and address mapping     *     * ADDR REG                  TYPE SIZE   PURPOSE     * 10   Pri CSR / DS Mem 0   Mem  4K     not used     * 14   Pri CSR              IO   N/A    21555 CSRs     * 18   Downstream IOM Bar 1 Mem  1(2)M  MEM/CSR 0/1 (1200's CSRs)     * 1C   Downstream Mem Bar 2 Mem  var    MEM 0 (1200's SDRAM)     * 20   Downstream Mem Bar 3 Mem  var    MEM 1 (unused at present)     */    pciConfigOutLong(pciBus, pciDevice, pciFunc,                     PCI_DS_MEM_0_SETUP, MASK_4K);    pciConfigOutLong(pciBus, pciDevice, pciFunc,                     PCI_DS_IOMEM_1_SETUP, MASK_1M);    pciConfigOutLong(pciBus, pciDevice, pciFunc,                     PCI_DS_MEM_2_SETUP, ~(sdramWindowSize-1) | PREFETCHABLE);    pciConfigOutLong(pciBus, pciDevice, pciFunc,                     PCI_DS_MEM_3_SETUP, 0);    /* IOMEM_1 is set to point to our CSR MEM base */    addr = *(UINT32 *) (IXM1200_PCI_MEM_BAR);    pciConfigOutLong(pciBus, pciDevice, pciFunc,                     PCI_DS_IOMEM_1_TBASE, addr);    pciConfigOutLong(pciBus, pciDevice, pciFunc,                     PCI_DS_MEM_2_TBASE, sdramWindowOffset);    /* Set secondary PCI command reg to allow transactions */    pciConfigOutWord(pciBus, pciDevice, pciFunc,                     PCI_CFG_COMMAND,                     PCI_CMD_IO_ENABLE |                     PCI_CMD_MEM_ENABLE |                     PCI_CMD_MASTER_ENABLE);    /* Allow primary PCI to do config cycles */    pciConfigInWord(pciBus, pciDevice, pciFunc,                    PCI_CHIP_CTRL_0,                    &data);    data &= ~(PCI_CHIP_C0_PR_ACC_LOCK);    pciConfigOutWord(pciBus, pciDevice, pciFunc,                     PCI_CHIP_CTRL_0,                     data);    /* Program Doorbell register */    /* Clear interrupt request */    REG_WRITE16(ntbInfo.ioBase + PCI_PRI_CLR_IRQ, DOORBELL_BITS);    /* Enable doorbell */    REG_WRITE16(ntbInfo.ioBase + PCI_PRI_CLR_IRQ_MASK, DOORBELL_BITS);    return OK;}/********************************************************************************* sysGet21555DBAddr - Get 21555 doorbell set address** This routine returns the address of the 21555 doorbell set register** RETURNS: Address*/UINT32 sysGet21555DBAddr (){    return (ntbInfo.ioBase + PCI_PRI_SET_IRQ);}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人午夜电影久久影院| 久久久久久久久99精品| 美日韩一区二区| 国产精品素人一区二区| 精品一区二区三区香蕉蜜桃| 日韩美女精品在线| 欧美成人a视频| 午夜欧美在线一二页| 欧美日本一道本在线视频| 欧美日精品一区视频| 久久99精品国产.久久久久久| 国产精品亲子伦对白| 欧美午夜一区二区三区免费大片| 国产宾馆实践打屁股91| 极品美女销魂一区二区三区| 午夜国产精品一区| 亚洲日本中文字幕区| 欧美国产禁国产网站cc| 久久亚洲欧美国产精品乐播| 欧美大肚乱孕交hd孕妇| 欧美午夜精品一区二区蜜桃 | 欧美大片在线观看一区二区| 欧美在线你懂的| 日本伦理一区二区| 国产精品一区一区| 一本久久a久久精品亚洲| 欧美精品v日韩精品v韩国精品v| 欧美草草影院在线视频| 国产精品乱人伦| 五月婷婷另类国产| 成人黄色免费短视频| 一本色道久久综合狠狠躁的推荐| 欧美精品久久久久久久久老牛影院| 欧美成人性战久久| 亚洲综合精品自拍| 成人免费电影视频| 欧美一级xxx| 亚洲欧美偷拍卡通变态| 国产一区二区三区久久久| 欧美在线视频全部完| 国产欧美日韩中文久久| 午夜激情久久久| 99久久婷婷国产综合精品| 欧美v国产在线一区二区三区| 亚洲摸摸操操av| 国产成人午夜精品影院观看视频| 欧美日韩国产123区| 中文字幕一区二区三区在线观看| 日产欧产美韩系列久久99| 在线观看不卡一区| 中文字幕亚洲在| 国产风韵犹存在线视精品| 欧美一二三区精品| 亚洲无人区一区| 不卡的av网站| 久久久www成人免费无遮挡大片| 亚洲国产美国国产综合一区二区| eeuss鲁一区二区三区| 欧美一区二区三区四区视频| 亚洲午夜久久久| 一本一本大道香蕉久在线精品 | 五月激情六月综合| 97精品久久久午夜一区二区三区| 精品美女一区二区| 麻豆91精品视频| 欧美一级高清大全免费观看| 亚洲精选免费视频| 一本一道久久a久久精品| 国产精品毛片大码女人| 国产毛片精品国产一区二区三区| 欧美精三区欧美精三区 | 欧美三级三级三级爽爽爽| 一区二区在线观看视频在线观看| 国产激情视频一区二区在线观看 | 国产精品亚洲一区二区三区在线| 日韩欧美一级二级三级久久久| 午夜精品久久久久久久久久久| 欧美日韩综合在线| 免费精品视频在线| 欧美mv日韩mv亚洲| 国产乱码精品一区二区三区av | 亚洲日本欧美天堂| 91蜜桃传媒精品久久久一区二区| 成人欧美一区二区三区小说| 国产99一区视频免费| 国产精品入口麻豆原神| 成人精品一区二区三区中文字幕| 欧美大片在线观看| 国产毛片精品一区| 国产精品私房写真福利视频| 99久久综合国产精品| 欧美国产精品一区二区三区| 国产精品自在在线| 亚洲特级片在线| 日韩一区二区三区免费观看| 老鸭窝一区二区久久精品| 久久久久九九视频| 91国产免费看| 精品亚洲porn| 国产精品久久久久久久久久久免费看 | 国产大陆精品国产| 国产精品二三区| 欧美日本一区二区在线观看| 韩日av一区二区| 一区二区三区高清在线| 91精品国产91久久综合桃花| 国产成人免费网站| 亚洲第一福利一区| 国产欧美一区二区精品仙草咪| 91久久国产综合久久| 国精品**一区二区三区在线蜜桃| 亚洲欧洲av另类| 亚洲精品一区二区三区精华液| 91视频免费播放| 国产一区二区在线观看视频| 亚洲色图欧洲色图婷婷| 日韩午夜激情电影| 色妹子一区二区| 国模冰冰炮一区二区| 亚洲欧美偷拍卡通变态| 久久久久久电影| 在线综合视频播放| 久久精品噜噜噜成人av农村| 亚洲精品v日韩精品| 久久一日本道色综合| 欧美精品乱码久久久久久| 91老师片黄在线观看| 高清不卡一二三区| 国产在线播精品第三| 日韩影院免费视频| 亚洲国产精品精华液网站| 综合久久国产九一剧情麻豆| 欧美经典三级视频一区二区三区| 日韩欧美在线不卡| 欧美日韩精品一区二区三区蜜桃 | 色美美综合视频| 成人高清视频在线观看| 狠狠网亚洲精品| 日本不卡的三区四区五区| 亚洲一区成人在线| 亚洲精品高清在线| 国产精品久久一卡二卡| 国产午夜亚洲精品理论片色戒 | 日韩黄色免费电影| 亚洲一区二区三区视频在线| 亚洲天堂a在线| 精品对白一区国产伦| 精品欧美一区二区在线观看| 91精品国产高清一区二区三区蜜臀| 欧美亚洲综合网| 91成人在线精品| 色婷婷国产精品久久包臀| aa级大片欧美| 顶级嫩模精品视频在线看| 久久黄色级2电影| 国产一区二三区好的| 国产乱人伦偷精品视频免下载| 激情伊人五月天久久综合| 三级影片在线观看欧美日韩一区二区| 亚洲福利视频三区| 亚洲午夜久久久| 亚洲电影欧美电影有声小说| 丝袜亚洲另类丝袜在线| 亚洲国产精品视频| 日本在线不卡视频一二三区| 天天色综合成人网| 久久99久久精品欧美| 国产久卡久卡久卡久卡视频精品| 成人免费视频一区| 色噜噜久久综合| 日韩一级精品视频在线观看| 久久亚洲精精品中文字幕早川悠里| 国产三级一区二区三区| 亚洲欧洲综合另类在线| 日日夜夜一区二区| 激情综合色播激情啊| 91毛片在线观看| 7777精品伊人久久久大香线蕉超级流畅 | 亚洲欧美在线观看| 亚洲一级二级三级在线免费观看| 三级亚洲高清视频| 成人永久免费视频| 欧美三级中文字幕在线观看| 精品国产一区二区在线观看| 国产精品欧美久久久久一区二区| 亚洲精品国产a| 国内精品在线播放| 99久久精品国产网站| 欧美一区二区三区在线视频 | 在线一区二区三区做爰视频网站| 69久久夜色精品国产69蝌蚪网 | 在线观看日韩高清av| 日韩欧美一级二级三级 | 欧美最新大片在线看| 久久精品人人做人人综合 | 久久人人97超碰com| 亚洲综合色自拍一区| 国产黄色成人av| 欧美一区二区三区精品| 日本一区二区视频在线观看|