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

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

?? boot5402.asm

?? dsp ti的5402的boot程序
?? ASM
?? 第 1 頁 / 共 3 頁
字號:
*************************************************************************
***	
***     VC5402 Bootloader Software      :       Version  1.03
***                     Origin Date     :       9/30/98
***                     Author(s)       :       RDP
***	
*************************************************************************
***	
***     This code sets up and executes the VC5402 Bootloader.
***	
***	Revision History:
***	----------------
***     1.00    Modified the VC5410 bootloader for use    RDP   09/30/98
***             on the VC5402. Added new HPI boot mode,
***             and removed McBSP2 code. See notes on
***             HPI boot mode below.
***     1.01    Fixed bug in 8bit parallel mode, by       RDP   11/12/98
***             masking off the upper ACCUA bits of
***             the word containing the upper byte
***             of the section size.
***     1.02    Fixed the 8bit standard serial mode,      RDP   02/26/99
***             by changing the initialization of RCR11
***             and XCR11 from 040h to 0h.
***             Added a SPI EEPROM bootmode, which is
***             selected via the INT3 flag (See notes
***             on SPI boot mode below). Changed the
***             references to the McBSP control
***             registers to emphasize the sub-bank 
***             addressing scheme. Added more comments,
***             and cleaned-up spacing on older code.
***             Fixed a bug in 8-bit I/O mode, by loading
***             the top of B with zero. Added code to
***             toggle the BDX1 pin during init, to
***             provide a high-to-low transition that
***             can be used to drive INT3 for selection
***             of the SPI boot mode.
***     1.03    Modified Parallel 8-bit.                  PMJ2   12/06/99
***             Modified I/O 8-bit boot modes. 
***             In the parallel 8-bit mode, the AG and AH 
***             are forced to zero for correct evaluation.  
***             In the 8-bit I/O mode, the XPC 
***             destination addr is correclty saved.
***             The BG and BH are forced to zero
***             for correct evaluation. The SPI mode boot
***             branches to the parallel boot after failure
***             of the first condition (08) and second condition (AA).
***             Reset McBSP1 before DX pins toggles. (for debugging)
***
*************************************************************************
***     --------------- Notes on '5402 HPI Boot Mode ---------------
***     The new HPI boot mode allows the host to load the on-chip RAM
***     after the '5402 is reset. The boot-mode also allows the host
***     to specify an entry point at load-time. After completing the
***     bootload process, the host must make another HPI access to load
***     the entry point to location 07Fh of on-chip RAM. This is how it
***     works: after reset, the bootloader initializes address 07Fh to
***     zero, then polls this location for a change while the host is
***     loading the code. When the bootloader detects a change in the
***     contents of address 07Fh, it performs a branch using the contents
***     as the destination address.
***     This new mode doesn't require the INT2 flag for selection. If the
***     INT2 pin is not used to select HPI boot mode, the bootloader
***     periodically checks various boot sources, including HPI, until a
***     boot condition is detected. Alternatively, the INT2 flag can be
***     used to force the bootloader to ignore all boot sources other
***     than HPI. If the INT2 flag is to be used, a high to low transition
***     is required on the INT2 pin within 30 cycles after the '5402 is
***     reset.
*************************************************************************
***     --------------- Notes on '5402 SPI Boot Mode ---------------
***     The SPI boot mode allows the '5402 to boot from an 8-bit serial
***     EEPROM using the SPI protocol. The mode is selected at reset via
***     the INT3 external interrupt . Proper selection of the boot mode
***     requires a high to low transition on the INT3 pin within 30 CPU
***     cycles after the '5402 is reset. 
***
***     The EEPROM must be connected to McBSP1 as follows:
***            McBSP1    EEPROM
***            ******    ******
***            BCLKX     SCK
***            BFSX      /CS
***            BDX       SI
***            BDR       SO
***            XF        /HOLD  (Optional - disables EEPROM when done)
***
***     The boot table used for programming the EEPROM is generated
***     using the 8bit serial option of the Hex conversion utility. 
***      example:
***       -bootorg SERIAL
***       -memwidth 8
*************************************************************************


          .title "bootVC5402"
         .mmregs
         .version 548
         .def    boot
         .def    endboot
         .def    bootend
         .def    dest
         .def    src
         .def    lngth
         .def    hbyte
         .ref    SPI_INIT, SPI_READ, SPI_WRITE
         .ref    SPI_RDSR, SPI_WRSR

*************************************
pa0      .set   0H              ; port address 0h for i/o boot load

