CCS C Software and Maintenance Offers
FAQFAQ   FAQForum Help   FAQOfficial CCS Support   SearchSearch  RegisterRegister 

ProfileProfile   Log in to check your private messagesLog in to check your private messages   Log inLog in 

CCS does not monitor this forum on a regular basis.

Please do not post bug reports on this forum. Send them to CCS Technical Support

SOLVED: PIC24 and getting the Configuration Bits address?
Goto page 1, 2  Next
 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
allenhuffman



Joined: 17 Jun 2019
Posts: 589
Location: Des Moines, Iowa, USA

View user's profile Send private message Visit poster's website

SOLVED: PIC24 and getting the Configuration Bits address?
PostPosted: Fri Dec 13, 2024 9:32 pm     Reply with quote

We use three different PIC24 chips on various boards. Our firmware has #defines for where the Configuration Bits/Fuses are located, like this:

Code:
#define START_ADDRESS_CONFIG        0xABFC  // The start address of the configuration words


Is there a way to obtain this in code, or is it just "look it up in the data sheet and hard code it"?

And here is why I ask... I am finally implementing a bootloader I wrote a few years ago. The bootloader contains the IVT, the bootloader code, and the #FUSES.

The application will have #FUSES none.

One of the options is to create a master .hex file that the factory can use to burn a fresh board -- this would have the bootloader and the application combined.

Using info from CCS support and others in this forum a few years ago, I use #import to pull in the bootloader to the application hex file:

Code:
#warning/information Including Bootloader in Application HEX file.
// Import the vector table and bootloader code.
#import(FILE=BOOTLOADER_HEX, HEX)


This produces the desired .hex, but it will give a warning about memory being used. Tonight I went searching and saw posts here where they said it was due to the bootloader.hex containing the FUSES, and import generates that warning. A suggestion was given to use two #imports, so I tested this tonight:

Code:
#warning/information Including Bootloader in Application HEX file.
// Import the vector table and bootloader code.
#import(FILE=BOOTLOADER_HEX, HEX, RANGE=0:BOOTLOADER_APP_ADDRESS-1)
// Import the configuration bits (fuses).
#import(FILE=BOOTLOADER_HEX, HEX, RANGE=START_ADDRESS_CONFIG:0xFFFFFF)


And no more warning.

However, while I had a #define for the start of the config bytes, I have not yet looked up our various PIC24s to see what the range should be.

Also, I was looking to see if there was a getenv("XXX") or something that would let me obtain the memory address instead of "just having to know" and hard code it in a #define.

Is there some way to get this value?
_________________
Allen C. Huffman, Sub-Etha Software (est. 1990) http://www.subethasoftware.com
Embedded C, Arduino, MSP430, ESP8266/32, BASIC Stamp and PIC24 programmer.
http://www.whywouldyouwanttodothat.com ?

Using: 24FJ256GA106, 24EP256GP202 and 24FJ64GA002.


Last edited by allenhuffman on Mon Dec 16, 2024 10:23 am; edited 1 time in total
jeremiah



Joined: 20 Jul 2010
Posts: 1358

View user's profile Send private message

PostPosted: Fri Dec 13, 2024 11:51 pm     Reply with quote

I think one of the
Code:
getenv()
parameters does, maybe PROGRAM_MEMORY. Should be easy to test
Ttelmah



Joined: 11 Mar 2010
Posts: 19589

View user's profile Send private message

PostPosted: Sat Dec 14, 2024 3:53 am     Reply with quote

The address you are using is the flash config words address, which is
always at the top of the last page in the program memory. The
PROGRAM_MEMORY value should give this, since it is the address immediately
above the maximum value the program can use. However a quick check
shows this is giving the address of the top of this area, so will need to
have the size of the config area subtracted. If your chips are all similar this
will be the same on them all.
It would be quite nice to have this available, so I'd ask CCS for this. They
may say it is already available.
jeremiah



Joined: 20 Jul 2010
Posts: 1358

View user's profile Send private message

PostPosted: Mon Dec 16, 2024 8:43 am     Reply with quote

Ttelmah wrote:
The address you are using is the flash config words address, which is
always at the top of the last page in the program memory. The
PROGRAM_MEMORY value should give this, since it is the address immediately
above the maximum value the program can use. However a quick check
shows this is giving the address of the top of this area, so will need to
have the size of the config area subtracted. If your chips are all similar this
will be the same on them all.
It would be quite nice to have this available, so I'd ask CCS for this. They
may say it is already available.


