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

Combining 3 .hex files into one.

 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
itullis



Joined: 01 Jun 2016
Posts: 2
Location: UK

View user's profile Send private message

Combining 3 .hex files into one.
PostPosted: Wed Jun 01, 2016 4:51 pm     Reply with quote

I have two independent programs that work on a 18f45k50. I'm using Version 5.059

Program A clock runs quickly to support USB and sets the configuration of my system in EEPROM - about 10 bytes.

Program B clock runs very slowly and spends most of it's time in sleep mode. It depends on the settings provided by program A. Both A & B are about 1/3 the size of available ROM.

There is very little common code between program A & B.

I've written a little demo code - a dispatcher to check the USB Vbus and decide to call A or B. This collection of code produces 3 .hex files.

Is there a simple way to combine these .hex files into one so I can load it on the PIC?

dispatcher
Code:
#include <18F45K50.h>
#device ADC=10

#ORG 0x1E00, 0x1FFF
#ORG 0x2000, 0x2FFF { }
#ORG 0x3000, 0x3FFF { }

#use delay(internal=31.25kHz)

void main(){
   if(input(PIN_A0)){
      goto_address(0x2000);
   }else{
      goto_address(0x3000);
   }
}


Program A
Code:
#include <18F45K50.h>
#device ADC=10
#ORG 0x1E00, 0x1FFF { }
#ORG 0x2000, 0x2FFF
#ORG 0x3000, 0x3FFF { }

unsigned int8 CONFIG[]={ 0x2b, 0xc8, 0x5e, 0x3c, 0x00, 0xd3, 0xa1, 0x00, 0x0f, 0xc0, 0x0f, 0xe0};  //setup fuses (fast clock)

#use delay(internal=24MHz,USB_FULL,ACT=USB)

#define USB_CABLE_IS_ATTACHED()  input(PIN_A0)
#define USB_CONFIG_BUS_POWER 500
#include <usb_cdc.h>

void main(){
   char c;

   write_configuration_memory(CONFIG,7);

   usb_init();

   while(TRUE){
      if(usb_cdc_kbhit()){
         c = usb_cdc_getc();
         usb_cdc_putc(c + 1);
      }     
   }
}


Program B
Code:
#include <18F45K50.h>
#device ADC=10
#ORG 0x1E00, 0x1FFF { }
#ORG 0x2000, 0x2FFF { }
#ORG 0x3000, 0x3FFF

#use delay(internal=31.25kHz)

unsigned int8 CONFIG[]={  <array of fuses for slow clock> };

void main(){

   write_configuration_memory(CONFIG,7);

   while(TRUE) {
      output_high(PIN_A4);     
      delay_ms(500);     
      output_low(PIN_A4);     
      delay_ms(500);
   }
}
stinky



Joined: 05 Mar 2012
Posts: 99
Location: Central Illinois

View user's profile Send private message

PostPosted: Fri Jun 03, 2016 11:45 am     Reply with quote

Not sure you can combine HEX files.
Any reason they couldn't just be one program?
asmboy



Joined: 20 Nov 2007
Posts: 2128
Location: albany ny

View user's profile Send private message AIM Address

PostPosted: Fri Jun 03, 2016 2:32 pm     Reply with quote

you are not going to get help merging hex files here.

But i don't see how that would help you.
Why can't you combine your code in one program..

will it not compile when combined for function?

I'm also troubled by the idea you are pursuing.......

REMEMBER that when you change configuration memory -
the pic will wake with those setting after an unplanned
hot or cold restart or WD reset ...
i don't see your startup verifying that the right config is loaded ...

too much info you have up our sleeve fro me to be happy about reliability.

all in all - what you are doing looks risky as all heck from a logical safe-ops startup standpoint.
Ttelmah



Joined: 11 Mar 2010
Posts: 19546

View user's profile Send private message

PostPosted: Fri Jun 03, 2016 2:44 pm     Reply with quote

Just load them one after the other into MPLAB.

Then export the whole of memory as one file.

This is the easiest way to combine a 'runtime' program into with a bootloader to give a single file, and the same process can be used here.

