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

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

?? pciext.c

?? WinCE5.0BSP for Renesas SH7770
?? C
?? 第 1 頁 / 共 2 頁
字號:
//
// Copyright (c) Microsoft Corporation.  All rights reserved.
//
/*

  Copyright(c) 2001 Microsoft.

	Module Name:

		pciext.c

	Revision History:
		Oct 26th for Talisker #664 ( Del EDBGOutputDebugString )

*/

#include <windows.h>
#include <nkintr.h>
#include <ceddk.h>
#include <halether.h>
#include "shx.h"
#include "platform.h"
#include "oalintr.h"
#include "pciext.h"

#define IRQ_INTA SYSINTR_PCI_START
#define IRQ_INTB (SYSINTR_PCI_START+1)
#define IRQ_INTC (SYSINTR_PCI_START+2)
#define IRQ_INTD (SYSINTR_PCI_START+3)
#define MAX_PCI_IRQ (SYSINTR_PCI_START+4)

static DWORD IrqTable[4][4] = {
    {IRQ_INTA, IRQ_INTB, IRQ_INTC, IRQ_INTD},       // Bus 0, Device 9, PCI-PCI bridge
    {IRQ_INTB, IRQ_INTC, IRQ_INTD, IRQ_INTA},       // Bus 0, Device 10, slot 3
    {IRQ_INTC, IRQ_INTD, IRQ_INTA, IRQ_INTB},       // Bus 0, Device 11, slot 2
    {IRQ_INTD, IRQ_INTA, IRQ_INTB, IRQ_INTC}        // Bus 0, Device 12, slot 1
};
ULONG Logic2SysIntr[MAX_PCI_IRQ + 1];
ULONG SysIntr2Logic[SYSINTR_MAXIMUM];
#if 0
void OEMInitInterrupts()
{
    memset(Logic2SysIntr, 0xFF, sizeof(Logic2SysIntr));
    memset(SysIntr2Logic, 0xFF, sizeof(SysIntr2Logic));

	WRITE_REGISTER_ULONG(FPGA_IMASK, 
		(READ_REGISTER_ULONG(FPGA_IMASK) | FPGA_IMASK_IV3 ));
}
#endif
DWORD OEMTranslateIrq(
    DWORD Irq 
    )
{
	if (Irq < SYSINTR_PCI_START)
		return Irq; // IF it is Built-in Interrupt. It is one-to-one map
	else
    if (Irq > MAX_PCI_IRQ ) {
		ASSERT(FALSE);
        return -1;
    } else {
		ASSERT( Logic2SysIntr[Irq]!=0xFF);
        return Logic2SysIntr[Irq];
    }
}


DWORD OEMTranslateSysIntr(
    DWORD SysIntr 
    )
{
    if (SysIntr >= SYSINTR_MAXIMUM) {
		ASSERT(FALSE);
        return -1;
    } else {
		ASSERT( Logic2SysIntr[SysIntr]!=0xFF);
        return SysIntr2Logic[SysIntr];
    }
}


DWORD OEMRequestSysIntr(
    DWORD Irq 
    )
{
    DWORD SysIntr;
    
	if (Irq < SYSINTR_PCI_START)
		return Irq; // IF it is Built-in Interrupt. It is one-to-one map
	else
    if (Irq > MAX_PCI_IRQ) {
		ASSERT(FALSE);
        return -1;
    }

    if ((Irq != IRQ_INTA) && (Irq != IRQ_INTB) && (Irq != IRQ_INTC) && (Irq != IRQ_INTD)) {
		ASSERT(FALSE);
		return -1;
    }
        
    // Look for next free SYSINTR
    for (SysIntr = SYSINTR_PCI_START; SysIntr < SYSINTR_MAXIMUM; SysIntr++) {
        if (SysIntr2Logic[SysIntr] == -1) break;
    }

    // No free SYSINTRs left
    if (SysIntr >= SYSINTR_MAXIMUM) {
		ASSERT(FALSE);
        return -1;
    }
    
    // Make SYSINTR -> Irq association
    SysIntr2Logic[SysIntr] = Irq;

    // Make Irq -> SYSINTR association, only if not multiply-mapped
    if (Logic2SysIntr[Irq] == -1) { 
        Logic2SysIntr[Irq] = SysIntr;
    }
    return SysIntr;
}