That's certainly strange. I just tested it on my PIC241024GB610 with v5.113 and it returns 0xABF00, which when I look at my hex is the start of the configuration words?

So for me "PROGRAM_MEMORY" gives the start of the configuration words (no subtraction needed in my case). Perhaps it is chip family specific. Which chip did you test out
Ttelmah



Joined: 11 Mar 2010
Posts: 19589

View user's profile Send private message

PostPosted: Mon Dec 16, 2024 9:59 am     Reply with quote

That is what I'd have expected/hoped. I tried it on a chip I'm using, and
got the figure for the top of memory. Suggests I may get a problem on
this chip if it gets close to using all the memory!!!!!.
I'll report this to CCS as a fault on this device.
Good news.
allenhuffman



Joined: 17 Jun 2019
Posts: 589
Location: Des Moines, Iowa, USA

View user's profile Send private message Visit poster's website

PostPosted: Mon Dec 16, 2024 10:23 am     Reply with quote

CCS replies:

Quote:
You can use getenv("CONFIGURATION_ADDRESS")

_________________
Allen C. Huffman, Sub-Etha Software (est. 1990) http://www.subethasoftware.com
Embedded C, Arduino, MSP430, ESP8266/32, BASIC Stamp and PIC24 programmer.
http://www.whywouldyouwanttodothat.com ?

Using: 24FJ256GA106, 24EP256GP202 and 24FJ64GA002.
allenhuffman



Joined: 17 Jun 2019
Posts: 589
Location: Des Moines, Iowa, USA

View user's profile Send private message Visit poster's website

PostPosted: Mon Dec 16, 2024 10:31 am     Reply with quote

Some testing shows maybe this is not solved:

Code:

#define START_ADDRESS_CONFIG    0x02AFF0    // The start address of the configuration words
#define START_ADDRESS_CONFIG2   getenv("CONFIGURATION_ADDRESS")


The hard-coded value matches what is shown in the .hex file:

Code:

Configuration Words
   02AFF0: 00FFFF4D 00FFFFEF 00FFFF7F 00FFFF39
   02AFF8: 00FFFFF8 00FFFFFF 00FFFFFF 00FFFFFF


But running this program shows:

Code:

START_ADDRESS_CONFIG       : 0x2aff0 (176112)
START_ADDRESS_CONFIG_GETENV: 0x55fd8 (352216)


The internal PIC address (2 bytes per address) should be double, I thought, meaning 0x55FE0 (352224) so the getenv() is returning 8 bytes later. Is this the end of the config bytes or something?
_________________
Allen C. Huffman, Sub-Etha Software (est. 1990) http://www.subethasoftware.com
Embedded C, Arduino, MSP430, ESP8266/32, BASIC Stamp and PIC24 programmer.
http://www.whywouldyouwanttodothat.com ?

Using: 24FJ256GA106, 24EP256GP202 and 24FJ64GA002.
allenhuffman



Joined: 17 Jun 2019
Posts: 589
Location: Des Moines, Iowa, USA

View user's profile Send private message Visit poster's website

PostPosted: Mon Dec 16, 2024 10:40 am     Reply with quote

If I add 8 to the returned value, I can get a match:

Code:

Configuration Words
   02AFF0: 00FFFF4D 00FFFFEF 00FFFF7F 00FFFF39
   02AFF8: 00FFFFF8 00FFFFFF 00FFFFFF 00FFFFFF

#define START_ADDRESS_CONFIG    0x02AFF0    // The start address of the configuration words
#define START_ADDRESS_CONFIG2   ((getenv("CONFIGURATION_ADDRESS")+8) / 2)

START_ADDRESS_CONFIG       : 0xabfc (44028)
START_ADDRESS_CONFIG_GETENV: 0xabfc (44028)


But I need to check on our two other PIC24 types just in case there is an error in the CCS reporting for this chip.
_________________
Allen C. Huffman, Sub-Etha Software (est. 1990) http://www.subethasoftware.com
Embedded C, Arduino, MSP430, ESP8266/32, BASIC Stamp and PIC24 programmer.
http://www.whywouldyouwanttodothat.com ?

Using: 24FJ256GA106, 24EP256GP202 and 24FJ64GA002.


Last edited by allenhuffman on Mon Dec 16, 2024 10:49 am; edited 3 times in total
allenhuffman



