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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? startup.s

?? 三星2410的BOOTLOADER,WINDOESCE5.0版本
?? S
?? 第 1 頁 / 共 2 頁
字號:
;
; Copyright (c) Microsoft Corporation.  All rights reserved.
;
;
; Use of this source code is subject to the terms of the Microsoft end-user
; license agreement (EULA) under which you licensed this SOFTWARE PRODUCT.
; If you did not accept the terms of the EULA, you are not authorized to use
; this source code. For a copy of the EULA, please see the LICENSE.RTF on your
; install media.
;


                INCLUDE kxarm.h
                INCLUDE armmacros.s
                INCLUDE s3c2410x.inc

;-------------------------------------------------------------------------------

MemoryMap       EQU     0x2a4
BANK_SIZE       EQU     0x00100000      ; 1MB per bank in MemoryMap array
BANK_SHIFT      EQU     20


;   Define RAM space for the Page Tables:
;
PHYBASE         EQU     0x30000000      ; physical start
PTs             EQU     0x30010000      ; 1st level page table address (PHYBASE + 0x10000)
                                        ; save room for interrupt vectors.

;-------------------------------------------------------------------------------

        TEXTAREA

        IMPORT  main

; Set up the MMU and Dcache for bootloader.
;
; This routine will initialize the first-level page table based up the contents
; of the MemoryMap array and enable the MMU and caches.
;
; Copy the image to RAM if it's not already running there.
;
; Include Files 



; Defines 

;------------------------------------------------------------------------------
; BUGBUG - ?

PLLVAL      EQU     (((0xa1 << 12) + (0x3 << 4) + 0x1))


;------------------------------------------------------------------------------
; Cache Configuration

DCACHE_LINES_PER_SET_BITS   EQU     (6)
DCACHE_LINES_PER_SET        EQU     (64)
DCACHE_NUM_SETS             EQU     (8)
DCACHE_SET_INDEX_BIT        EQU     (32 - DCACHE_LINES_PER_SET_BITS)
DCACHE_LINE_SIZE            EQU     (32)

;------------------------------------------------------------------------------
; Sleep state constants 
; 
; Location of sleep data 

; BUGBUG - this needs to be declared as a local var.

SLEEPDATA_BASE_PHYSICAL         EQU     0x30058000

; Sleep State memory locations

SleepState_Data_Start           EQU     (0)
SleepState_WakeAddr             EQU     (SleepState_Data_Start  + 0)
SleepState_MMUCTL               EQU     (SleepState_WakeAddr    + WORD_SIZE)
SleepState_MMUTTB               EQU     (SleepState_MMUCTL      + WORD_SIZE)
SleepState_MMUDOMAIN            EQU     (SleepState_MMUTTB      + WORD_SIZE)
SleepState_SVC_SP               EQU     (SleepState_MMUDOMAIN   + WORD_SIZE)
SleepState_SVC_SPSR             EQU     (SleepState_SVC_SP      + WORD_SIZE)
SleepState_FIQ_SPSR             EQU     (SleepState_SVC_SPSR    + WORD_SIZE)
SleepState_FIQ_R8               EQU     (SleepState_FIQ_SPSR    + WORD_SIZE)
SleepState_FIQ_R9               EQU     (SleepState_FIQ_R8      + WORD_SIZE)
SleepState_FIQ_R10              EQU     (SleepState_FIQ_R9      + WORD_SIZE)
SleepState_FIQ_R11              EQU     (SleepState_FIQ_R10     + WORD_SIZE)
SleepState_FIQ_R12              EQU     (SleepState_FIQ_R11     + WORD_SIZE)
SleepState_FIQ_SP               EQU     (SleepState_FIQ_R12     + WORD_SIZE)
SleepState_FIQ_LR               EQU     (SleepState_FIQ_SP      + WORD_SIZE)
SleepState_ABT_SPSR             EQU     (SleepState_FIQ_LR      + WORD_SIZE)
SleepState_ABT_SP               EQU     (SleepState_ABT_SPSR    + WORD_SIZE)
SleepState_ABT_LR               EQU     (SleepState_ABT_SP      + WORD_SIZE)
SleepState_IRQ_SPSR             EQU     (SleepState_ABT_LR      + WORD_SIZE)
SleepState_IRQ_SP               EQU     (SleepState_IRQ_SPSR    + WORD_SIZE)
SleepState_IRQ_LR               EQU     (SleepState_IRQ_SP      + WORD_SIZE)
SleepState_UND_SPSR             EQU     (SleepState_IRQ_LR      + WORD_SIZE)
SleepState_UND_SP               EQU     (SleepState_UND_SPSR    + WORD_SIZE)
SleepState_UND_LR               EQU     (SleepState_UND_SP      + WORD_SIZE)
SleepState_SYS_SP               EQU     (SleepState_UND_LR      + WORD_SIZE)
SleepState_SYS_LR               EQU     (SleepState_SYS_SP      + WORD_SIZE)
SleepState_Data_End             EQU     (SleepState_SYS_LR      + WORD_SIZE)