BOOL
OEMGetInterrupt(
    PDEVICE_LOCATION pDevLoc,
    PDWORD pIrq
    )
{
    BOOL RetVal = TRUE;
    int Bus = pDevLoc->BusNumber;
    int Device = (pDevLoc->LogicalLoc >> 8) & 0xFF;

    *pIrq = 0xFF;
    
    // Currently supporting only PCIbus
    if (pDevLoc->IfcType != PCIBus) return FALSE;

    // Make sure interrupt Pin is in range
    if ((pDevLoc->Pin < 1) || (pDevLoc->Pin > 4)) return FALSE;

    if (Bus == 0) {
        // Bus 0 has devices 9 through 12 mapped
        if ((Device < 12) || (Device > 16)) {
            return FALSE;
        }

        *pIrq = IrqTable[Device - 13][pDevLoc->Pin - 1];
        return TRUE;
    } else {
        // All other buses behind PCI-PCI bridge conform to PCI convention
        Device = Device % 4;

        *pIrq = IrqTable[Device][pDevLoc->Pin - 1];
    }

    return RetVal;
}

#define DEVICE_360						360
#	define V3_DEVICE					DEVICE_360
/* Some defines for SH4, and ASPEN. These would later be moved to a separate
 * header file */
#define FRQCR							0xFFC00000		// Frequency Regoister
#define MExINT							0xA6000000		// Interrupt Register
#define ExINT							0xA6000002		// Interrupt Register

#define BCR1							0xFF800000
#define BCR2							0xFF800004
#define WCR1							0xFF800008
#define WCR2							0xFF80000C
#define WCR3							0xFF800010
#define MCR								0xFF800014

/* Some predefined Sizes in MB */
#define MB_1							0x00100000
#define MB_2							(2  * MB_1)
#define MB_4							(4  * MB_1)
#define MB_8							(8  * MB_1)
#define MB_16							(16 * MB_1)
#define MB_32							(32 * MB_1)
#define MB_64							(64 * MB_1)

/* Type of cycles that can be generated on PCI bus. Value to be written to LB_MAP registers. */
#define TYPE_INT						0x0		/* Interrupt acknowledge (read) */
#define TYPE_IO							0x2		/* IO Read/Write */
#define TYPE_MEM						0x6		/* Memory Read/Write */
#define TYPE_CONFIG						0xA		/* Config Read/Write */
#define TYPE_MEM_MULTIPLE				0xC		/* Memory Read Multiple/ Memory Write */

				
#	define PCI_MEM_SIZE						MB_16
#	define PCI_IO_SIZE						MB_1	/* size of PCI IO Area. */
#	define PCI_CONFIG_SIZE					PCI_MEM_SIZE
#	define V3_InternalRegBase 				PHYSICAL_V3_INTERNAL_REG_BASE
/* Interrupt for PCI_INT_CFG */
#define PCI_INTD_CFG	0x8000
#define PCI_INTC_CFG	0x0400
#define PCI_INTB_CFG	0x0020
#define PCI_INTA_CFG	0x8001


/* Register common to all V3 devices supported. */
#define V3_PCI_DEV_VEN	 	(*(volatile unsigned long*)(0x00+V3_InternalRegBase))
#define V3_PCI_STAT_CMD	 	(*(volatile unsigned long*)(0x04+V3_InternalRegBase))
#define V3_PCI_CC_REV		(*(volatile unsigned long*)(0x08+V3_InternalRegBase))
#define V3_PCI_HDR_CFG	 	(*(volatile unsigned long*)(0x0C+V3_InternalRegBase))

#define V360_PCI_BASE0		(*(volatile unsigned long*)(0x14+V3_InternalRegBase))
#define V360_PCI_BASE1		(*(volatile unsigned long*)(0x18+V3_InternalRegBase))
#define V360_PCI_MAP0		(*(volatile unsigned long*)(0x40+V3_InternalRegBase))
#define V360_PCI_MAP1		(*(volatile unsigned long*)(0x44+V3_InternalRegBase))

#define V360_PCI_INT_STAT	(*(volatile unsigned long*)(0x48+V3_InternalRegBase))
#define V360_PCI_INT_CFG	(*(volatile unsigned long*)(0x4c+V3_InternalRegBase))

