Using the Algorithms With C Code to Erase and Reprogram the ’F240
PRELIMINARY
A-50
PRELIMINARY
.bss :{} > B1 PAGE 1
.cinit :{} > B1 PAGE 1
.const : load = EXTRAM PAGE 0, run = DSRAM PAGE 1
{
/* GET RUN ADDRESS */
__const_run = .;
/* MARK LOAD ADDRESS */
*(.c_mark)
/* ALLOCATE .const */
*(.const)
/* COMPUTE LENGTH */
__const_length = .– __const_run;
}
.data :{} > B1 PAGE 1
.stack :{} > B1 PAGE 1 /*C stack. */
}
A.6.3 C Function for Disabling TMS320F240 Watchdog Timer
***********************************************************************
* Watchdog Timer Disable function *
* Arguments passed from Caller: None *
* Local Variables: None *
***********************************************************************
SYSSR .set 0701Ah ; System Module Status Register
WDCR .set 07029h ; WDT Control reg
DP_PF1 .set 224 ; 7000h/80h = 100h or 224
.globl _wdtoff
.text
.def _wdtoff
_wdtoff: ; presume ARP = AR1 (SP)
*****************************************************************************
* On entry, presume ARP = AR1 (SP) *
* *
* Step 1. Pop the return address off the h/w stack and push to s/w stack *
*****************************************************************************
POPD *+ ; pop return address, push on software stack
; ARP=AR1, SP=SP+1
*****************************************************************************
* Step 2. Push the frame pointer onto s/w stack *
*****************************************************************************
SAR AR0,*+ ; push AR0 (FP) onto SP
; ARP=AR1, SP=SP+2
*****************************************************************************
* Step 3. Allocate the local frame *
*****************************************************************************
SAR AR1,* ; *SP = FP
LAR AR0,#1 ; FP = size of local frame, 1
LAR AR0,*0+ ; FP = SP, SP += size ==> allocate frame
*****************************************************************************
* Step 5. Begin code that will disable the WDT *
*****************************************************************************
LDP #DP_PF1 ; Page DP_PF1 includes WET through EINT frames
LACL WDCR ; ACC = WDTCR, watchdog timer control register