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

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

?? era_alg.asm

?? ti dsp lf2407的flash接口程序
?? ASM
?? 第 1 頁(yè) / 共 3 頁(yè)
字號(hào):
SECTORS_DONE:
        SPLK    #0,flashAlgoVars.ALGO_STATUS    ;No errors encountered.
        B       STACK_RESTORE

NO_SECTORS:
        SPLK    #11,flashAlgoVars.ALGO_STATUS   ;No sectors specified for erase.
        B       STACK_RESTORE

ERROR1: POPD    flashAlgoVars.PAD               ;Adjust stack depth.
        SPLK    #2,flashAlgoVars.ALGO_STATUS    ;Error encountered in ERASE.
        B       STACK_RESTORE

;--------------------------------------------------------------------------------------------------
; Restore the hardware stack and exit to caller.
;--------------------------------------------------------------------------------------------------
STACK_RESTORE:
        LAR     AR2,#flashAlgoVars.STACK7       ;Point AR2 to the last of the stored stack contents
        MAR     *,AR2                           ;Make AR2 the current AR
        
        RPT     #7                              ;Restore ALL stack locations.
        PSHD    *-
        MAR     *,AR1                           ;Make AR1 the current AR
        RET                                     ;Return to caller


;--------------------------------------------------------------------------------------------------    
; ERASE_SECTOR:
;--------------------------------------------------------------------------------------------------    
; This function is the implementation of the erase algorithm for the pre-program
; conditioning of the flash array. This function is desginated as a LEVEL_1 
; subroutine.
;--------------------------------------------------------------------------------------------------
ERASE_SECTOR:
        SPLK    #MX_ECNT,flashAlgoVars.PLS_CNT              ;Initialize the program pulse count. 
        SPLK    #0ffffh,flashAlgoVars.DATA                  ;Load 0ffffh for compare.
    
        BLDD    #flashAlgoVars.FL_SECST,flashAlgoVars.ADDR  ;Point address to the start of sector.
        SPLK    #0000,flashAlgoVars.LASTVER                 ;Initialize LASTVERIFY Flag 
;--------------------------------------------------------------------------------------------------
;   ENABLE
;--------------------------------------------------------------------------------------------------
; Enable the flash for erase:
; To accept commands the following must happen:
;   1. Place the flash in the register mode.
;   2. Copy the sector key to the SECT register.
;   3. Enable the core by setting Bit 0 of the ENAB Register
;--------------------------------------------------------------------------------------------------
ENABLE: ACCESS_REGS                                         ;Put the flash in register mode.

        LACC    #SECT                                       ;Enable sector.
        BLDD    #flashAlgoVars.SECTOR_KEY,flashAlgoVars.PAD ;Copy the sector key
        TBLW    flashAlgoVars.PAD                           ;
                                                            ;
        LACC    #ENAB                                       ;Enable core.
        SPLK    #0001h,flashAlgoVars.PAD                    ;
        TBLW    flashAlgoVars.PAD                           ;

        B    ERVER                                          ;Enter erase loop from the erase verify.

;--------------------------------------------------------------------------------------------------
;   PERASE:
;--------------------------------------------------------------------------------------------------
;   This loop erases the sector, based on the address passed by the caller in
;   flashAlgoVars.FL_SECST.
;--------------------------------------------------------------------------------------------------
PERASE:
        LACC    flashAlgoVars.PLS_CNT                       ;Get the pulse counter value.
        BCND    ERROR,EQ                                    ;If remaining pulses == 0 then
                                                            ;commence the error handling.
;--------------------------------------------------------------------------------------------------
        LACC    #WADDR                                      ;The sector is selected by writing
                                                            ;WADDR with the first address of 
                                                            ;the sector
        CALL    SETWADDR                                    ;Execute the write to WADDR.

        LACC    #WDATA                                      ;Load the WDATA register with 0xffff.
        TBLW    flashAlgoVars.DATA
;--------------------------------------------------------------------------------------------------
        LACC    #CTRL                                       ;Setup the erase mode.
        SPLK    #0001,flashAlgoVars.PAD
        TBLW    flashAlgoVars.PAD
