这些小活动你都参加了吗?快来围观一下吧!>>
电子产品世界 » 论坛首页 » 综合技术 » 基础知识 » IAR,10A,FLASH,20A,FLASH 用IAR的3.10A调试能正确写

共2条 1/1 1 跳转至

IAR,10A,FLASH,20A,FLASH 用IAR的3.10A调试能正确写FLASH,但用3.20A却不能正确写FLASH的原因

院士
2006-09-17 18:14:16     打赏
IAR,10A,FLASH,20A,FLASH 用IAR的3.10A调试能正确写FLASH,但用3.20A却不能正确写FLASH的原因



关键词: FLASH     3.10A     调试     正确     但用     3.20    

院士
2006-12-22 22:43:00     打赏
2楼
问 下面程序用IAR的3.10A及126B调试,能正确写FLASH,但用3.20A却不能正确写FLASH,INFO中总是FFH,不知是什么原因,请各位大侠多多指教。

//****************************************************************************
// MSP-FET430x110 Demo - Flash In-System Programming
//
// Description; This program first erases flash seg A, then it increments all
// values in seg A, then it erases seg B, then copies seg A to seg B.
// Assumed MCLK 550kHz - 900kHz.
//
// MSP430F1121
// -----------------
// /|\| XIN|-
// | | |
// --|RST XOUT|-
// | |
//
// M. Mitchell
// Texas Instruments, Inc
// August 2002
// Built with IAR Embedded Workbench Version: 1.25A
// December 2003
// Updated for IAR Embedded Workbench Version: 2.21B
//******************************************************************************
//******************************************************************************

#include <MSP430x11x1.h>

char value; // 8-bit value to write to segment A

// Function prototypes
void write_SegA (char value);
void copy_A2B (void);

void main(void)
{
WDTCTL = WDTPW + WDTHOLD; // Stop watchdog timer
FCTL2 = FWKEY + FSSEL0 + FN0; // MCLK/2 for Flash Timing Generator
value = 0; // initialize value

while(1) // Repeat forever
{
write_SegA(value++); // Write segment A, increment value
copy_A2B(); // Copy segment A to B
}
}

void write_SegA (char value)
{
char *Flash_ptr; // Flash pointer
unsigned int i;

Flash_ptr = (char *) 0x1080; // Initialize Flash pointer
FCTL1 = FWKEY + ERASE; // Set Erase bit
FCTL3 = FWKEY; // Clear Lock bit
*Flash_ptr = 0; // Dummy write to erase Flash segment

FCTL1 = FWKEY + WRT; // Set WRT bit for write operation

for (i=0; i<128; i++)
{
*Flash_ptr++ = value; // Write value to flash
}

FCTL1 = FWKEY; // Clear WRT bit
FCTL3 = FWKEY + LOCK; // Reset LOCK bit
}


void copy_A2B (void)
{
char *Flash_ptrA; // Segment A pointer
char *Flash_ptrB; // Segment B pointer
unsigned int i;

Flash_ptrA = (char *) 0x1080; // Initialize Flash segment A pointer
Flash_ptrB = (char *) 0x1000; // Initialize Flash segment B pointer
FCTL1 = FWKEY + ERASE; // Set Erase bit
FCTL3 = FWKEY; // Clear Lock bit
*Flash_ptrB = 0; // Dummy write to erase Flash segment B
FCTL1 = FWKEY + WRT; // Set WRT bit for write operation

for (i=0; i<128; i++)
{
*Flash_ptrB++ = *Flash_ptrA++; // copy value segment A to segment B
}

FCTL1 = FWKEY; // Clear WRT bit
FCTL3 = FWKEY + LOCK; // Reset LOCK bit
} 1: 这个不是书上的例程序吗,我还没有测试过,没有想到有问题呀! 2: 确实不一样, 3: 3.20A是一个做得很烂的编译器,没办法,只能返回到3.10A.

共2条 1/1 1 跳转至

回复

匿名不能发帖!请先 [ 登陆 注册 ]