/* Register common between 292 and 360 are named as V360... */
#define V360_LB_BASE0	 	(*(volatile unsigned long*)(0x54+V3_InternalRegBase))
#define V360_LB_BASE1	 	(*(volatile unsigned long*)(0x58+V3_InternalRegBase))
#define V360_LB_MAP0_RES 	(*(volatile unsigned long*)(0x5c+V3_InternalRegBase))
#define V360_LB_MAP1_RES 	(*(volatile unsigned long*)(0x60+V3_InternalRegBase))
#define V360_LB_IO_BASE_RES	(*(volatile unsigned long*)(0x6c+V3_InternalRegBase))
#define V360_LB_CFG_SYSTEM	(*(volatile unsigned long*)(0x78+V3_InternalRegBase))
#define V360_FIFO_PRIOR_CFG	(*(volatile unsigned long*)(0x70+V3_InternalRegBase))
#define V360_LB_ISTAT	 	(*(volatile unsigned short*)(0x76+V3_InternalRegBase))
#define V360_PCI_CFG		(*(volatile unsigned long*)(0x7C+V3_InternalRegBase))
//#define V360_INITIAL_LB_IO_BASE_RES	(*(volatile unsigned long*)(0x6c+PHYSICAL_V3_INTERNAL_REG_BASE))

/* Register specific to V320 */
#define V320_LB_PCI_BASE0 	(*(volatile unsigned long*)(0x54+V3_InternalRegBase))
#define V320_LB_PCI_BASE1 	(*(volatile unsigned long*)(0x58+V3_InternalRegBase))
#define V320_LB_BUS_CFG		(*(volatile unsigned long*)(0x78+V3_InternalRegBase))
#define V320_SYSTEM_LB_REG_BASE		(*(volatile unsigned long*)(0x70+V3_InternalRegBase))

#define V320_INITIAL_SYSTEM_LB_REG_BASE		(*(volatile unsigned long*)(0x70+V3_InternalRegBase))

#define INIT_WAIT_TIME			0x6FFFF	 /* Need to fine tune */
#define INIT_WAIT   { int i; for(i = 0; i < INIT_WAIT_TIME; i ++); }
#define CONFIG_WAIT_TIME 		0x60000
#define CONFIG_WAIT { int i; for(i = 0; i < CONFIG_WAIT_TIME; i ++); }

DWORD PciConfigBase=0;
DWORD NKCallIntChainWrapped( BYTE bIRQ ) ;
#ifdef BSP_NOPCIBUS
int PCI_ISR()
{						// From PCI external board.

	DWORD dwFpgaIStat;
	DWORD old_val;
	DWORD dwIrq=-1;
	DWORD nSysIntr=SYSINTR_NOP;

	dwFpgaIStat = READ_REGISTER_ULONG(FPGA_ISTAT);
	if ((dwFpgaIStat &  FPGA_IMASK_IV3)==0 && PciConfigBase==0) {
		OEMWriteDebugString(TEXT("Wrong PCI Interrupt\r\n"));
		return SYSINTR_NOP;
	}

	// Save OLD Value of LB_MAP1 so that you can restore it after the access
	old_val = V360_LB_MAP1_RES;
	V360_LB_MAP1_RES=0x00000000; // Intr Ack Cycle.
	dwIrq=*(volatile DWORD *)PciConfigBase;
	dwIrq +=SYSINTR_PCI_START;
	V360_LB_MAP1_RES=old_val;

	nSysIntr = NKCallIntChainWrapped((BYTE)dwIrq);
	if (nSysIntr == SYSINTR_CHAIN) {
		nSysIntr = OEMTranslateIrq(dwIrq);
		OEMPciIntrDisable(dwIrq);

	}
	return (nSysIntr==-1? SYSINTR_NOP: nSysIntr);

};
BOOL OEMPciIntrEnable(DWORD dwIrq)
{
	switch (dwIrq) {
	case IRQ_INTA:
		V360_PCI_INT_CFG  |=PCI_INTA_CFG;
		break;
	case IRQ_INTB:
		V360_PCI_INT_CFG  |=PCI_INTB_CFG;
		break;
	case IRQ_INTC:
		V360_PCI_INT_CFG  |=PCI_INTC_CFG;
		break;
	case IRQ_INTD:
		V360_PCI_INT_CFG  |=PCI_INTD_CFG;
		break;
	default:
		return FALSE;
	}
	return TRUE;
}