xentry   .set   61H             ; XPC of entry point
entry    .set   62H             ; entry point
hbyte    .set   63H             ; high byte of 8-bit serial word
p8word   .set   64H             ; concatenator for 8-bit memory load
src      .set   65H             ; source address
dest     .set   66H             ; destination address (dmov from above)
xdest    .set   67H             ; XPC of destination address.
lngth    .set   68H             ; code length
temp0    .set   69H             ; temporary register0
temp1    .set   6aH             ; temporary register1
temp2    .set   6bH             ; temporary register2
temp3    .set   6cH             ; temporary register3

HPIentry .set   7Fh             ; Entry point for HPI boot.

***********************************************
*    MMR definition for c54xlp peripherals    *
*-------------  MCBSP0  ----------------------*
drr10           .set    21H     ; Data Receive Register
dxr10           .set    23H     ; Data Transmit Register
SPSA0           .set  0038H     ; Serial Port 0 Sub-bank Address Register 
SPSD0           .set  0039H     ; Serial Port 0 Sub-bank Data Register 


*-------------  MCBSP1  ----------------------*
drr11           .set    41H     ; Data Receive Register         
dxr11           .set    43H     ; Data Transmit Register
SPSA1           .set  0048H     ; Serial Port 1 Sub-bank Address Register
SPSD1           .set  0049H     ; Serial Port 1 Sub-bank Data Register

*----------- MCBSP CONTROL REGS --------------*
SPCR1_SUBADDR   .set  0000H     ; Serial Port Control Register 1 (subaddress)
SPCR2_SUBADDR   .set  0001H     ; Serial Port 1 Control Register 2 (subaddress)
RCR1_SUBADDR    .set  0002H     ; Receive Control Register 1 (subaddress)
RCR2_SUBADDR    .set  0003H     ; Receive Control Register 2 (subaddress)
XCR1_SUBADDR    .set  0004H     ; Transmit Control Register 1 (subaddress)
XCR2_SUBADDR    .set  0005H     ; Transmit Control Register 2 (subaddress)
SRGR1_SUBADDR   .set  0006H     ; Sample Rate Genarator Register 1 (subaddress)
SRGR2_SUBADDR   .set  0007H     ; Sample Rate Genarator Register 2 (subaddress)
PCR_SUBADDR     .set  000EH     ; Pin Control Register (subaddress)

*-------------- Other contants ---------------*
int2msk         .set   0004H    ; INT2_ bit position on IFR
int3msk         .set   0100H    ; INT3_ bit position in IFR/IMR

**********************************************************
*	bootloader
**********************************************************
         .sect "boot"
boot
         
        ssbx    intm            ; disable all interrupts
        stm     #0FFFFh,@ifr    ; clear IFR flag
        ld      #0, dp
        orm     #02b00h, @st1   ; xf=1, hm=0, intm=1, ovm=1, sxm=1
        orm     #020h, @pmst    ; ovly=1
        stm     #07fffh, swwsr  ; 7 wait states for P_,D_, and I_ spaces
        stm     #0007dh, sp     ; Use top part of scratch-pad RAM for stack.

*****************************************************************
*    RDP, Modified old HPI boot check to support host loading
*    after reset. Initialize HPI boot entry point to 0. The host
*    will change the value of this location after loading RAM.
*****************************************************************
        stm     #0, @HPIentry   ; Set HPI entry to known value.
        stm     #08h, hpic      ; Set HINT pin low. Ok to start
                                ; host load.
*****************************************************************
*    Toggling the BDX pin on McBSP1. This pin can be used to
*    drive /INT3 and select the SPI boot mode, without requiring
*    an external signal.
*****************************************************************

        STM     SPCR2_SUBADDR,SPSA1
        STM     #0000h,SPSD1    ; DISABLES TRANSMIT. (reset) 1.03

        stm     #PCR_SUBADDR, SPSA1
        stm     #02020h, SPSD1  ; Set DX high.
        rpt     #5              ; Keep high a while.
        nop
        stm     #02000h, SPSD1  ; Set DX low.

        rpt     #5              ; wait several cycles
        nop                     ; before checking INT2
        bitf    @ifr, #int2msk  ; Check if INT2_ flag is set
        nop
        bc      HPI, tc         ; If int2 is set then HPI boot.

        bitf    @ifr, #int3msk  ; Else, check if INT3_ flag is set
        nop
        bc      SPIBOOT, tc     ; If int3 is set then SPI boot.

        b       parallel        ; Otherwise, check other boot modes.
*****************************************************************
*    HPI boot mode selected through int2.
*****************************************************************
HPI                             ; Else, this is an HPI boot, all
                                ; other boot modes are ignored.
        stm     #int2msk, ifr   ; Clear INT2_ bit in ifr.

        ldm     HPIentry, a     ; Get HPI entry vector.
        bc      hpiboot, aneq   ; If not zero, HPI boot.
        b       $-3             ; else, keep looping.