SLEEPDATA_SIZE                  EQU     (SleepState_Data_End - SleepState_Data_Start) / 4



; External Variables 

; External Functions 

; Global Variables 
 
; Local Variables 
 
; Local Functions 

;-------------------------------------------------------------------------------
;   Function: Startup
;
;   Main entry point for CPU initialization.
;

        STARTUPTEXT
        LEAF_ENTRY      StartUp
    
        ; Jump over power-off code. 
        b       ResetHandler

        ; Power-off the CPU. 
        str     r1, [r0]                        ; enable SDRAM self-refresh.
        str     r3, [r2]                        ; MISCCR setting.
        str     r5, [r4]                        ; POWER OFF!!!!!
        b       .
    
ResetHandler

        ; Make sure that TLB & cache are consistent
        mov     r0, #0
        mcr     p15, 0, r0, c8, c7, 0           ; flush both TLB
        mcr     p15, 0, r0, c7, c5, 0           ; invalidate instruction cache
        mcr     p15, 0, r0, c7, c6, 0           ; invalidate data cache
        
        ldr     r0, = GPFCON
        ldr     r1, = 0x55aa      
        str     r1, [r0]

        ldr     r0, = WTCON                     ; disable watch dog
        ldr     r1, = 0x0         
        str     r1, [r0]

        ldr     r0, = INTMSK
        ldr     r1, = 0xffffffff                ; disable all interrupts
        str     r1, [r0]

        ldr     r0, = INTSUBMSK
        ldr     r1, = 0x7ff                     ; disable all sub interrupt
        str     r1, [r0]

        ldr     r0, = INTMOD
        mov     r1, #0x0                        ; set all interrupt as IRQ
        str     r1, [r0]

        ldr     r0, = CLKDIVN
        ldr     r1, = 0x3                       ; 0x0 = 1:1:1,  0x1 = 1:1:2
                                                ; 0x2 = 1:2:2,  0x3 = 1:2:4,
                                                ; 0x8 = 1:4:4
        str     r1, [r0]

        ands    r1, r1, #0x2                    ; set AsyncBusMode
        beq     %F10

        mrc     p15, 0, r0, c1, c0, 0
        orr     r0, r0, #R1_nF:OR:R1_iA
        mcr     p15, 0, r0, c1, c0, 0
10
        ldr     r0, = LOCKTIME                  ; To reduce PLL lock time, adjust the LOCKTIME register. 
        ldr     r1, = 0xffffff
        str     r1, [r0]
    
        ldr     r0, = MPLLCON                   ; Configure MPLL
                                                ; Fin=12MHz, Fout=50MHz
        ldr     r1, = PLLVAL
        str     r1, [r0]

        ldr     r0, = UPLLCON                   ; Fin=12MHz, Fout=48MHz
        ldr     r1, = ((0x48 << 12) + (0x3 << 4) + 0x2)  
        str     r1, [r0]

        mov     r0, #0x2000
20   
        subs    r0, r0, #1
        bne     %B20

;------------------------------------------------------------------------------
;   Add for Power Management 

        ldr     r1, =GSTATUS2                   ; Determine Booting Mode
        ldr     r10, [r1]
        tst     r10, #0x2
        beq     %F30                            ; if not wakeup from PowerOffmode
                                                ;    skip MISCCR setting

        ldr     r1, =MISCCR                     ; MISCCR's Bit 17, 18, 19 -> 0
        ldr     r0, [r1]                        ; I don't know why, Just fallow Sample Code.
        bic     r0, r0, #(7 << 17)              ; SCLK0:0->SCLK, SCLK1:0->SCLK, SCKE:L->H
        str     r0, [r1]
30

;------------------------------------------------------------------------------
;   Initialize memory controller


        add     r0, pc, #MEMCTRLTAB - (. + 8)
        ldr     r1, = BWSCON                    ; BWSCON Address
        add     r2, r0, #52                     ; End address of MEMCTRLTAB
40      ldr     r3, [r0], #4    
        str     r3, [r1], #4    
        cmp     r2, r0      
        bne     %B40

