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

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

?? bdcomm.c

?? 這是單板上DPRAM的驅動程序
?? C
?? 第 1 頁 / 共 2 頁
字號:
#if (BRD_ICACHE == YES)
        SysIcacheInv(0, BD_SIZE_OF_ICACHE);
#endif
        splx(OldIpl);
#endif /* (BRD_DCACHE == YES) || (BRD_ICACHE == YES) */

}
/***********************************************************************/
/* BspCpuClkRate: Return the processor clock speed in multiple of MHz  */
/*                                                                     */
/* INPUTS:  None                                                       */
/* OUTPUTS: Returns the current cpu clock rate                         */
/*                                                                     */
/***********************************************************************/
ULONG        
BspCpuClkRate(void)
{
        return
            (bspGetInputClkHz() * ((S_PLL_ControlReg >> 20) + 1)) / 1000000;
}
/***********************************************************************/
/*  BspRamBase: Return starting/base address of RAM (as seen by CPU)   */
/*                                                                     */
/*     RETURNS: starting address of onboard DRAM                       */
/*     NOTE(S):                                                        */
/*                                                                     */
/***********************************************************************/
unsigned long BspRamBase(void)
{
        return BD_DRAM_BASE_ADDR;
}

/***********************************************************************/
/* Local function to get the size of the DRAM installed on the board   */
/***********************************************************************/
ULONG
BspGetDramSize(void)
{
        return(BD_DRAM_SIZE);
}

/***********************************************************************/
/*     RamSize: Return the amount of DRAM installed on the board       */
/*                                                                     */
/*     RETURNS: The size of DRAM SIMMs in bytes                        */
/*        NOTE: Returns 0 if SIM type not recognized                   */
/*                                                                     */
/***********************************************************************/
ULONG RamSize(void)
{
        return(BD_DRAM_SIZE);
}
ULONG BspCpuRev()
{
        return( GetIMMR() & CPU_REV_MASK);
}

/***********************************************************************/
/* ClrAbortInt: Clear interrupt signal after abort interrupt.          */
/*                                                                     */
/***********************************************************************/
unsigned long ClrAbortInt(void)
{
    /* do not fool with interrupts mask, pSOS can be screwed up if do */
    Print("\n    !!!! ABORT Button Pressed !!!!\n");
    return 0;
}

/***********************************************************************/
/* SysInitFail: Report a system initalization failure                  */
/*                                                                     */
/*      INPUTS: string = Pointer to text of message                    */
/*                                                                     */
/*        NOTE: Doesn't return.  Just continually prints the error     */
/*              message on the serial channel once per second.         */
/*                                                                     */
/***********************************************************************/
void SysInitFail(const char *string)
{
const char *ptr;
int i;
 
#if        BSP_NEW_SERIAL
    ProbeIOInit();
    for (;;)
        {
        ptr = string;
        while (*ptr)
            ProbeConout(*ptr++);
        ProbeConout('\n');
        ProbeConout('\r');
        for (i = 1; i <= 10; i++)
            Delay100ms();
        }                                           
#else
        Delay100ms();
        SerialSetup(9600, 1, 0);
        SerialPollInit();
        Delay100ms();
        for (;;)
            {
            ptr = string;
            while (*ptr)
                SerialPollConout(*ptr++);
            SerialPollConout('\n');
            SerialPollConout('\r');
            for (i = 1; i <= 10; i++)
                Delay100ms();
            }
#endif
}

