TI中文支持网
TI专业的中文技术问题搜集分享网站

28335看门狗能中断不能复位

// Step 1. Initialize System Control:
// PLL, WatchDog, enable Peripheral Clocks
// This example function is found in the DSP2833x_SysCtrl.c file.
InitSysCtrl();
// Step 2. Initalize GPIO:// This example function is found in the DSP2833x_Gpio.c file and
// illustrates how to set the GPIO to it's default state.
// InitGpio(); // Skipped for this example

// Step 3. Clear all interrupts and initialize PIE vector table:
// Disable CPU interrupts DINT;

// Initialize PIE control registers to their default state.
// The default state is all PIE interrupts disabled and flags
// are cleared.// This function is found in the DSP2833x_PieCtrl.c file.
InitPieCtrl();

// Disable CPU interrupts and clear all CPU interrupt flags:
IER = 0x0000;
IFR = 0x0000;

// Initialize the PIE vector table with pointers to the shell Interrupt// Service Routines (ISR).// This will populate the entire table, even if the interrupt
// is not used in this example. This is useful for debug purposes.
// The shell ISR routines are found in DSP2833x_DefaultIsr.c.
// This function is found in DSP2833x_PieVect.c.
//InitPieVectTable();

// Connect the watchdog to the WAKEINT interrupt of the PIE
// Write to the whole SCSR register to avoid clearing WDOVERRIDE bit
EALLOW;
// SysCtrlRegs.SCSR = 0;
EDIS;

// Interrupts that are used in this example are re-mapped to
// ISR functions found within this file. EALLOW; // This is needed to write to EALLOW protected registers
PieVectTable.WAKEINT = &wakeint_isr;
EDIS; // This is needed to disable write to EALLOW protected registers
// Step 4. Initialize all the Device Peripherals:
// This function is found in DSP2833x_InitPeripherals.c
// InitPeripherals(); // Not required for this example
// Step 5. User specific code, enable interrupts:

// Clear the counters
WakeCount = 0; // Count interrupts
LoopCount = 0; // Count times through idle loop

// Enable WAKEINT in the PIE: Group 1 interrupt 8
// Enable INT1 which is connected to WAKEINT:
PieCtrlRegs.PIECTRL.bit.ENPIE = 1; // Enable the PIE block
PieCtrlRegs.PIEIER1.bit.INTx8 = 1; // Enable PIE Gropu 1 INT8
IER |= M_INT1; // Enable CPU int1
EINT; // Enable Global Interrupts

// Reset the watchdog counter
ServiceDog();

EALLOW;
SysCtrlRegs.SCSR = 0;
EDIS;

// Enable the watchdog
EALLOW;
SysCtrlRegs.WDCR = 0x002F;
EDIS;

看门狗初始化代码如上所述,当SysCtrlRegs.SCSR = 2时,能正常进入看门狗中断,而当SysCtrlRegs.SCSR = 0时为何不能实现28335的看门狗复位

mangui zhang:

查看寄存器手册。此位就是用来选择看门狗中断和复位的

// Step 1. Initialize System Control:
// PLL, WatchDog, enable Peripheral Clocks
// This example function is found in the DSP2833x_SysCtrl.c file.
InitSysCtrl();
// Step 2. Initalize GPIO:// This example function is found in the DSP2833x_Gpio.c file and
// illustrates how to set the GPIO to it's default state.
// InitGpio(); // Skipped for this example

// Step 3. Clear all interrupts and initialize PIE vector table:
// Disable CPU interrupts DINT;

// Initialize PIE control registers to their default state.
// The default state is all PIE interrupts disabled and flags
// are cleared.// This function is found in the DSP2833x_PieCtrl.c file.
InitPieCtrl();

// Disable CPU interrupts and clear all CPU interrupt flags:
IER = 0x0000;
IFR = 0x0000;

// Initialize the PIE vector table with pointers to the shell Interrupt// Service Routines (ISR).// This will populate the entire table, even if the interrupt
// is not used in this example. This is useful for debug purposes.
// The shell ISR routines are found in DSP2833x_DefaultIsr.c.
// This function is found in DSP2833x_PieVect.c.
//InitPieVectTable();

// Connect the watchdog to the WAKEINT interrupt of the PIE
// Write to the whole SCSR register to avoid clearing WDOVERRIDE bit
EALLOW;
// SysCtrlRegs.SCSR = 0;
EDIS;

// Interrupts that are used in this example are re-mapped to
// ISR functions found within this file. EALLOW; // This is needed to write to EALLOW protected registers
PieVectTable.WAKEINT = &wakeint_isr;
EDIS; // This is needed to disable write to EALLOW protected registers
// Step 4. Initialize all the Device Peripherals:
// This function is found in DSP2833x_InitPeripherals.c
// InitPeripherals(); // Not required for this example
// Step 5. User specific code, enable interrupts:

// Clear the counters
WakeCount = 0; // Count interrupts
LoopCount = 0; // Count times through idle loop

// Enable WAKEINT in the PIE: Group 1 interrupt 8
// Enable INT1 which is connected to WAKEINT:
PieCtrlRegs.PIECTRL.bit.ENPIE = 1; // Enable the PIE block
PieCtrlRegs.PIEIER1.bit.INTx8 = 1; // Enable PIE Gropu 1 INT8
IER |= M_INT1; // Enable CPU int1
EINT; // Enable Global Interrupts

// Reset the watchdog counter
ServiceDog();

EALLOW;
SysCtrlRegs.SCSR = 0;
EDIS;

// Enable the watchdog
EALLOW;
SysCtrlRegs.WDCR = 0x002F;
EDIS;

看门狗初始化代码如上所述,当SysCtrlRegs.SCSR = 2时,能正常进入看门狗中断,而当SysCtrlRegs.SCSR = 0时为何不能实现28335的看门狗复位

QIN ZHOU2:

回复 mangui zhang:

是的,所以我对此位进行了正确的配置,已经配置成复位了,但是芯片仍旧没能复位。

// Step 1. Initialize System Control:
// PLL, WatchDog, enable Peripheral Clocks
// This example function is found in the DSP2833x_SysCtrl.c file.
InitSysCtrl();
// Step 2. Initalize GPIO:// This example function is found in the DSP2833x_Gpio.c file and
// illustrates how to set the GPIO to it's default state.
// InitGpio(); // Skipped for this example

// Step 3. Clear all interrupts and initialize PIE vector table:
// Disable CPU interrupts DINT;

// Initialize PIE control registers to their default state.
// The default state is all PIE interrupts disabled and flags
// are cleared.// This function is found in the DSP2833x_PieCtrl.c file.
InitPieCtrl();

// Disable CPU interrupts and clear all CPU interrupt flags:
IER = 0x0000;
IFR = 0x0000;

// Initialize the PIE vector table with pointers to the shell Interrupt// Service Routines (ISR).// This will populate the entire table, even if the interrupt
// is not used in this example. This is useful for debug purposes.
// The shell ISR routines are found in DSP2833x_DefaultIsr.c.
// This function is found in DSP2833x_PieVect.c.
//InitPieVectTable();

// Connect the watchdog to the WAKEINT interrupt of the PIE
// Write to the whole SCSR register to avoid clearing WDOVERRIDE bit
EALLOW;
// SysCtrlRegs.SCSR = 0;
EDIS;

// Interrupts that are used in this example are re-mapped to
// ISR functions found within this file. EALLOW; // This is needed to write to EALLOW protected registers
PieVectTable.WAKEINT = &wakeint_isr;
EDIS; // This is needed to disable write to EALLOW protected registers
// Step 4. Initialize all the Device Peripherals:
// This function is found in DSP2833x_InitPeripherals.c
// InitPeripherals(); // Not required for this example
// Step 5. User specific code, enable interrupts:

// Clear the counters
WakeCount = 0; // Count interrupts
LoopCount = 0; // Count times through idle loop

// Enable WAKEINT in the PIE: Group 1 interrupt 8
// Enable INT1 which is connected to WAKEINT:
PieCtrlRegs.PIECTRL.bit.ENPIE = 1; // Enable the PIE block
PieCtrlRegs.PIEIER1.bit.INTx8 = 1; // Enable PIE Gropu 1 INT8
IER |= M_INT1; // Enable CPU int1
EINT; // Enable Global Interrupts

// Reset the watchdog counter
ServiceDog();

EALLOW;
SysCtrlRegs.SCSR = 0;
EDIS;

// Enable the watchdog
EALLOW;
SysCtrlRegs.WDCR = 0x002F;
EDIS;

看门狗初始化代码如上所述,当SysCtrlRegs.SCSR = 2时,能正常进入看门狗中断,而当SysCtrlRegs.SCSR = 0时为何不能实现28335的看门狗复位

Seven Han:

请问您是怎么判断芯片没有复位的呢?

可以在main之后加断点,判断复位之后代码停在是否断点处。

// Step 1. Initialize System Control:
// PLL, WatchDog, enable Peripheral Clocks
// This example function is found in the DSP2833x_SysCtrl.c file.
InitSysCtrl();
// Step 2. Initalize GPIO:// This example function is found in the DSP2833x_Gpio.c file and
// illustrates how to set the GPIO to it's default state.
// InitGpio(); // Skipped for this example

// Step 3. Clear all interrupts and initialize PIE vector table:
// Disable CPU interrupts DINT;

// Initialize PIE control registers to their default state.
// The default state is all PIE interrupts disabled and flags
// are cleared.// This function is found in the DSP2833x_PieCtrl.c file.
InitPieCtrl();

// Disable CPU interrupts and clear all CPU interrupt flags:
IER = 0x0000;
IFR = 0x0000;

// Initialize the PIE vector table with pointers to the shell Interrupt// Service Routines (ISR).// This will populate the entire table, even if the interrupt
// is not used in this example. This is useful for debug purposes.
// The shell ISR routines are found in DSP2833x_DefaultIsr.c.
// This function is found in DSP2833x_PieVect.c.
//InitPieVectTable();

// Connect the watchdog to the WAKEINT interrupt of the PIE
// Write to the whole SCSR register to avoid clearing WDOVERRIDE bit
EALLOW;
// SysCtrlRegs.SCSR = 0;
EDIS;

// Interrupts that are used in this example are re-mapped to
// ISR functions found within this file. EALLOW; // This is needed to write to EALLOW protected registers
PieVectTable.WAKEINT = &wakeint_isr;
EDIS; // This is needed to disable write to EALLOW protected registers
// Step 4. Initialize all the Device Peripherals:
// This function is found in DSP2833x_InitPeripherals.c
// InitPeripherals(); // Not required for this example
// Step 5. User specific code, enable interrupts:

// Clear the counters
WakeCount = 0; // Count interrupts
LoopCount = 0; // Count times through idle loop

// Enable WAKEINT in the PIE: Group 1 interrupt 8
// Enable INT1 which is connected to WAKEINT:
PieCtrlRegs.PIECTRL.bit.ENPIE = 1; // Enable the PIE block
PieCtrlRegs.PIEIER1.bit.INTx8 = 1; // Enable PIE Gropu 1 INT8
IER |= M_INT1; // Enable CPU int1
EINT; // Enable Global Interrupts

// Reset the watchdog counter
ServiceDog();

EALLOW;
SysCtrlRegs.SCSR = 0;
EDIS;

// Enable the watchdog
EALLOW;
SysCtrlRegs.WDCR = 0x002F;
EDIS;

看门狗初始化代码如上所述,当SysCtrlRegs.SCSR = 2时,能正常进入看门狗中断,而当SysCtrlRegs.SCSR = 0时为何不能实现28335的看门狗复位

QIN ZHOU2:

回复 Seven Han:

我在初始化会让2盏指示灯闪亮几下的,看门狗设置完以后并没有再看到这两盏灯闪过或是亮过了,主循环的灯和看门狗中断的灯也都不亮了,且等我把程序停下来的时候,发现程序运行到了0X3FF0B0这类地址的地方。

// Step 1. Initialize System Control:
// PLL, WatchDog, enable Peripheral Clocks
// This example function is found in the DSP2833x_SysCtrl.c file.
InitSysCtrl();
// Step 2. Initalize GPIO:// This example function is found in the DSP2833x_Gpio.c file and
// illustrates how to set the GPIO to it's default state.
// InitGpio(); // Skipped for this example

// Step 3. Clear all interrupts and initialize PIE vector table:
// Disable CPU interrupts DINT;

// Initialize PIE control registers to their default state.
// The default state is all PIE interrupts disabled and flags
// are cleared.// This function is found in the DSP2833x_PieCtrl.c file.
InitPieCtrl();

// Disable CPU interrupts and clear all CPU interrupt flags:
IER = 0x0000;
IFR = 0x0000;

// Initialize the PIE vector table with pointers to the shell Interrupt// Service Routines (ISR).// This will populate the entire table, even if the interrupt
// is not used in this example. This is useful for debug purposes.
// The shell ISR routines are found in DSP2833x_DefaultIsr.c.
// This function is found in DSP2833x_PieVect.c.
//InitPieVectTable();

// Connect the watchdog to the WAKEINT interrupt of the PIE
// Write to the whole SCSR register to avoid clearing WDOVERRIDE bit
EALLOW;
// SysCtrlRegs.SCSR = 0;
EDIS;

// Interrupts that are used in this example are re-mapped to
// ISR functions found within this file. EALLOW; // This is needed to write to EALLOW protected registers
PieVectTable.WAKEINT = &wakeint_isr;
EDIS; // This is needed to disable write to EALLOW protected registers
// Step 4. Initialize all the Device Peripherals:
// This function is found in DSP2833x_InitPeripherals.c
// InitPeripherals(); // Not required for this example
// Step 5. User specific code, enable interrupts:

// Clear the counters
WakeCount = 0; // Count interrupts
LoopCount = 0; // Count times through idle loop

// Enable WAKEINT in the PIE: Group 1 interrupt 8
// Enable INT1 which is connected to WAKEINT:
PieCtrlRegs.PIECTRL.bit.ENPIE = 1; // Enable the PIE block
PieCtrlRegs.PIEIER1.bit.INTx8 = 1; // Enable PIE Gropu 1 INT8
IER |= M_INT1; // Enable CPU int1
EINT; // Enable Global Interrupts

// Reset the watchdog counter
ServiceDog();

EALLOW;
SysCtrlRegs.SCSR = 0;
EDIS;

// Enable the watchdog
EALLOW;
SysCtrlRegs.WDCR = 0x002F;
EDIS;

看门狗初始化代码如上所述,当SysCtrlRegs.SCSR = 2时,能正常进入看门狗中断,而当SysCtrlRegs.SCSR = 0时为何不能实现28335的看门狗复位

QIN ZHOU2:

回复 Seven Han:

我用自己做的板子和网上买的一款开发板都试了,现象是一样的,CMD文件是用的RAM的,看门狗的中断是没问题的,但是设置成复位以后就复位不了哦

// Step 1. Initialize System Control:
// PLL, WatchDog, enable Peripheral Clocks
// This example function is found in the DSP2833x_SysCtrl.c file.
InitSysCtrl();
// Step 2. Initalize GPIO:// This example function is found in the DSP2833x_Gpio.c file and
// illustrates how to set the GPIO to it's default state.
// InitGpio(); // Skipped for this example

// Step 3. Clear all interrupts and initialize PIE vector table:
// Disable CPU interrupts DINT;

// Initialize PIE control registers to their default state.
// The default state is all PIE interrupts disabled and flags
// are cleared.// This function is found in the DSP2833x_PieCtrl.c file.
InitPieCtrl();

// Disable CPU interrupts and clear all CPU interrupt flags:
IER = 0x0000;
IFR = 0x0000;

// Initialize the PIE vector table with pointers to the shell Interrupt// Service Routines (ISR).// This will populate the entire table, even if the interrupt
// is not used in this example. This is useful for debug purposes.
// The shell ISR routines are found in DSP2833x_DefaultIsr.c.
// This function is found in DSP2833x_PieVect.c.
//InitPieVectTable();

// Connect the watchdog to the WAKEINT interrupt of the PIE
// Write to the whole SCSR register to avoid clearing WDOVERRIDE bit
EALLOW;
// SysCtrlRegs.SCSR = 0;
EDIS;

// Interrupts that are used in this example are re-mapped to
// ISR functions found within this file. EALLOW; // This is needed to write to EALLOW protected registers
PieVectTable.WAKEINT = &wakeint_isr;
EDIS; // This is needed to disable write to EALLOW protected registers
// Step 4. Initialize all the Device Peripherals:
// This function is found in DSP2833x_InitPeripherals.c
// InitPeripherals(); // Not required for this example
// Step 5. User specific code, enable interrupts:

// Clear the counters
WakeCount = 0; // Count interrupts
LoopCount = 0; // Count times through idle loop

// Enable WAKEINT in the PIE: Group 1 interrupt 8
// Enable INT1 which is connected to WAKEINT:
PieCtrlRegs.PIECTRL.bit.ENPIE = 1; // Enable the PIE block
PieCtrlRegs.PIEIER1.bit.INTx8 = 1; // Enable PIE Gropu 1 INT8
IER |= M_INT1; // Enable CPU int1
EINT; // Enable Global Interrupts

// Reset the watchdog counter
ServiceDog();

EALLOW;
SysCtrlRegs.SCSR = 0;
EDIS;

// Enable the watchdog
EALLOW;
SysCtrlRegs.WDCR = 0x002F;
EDIS;

看门狗初始化代码如上所述,当SysCtrlRegs.SCSR = 2时,能正常进入看门狗中断,而当SysCtrlRegs.SCSR = 0时为何不能实现28335的看门狗复位

QIN ZHOU2:

回复 Seven Han:

我的CMD用RAM,但是BOOT引脚配置的却是1111(JUMP TO FLASH),所以才出现这个问题,我把BOOT引脚配置成0100(JUMP TO RAM)后看门狗便能正常复位了,非常感谢您的解答。

赞(0)
未经允许不得转载:TI中文支持网 » 28335看门狗能中断不能复位
分享到: 更多 (0)