;------------------------------------------------------------------------------
;   Add for Power Management 

        tst     r10, #0x2
        beq     BringUpWinCE                    ; Normal Mode Booting

;------------------------------------------------------------------------------
;   Recover Process : Starting Point
;
;   1. Checksum Calculation saved Data

        ldr     r5, =SLEEPDATA_BASE_PHYSICAL    ; pointer to physical address of reserved Sleep mode info data structure 
        mov     r3, r5                          ; pointer for checksum calculation
        mov     r2, #0
        ldr     r0, =SLEEPDATA_SIZE             ; get size of data structure to do checksum on
50      ldr     r1, [r3], #4                    ; pointer to SLEEPDATA
        and     r1, r1, #0x1
        mov     r1, r1, LSL #31
        orr     r1, r1, r1, LSR #1
        add     r2, r2, r1
        subs    r0, r0, #1                      ; dec the count
        bne     %b50                            ; loop till done    

        ldr     r0,=GSTATUS3
        ldr     r3, [r0]                        ; get the Sleep data checksum from the Power Manager Scratch pad register
        teq     r2, r3                          ; compare to what we saved before going to sleep
        bne     BringUpWinCE                    ; bad news - do a cold boot

;   2. MMU Enable

        ldr     r10, [r5, #SleepState_MMUDOMAIN] ; load the MMU domain access info
        ldr     r9,  [r5, #SleepState_MMUTTB]    ; load the MMU TTB info 
        ldr     r8,  [r5, #SleepState_MMUCTL]    ; load the MMU control info 
        ldr     r7,  [r5, #SleepState_WakeAddr ] ; load the LR address
        nop         
        nop
        nop
        nop
        nop

; if software reset

        mov     r1, #0
        teq     r1, r7
        bne     %f60
        bl      BringUpWinCE

; wakeup routine
60      mcr     p15, 0, r10, c3, c0, 0          ; setup access to domain 0
        mcr     p15, 0, r9,  c2, c0, 0          ; PT address
        mcr     p15, 0, r0,  c8, c7, 0          ; flush I+D TLBs
        mcr     p15, 0, r8,  c1, c0, 0          ; restore MMU control

;   3. Jump to Kernel Image's fw.s (Awake_address)

        mov     pc, r7                          ;  jump to new VA (back up Power management stack)
        nop

;------------------------------------------------------------------------------
;   Add for Power Management ?

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品久久久久99| 欧美亚洲国产一区在线观看网站| 日本成人在线网站| 国产在线视频一区二区三区| 94-欧美-setu| 欧美一区二区三区免费观看视频 | 日韩三级中文字幕| 欧美精品一区二区在线观看| 国产精品久久久久久亚洲毛片 | 欧美大胆人体bbbb| 亚洲国产精品av| 天堂影院一区二区| 99视频在线精品| 久久免费美女视频| 一区二区三区在线免费视频| 免费观看在线综合色| 国产成人三级在线观看| 欧美写真视频网站| 最新不卡av在线| 久久精品国产一区二区| 欧美日韩一区二区不卡| 国产精品乱码人人做人人爱| 日韩电影在线一区二区| 色婷婷亚洲综合| 欧美国产日产图区| 成人午夜激情在线| 欧美tk—视频vk| 国产精品久久久久影视| 国产很黄免费观看久久| 4438x成人网最大色成网站| 亚洲国产美国国产综合一区二区| 国产91精品欧美| 日韩欧美不卡在线观看视频| 亚洲自拍另类综合| 成人av网站免费| 国产亚洲精品aa午夜观看| 丝袜a∨在线一区二区三区不卡| 久久精品99国产精品| 欧美三级乱人伦电影| 精品剧情v国产在线观看在线| 日韩成人dvd| 日本精品视频一区二区三区| 亚洲欧美日韩在线| 国产999精品久久| 中文字幕一区二区三区四区不卡| 国产美女一区二区三区| 在线播放91灌醉迷j高跟美女| 日本女优在线视频一区二区| 欧美日韩视频不卡| 久久精工是国产品牌吗| 欧美一级日韩不卡播放免费| 亚洲精品一卡二卡| 在线观看欧美黄色| 亚洲伦理在线精品| 日韩一区二区三区电影| 午夜精品久久久久久久99樱桃| 欧美精品精品一区| 亚洲成人av一区二区| 一本久久a久久精品亚洲| 尤物av一区二区| 欧美军同video69gay| 激情综合色丁香一区二区| 欧美一二三区精品| 国产超碰在线一区| 国产精品久久久久天堂| 欧美性大战久久久久久久蜜臀| 视频一区欧美日韩| 欧美日韩www| 国产精品1区2区| 中文天堂在线一区| 91丝袜呻吟高潮美腿白嫩在线观看| 国产精品免费视频网站| 色婷婷久久久综合中文字幕| 亚洲蜜臀av乱码久久精品| 欧美一区二区福利在线| 激情国产一区二区| 中文字幕的久久| 欧美亚洲动漫制服丝袜| 久久精品国产第一区二区三区| 久久久99精品免费观看不卡| 精品在线免费视频| 亚洲人成精品久久久久| 91精品国产综合久久精品图片 | 欧美三片在线视频观看| 国内精品不卡在线| 亚洲人成网站在线| 国产欧美日韩综合| 欧美日韩三级一区二区| 精品一区二区精品| 夜夜揉揉日日人人青青一国产精品| 日韩亚洲欧美中文三级| 成人黄色一级视频| 肉丝袜脚交视频一区二区| 国产亚洲精品超碰| 91一区二区三区在线观看| 久久99这里只有精品| 亚洲免费观看视频| 中文欧美字幕免费| 精品裸体舞一区二区三区| 欧美视频在线观看一区二区| 国产高清视频一区| 美洲天堂一区二卡三卡四卡视频 | 看国产成人h片视频| 欧美韩国日本不卡| 欧美精品丝袜久久久中文字幕| 国产精品2024| 免费看日韩精品| 亚洲精品成人少妇| 国产精品区一区二区三区| 在线欧美日韩精品| 成人黄色免费短视频| 精品一区二区三区日韩| 亚洲综合另类小说| 亚洲精品视频在线看| 国产精品欧美极品| 欧美色网站导航| 色偷偷久久人人79超碰人人澡| 国产91精品在线观看| 国产一区二区不卡| 青青青伊人色综合久久| 日本不卡视频在线观看| 一区二区三区高清在线| 亚洲成人av在线电影| 一区二区三区四区不卡在线| 亚洲精品五月天| 综合在线观看色| 国产亚洲综合性久久久影院| 亚洲精品一区在线观看| 精品国产乱码久久久久久图片| 日韩一区二区三区观看| 欧美一级在线视频| 日韩亚洲欧美高清| 欧美成人欧美edvon| 日韩精品专区在线| 精品福利av导航| 久久九九99视频| 国产午夜精品理论片a级大结局| 337p日本欧洲亚洲大胆色噜噜| 日韩一级黄色大片| www国产亚洲精品久久麻豆| 在线观看精品一区| 日韩精品一区二区三区在线观看 | 一区二区在线观看免费视频播放| 国产精品福利一区| 亚洲欧美成人一区二区三区| 亚洲综合在线五月| 亚洲成人av一区二区三区| 一区二区视频在线| 日韩激情在线观看| 狠狠网亚洲精品| 91麻豆123| 日韩你懂的电影在线观看| 欧美—级在线免费片| 亚洲特级片在线| 久久精品国产精品亚洲红杏| 国产高清不卡一区| 成人精品gif动图一区| 色悠悠亚洲一区二区| 色婷婷av一区| 久久久久久综合| 中文字幕一区二区三| 免费在线欧美视频| 国产成人综合视频| 欧美夫妻性生活| 亚洲三级电影网站| 美女性感视频久久| 国产精品白丝av| 欧美日韩国产小视频| 久久久蜜臀国产一区二区| 亚洲成人av在线电影| 午夜精品久久久久久久 | 色综合久久中文综合久久牛| 日韩欧美中文字幕精品| 欧美不卡激情三级在线观看| 中文字幕在线不卡一区二区三区| 午夜视频在线观看一区二区 | 欧美精品一区二区久久久| 国产精品国产馆在线真实露脸| 亚洲一区二区精品视频| 99精品久久久久久| 欧美tk—视频vk| 日韩av中文字幕一区二区| av综合在线播放| 国产欧美日韩不卡免费| 天堂在线亚洲视频| 欧美日韩精品一区二区天天拍小说| 精品处破学生在线二十三| 日韩高清一区二区| 91美女在线视频| 亚洲素人一区二区| 国产精品一区二区91| 精品区一区二区| 午夜一区二区三区在线观看| 在线观看亚洲一区| 中文字幕欧美三区| 99精品欧美一区二区三区综合在线| 欧美va亚洲va在线观看蝴蝶网| 日本vs亚洲vs韩国一区三区| 色噜噜狠狠一区二区三区果冻| 成人免费一区二区三区视频|