*****************************************************************
*    Check Parallel Boot
*****************************************************************
parallel
        stm     #0h, @xentry    ; initialize the entry point
        stm     #boot, @entry   ;
        portr   #0ffffh, @src   ; read source address of boot table
        mvdk    @src, ar1       ; ar1 points at source memory (Data)
        ld      *ar1+, a        ; load accumulator A with BRW
        sub     #10AAh, a, b    ; check 16-bit Boot?
        bc      par16, beq      ; a=010AAh
        and     #0ffh, a        ; check acc AL = 08
        sub     #8h, a, b       ; check 8-bit Boot?
        bc      chk_data, bneq  ; a=08xxh
        ld      *ar1+, a        ; 8-bit mode, LSB
        and     #0ffh, a        ; check acc AL = AAh
        sub     #0AAh, a        ; LSB = 0AAh?
        bc      par08, aeq      ; 8-bit Parallel Boot
chk_data stm     #0FFFFh, ar1    ; check data memory 0xFFFF
        nop                     ; prevent pipeline conflict
        nop                     ;
        ld      *ar1+, a        ; load accumulator A with BRW
        stlm    a, ar1          ; ar1 point at source memory (Data)
        nop                     ; prevent posibble pipeline conflic
        nop                     ;
        ld      *ar1+, a        ; load acculator A with BRW
        sub     #10AAh, a, b    ; check 16-bit Boot?
        bc      par16, beq      ; a=010AAh
        stm     #0FFFFh, ar1    ; check data memory 0xFFFF & 0xFFFE
        nop                     ; prevent possible pipeline conflic
        nop                     ;
        ldu   *ar1-, a          ; acc A <-- source address
        and   #0FFh, a          ; 0 the high byte
        add   *ar1, 8, a        ;
        stlm    a, ar1          ;
        nop                     ; prvent possible pipeline conflic
        nop                     ;
        ld      *ar1+, a        ; load accumulator A with BRW
        and   #0ffh, a          ; check acc AL = 08h
        sub     #8h, a, b       ; check 8-bit Boot?
        bc      ser_ini, bneq   ; acc A = 08xxh
        ld      *ar1+, a        ; 8-bit mode, LSB
        and     #0ffh, a        ; check acc AL = AAh
        sub     #0AAh, a        ; LSB = 0AAh?
        bc      par08, aeq      ; 8-bit Parallel Boot

ser_ini
 
