⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 clr24_x1.asm

📁 jaaj
💻 ASM
字号:
*************************************************************
** CLEAR  Subroutine
*
* TMS320F2XX Flash Utilities.
* Revision: 2.1   4 Dec 97
*
* Filename: CLR24_X1.ASM
* Changes: Re-written to include latest flash algorithms.
*
*		 DSP Applications
*		 Texas Instruments Inc.
*
* Change: Added Delay initialisation to the clear algorithm.
*	  This is also used by the Erase & Prog algs.
*
*
* Called by : c2xx_bcx.asm or flash application programs.
*
* !!CAUTION - INITIALIZE DP BEFORE CALLING THIS ROUTINE!!
*
* Function  : Clears one or more contiguous segments of
*	      flash array 0/1 as specified by the fol
*	      -lowing variables.
*	      SEG_ST = Segment start address.
*	      SEG_END= Segment end address.
*	      PROTECT= Sector protect enable.
*
* The algorithm used is "row-horizontal" which means that
* an entire flash row (32 words) are programed in parallel
* This method provides better uniformity of programming
* levels between adjacent bits then if each address were
* programed independently. The algorithm also uses a 3-read
* check for VER0 margin (i.e. The flash location is read
* three times and the first two values are discarded.) This
* provides low-freq read-back margin on programed bits. For
* example, if the flash is programmed using a CLKOUT period
* of 50ns, the flash can be reliably readback over the
* CLKOUT period range of 50ns to 150ns (6.67Mhz-20Mhz).
* The programming pulse-width is 100us, and a maximum of
* 150 pulses are applied per row.
*
* The following resources are used for temporary storage:
*	 AR0  - Used for comparisons.
*	 AR1  - Used for pgm pulse count.
*	 AR2  - Used for row banz loop.
*	 AR6  - Parameter passed to Delay.
*    FL_ADRS  - Used for flash address.
*    FL_DATA  - Used for flash data.
*      FL_ST  - Used for flash start address.
*	B2_0  - Used for row-done flag.
*	B2_1  - Used for row start address.
*      SPAD1  - Flash commands.
*      SPAD2  - Flash commands.
*
*************************************************************
	.include "svar2X.h"
*
MAX_PGM .set    150        ;Only allow 150 pulses per row.
VER0    .set    010h       ;VER0 command.
WR_CMND .set    4          ;Write command.
WR_EXE  .set    045h       ;Write EXEBIN command.
STOP    .set    0          ;Reset command.

	.def	CLEAR

;	.def	GCLR
;	.ref	PROTECT,SEG_ST,SEG_END
;	.ref	DELAY,REGS,ARRAY

;	.sect	"clr_flsh"
	.sect	".alg"

;GCLR:	 SPLK	 #0,IMR 	 ;MASK ALL INTERRUPTS
;	SETC	INTM		;GLOBALLY MASK ALL INTERRUPTS
;	CLRC	SXM		;Disable sign extension.


;	CALL	CLEAR		;Clear the specified segments.

************************************************
* CLEAR:    This routine performs a clear opera*
* -tion on the flash array defined by the FL_ST*
* variable. The segments to be cleared are     *
* defined by the SEG_ST, SEG_END, and PROTECT  *
* variables.                                   *
* The following resources are used for temp    *
* storage:                                     *
*        AR0  - Used for comparisons.          *
*        AR1  - Used for pgm pulse count.      *
*        AR2  - Used for row banz loop.        *
*    FL_ADRS  - Used for flash address.        *
*    FL_DATA  - Used for flash data.           *
*        B2_0 - Used for row-done flag.        *
*        B2_1 - Used for row start address.    *
************************************************
CLEAR:
        LACL    SEG_ST                  ;Get segment start address.
        SACL    FL_ADRS                 ;Save as current address.
;	LACL	SEG_ST			;Get segment start address.
	AND	#04000h 		;Get array start address.
	SACL	FL_ST			;Save array start address.

;Initialisation of Delay values are done only here in the Clear alg.
;Erase & Program algs rely on these values also. (DAF)
	SPLK	#0200, DLY10		;Delay val for 10uS
	SPLK	#2000, DLY100		;Delay val for 100uS
	SPLK	#0FFFFh, DLY3K3 	;Dealy val for 3.3mS