/***********************************************************************/
/* InitBoard: Perform board initialization.                            */
/*                                                                     */
/***********************************************************************/
void InitBoard(void)
{
int   Var;
ULONG cpu_speed;
SET_PC_BIT(14,1); 
resetSWT();
SET_PC_BIT(13,1);
/*---------------------------------------------------------------------*/
/* Issue CP reset command so RISC re-initializes its internal state.   */
/*---------------------------------------------------------------------*/
S_CP_CommandReg = CPM_SW_RESET + SEMAPHORE_FLAG;

/*---------------------------------------------------------------------*/
/* Reset the RISC processor control                                    */
/*---------------------------------------------------------------------*/
S_RISC_ConfigReg = 0;

/*---------------------------------------------------------------------*/
/* Disable all SIU interrupts                                          */
/*---------------------------------------------------------------------*/
S_SiMaskRegister = 0x0;  

/*---------------------------------------------------------------------*/
/* Clear the entire Dual-Ported RAM.                                   */
/*---------------------------------------------------------------------*/
for (Var = 0x000; Var <= 0x1000; ++Var)
    *(volatile UCHAR *)(M_DPRAM_BASE + Var) = 0;
 
/*---------------------------------------------------------------------*/
/* Note: PLL Cotrol register is now set HdwInitDRAM if run in ROM.     */ 
/* for RAM code we just the value set in ROM.                          */
/*---------------------------------------------------------------------*/

/*---------------------------------------------------------------------*/
/* Calculate the time constant. The decrementer decrements once every  */
/* four input clocks (bspGetInputClkHz()).                             */
/* i.e. timeconst = (bspGetInputClkHz()) / (4 * ticks2sec)             */
/*---------------------------------------------------------------------*/
#if ( BD_CPU_SPEED*1000000/BD_INPUT_CLOCK )<=2
BoardDecClkRateHz = (bspGetInputClkHz() / 16 );
#else
BoardDecClkRateHz = (bspGetInputClkHz() / 4 );
#endif

 
/*---------------------------------------------------------------------*/
/* Setup the MPC860 Input,Output,Interrupt Leaders configuration       */
/*---------------------------------------------------------------------*/
SetupIOI();

/*---------------------------------------------------------------------*/
/* Disable the ethernet interface                                      */
/*---------------------------------------------------------------------*/
#if (BSP_LAN1 == YES)
LanStop();
#endif

/*---------------------------------------------------------------------*/
/* Issue CP reset command so RISC re-initializes its internal state.   */
/*---------------------------------------------------------------------*/
S_CP_CommandReg = CPM_SW_RESET + SEMAPHORE_FLAG;
while (S_CP_CommandReg & SEMAPHORE_FLAG);


/*---------------------------------------------------------------------*/
/* Configure the Master CPM Interrupt Controller                       */
/*---------------------------------------------------------------------*/
S_CP_IntConfigReg =
   /*
   ** Set the CPM interrupt priority.
   */
   (CPM_IRQ_LEVEL << 13)

   /*
   ** Declare the highest priority CPM interrupt.
   */
   + (0x1F << 8)

   /*
   ** Establish the SCC priority spread scheme.
   */
   + GROUPED

   /*
   ** Enable the CPM Interrupts.
   */
   +CPM_EN_INTS;

S_SCC1MaskReg  = 0;
S_SCC1EventReg = 0xFFFF;
S_SCC2MaskReg  = 0;
S_SCC2EventReg = 0xFFFF;
S_SMC1MaskReg = 0;
S_SMC2MaskReg = 0;

/*---------------------------------------------------------------------*/
/* Set-up the shared dual ported memory bit map.                       */
/*---------------------------------------------------------------------*/
dpram_init();

/*---------------------------------------------------------------------*/
/* Enable Caches according to the specified mode in board.h            */
/*                                                                     */
/* The instruction cache is only turned on for REV A or greater chips. */
/* The mmu and data cache are not supported.                           */
/*---------------------------------------------------------------------*/
#if (BRD_ICACHE == YES) && (BSP_MMU == NO)
if ((GetIMMR() & 0x00FF) >= REVA)  /* Enable for chips REV A or greater */
   SysIcacheInit();
#endif
 
/*---------------------------------------------------------------------*/
/* Setup the vector table                                              */
/*---------------------------------------------------------------------*/
vectorSetup();

/*---------------------------------------------------------------------*/
/* Initilize the interrupt handler (must be done before enabling any   */
/* interrupts.                                                         */
/*---------------------------------------------------------------------*/
IsrHandlerInit(0);

/*---------------------------------------------------------------------*/
/* Enable CPM interrupt level                                          */
/*---------------------------------------------------------------------*/
S_SiMaskRegister =  SIU_ILEV_MASK_BIT(CPM_IRQ_LEVEL);  

/*---------------------------------------------------------------------*/
/* Enable the LAN on the Board.                                        */
/*---------------------------------------------------------------------*/
#if (BSP_LAN1 == YES)
LanEnable();
#endif

BoardSpecInit();

InitTDM();
SET_PC_BIT(5,1);
resetSWT();
SysInit();
}

/* miscillenious function for board */

void initTBSCR(void)
{
        PDA  *pda;
        pda = (PDA *)(GetIMMR() & IO_MAP_MASK);
        if((pda->simt_tbscr & 0x1)!=0x1)
                pda->simt_tbscr=1;
}


unsigned long  getTimeBaseClock(void)
{
#if ( BD_CPU_SPEED*1000000/BD_INPUT_CLOCK )<=2
        return (BD_INPUT_CLOCK>>4);
#else
        return (BD_INPUT_CLOCK>>2);
#endif
}

unsigned long getResetStatusReg(void)
{
        PDA  *pda;
        pda = (PDA *)(GetIMMR() & IO_MAP_MASK);
        return pda->clkr_rsr;
}

void resetSWT(void){
        PDA  *pda;
        pda = (PDA *)(GetIMMR() & IO_MAP_MASK);
	SPLX(pda->siu_swsr=0x556c; pda->siu_swsr=0xaa39; )
}

void disableSWT(void){
        PDA  *pda;
        pda = (PDA *)(GetIMMR() & IO_MAP_MASK);
        pda->siu_sypcr=0xffffff88;
}

void enableSWT(void){
        PDA  *pda;
        pda = (PDA *)(GetIMMR() & IO_MAP_MASK);
        pda->siu_sypcr=0xffffff8f;
}

unsigned long readSWT(void)
{
        PDA  *pda;
        pda = (PDA *)(GetIMMR() & IO_MAP_MASK);
        return (unsigned long)(pda->siu_sypcr);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产成人在线免费观看| 欧美性大战久久| 欧美色综合久久| 久久亚洲免费视频| 日韩中文欧美在线| 一本久久a久久免费精品不卡| 宅男噜噜噜66一区二区66| 亚洲视频香蕉人妖| 国产一区久久久| 日韩欧美高清在线| 石原莉奈一区二区三区在线观看| 成人动漫一区二区| 欧美成人video| 奇米四色…亚洲| 欧美写真视频网站| 亚洲欧美日韩国产另类专区| 成人性生交大片免费看视频在线| 欧美不卡123| 久久99深爱久久99精品| 日韩女优av电影| 日本sm残虐另类| 91精品国产色综合久久ai换脸| 一区二区三区资源| 欧洲一区二区三区在线| 亚洲美女免费在线| 在线观看成人免费视频| 一区av在线播放| 欧美色视频在线观看| 亚洲最大成人综合| 欧美日韩精品专区| 天堂va蜜桃一区二区三区| 欧美三级欧美一级| 丝袜脚交一区二区| 91精品欧美久久久久久动漫 | 久久久综合视频| 久久精品国产亚洲高清剧情介绍| 日韩免费电影一区| 狠狠v欧美v日韩v亚洲ⅴ| 国产三级久久久| 成人高清视频在线| 一区二区在线观看视频| 欧美午夜精品免费| 久久精品噜噜噜成人88aⅴ| 亚洲精品一线二线三线| 成人a免费在线看| 一区二区三区中文字幕在线观看| 欧美精品黑人性xxxx| 久久精品国产77777蜜臀| 欧美激情在线一区二区三区| 成人免费三级在线| 亚洲国产精品一区二区www在线| 欧美日韩国产高清一区二区| 久久精品国产999大香线蕉| 国产女人aaa级久久久级| 色先锋资源久久综合| 五月综合激情婷婷六月色窝| 久久久亚洲精品石原莉奈| 91香蕉国产在线观看软件| 五月婷婷色综合| 国产午夜亚洲精品羞羞网站| 欧洲另类一二三四区| 黄网站免费久久| 亚洲一区在线电影| 欧美精品一区二区不卡| 色婷婷亚洲精品| 国产在线精品视频| 中文字幕一区二区三区视频| 欧美一级免费观看| 91色乱码一区二区三区| 久久91精品国产91久久小草| 亚洲欧美区自拍先锋| 欧美mv日韩mv国产| 欧洲人成人精品| 成人午夜av在线| 日韩av午夜在线观看| 亚洲精品综合在线| 精品免费一区二区三区| 欧美优质美女网站| 99精品久久只有精品| 激情六月婷婷久久| 五月天网站亚洲| 亚洲欧美日韩一区二区 | 国产高清在线精品| 琪琪一区二区三区| 一区二区三区四区在线免费观看| 亚洲精品一区二区三区香蕉| 欧美在线观看18| 91一区二区在线| 国产福利一区在线| 国内精品伊人久久久久av一坑| 亚洲一区二区三区四区五区中文| 国产精品污污网站在线观看| 精品国精品国产| 91精品国产aⅴ一区二区| 色婷婷国产精品综合在线观看| 丁香激情综合国产| 国产精品一区三区| 蜜桃av一区二区三区电影| 日本亚洲三级在线| 日韩高清国产一区在线| 日韩精品1区2区3区| 午夜影院久久久| 亚洲国产综合在线| 亚洲综合丁香婷婷六月香| 中文字幕第一区综合| 欧美国产国产综合| 国产视频一区二区在线| 2019国产精品| 国产日韩欧美亚洲| 国产精品嫩草影院av蜜臀| 欧美高清在线视频| 国产精品久久夜| 国产精品国产三级国产有无不卡| 中文字幕制服丝袜一区二区三区| 国产精品国产自产拍高清av| 亚洲天堂成人网| 一区二区三区在线观看国产| 亚洲精品水蜜桃| 丝袜亚洲另类欧美| 日本亚洲天堂网| 国产乱码精品一区二区三区五月婷| 久久99热这里只有精品| 国产成人夜色高潮福利影视| 国产成人免费高清| 91视频观看免费| 欧美综合一区二区| 日韩免费观看2025年上映的电影| 26uuu精品一区二区| 中文成人av在线| 亚洲综合另类小说| 日本欧美一区二区| 国产一区二区在线观看免费| 成人一区二区三区中文字幕| 色狠狠一区二区| 91精品国产综合久久久久久| 精品少妇一区二区| 最新不卡av在线| 欧美国产日韩精品免费观看| 综合激情网...| 奇米一区二区三区av| 成人综合婷婷国产精品久久| 日本韩国一区二区三区视频| 日韩精品自拍偷拍| 亚洲天堂av老司机| 日本不卡的三区四区五区| 成人免费毛片片v| 欧美日韩视频第一区| 国产日产欧美一区二区三区| 一区二区三区四区视频精品免费 | 一区二区三区在线播放| 青青草91视频| 色域天天综合网| 精品av综合导航| 一区二区免费视频| 国产一区二区三区| 欧美精品一二三| 中文字幕 久热精品 视频在线| 亚洲国产精品久久久久婷婷884| 久久精品国产精品青草| 色综合久久久久久久| ww亚洲ww在线观看国产| 香蕉成人伊视频在线观看| 成人免费视频一区| 日韩片之四级片| 亚洲一区二区偷拍精品| 粉嫩在线一区二区三区视频| 91精品国产高清一区二区三区蜜臀 | 色综合久久中文综合久久牛| 精品sm在线观看| 日韩精品三区四区| 91成人免费在线| 国产精品视频免费| 国产大陆亚洲精品国产| 日韩欧美精品三级| 午夜久久久影院| 欧洲视频一区二区| 日韩美女视频一区二区 | 国产精品亚洲午夜一区二区三区| 在线不卡的av| 亚洲不卡av一区二区三区| 99久久国产综合色|国产精品| 国产亚洲精品免费| 精品一区二区三区日韩| 日韩一区二区三区在线| 亚洲高清不卡在线观看| 欧美在线三级电影| 一区二区久久久| 色屁屁一区二区| 一区二区三区在线免费观看| 99久久精品国产观看| 综合电影一区二区三区 | 99国产精品99久久久久久| 欧美激情一区二区三区蜜桃视频| 国产综合色精品一区二区三区| 欧美一区二区三区视频免费播放| 石原莉奈在线亚洲三区| 日韩一区二区三区免费看| 男男gaygay亚洲| 精品免费国产二区三区| 精品亚洲国内自在自线福利|