BOOL OEMPciIntrDisable(DWORD dwIrq)
{
	switch (dwIrq) {
	case IRQ_INTA:
		V360_PCI_INT_CFG &=~PCI_INTA_CFG;
		break;
	case IRQ_INTB:
		V360_PCI_INT_CFG &=~PCI_INTB_CFG;
		break;
	case IRQ_INTC:
		V360_PCI_INT_CFG &=~PCI_INTC_CFG;
		break;
	case IRQ_INTD:
		V360_PCI_INT_CFG &=~PCI_INTD_CFG;
		break;
	default:
		return FALSE;
	}
	return TRUE;
}
BOOL OEMPciIntrDone(DWORD dwIrq)
{
	return OEMPciIntrEnable(dwIrq);
}
#endif
/*
[HKEY_LOCAL_MACHINE\Drivers\BuiltIn\PCI]
    "Dll"="PCIbus.dll"
    "Order"=dword:20
    "Flags"=dword:1
    "NoConfig"=dword:0
    "MemBase"=dword:10000000
    "MemLen"=dword:04000000
    "IoBase"=dword:0
    "IoLen"=dword:00040000
*/
#ifdef BSP_NOPCIBUS
/*****************************************************************************
 * Function: MapRegisters
 * Input:    None
 * Output:   Sets the members of the PciBaseAddresses structure.
 * Synopsis: 1. This function is used to Map the virtual address space of PCI
 *              registers to the address space of the PCI driver.
 *           2. If you are using this routine as a part of SDBTESTS, it does

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人免费毛片嘿嘿连载视频| 欧美性极品少妇| 亚洲欧美区自拍先锋| 日韩欧美高清在线| 欧美午夜一区二区三区| 国产激情视频一区二区三区欧美| 亚洲国产日韩av| 国产精品久久久久影院色老大| 日韩美一区二区三区| 色欧美日韩亚洲| 成人高清视频免费观看| 秋霞午夜鲁丝一区二区老狼| 亚洲精品视频免费看| 国产日韩欧美综合在线| 欧美成人三级在线| 欧美喷潮久久久xxxxx| 欧洲在线/亚洲| 99久久精品免费精品国产| 国产成人免费在线观看| 韩国精品免费视频| 久久精品国产亚洲5555| 日日夜夜精品视频天天综合网| 亚洲免费三区一区二区| 国产精品不卡一区| 国产精品久久久久aaaa| 国产日韩av一区二区| 日韩精品一区二区三区四区| 欧美一区二区大片| 日韩欧美国产小视频| 欧美一区二区三区四区五区| 欧美日韩视频在线一区二区| 欧美亚洲高清一区二区三区不卡| 91国产免费观看| 91电影在线观看| 在线日韩国产精品| 在线视频国内自拍亚洲视频| 欧美在线观看视频在线| 在线看不卡av| 精品污污网站免费看| 欧美乱妇一区二区三区不卡视频| 欧美色大人视频| 欧美日韩久久久一区| 欧美精品自拍偷拍| 日韩午夜在线观看| 精品成人私密视频| 国产日韩精品一区二区浪潮av| 亚洲欧洲av另类| 中文字幕一区二区三区视频| 亚洲色图欧美在线| 亚洲成人激情av| 日日嗨av一区二区三区四区| 日本最新不卡在线| 国产在线播精品第三| 成人三级伦理片| 一本色道久久加勒比精品| 欧美在线播放高清精品| 欧美高清视频不卡网| 日韩亚洲欧美综合| 精品国产乱码久久久久久夜甘婷婷 | 国产精品日韩精品欧美在线| 欧美激情中文字幕| 亚洲男人天堂av| 三级成人在线视频| 国产一区二区免费在线| 不卡免费追剧大全电视剧网站| 一本到三区不卡视频| 91麻豆精品久久久久蜜臀| 精品1区2区在线观看| 综合色中文字幕| 日韩福利电影在线| 盗摄精品av一区二区三区| 欧洲国内综合视频| 久久这里只有精品6| 亚洲欧美另类图片小说| 日韩成人午夜电影| 成人国产精品免费观看动漫| 欧美日韩一区二区三区四区 | 久久99国产精品尤物| 成人黄色网址在线观看| 欧美在线观看视频一区二区三区| 欧美一级在线免费| 亚洲婷婷在线视频| 麻豆精品国产91久久久久久| 99re66热这里只有精品3直播| 欧美一区二区三区在线视频| 亚洲欧洲日韩综合一区二区| 青青草成人在线观看| 97超碰欧美中文字幕| 精品国产免费人成在线观看| 亚洲另类在线一区| 国产呦萝稀缺另类资源| 欧美视频中文一区二区三区在线观看| 久久色成人在线| 一区二区高清在线| 国产999精品久久久久久绿帽| 欧美色图免费看| 亚洲欧美在线视频观看| 久久国产精品一区二区| 欧洲国产伦久久久久久久| 欧美经典一区二区| 免费国产亚洲视频| 欧美体内she精高潮| 国产精品久久久久久久浪潮网站| 日本亚洲三级在线| 欧美亚洲动漫制服丝袜| 日韩1区2区3区| 91视频xxxx| 日本一区二区三区四区在线视频| 蜜桃av一区二区在线观看| 欧美视频在线不卡| 自拍偷拍国产精品| 国产成人免费视频一区| 欧美精品一区二区久久久| 视频一区国产视频| 欧美日韩在线综合| 一区二区三区在线观看国产| 成人午夜视频福利| 久久精品人人做人人爽人人| 乱中年女人伦av一区二区| 91麻豆精品国产91久久久资源速度 | 欧美精品久久99| 亚洲中国最大av网站| 色婷婷综合久色| 亚洲人精品午夜| 99国内精品久久| 亚洲欧美在线视频| 91丨九色丨黑人外教| 国产精品美女一区二区在线观看| 国产激情一区二区三区| 久久精品日韩一区二区三区| 国内久久精品视频| 久久久久国产精品免费免费搜索| 国内成人精品2018免费看| 精品精品欲导航| 国产精品一区久久久久| 国产婷婷色一区二区三区四区 | 日韩免费观看高清完整版| 日本一不卡视频| 精品日韩欧美一区二区| 久久99国产精品免费| 久久久精品中文字幕麻豆发布| 久久99热这里只有精品| 337p粉嫩大胆噜噜噜噜噜91av | 欧美三级乱人伦电影| 午夜精品久久久久久久久| 91精品在线观看入口| 麻豆91免费观看| 国产亚洲女人久久久久毛片| 成人激情动漫在线观看| 亚洲视频一区在线| 久久久亚洲综合| 成人黄色小视频在线观看| 亚洲视频一区在线观看| 欧美视频日韩视频| 久久er99热精品一区二区| 国产婷婷色一区二区三区四区| fc2成人免费人成在线观看播放| 亚洲视频综合在线| 欧美老年两性高潮| 九色porny丨国产精品| 国产精品素人一区二区| 91老司机福利 在线| 日本va欧美va欧美va精品| 久久久久九九视频| 色综合中文字幕国产 | 国产在线观看一区二区| 自拍偷拍国产亚洲| 在线电影国产精品| 成人中文字幕在线| 亚欧色一区w666天堂| 久久精品日韩一区二区三区| 一本大道久久a久久综合| 蜜臀久久99精品久久久画质超高清| 久久久久国产一区二区三区四区| 色综合婷婷久久| 免费在线观看视频一区| 亚洲欧洲精品天堂一级| 欧美一区二区在线看| 成人白浆超碰人人人人| 视频一区在线视频| 国产精品乱码妇女bbbb| 欧美精品一级二级| av在线一区二区三区| 蜜臀va亚洲va欧美va天堂| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 3d动漫精品啪啪| 91香蕉视频污在线| 韩国视频一区二区| 亚洲在线观看免费| 国产精品无遮挡| 日韩欧美国产wwwww| 91极品视觉盛宴| 国产电影精品久久禁18| 日本在线播放一区二区三区| 亚洲天堂免费看| 国产午夜亚洲精品午夜鲁丝片| 欧美日本一区二区| 99久久精品免费观看| 国产精品一区二区在线观看不卡| 亚洲电影你懂得|