********Begin a new row.*
NEWROW
        SACL    B2_1                    ;Save row start address.
        LAR     AR1,#0                  ;Init pulse count to zero.
********Same row, next pulse.*
SAMEROW
        SPLK    #1,B2_0                 ;Set row done flag = 1(True).
        LACL    B2_1                    ;Get row start address.
        SACL    FL_ADRS                 ;Save as current address.
        LAR     AR2,#31                 ;Init row index.
********Repeat the following code 32 times until end of row.*
********First do low-byte.*
LOBYTE                                  
        CALL    SET_RD_VER0             ;Read word at VER0 level.
        LACL    #0FFh                   ;Get lo-byte mask.
        AND     FL_DATA                 ;Xor with read-back value.
        BCND    HIBYTE,EQ               ;If zero then done.
        XOR     #0FFFFh                 ;else, mask off good bits.
        SACL    FL_DATA                 ;New data.
        CALL    EXE_PGM                 ;PGM Pulse.
        SPLK    #0,B2_0                 ;Set row done flag = 0(False).
********Now do hi-byte.*
HIBYTE
        CALL    SET_RD_VER0             ;Read word at VER0 level.
        LACC    #0FF00h                 ;Get hi-byte mask.
        AND     FL_DATA                 ;And with read-back value.
        BCND    NEXTWORD,EQ             ;If zero then done.
        XOR     #0FFFFh                 ;else, mask off good bits.
        SACL    FL_DATA                 ;New data.
        CALL    EXE_PGM                 ;PGM Pulse.
        SPLK    #0,B2_0                 ;Set row done flag = 0(False).
********************
NEXTWORD
        LACL    FL_ADRS                 ;Load address for next word.
        ADD     #1                      ;Increment address.
        SACL    FL_ADRS                 ;Save as current address.
        MAR     *, AR2                  ;Point to row index.
        BANZ    LOBYTE                  ;Do next word,and dec AR2.
********Reached end of row. Check if row done. *
        BIT     B2_0,15                 ;Get row_done flag.
        BCND    ROW_DONE,TC             ;If 1 then row is done.
        MAR     *,AR1                   ;Else, row is not done, so
        MAR     *+                      ;inc row pulse count.
        LAR     AR0,#MAX_PGM            ;Check if passed allowable max.
        CMPR    2                       ;If AR1>MAX_PGM then
        BCND    EXIT,TC                 ;fail, don't continue.
        B       SAMEROW                 ;else, go to beginning
                                        ;of same row.
********If row done then check if Array done. *
ROW_DONE                                ;Check if end of array.
        SUB     SEG_END                 ;Subtract segment end address.
        BCND    DONE, GEQ               ;If >0 then done.
********Else, goto next row. *
        LACL    FL_ADRS
        B       NEWROW                  ;Start new row.

DONE:
FINISHED:
;	IN	DUMMY, F24X_ACCS
	CALL	ARRAY		;ACCES FLASH IN ARRAY MODE.
        RET

********If here then unit failed to program. *
EXIT    SPLK    #1,ERROR        ;Update error flag.
        B       FINISHED        ;Get outa here.

************************************************************
	.page
************************************************************
* THIS SECTION PROGRAMS THE VALUE STORED IN FL_DATA INTO   *
* THE FLASH ADDRESS DEFINED BY FL_ADRS.                    *
*							   *
* The following resources are used for temporary storage:  *
*        AR6  - Parameter passed to Delay.                 *
*        SPAD1 - Flash program and STOP commands.          *
*        SPAD2 - Flash program + EXE command.              *
************************************************************
EXE_PGM 			;			   *
*							   *

;	IN	DUMMY, F24X_ACCS
	CALL	ARRAY		;ACCESS ARRAY		   *
* LOAD WADRS AND WDATA					  **
        LACL    FL_ADRS            ;ACC => PROGRAM ADRS    *
        TBLW    FL_DATA            ;LOAD WADRS AND WDATA   *

