Other Parts Discussed in Thread: C2000WARE
I am using the internal ADC of tms320f28335, when i am programming in the ram mode every thing is working fine, but when i am adding the flash linker and loading the file ADC is not responding in debug mode and in default its triggering illegal interrupt
interrupt void
ILLEGAL_ISR(void)
{
//
// Insert ISR Code here
//
//
// Next two lines for debug only to halt the processor here
// Remove after inserting ISR Code
//
asm (" ESTOP0");
for(;;);
}
or PLL is getting unlocked and waiting at this line "while(SysCtrlRegs.PLLSTS.bit.PLLLOCKS != 1) "
The code is the example file as below -
#include "DSP28x_Project.h" // Device Headerfile and Examples Include File
//
// Defines for ADC start parameters
//
#if (CPU_FRQ_150MHZ) // Default - 150 MHz SYSCLKOUT
//
// HSPCLK = SYSCLKOUT/2*ADC_MODCLK2 = 150/(2*3) = 25.0 MHz
//
#define ADC_MODCLK 0x3
#endif
#if (CPU_FRQ_100MHZ)
//
// HSPCLK = SYSCLKOUT/2*ADC_MODCLK2 = 100/(2*2) = 25.0 MHz
//
#define ADC_MODCLK 0x2
#endif
//
// ADC module clock = HSPCLK/2*ADC_CKPS = 25.0MHz/(1*2) = 12.5MHz
//
#define ADC_CKPS 0x1
#define ADC_SHCLK 0xf // S/H width in ADC module periods = 16 ADC clocks
#define AVG 1000 // Average sample limit
#define ZOFFSET 0x00 // Average Zero offset
#define BUF_SIZE 2048 // Sample buffer size
//
// Globals
//
Uint16 ADC_0;
Uint16 ADC_1;
//
// Main
//
void main(void)
{
Uint16 i;
//
// Step 1. Initialize System Control:
// PLL, WatchDog, enable Peripheral Clocks
// This example function is found in the DSP2833x_SysCtrl.c file.
//
InitSysCtrl();
//
// Specific clock setting for this example
//
EALLOW;
SysCtrlRegs.HISPCP.all = ADC_MODCLK; // HSPCLK = SYSCLKOUT/ADC_MODCLK
EDIS;
//
// Step 2. Initialize 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 the 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();
//
// Step 4. Initialize all the Device Peripherals:
// This function is found in DSP2833x_InitPeripherals.c
//
// InitPeripherals(); // Not required for this example
InitAdc(); // For this example, init the ADC
//
// Specific ADC setup for this example:
//
AdcRegs.ADCTRL1.bit.ACQ_PS = ADC_SHCLK;
AdcRegs.ADCTRL3.bit.ADCCLKPS = ADC_CKPS;
AdcRegs.ADCTRL3.bit.SMODE_SEL = 0x1;// Setup simultaneous sampling mode
AdcRegs.ADCTRL1.bit.SEQ_CASC = 0x1; // Setup cascaded sequencer mode
AdcRegs.ADCMAXCONV.all = 0x0001; // 8 double conv's (16 total)
// AdcRegs.ADCTRL1.bit.SEQ_CASC = 1; // 1 Cascaded mode
AdcRegs.ADCTRL1.bit.CONT_RUN = 1; // Setup continuous run
//
// Step 5. User specific code, enable interrupts:
//
//
// Start SEQ1
//
AdcRegs.ADCTRL2.all = 0x2000;
//
// Take ADC data and log the in SampleTable array
//
for(;;)
{
//
// Wait for interrupt
//
AdcRegs.ADCCHSELSEQ1.bit.CONV00 = 0x0;
while (AdcRegs.ADCST.bit.INT_SEQ1== 0)
{
}
AdcRegs.ADCST.bit.INT_SEQ1_CLR = 1;
ADC_0 =((AdcRegs.ADCRESULT0>>4));
AdcRegs.ADCCHSELSEQ1.bit.CONV01 = 0x1;
while (AdcRegs.ADCST.bit.INT_SEQ1== 0)
{
}
AdcRegs.ADCST.bit.INT_SEQ1_CLR = 1;
ADC_1 =((AdcRegs.ADCRESULT2>>4));
}
}