********************************************************************************
*
*                    Initialization for 5402 BSPs                                         
*
********************************************************************************
*
* 1. BSP0 is configured for 16-bit, BCLKX input, BFSX input.                    
*
********************************************************************************
*
        STM     SPCR1_SUBADDR,SPSA0
        STM     #0000h,SPSD0            ; DISABLES RECEIVE.
	
        STM     SPCR2_SUBADDR,SPSA0

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩精品一级二级 | 中文字幕中文字幕一区二区| 51精品秘密在线观看| 欧美性猛交xxxx乱大交退制版| 99久久精品费精品国产一区二区| 国产精品亚洲视频| 国产一区二区在线观看视频| 黑人巨大精品欧美一区| 国产精品高潮久久久久无| 久久这里只有精品6| 国产日韩欧美不卡| 亚洲免费在线看| 亚洲综合在线免费观看| 亚洲小说欧美激情另类| 麻豆精品视频在线| 成人午夜大片免费观看| 色悠悠亚洲一区二区| 精品国产精品网麻豆系列| 国产精品无圣光一区二区| 天堂成人国产精品一区| 国产高清无密码一区二区三区| 91丨porny丨中文| 日韩欧美亚洲一区二区| 中文字幕一区二区不卡| 亚洲午夜av在线| 粉嫩在线一区二区三区视频| 欧美日本视频在线| 国产精品短视频| 精品亚洲免费视频| 欧美视频精品在线| 精品99久久久久久| 国产精品人妖ts系列视频| 热久久一区二区| 欧日韩精品视频| 亚洲免费在线看| 不卡av在线网| 中文字幕一区二区三区视频| 久久99久久久久| 欧美一区二区三区在线视频| 亚洲高清免费一级二级三级| gogogo免费视频观看亚洲一| 欧美高清在线精品一区| 国产麻豆精品theporn| 精品动漫一区二区三区在线观看| 日日夜夜免费精品视频| 欧美在线999| 综合色中文字幕| 国产精品99久久久久久似苏梦涵 | 中文久久乱码一区二区| 奇米精品一区二区三区在线观看| 欧美区视频在线观看| 久久不见久久见免费视频7| 欧美不卡视频一区| 成人精品高清在线| 亚洲自拍偷拍av| 欧美高清一级片在线| 精品一区二区av| 亚洲欧美日本在线| 欧美午夜精品电影| 精品在线观看免费| 亚洲乱码日产精品bd| 欧美日韩国产电影| 国产一区久久久| 亚洲图片欧美一区| 久久理论电影网| 在线日韩国产精品| 成人午夜在线播放| 午夜免费久久看| 日韩免费在线观看| 色综合久久99| 国产精品一卡二| 日韩黄色在线观看| 国产精品国产三级国产有无不卡| 欧美美女激情18p| 93久久精品日日躁夜夜躁欧美| 激情五月婷婷综合| 视频一区二区三区在线| 一区二区三区中文字幕精品精品| 精品三级在线观看| 欧美久久一二三四区| 在线视频国产一区| 91在线国产福利| 972aa.com艺术欧美| 成人黄色在线网站| 国产·精品毛片| 国产激情偷乱视频一区二区三区| 欧美aaaaaa午夜精品| 美腿丝袜亚洲三区| 亚洲欧美日韩电影| 国产精品欧美久久久久无广告 | 国产精品天干天干在观线| 久久先锋影音av鲁色资源网| 26uuu欧美日本| 久久久久亚洲蜜桃| 国产精品久久久久aaaa| 亚洲欧美日韩国产另类专区| 一区二区三区精品视频| 亚洲线精品一区二区三区八戒| 亚洲午夜日本在线观看| 婷婷久久综合九色综合绿巨人 | 激情综合网最新| 国产很黄免费观看久久| 成人av小说网| 欧美日韩一区不卡| 欧美成人aa大片| 亚洲免费观看高清| 麻豆国产精品视频| 国产一级精品在线| 成人毛片视频在线观看| 色88888久久久久久影院按摩 | 国产精品妹子av| 日本亚洲最大的色成网站www| 国产毛片精品视频| 欧美色爱综合网| 亚洲国产高清aⅴ视频| 三级一区在线视频先锋| 不卡大黄网站免费看| 日韩欧美国产一区二区三区 | 极品少妇一区二区| 欧美日韩久久久| 亚洲免费观看在线观看| 久久精品国产亚洲高清剧情介绍| 成人国产精品视频| 久久久久国色av免费看影院| 日韩成人精品在线观看| 欧洲一区二区三区在线| 亚洲视频免费观看| av不卡在线播放| 综合av第一页| 色诱亚洲精品久久久久久| 国产精品亲子伦对白| 美女在线视频一区| 日韩欧美久久一区| 精品中文字幕一区二区小辣椒| 欧美日韩精品一区二区| 亚洲va天堂va国产va久| 欧美日韩一区二区三区高清| 午夜精彩视频在线观看不卡| 欧美丝袜自拍制服另类| 一区二区三区精品视频| 精品1区2区3区| 亚洲欧美成aⅴ人在线观看| 国产成人在线电影| 欧美sm极限捆绑bd| 狠狠狠色丁香婷婷综合激情| 久久综合九色欧美综合狠狠| 国产.欧美.日韩| 亚洲美腿欧美偷拍| 9191国产精品| 大白屁股一区二区视频| 亚洲午夜成aⅴ人片| 国产精品影视网| 国产精品少妇自拍| 久久综合视频网| 欧美性大战xxxxx久久久| 成人综合婷婷国产精品久久| 午夜精品免费在线观看| 亚洲欧美激情插 | 97国产精品videossex| 激情小说欧美图片| 免费人成网站在线观看欧美高清| 亚洲精品videosex极品| 中文字幕一区二区三中文字幕| 精品成人一区二区三区四区| 欧美美女直播网站| 欧美日本精品一区二区三区| 欧美日韩一区在线| 在线免费观看日本一区| 色哟哟国产精品免费观看| 97久久超碰国产精品| 99久久久久久| 欧美性三三影院| 欧美日韩午夜在线| 69久久99精品久久久久婷婷| 欧美日韩高清一区二区| 日韩欧美中文字幕制服| 精品国产伦一区二区三区免费 | 久久成人av少妇免费| 极品美女销魂一区二区三区| 国产精品一二二区| 成人av网址在线| 欧美在线|欧美| 欧美大片一区二区三区| 国产精品久久久久影院| 亚洲自拍偷拍欧美| 老司机免费视频一区二区| 国产高清成人在线| 欧美日韩一区二区三区免费看| 26uuu亚洲综合色欧美| 国产精品视频九色porn| 丝袜亚洲精品中文字幕一区| 国产精品自拍av| 51久久夜色精品国产麻豆| 中文成人综合网| 美女爽到高潮91| 欧美日韩高清一区二区| 亚洲欧洲av一区二区三区久久| 日韩av在线播放中文字幕| aaa欧美日韩| 国产亚洲精品福利|