Wednesday, May 31, 2006

current reference lookup for encoder

made a file that converts the reference for hall effects to a reference for the encoder

I had difficulty when I tried to run that as there was apparently not enough room in DRAMH0

I increased the size of DRAMH0 in the cmd file in ccs and then rebuilt the project. This time the project built but the motor did not work.

I then tried with an internal memory map for the cmd file in the ezdsp setup in the model.

This time it I get the same error

[Linking...] "C:\ti\c2000\cgtools\bin\cl2000" -@"Custom_MW.lkf"
>> error: can't allocate .ebss (sz: 00003174 page: 1) in DRAMH0 (avail:
00002000)
>> error: errors in input - afm_060530a.out not built

Build Complete,
2 Errors, 0 Warnings, 0 Remarks.


here is the cmd file that i am using

/* This linker command file is generated by the Target for TI C2000(tm). */



MEMORY
{
PAGE 0 :
PRAMH0 : origin = 0x3F8000, length = 0x002000
RESET : origin = 0x3FFFC0, length = 0x000002
BOOTROM : origin = 0x3FF000, length = 0x000fc0
PAGE 1 :
RAMM0 : origin = 0x000000, length = 0x000400
RAMM1 : origin = 0x000400, length = 0x000400
DRAMH0 : origin = 0x008000, length = 0x002000
DEV_EMU : origin = 0x000880, length = 0x000180
PIE_VECT : origin = 0x000D00, length = 0x000100
FLASH_REGS : origin = 0x000A80, length = 0x000060
CSM : origin = 0x000AE0, length = 0x000010
XINTF : origin = 0x000B20, length = 0x000020
CPU_TIMER0 : origin = 0x000C00, length = 0x000008
PIE_CTRL : origin = 0x000CE0, length = 0x000020
ECANA : origin = 0x006000, length = 0x000040
ECANA_LAM : origin = 0x006040, length = 0x000040
ECANA_MOTS : origin = 0x006080, length = 0x000040
ECANA_MOTO : origin = 0x0060C0, length = 0x000040
ECANA_MBOX : origin = 0x006100, length = 0x000100
SYSTEM : origin = 0x007010, length = 0x000020
SPIA : origin = 0x007040, length = 0x000010
SCIA : origin = 0x007050, length = 0x000010
XINTRUPT : origin = 0x007070, length = 0x000010
GPIOMUX : origin = 0x0070C0, length = 0x000020
GPIODAT : origin = 0x0070E0, length = 0x000020
ADC : origin = 0x007100, length = 0x000020
EVA : origin = 0x007400, length = 0x000040
EVB : origin = 0x007500, length = 0x000040
SCIB : origin = 0x007750, length = 0x000010
MCBSPA : origin = 0x007800, length = 0x000040
CSM_PWL : origin = 0x3F7FF8, length = 0x000008
}



SECTIONS
{
codestart : > PRAMH0, PAGE = 0
.text : > PRAMH0, PAGE = 0
.cinit : > PRAMH0, PAGE = 0
ramfuncs : > PRAMH0, PAGE = 0, TYPE = DSECT
.reset : > RESET, PAGE = 0, TYPE = DSECT
IQmath : > PRAMH0 PAGE = 0
IQmathTables : > BOOTROM PAGE = 0, TYPE = NOLOAD
.stack : > RAMM1, PAGE = 1
.bss : > DRAMH0, PAGE = 1
.ebss : > DRAMH0, PAGE = 1
.const : > DRAMH0, PAGE = 1
.econst : > DRAMH0, PAGE = 1
.sysmem : > DRAMH0, PAGE = 1
PieVectTableFile : > PIE_VECT, PAGE = 1
/*** Peripheral Frame 0 Register Structures ***/
DevEmuRegsFile : > DEV_EMU, PAGE = 1
FlashRegsFile : > FLASH_REGS, PAGE = 1
CsmRegsFile : > CSM, PAGE = 1
XintfRegsFile : > XINTF, PAGE = 1
CpuTimer0RegsFile : > CPU_TIMER0, PAGE = 1
PieCtrlRegsFile : > PIE_CTRL, PAGE = 1
/*** Peripheral Frame 1 Register Structures ***/
SysCtrlRegsFile : > SYSTEM, PAGE = 1
SpiaRegsFile : > SPIA, PAGE = 1
SciaRegsFile : > SCIA, PAGE = 1
XIntruptRegsFile : > XINTRUPT, PAGE = 1
GpioMuxRegsFile : > GPIOMUX, PAGE = 1
GpioDataRegsFile : > GPIODAT PAGE = 1
AdcRegsFile : > ADC, PAGE = 1
EvaRegsFile : > EVA, PAGE = 1
EvbRegsFile : > EVB, PAGE = 1
ScibRegsFile : > SCIB, PAGE = 1
McbspaRegsFile : > MCBSPA, PAGE = 1
/*** Peripheral Frame 2 Register Structures ***/
ECanaRegsFile : > ECANA, PAGE = 1
ECanaLAMRegsFile : > ECANA_LAM PAGE = 1
ECanaMboxesFile : > ECANA_MBOX PAGE = 1
ECanaMOTSRegsFile : > ECANA_MOTS PAGE = 1
ECanaMOTORegsFile : > ECANA_MOTO PAGE = 1
/*** Code Security Module Register Structures ***/
CsmPwlFile : > CSM_PWL, PAGE = 1
}



/* [EOF] afm_060530a.cmd */


which now that i look at it is the same memory mapping as the custom one that I was using.


Try the modified one that is based on jess' (afm_060530.cmd)

same error


[Linking...] "C:\ti\c2000\cgtools\bin\cl2000" -@"Custom_MW.lkf"
>> error: can't allocate .ebss (sz: 00003174 page: 1) in DRAMH0 (avail:
00001000)
>> error: errors in input - afm_060530a.out not built

Build Complete,
2 Errors, 0 Warnings, 0 Remarks.


this is what that cmd memory map looks like


/* This linker command file is generated by the Target for TI C2000(tm). */
/* modified by Greg Heins on 11/12/05 to fix problems with "from memory" block */
/* modified by Greg Heins on 26/05/06 to fix problems with rtdx */

/* MODULE RTDX (taken from the RTDX demo) */
_RTDX_interrupt_mask = ~0x0000;

/* reduce the priority of the interrupt mask - see blog for explanation*/
/*_RTDX_interrupt_mask = ~0x0008;*/


MEMORY
{
PAGE 0: /* Program Memory */
ZONE6 : origin = 0x100000, length = 0x008000
OTP : origin = 0x3D7800, length = 0x000800
BEGIN : origin = 0x3F7FF6, length = 0x000002
/* PRAMH0 has been modifed to match Jess' program */
PRAMH0 : origin = 0x3F8002, length = 0x000FFE
ROM : origin = 0x3FF000, length = 0x000FC0
RESET : origin = 0x3FFFC0, length = 0x000002
VECTORS : origin = 0x3FFFC2, length = 0x00003E
PAGE 1 : /* Data Memory */
RAMM0 : origin = 0x000000, length = 0x000400
RAMM1 : origin = 0x000400, length = 0x000400
DEV_EMU : origin = 0x000880, length = 0x000180
PIE_VECT : origin = 0x000D00, length = 0x000100
FLASH_REGS : origin = 0x000A80, length = 0x000060
CSM : origin = 0x000AE0, length = 0x000010
XINTF : origin = 0x000B20, length = 0x000020
CPU_TIMER0 : origin = 0x000C00, length = 0x000008
PIE_CTRL : origin = 0x000CE0, length = 0x000020
ECANA : origin = 0x006000, length = 0x000040
ECANA_LAM : origin = 0x006040, length = 0x000040
ECANA_MOTS : origin = 0x006080, length = 0x000040
ECANA_MOTO : origin = 0x0060C0, length = 0x000040
ECANA_MBOX : origin = 0x006100, length = 0x000100
SYSTEM : origin = 0x007010, length = 0x000020
SPIA : origin = 0x007040, length = 0x000010
SCIA : origin = 0x007050, length = 0x000010
XINTRUPT : origin = 0x007070, length = 0x000010
GPIOMUX : origin = 0x0070C0, length = 0x000020
GPIODAT : origin = 0x0070E0, length = 0x000020
ADC : origin = 0x007100, length = 0x000020
EVA : origin = 0x007400, length = 0x000040
EVB : origin = 0x007500, length = 0x000040
SCIB : origin = 0x007750, length = 0x000010
MCBSPA : origin = 0x007800, length = 0x000040
RAML0 : origin = 0x008000, length = 0x001000
RAML1 : origin = 0x009000, length = 0x001000
ZONE6 : origin = 0x108000, length = 0x008000
CSM_PWL : origin = 0x3F7FF8, length = 0x000008
/* DRAMH0 has been modifed to match Jess' program */
DRAMH0 : origin = 0x3F9000, length = 0x001000
}

/* all referneces to Zone6 have been changed to PRAM and DRAM */

SECTIONS
{
codestart : > BEGIN PAGE = 0
.text : > PRAMH0 PAGE = 0
.cinit : > PRAMH0 PAGE = 0
.pinit : > PRAMH0, PAGE = 0
.reset : > RESET, PAGE = 0, TYPE = DSECT
IQmath : > PRAMH0 PAGE = 0
IQmathTables : > ROM PAGE = 0, TYPE = NOLOAD
.stack : > RAML1 PAGE = 1
.ebss : > DRAMH0 PAGE = 1
.econst : > DRAMH0 PAGE = 1
.esysmem : > DRAMH0 PAGE = 1
PieVectTableFile : > PIE_VECT, PAGE = 1
/*** Peripheral Frame 0 Register Structures ***/
DevEmuRegsFile : > DEV_EMU, PAGE = 1
FlashRegsFile : > FLASH_REGS, PAGE = 1
CsmRegsFile : > CSM, PAGE = 1
XintfRegsFile : > XINTF, PAGE = 1
CpuTimer0RegsFile : > CPU_TIMER0, PAGE = 1
PieCtrlRegsFile : > PIE_CTRL, PAGE = 1
/*** Peripheral Frame 1 Register Structures ***/
SysCtrlRegsFile : > SYSTEM, PAGE = 1
SpiaRegsFile : > SPIA, PAGE = 1
SciaRegsFile : > SCIA, PAGE = 1
XIntruptRegsFile : > XINTRUPT, PAGE = 1
GpioMuxRegsFile : > GPIOMUX, PAGE = 1
GpioDataRegsFile : > GPIODAT PAGE = 1
AdcRegsFile : > ADC, PAGE = 1
EvaRegsFile : > EVA, PAGE = 1
EvbRegsFile : > EVB, PAGE = 1
ScibRegsFile : > SCIB, PAGE = 1
McbspaRegsFile : > MCBSPA, PAGE = 1
/*** Peripheral Frame 2 Register Structures ***/
ECanaRegsFile : > ECANA, PAGE = 1
ECanaLAMRegsFile : > ECANA_LAM PAGE = 1
ECanaMboxesFile : > ECANA_MBOX PAGE = 1
ECanaMOTSRegsFile : > ECANA_MOTS PAGE = 1
ECanaMOTORegsFile : > ECANA_MOTO PAGE = 1
/*** Code Security Module Register Structures ***/
CsmPwlFile : > CSM_PWL, PAGE = 1
}



/* [EOF] from_memory.cmd */


that has an even smaller DRAMHO

0 Comments:

Post a Comment

<< Home