;--------------------------------------------------------------------------------------------------
        SDELAY    #T_esu_er                                 ;T_esu(ER) Delay.
;--------------------------------------------------------------------------------------------------
        LACC    #PMPC                                       ;Activate the erase mode.
        SPLK    #0005h,flashAlgoVars.PAD    
        TBLW    flashAlgoVars.PAD    
;--------------------------------------------------------------------------------------------------
EPW:    LAR     AR2,#ERASE_PULSE                            ;Call the delay routine to define the
        CALL    DELAY,AR2                                   ;erase pulse width to T_erase(E)
;--------------------------------------------------------------------------------------------------
        SPLK    #0000h,flashAlgoVars.PAD1                   ;De-activate the erase mode.
        CALL    CLRCMD
;--------------------------------------------------------------------------------------------------
        SDELAY  #T_eh_er    ;T_eh(ER)                       ;Algo delay.
;--------------------------------------------------------------------------------------------------
        LACC    #CTRL                                       ;Exit the Erase mode.
        SPLK    #0000,flashAlgoVars.PAD
        TBLW    flashAlgoVars.PAD
;--------------------------------------------------------------------------------------------------
        SDELAY  #Teh_C                                     ;Wait in normal mode.
;--------------------------------------------------------------------------------------------------
        LACC    flashAlgoVars.PLS_CNT                       ;Advance the erase pulse counter.
        SUB     #1h
        SACL    flashAlgoVars.PLS_CNT
;--------------------------------------------------------------------------------------------------
; ERVER: ERASE Verify
;--------------------------------------------------------------------------------------------------
; This subroutine checks the flash to see if the flash is erased.
; To do this it does the followign steps:
;   1.  Reads the flash array in erase verify mode.
;   2.  Branches to the Erase routine if a word is non-FFFFh
;   3.  If all the words in the sector are ffffh then it transfers control
;       to PASSERVER.
;--------------------------------------------------------------------------------------------------
ERVER:  BLDD    #flashAlgoVars.FL_SECST,flashAlgoVars.ADDR  ;Init ADDR to first location in sector.
    
B0      LACC    #CTRL                                       ;Init the Erase verify mode.
        SPLK    #0002,flashAlgoVars.PAD
        TBLW    flashAlgoVars.PAD
        SDELAY  #T_eva_e                                    ;T_eva(E) ; Algo Delay.

B1

        CALL    READWORD                                    ;Read out the word in erase ver mode.

COMPARE:
        LACL    flashAlgoVars.READ                          ;Check to see if the word read out is
        XOR     #0FFFFh                                     ;0ffffh.
        BCND    PROCEED_TO_ERASE,NEQ                                  ;If not, then proceed to apply an erase 
                                                            ;pulse to the sector.
    
        LACC    flashAlgoVars.ADDR                          ;See if the current address is 
        SUB     flashAlgoVars.FL_SECEND                     ;end-of-sector. If so, transfer control
        BCND    PASSERVER,EQ                                ;to PASSERVER.

        ADD     flashAlgoVars.FL_SECEND                     ;Increment the ADDR counter variable.
        ADD     #1                                          ;to next address
        SACL    flashAlgoVars.ADDR                          ;Store back incremented variable.

        B       B1                                          ;Proceed to check the next word.

PROCEED_TO_ERASE:

        LACC    #CTRL                                       ;Exit the Erase verify mode.
        SPLK    #0000,flashAlgoVars.PAD
        TBLW    flashAlgoVars.PAD

        SDELAY  #Tevh_C                                     ;Wait in normal mode.

        B       PERASE

;--------------------------------------------------------------------------------------------------
;PASSERVER
;--------------------------------------------------------------------------------------------------
; This section of code is executed upon successful erase verify.
; This then
;       1. Checks to see if compaction verify has passed.
;       2. If yes, the erase operation is complete for this sector, and the
;          control is transferred to 'DONE' which finishes up.
;       3. If not, control is passed to the compaction verify routine.
;--------------------------------------------------------------------------------------------------
PASSERVER:

        LACC    #CTRL                                       ;Exit the Erase verify mode.
        SPLK    #0000,flashAlgoVars.PAD
        TBLW    flashAlgoVars.PAD

        SDELAY  #Tevh_C                                     ;Wait in normal mode.


        LACC    flashAlgoVars.LASTVER                       ;Check to see if compaction ver passed.
        BCND    DONE,NEQ                                    ;If yes, the erase is complete.
        B       CMPCTVER                                    ;else start compaction verify.

