View previous topic :: View next topic |
Author |
Message |
Tom-H-PIC
Joined: 08 Sep 2003 Posts: 105 Location: New Castle, DE
|
Question about constants? |
Posted: Tue Sep 14, 2004 1:44 pm |
|
|
Ok if I understand this correctly and please point out if I do not have it right.
Ok if I declare a constant as in this.
Code: |
const char AT[3][25] = "ATD01110000001",
"ATXX",
"ATXXX";
|
The compiler programs this in to PIC program memory (ROM) space. The compiler also puts in code to copy the constants to RAM on start up.
Ok if all that is true I don’t see the code in the list file to copy the constants to RAM.
How do I fine the address in RAM in the list file? I would like to review the data to see if it is correct in the ICD RAM window. |
|
|
PCM programmer
Joined: 06 Sep 2003 Posts: 21708
|
|
Posted: Tue Sep 14, 2004 2:01 pm |
|
|
Quote: |
The compiler programs this in to PIC program memory (ROM) space.
|
The compiler only puts the data in ROM if you reference it in your
program. The way that you access the data affects how the compiler
stores it in ROM. If you access just one byte of the data, the compiler
will put in code to fetch that byte as immediate data with a MOVLW
instruction. The rest of the data (ie., the strings) won't even appear
in ROM. Example:
c = AT[0][0];
If you use variables as the array indexes, then the compiler will
put the entire strings into ROM. Example:
c = AT[i][k];
Quote: | The compiler also puts in code to copy the constants to RAM on start up. |
This is not true. If you use the array index method of accessing the
strings, then the compiler will put in code at the start of the strings
to fetch them, one byte at a time, using the RETLW instruction.
This code is executed if you use printf() to display the strings (for example).
Also, to see the strings in ROM (if they are put in by the compiler)
you need to View Program Memory in MPLAB, or edit the .H file for
your PIC and temporarily comment out the #nolist statement at the
start of the file. Then you can view the strings in the .LST file. |
|
|
Ttelmah Guest
|
Re: Question about constants? |
Posted: Tue Sep 14, 2004 2:42 pm |
|
|
Tom-H-PIC wrote: | Ok if I understand this correctly and please point out if I do not have it right.
Ok if I declare a constant as in this.
Code: |
const char AT[3][25] = "ATD01110000001",
"ATXX",
"ATXXX";
|
The compiler programs this in to PIC program memory (ROM) space. The compiler also puts in code to copy the constants to RAM on start up.
Ok if all that is true I don’t see the code in the list file to copy the constants to RAM.
How do I fine the address in RAM in the list file? I would like to review the data to see if it is correct in the ICD RAM window. |
Worth saying, that if you do want the values copied to RAM, just remove the 'const' declaration. Without this, the aray will be a RAM array, which will be initialised with the specified values from ROM on boot...
Best Wishes |
|
|
Tom-H-PIC
Joined: 08 Sep 2003 Posts: 105 Location: New Castle, DE
|
Ok compiler not having pointers to constants ISSUES! |
Posted: Tue Sep 14, 2004 3:54 pm |
|
|
I use the constants above on this code.
Code: |
if (strncmp(Rxcom, AT[0], 3) == 0){ //this is a dial command
if (strcmp(Rxcom,AT[0]) == 0){ //this is a Blue Radio command
BR_error = 0; //clear error counter
ok_ctr = 0; //clear OK counter
BR_on = 0; BR_reset = 0; //Turn off Blue Radio
BR_Online = False; //let software that phone is off line
BR_initz = True; //turn on initialization fuction to look for new BT phone
BR_initz_timer = 2; //off timer set for one second
return;} //get out of fuction
}
|
The compiler gives this error
Error[51] :A numeric expression must appear here
Seeing as strncmp uses pointers to the strings this is why I get the error correct?
So how do I make a look up function for looking up a string that is received in the serial port and then act on it? |
|
|
PCM programmer
Joined: 06 Sep 2003 Posts: 21708
|
|
Posted: Tue Sep 14, 2004 4:12 pm |
|
|
Quote: | Seeing as strncmp uses pointers to the strings this is why I get the error correct ? |
You can't use pointers to constant strings in CCS. The strncmp()
function expects the strings to be in RAM. You first have to use the
CCS function strcpy() to copy the constant string to a RAM array,
and then pass the address of the RAM array to strncmp(). |
|
|
|