However you are going to have to add the code to each section to switch the clock speeds. Honestly best to have all use the same clock settings as the fast one, and then switch the clock down for the slow ones. Use a defined macro to give the correct factor for the delay statements (this has been described here).

Seems a complex way to go though. Just write one program and change the clocks.
itullis



Joined: 01 Jun 2016
Posts: 2
Location: UK

View user's profile Send private message

PostPosted: Fri Jun 03, 2016 5:31 pm     Reply with quote

I thought that combining hex files was easy because people would want to combine a generic bootloader with their code into one hex file.

Thanks all for your help.
temtronic



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

View user's profile Send private message

PostPosted: Fri Jun 03, 2016 7:17 pm     Reply with quote

re: ...to combine a generic bootloader with their code into one hex file.

That isn't going to work if I'm reading it right...

You FIRST need to program the PIC WITH a 'bootloader' Then you can tell the 'bootloader' to load and program the PIC with the 'main' program.
The 'bootloader' always resides in 'protected' memory.

You can't, for instance, connect a 'blank ' PIC to a PC and download both bootloader and main program, as the PIC has no method of reading and storing the programs.

Jay
Ttelmah



Joined: 11 Mar 2010
Posts: 19546

View user's profile Send private message

PostPosted: Sat Jun 04, 2016 12:56 am     Reply with quote

itullis wrote:
I thought that combining hex files was easy because people would want to combine a generic bootloader with their code into one hex file.

Thanks all for your help.


In a sense, yes. However, key thing is that both the bootloader, and main program _must_ start using the same clock and fuses. The easiest way to do the combining is to load both into MPLAB, or in some cases the programming software (most have options to not erase on load, so you can load the bootloader, and then load the second program 'over the top'). Then you save the combined code. But for this to work, both programs must have the same clock/fuses. This is why many bootloaders will not change the fuses (since otherwise if you loaded a program that did this, the bootloader would no longer work).

Hence the comment that you really need to re-write the programs to all start using the same fuses. Once you have done this, it is honestly easier just to combine the routines into a single program.
jeremiah



Joined: 20 Jul 2010
Posts: 1355

View user's profile Send private message

PostPosted: Sat Jun 04, 2016 9:12 am     Reply with quote

I think you can also do things like:

Code:

#fuses NONE
#use delay(clock=8MHz)


In your application to avoid changing your fuses. I *think* (this would need to be verified) by avoiding "internal", "external", "crystal", etc. in your #use delay() statement and just stick to "clock" it won't do behind the scenes fuse changes. Again, that should be verified (Easy to do in the application .LST). So far that has worked for me on mine, but I only have a small subset of chips that I use.

If you are using a different clock than the bootloader, you still have to do all the settings yourself in the code though.
Ttelmah



Joined: 11 Mar 2010
Posts: 19546

View user's profile Send private message

PostPosted: Sat Jun 04, 2016 11:33 am     Reply with quote

Yes.

However all three code sections must be written to use the fuses they then 'inherit' from the first one loaded.
jeremiah



Joined: 20 Jul 2010
Posts: 1355

View user's profile Send private message

PostPosted: Sat Jun 04, 2016 12:34 pm     Reply with quote

Yep.

I was thinking that would (or at least should be) the bootloader. Normally we base all our apps off of the bootloader fuses and change things at runtime as needed.
Ttelmah



Joined: 11 Mar 2010
Posts: 19546

View user's profile Send private message

PostPosted: Sat Jun 04, 2016 1:26 pm     Reply with quote

Exactly.

However the point about doing the separate load with the bootloader, is that it is much more difficult to make just one program/file. This does not apply here. It'd be so much easier to just write one program. There is no need for ORG's or jumps here. A single program that selects which part is to be run depending on whatever rule is required, and then switches clock rates etc., as required.

The approach is not a 'sledgehammer nut' solution, instead it is a 'playing chess using oven gloves' solution. Making things miles more complex than needed.
Display posts from previous:   
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion All times are GMT - 6 Hours
Page 1 of 1

 
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