;--------------------------------------------------------------------------------------------------
;ERROR Error handling
;--------------------------------------------------------------------------------------------------
; This section of code is executed upon encountering errors.
;       1. Clears control registers.
;       2. Transfers control to an error exit point.
;--------------------------------------------------------------------------------------------------

ERROR:  SPLK    #6,flashAlgoVars.PAD1                       ; Set up for clearing 6 control regs
        CALL    CLRCMD                                      ; Call routine to do so.
        B       ERROR1

;--------------------------------------------------------------------------------------------------
; READWORD
; This routine performs the following operations
;    1.    Reads the word at the location pointed to by ADDR.
;    2.  Stores the word in the variable READ.
;    3.  Returns to the caller in Register Mode.
;--------------------------------------------------------------------------------------------------
READWORD
        ACCESS_ARRAY
        LACC    flashAlgoVars.ADDR                          ;Read word flash 
        TBLR    flashAlgoVars.READ                          ;store word in READ (data space)
        ACCESS_REGS

        RET

;--------------------------------------------------------------------------------------------------
; CMPCTVER: 
;--------------------------------------------------------------------------------------------------
; This section performs the following functions:
;   1.  Checks to see if compaction operation is needed.
;   2.  Calls the compaction routine if needed.

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
丝袜亚洲另类欧美| 国产在线视频不卡二| 欧美日韩国产另类一区| 久久国产精品99精品国产 | 亚洲免费在线视频| 日韩视频在线一区二区| 99精品视频中文字幕| 日av在线不卡| 亚洲国产毛片aaaaa无费看| 中日韩av电影| 精品久久久久久亚洲综合网 | 欧美变态口味重另类| 色婷婷亚洲婷婷| 国产69精品久久久久毛片| 蜜桃视频在线观看一区| 亚洲国产精品久久久男人的天堂| 国产日韩欧美精品综合| 精品不卡在线视频| 日韩欧美国产精品一区| 欧美美女bb生活片| 在线欧美小视频| 99精品热视频| 97久久精品人人做人人爽50路| 九九国产精品视频| 天天综合天天综合色| 一区二区三区四区在线免费观看| 日本一区二区高清| 国产亚洲成aⅴ人片在线观看| 日韩欧美国产精品一区| 日韩欧美你懂的| 日韩欧美国产一区二区在线播放| 这里只有精品电影| 欧美区视频在线观看| 欧美综合天天夜夜久久| 欧美午夜精品一区二区蜜桃| 91免费在线看| 欧美伊人久久久久久午夜久久久久| 97se亚洲国产综合自在线不卡| 成人高清在线视频| 国产凹凸在线观看一区二区| 国产电影精品久久禁18| 国产精品99久久久久久似苏梦涵| 国产精品亚洲综合一区在线观看| 国产成人免费网站| 波多野结衣的一区二区三区| 99精品视频在线观看| 色屁屁一区二区| 欧美私人免费视频| 欧美另类videos死尸| 日韩免费观看高清完整版 | 精品88久久久久88久久久| 欧美成人一区二区三区| 2023国产精品视频| 国产精品久久免费看| 亚洲日本一区二区| 亚洲综合成人在线| 日韩国产一二三区| 国产一区二区三区在线观看精品| 岛国精品在线观看| 色欲综合视频天天天| 欧美日韩精品一区二区三区四区| 欧美日韩精品欧美日韩精品| 精品国产髙清在线看国产毛片| 久久久午夜精品理论片中文字幕| 国产精品久久看| 亚洲线精品一区二区三区| 日韩av电影免费观看高清完整版| 国产九九视频一区二区三区| 91网站最新地址| 欧美精品欧美精品系列| 精品国产伦一区二区三区观看方式| 欧美国产精品一区二区| 国产精品电影一区二区| 午夜精品久久久久久| 韩国三级中文字幕hd久久精品| 国产91精品入口| 欧美日韩国产美| 欧美国产视频在线| 丝袜美腿亚洲一区二区图片| 国产精品一二三区| 欧美日韩国产一级二级| 国产亚洲一本大道中文在线| 一区二区三区在线免费播放| 韩国v欧美v日本v亚洲v| 色婷婷综合久久久久中文| 精品久久一区二区三区| 亚洲综合丁香婷婷六月香| 国内精品视频一区二区三区八戒 | 欧美色综合网站| 久久亚洲精品国产精品紫薇| 一级女性全黄久久生活片免费| 国内成人自拍视频| 欧美日韩精品系列| 国产精品久久久久久久久免费樱桃| 日韩精品一二三四| 色8久久精品久久久久久蜜| 久久亚洲捆绑美女| 日韩不卡一二三区| 色天天综合久久久久综合片| 久久精品视频一区| 日韩福利电影在线| 色88888久久久久久影院按摩 | 午夜精品久久久久久久99水蜜桃| 成人性生交大片| 欧美电影免费观看高清完整版在 | 色av综合在线| 国产精品人人做人人爽人人添| 日韩高清在线观看| 欧美一a一片一级一片| 国产精品视频九色porn| 麻豆成人久久精品二区三区小说| 欧美亚洲综合色| 亚洲欧美日韩在线| 不卡av免费在线观看| 久久久国际精品| 久久99国产精品久久| 91精品国产综合久久久蜜臀图片| 亚洲自拍偷拍综合| 91福利精品视频| 亚洲人一二三区| av成人动漫在线观看| 欧美国产欧美综合| 成人一区二区三区视频| 久久久久亚洲蜜桃| 国模少妇一区二区三区| 日韩欧美国产电影| 精品一区二区三区在线播放| 日韩一区二区三区电影| 天天色天天爱天天射综合| 欧美精品一级二级三级| 亚洲国产裸拍裸体视频在线观看乱了 | 国产一区久久久| 精品少妇一区二区三区在线视频| 日本美女一区二区三区| 91精品国产麻豆| 日本麻豆一区二区三区视频| 日韩视频一区二区在线观看| 日韩综合小视频| 欧美一区二区三区电影| 麻豆免费精品视频| 久久久久亚洲蜜桃| 成人午夜av在线| 亚洲欧美日韩中文播放| 在线观看av一区| 香蕉成人伊视频在线观看| 91精品蜜臀在线一区尤物| 丝袜诱惑亚洲看片| 欧美成人精品福利| 国产99精品国产| 日韩毛片一二三区| 欧美日韩国产免费一区二区| 免费观看在线色综合| 久久九九国产精品| av不卡免费在线观看| 亚洲午夜久久久久久久久电影网 | 色综合天天性综合| 亚洲制服丝袜在线| 日韩午夜激情电影| 国产91丝袜在线18| 一区二区日韩电影| 日韩欧美你懂的| 成人综合在线视频| 夜夜精品浪潮av一区二区三区| 欧美精品欧美精品系列| 国产一级精品在线| 亚洲欧美激情小说另类| 欧美精品久久一区二区三区| 另类人妖一区二区av| 欧美国产精品专区| 欧美日韩黄色影视| 国产精品 欧美精品| 一区二区三区日韩在线观看| 日韩亚洲欧美在线观看| 高清免费成人av| 亚洲大型综合色站| 久久久精品欧美丰满| 欧美亚洲综合网| 国产a区久久久| 天天爽夜夜爽夜夜爽精品视频| 国产欧美一区二区精品秋霞影院 | 一区二区视频在线| 日韩精品最新网址| 91视频在线观看| 日本亚洲免费观看| 亚洲欧美日韩系列| 日韩美女一区二区三区四区| 97成人超碰视| 国产一区二区三区在线观看精品 | 欧美成人bangbros| 91美女精品福利| 国产在线日韩欧美| 丝瓜av网站精品一区二区| 国产精品美女一区二区| 欧美成人一区二区| 欧美人xxxx| 色综合久久综合| 高清国产午夜精品久久久久久| 日本视频一区二区三区| 一区二区三区四区蜜桃| 国产欧美日韩中文久久|