Joined: 17 Jun 2019
Posts: 589
Location: Des Moines, Iowa, USA

View user's profile Send private message Visit poster's website

PostPosted: Mon Dec 16, 2024 10:43 am     Reply with quote

Ah, on one of our othjer boards using 24FJ64GA002, the getenv() matches what is in the hex:


Code:

Configuration Words
   00ABFC: 00FFFB15 00FF3F7F

#define START_ADDRESS_CONFIG    0xABFC  // The start address of the configuration words
#define START_ADDRESS_CONFIG2   (getenv("CONFIGURATION_ADDRESS") / 2)

START_ADDRESS_CONFIG       : 0xabfc (44028)
START_ADDRESS_CONFIG_GETENV: 0xabfc (44028)

_________________
Allen C. Huffman, Sub-Etha Software (est. 1990) http://www.subethasoftware.com
Embedded C, Arduino, MSP430, ESP8266/32, BASIC Stamp and PIC24 programmer.
http://www.whywouldyouwanttodothat.com ?

Using: 24FJ256GA106, 24EP256GP202 and 24FJ64GA002.
Ttelmah



Joined: 11 Mar 2010
Posts: 19589

View user's profile Send private message

PostPosted: Mon Dec 16, 2024 10:55 am     Reply with quote

That is really interesting.
Implies that the CCS values have rather more faults than I'd have expected
or hoped for. Sad
temtronic



Joined: 01 Jul 2010
Posts: 9269
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Mon Dec 16, 2024 4:36 pm     Reply with quote

well.. it IS a 'Monday' after all....... Smile
Ttelmah



Joined: 11 Mar 2010
Posts: 19589

View user's profile Send private message

PostPosted: Wed Dec 18, 2024 2:40 am     Reply with quote

8.

Wonder. Remember the user_ID is actually part of the configuration data,
and is normally 8 bytes below the actual fuses.
jeremiah



Joined: 20 Jul 2010
Posts: 1358

View user's profile Send private message

PostPosted: Wed Dec 18, 2024 8:34 am     Reply with quote

allenhuffman wrote:
Ah, on one of our othjer boards using 24FJ64GA002, the getenv() matches what is in the hex:


Code:

Configuration Words
   00ABFC: 00FFFB15 00FF3F7F

#define START_ADDRESS_CONFIG    0xABFC  // The start address of the configuration words
#define START_ADDRESS_CONFIG2   (getenv("CONFIGURATION_ADDRESS") / 2)

START_ADDRESS_CONFIG       : 0xabfc (44028)
START_ADDRESS_CONFIG_GETENV: 0xabfc (44028)


Out of curiosity, did you try PROGRAM_MEMORY and see how it compared to the other options?
jeremiah



Joined: 20 Jul 2010
Posts: 1358

View user's profile Send private message

PostPosted: Wed Dec 18, 2024 8:34 am     Reply with quote

Ttelmah wrote:
That is what I'd have expected/hoped. I tried it on a chip I'm using, and
got the figure for the top of memory. Suggests I may get a problem on
this chip if it gets close to using all the memory!!!!!.
I'll report this to CCS as a fault on this device.
Good news.


which chip was it?
allenhuffman



Joined: 17 Jun 2019
Posts: 589
Location: Des Moines, Iowa, USA

View user's profile Send private message Visit poster's website

PostPosted: Wed Dec 18, 2024 11:30 am     Reply with quote

jeremiah wrote:
Out of curiosity, did you try PROGRAM_MEMORY and see how it compared to the other options?


Not yet, but I will do that today.

I now can build a sample "blink S.O.S. on the LED" application in to my bootloader, and using the two imports I can bring in the bootloader and fuses only, skipping the S.O.S. app and allow me to have my real app there.

When I first wrote this a few years ago, I had to ifdef my stub test app function since it would conflict when trying to import the bootloader.

Learning is fun.
_________________
Allen C. Huffman, Sub-Etha Software (est. 1990) http://www.subethasoftware.com
Embedded C, Arduino, MSP430, ESP8266/32, BASIC Stamp and PIC24 programmer.
http://www.whywouldyouwanttodothat.com ?

Using: 24FJ256GA106, 24EP256GP202 and 24FJ64GA002.
Display posts from previous:   
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion All times are GMT - 6 Hours
Goto page 1, 2  Next
Page 1 of 2

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum


Powered by phpBB © 2001, 2005 phpBB Group