This thread has been locked.

If you have a related question, please click the "Ask a related question" button in the top right corner. The newly created question will be automatically linked to this question.

TMS320F28335: Internal ADC not working when programmed in flash mode

Part Number: TMS320F28335
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));

}
}

  • I would recommend looking at the flash based example in C2000Ware here: C:\ti\c2000\C2000Ware_4_00_00_00\device_support\f2833x\examples\flash_f28335 and make sure that you have followed that file's example of what changes need to be made to take a RAM based example to Flash based example.

    Illegal ISR is typically caused by executing op code 0x0000 or 0xFFFF; if the flash is not programmed correctly(still erased would be 0xFFFF) then this will occur.  I would recommend single stepping the code after loading to see if this is what is happening.

    Best,

    Matthew