;	OUT	DUMMY, F24X_ACCS;(DAF)
	CALL	REGS		;ACCESS FLASH REGS	   *
* SET-UP WRITE COMMAND WORDS				  **
        LACL    PROTECT         ;GET SEGMENT PROTECT MASK **
        OR      #WR_CMND        ;OR IN WRITE COMMAND      **
        SACL    SPAD1           ;SPAD1 = WRITE COMMAND    **
        OR      #WR_EXE         ;OR IN EXEBIN COMMAND     **
        SACL    SPAD2           ;SPAD2 = WRITE EXE COMMAND**
*							   *
        LACL    FL_ST           ;ACC => 0 (FLASH0)         *
* ACTIVATE WRITE BIT					  **
        TBLW    SPAD1           ;EXECUTE COMMAND          **
	RPT	DLY10		;(DAF)
	NOP
;	LAR	AR6,#D10	;SET DELAY		  **
;	CALL	DELAY,*,AR6	;WAIT			  **
* SET EXEBIN BIT					 ***
        TBLW    SPAD2           ;EXECUTE COMMAND         ***
	RPT	DLY100		;(DAF)
	NOP
;	LAR	AR6,#D100	;SET DELAY		 ***
;	CALL	DELAY,*,AR6	;WAIT			 ***
* STOP WRITE OPERATION					   *
        SPLK    #0,SPAD1        ;SHUTDONW WRITE OPERATION  *
        TBLW    SPAD1           ;EXECUTE COMMAND           *
        TBLW    SPAD1           ;EXECUTE COMMAND           *
	RPT	DLY10		;(DAF)
	NOP
;	LAR	AR6,#D10	;SET DELAY		   *
;	CALL	DELAY,*,AR6	;WAIT			   *
*							   *
	RET		;RETURN TO CALLING SEQUENCE	   *
************************************************************
	.page
***********************************************************
* ACTIVATE VER0 ON FLASH READS				  *
* LOADS FLASH WORD AT ADDR FL_ADRS TO FL_DATA.            *
* Uses SPAD1 for temporary storage of flash comands.      *
***********************************************************
SET_RD_VER0                     ;                         *

;	OUT	DUMMY, F24X_ACCS
	CALL	REGS		;ACCESS FLASH REGISTERS   *
        LACL    FL_ST           ;ACC => FLASH             *
        SPLK    #VER0,SPAD1      ;ACTIVATE VER0           *
        TBLW    SPAD1            ;EXECUTE COMMAND         *
	RPT	DLY10		;(DAF)
	NOP
;	LAR	AR6,#D10	;SET DELAY		  *
;	CALL	DELAY,*,AR6	;WAIT			  *

;	IN	DUMMY, F24X_ACCS
	CALL	ARRAY		;ACCESS FLASH ARRAY	  *
        LACL    FL_ADRS         ;POINT TO ADRS            *
        TBLR    FL_DATA         ;GET FLASH WORD 1x read   *
        TBLR    FL_DATA         ; 2x read                 *
        TBLR    FL_DATA         ; 3x read                 *

;	OUT	DUMMY, F24X_ACCS
	CALL	REGS		;ACCESS FLASH REGISTERS   *
        LACL    FL_ST           ;ACC => FLASH             *
        SPLK    #STOP,SPAD1      ;DEACTIVATE VER0         *
        TBLW    SPAD1            ;EXECUTE COMMAND         *
	RPT	DLY10		;(DAF)
	NOP
;	LAR	AR6,#D10	;SET DELAY		  *
;	CALL	DELAY,*,AR6	;WAIT			  *


;	IN	DUMMY, F24X_ACCS
	CALL	ARRAY		;ACCESS FLASH ARRAY	  *
        RET             ;RETURN TO CALLING SEQUENCE       *

ARRAY:	IN	DUMMY, F24X_ACCS
;	LDP	#0E0H
;	SPLK	#0,7018H
;	LDP	#6

	RET

REGS:	OUT	DUMMY, F24X_ACCS
;	LDP	#0E0H
;	SPLK	#0800H,7018H
;	LDP	#6
	RET

***********************************************************
        .end

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -