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

DSPIC33FJ PCD Bootloader help and direction

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



Joined: 08 Aug 2007
Posts: 10

View user's profile Send private message

DSPIC33FJ PCD Bootloader help and direction
PostPosted: Fri Dec 01, 2017 6:51 pm     Reply with quote

I have spent enough time fighting with this and realize that I really need some help. Confused

First I am using PCWHD IDE and PCD Version 5.075
Target is a DSPIC dsPIC33FJ128GP306A

Here is the goal.
I would like a standalone bootloader that I can program into the chip. I want it to live in the Boot Segment Access Area of the chip. According to the data sheet I have set the fuses like this in the example bootloader.c.
Eventually I would like to write protect this bootloader but for now I'll be happy if I can get everything in the right place. I am not using the push button and have basically commented out the loader section. For now I am just trying to see an RS32 response from the bootloader and then the main program.
Code:

//The setup for 6 different chips, one from each of these chip families,
//is listed below.
#define DSPIC33FJ
//#define DSPIC30F
//#define PIC24FJ
//#define PIC24FJ_REV2
//#define PIC24HJ
//#define PIC24EP

#if defined(DSPIC33FJ)
   #include <33FJ128GP306A.h>   
   #FUSES NOWDT                              //No Watch Dog Timer
   #FUSES BSSSL                              //Boot Segment Code Protect Standard Security, Large Boot Segment
   #FUSES RBS1024                            //Boot RAM is 1024 bytes
   #use delay(clock=22110000, internal)      // works with baud
   #use rs232(UART2, baud=115200, errors, stream=COM_PORT)   // works at internal=40MHZ and xtal=22118400 and internal=2211000 w/o BRGH1OK)
   #define PUSH_BUTTON PIN_B2
#elif defined(DSPIC30F)
   #include <30F4012.h>
   #fuses NOWDT
   #use delay(crystal=20M)
   #use rs232(BAUD=9600,UART1A,errors)
   #define PUSH_BUTTON PIN_B1
#elif defined(PIC24FJ)
   #include <24FJ128GA006.h>
   #fuses NOWDT
   #use delay(crystal=20MHz)
   #use rs232(BAUD=9600,UART1,errors)
   #define PUSH_BUTTON PIN_F6
#elif defined(PIC24FJ_REV2)
   #include <24FJ256GA106.h>
   #fuses NOWDT
   #use delay(crystal=20MHz)
   #pin_select U1TX = PIN_F3
   #pin_select U1RX = PIN_F2
   #use rs232(BAUD=9600,UART1,errors)
   #define PUSH_BUTTON PIN_F6
#elif defined(PIC24HJ)
   #include <24HJ128GP306.h>
   #fuses NOWDT
   #use delay(crystal=20MHz)
   #use rs232(Baud=9600,UART1,errors)
   #define PUSH_BUTTON PIN_F6
#elif defined(PIC24EP)
   #include <24ep256gp206.h>
   #fuses NOWDT
   #use delay(crystal=20MHz)
   #pin_select U1TX = PIN_A4
   #pin_select U1RX = PIN_A9   
   #use rs232(Baud=9600,UART1,errors)
   #define PUSH_BUTTON PIN_C3
#endif

#define _bootloader
//#define BOOTLOADER_MODE2X

#include <pcd_bootloader.h>
#include <loader_pcd.c>

#org APPLICATION_START
void application(void)
{   
   while(TRUE);
}

void main(void)
{

   printf("\r\nBootLoader Version 1.0\r\n");
   
//!   if(!input(PUSH_BUTTON))
//!   {
//!      delay_ms(140); // wait for PLL
//!     
//!      printf("\r\nBootloader Version 1.0\r\n");
//!
//!      // Let the user know it is ready to accept a download
//!      printf("\r\nWaiting for download...");
//!
//!      // Load the program
//!      load_program();
//!   }
//!
   application();
}

#int_default
void isr(void)
{
   jump_to_isr(LOADER_END+5);
}


I also include the standard the pcd_bootloader.h and flash it to the chip and it works. I can see output from the Serial Port etc... I really can't try to actually bootload until I replace the loader_pcd.c on the hardware I am using the RS232 is not standard protocol, using FTDI D2xx library but still I have working code for that later, for now on with the show.

So now I make a new build file for the payload application as a test.
Code:

#define DSPIC33FJ


#if defined(DSPIC33FJ)
   #include <33FJ128GP306A.h>   
   #Fuses NONE
   #use delay(clock=22110000, internal)      // works with baud
   #use rs232(UART2, baud=115200, errors, stream=COM_PORT)   // works at internal=40MHZ and xtal=22118400 and internal=2211000 w/o BRGH1OK)
   #define PUSH_BUTTON PIN_B2
 
#endif

//#define BOOTLOADER_MODE2X

//This is a necessary include file.  It reserves space so that the
//bootloader is not overwritten.
//#include <pcd_bootloader.h>


// START OF bootloader definition
// According to data sheet Boot Segment ends at 0x003FFF with the Fuse settings I selected
#define LOADER_END 0x003FFF
#build(reset=LOADER_END+2, interrupt=LOADER_END+6)
#org 0, LOADER_END {} // nothing will replace the bootloader memory space
// END OF bootloader definition

// Variable definitions, interrupt service routines, main, etc. below here

rom char version[] = "Application Version 1.0";

void main()
{
   delay_ms(100);

   printf("\r\n%s\r\n", version);
   
   printf("You can put whatever code you want here.\r\n");
   
   printf("So enjoy!\r\n");
   
   while(TRUE)
   {
   }
}

Notice I have commented out the pcd_bootloader.h and just added my own build and org lines. Hopefully this is OK.

So, problems / questions. I can not seem to test this. My plan was to use the programmer erase and flash the bootloader and then flash the application on top of that, sort of merge them together as they would be if properly bootloaded. However the programmer PICKIT3 and MPLABX IPE don't seem to want to let that fly. Bootloader is fine but if I don't erase the part entirely the application fails to program. Ideally I can develop the main application somehow without having to actually bootload each time.

The other part of this is I do not understand the pcd_bootlader.h at all. Seems like I really could just build the bootloader normally since it lives right after the Reset/Interrupt Vector Space and then use the build and org commands for my main app.

Also do I need to define fuses in both the bootloader and the main app?
Also do I really need to be moving the interrupt vectors around if I am not using them for the bootload process?
Also would the bootload option for #Build be advisable in this situation?

To Summarize:
Ideally Bootloader lives in protected space from Reset Vector to 0x003FF.
Bootloader loads every time, looks for PC communication if does not get it, then times out and passes it over to main app.
Main App never knows bootloader exists.
It would be nice if there was some way to work on main app without having to bootload every time, not sure how to accomplish this.

Any help would be greatly appreciated,
its taking me a long while to get to this point and while I feel like I am close, I still feel very far away from the goal...

thanks
Eric


Last edited by ednspace on Wed Dec 13, 2017 10:11 am; edited 1 time in total
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Fri Dec 01, 2017 7:11 pm     Reply with quote

Quote:

My plan was to use the programmer erase and flash the bootloader and
then flash the application on top of that, sort of merge them together as
they would be if properly bootloaded.

See Ttelmah's answer in this thread, about how to create a combined
Hex file of the bootloader and the application:
http://www.ccsinfo.com/forum/viewtopic.php?t=55676
ednspace



Joined: 08 Aug 2007
Posts: 10

View user's profile Send private message

PostPosted: Fri Dec 01, 2017 7:27 pm     Reply with quote

Thanks PCM programmer for that!!!
I will give it a go and see if I can get it working.
Any comments on the other parts of this mystery are more than welcome...
Ttelmah



Joined: 11 Mar 2010
Posts: 19602

View user's profile Send private message

PostPosted: Sat Dec 02, 2017 1:05 pm     Reply with quote

The normal way to not have the bootloader wait, is to use a jumper. That is why it is there.
However you can do the same thing with the RS232.
Depending on the hardware used, if you design it so that you see 'break' (RS232 input low to the PIC), when the cable is disconnected, all the bootloader needs to do is check if the line is high. If it isn't jump straight to the main code.
ednspace



Joined: 08 Aug 2007
Posts: 10

View user's profile Send private message

PostPosted: Thu Dec 14, 2017 3:21 pm     Reply with quote

Thanks to Ttelmah and PCM programmer for responding to my previous post.

I almost have everything working at this point.
I am programming the bootloader with the programmer as and bootloading the main app for now just to keep confusion down for now and to keep testing and working with my PC application.

The decision to go into bootloader mode is being made by an RS232 timeout. If the bootloader does not receive its bootloader character soon after a reboot then it jumps to the main app. This all works great. I have an FTDI running in D2XX library mode and one of its pins can turn the power supply on and off to the DSPIC so... I can reboot the DSPIC with my PC side bootloader application send the character and bing, into bootloader mode. My PC app also can send the main app very quickly now and its almost a treat to use over the programmer.

Only two more questions remain. How can I tell where the Interrupt vectors are being moved and if they are in the right place? Can I see this in the list file somehow or can I decode it from the HEX file? All my interrupts are working fine, I just want to know how to ease any doubt and convince myself that all is well. I think the line that moves the vectors is, jump_to_isr(LOADER_END+5); Is this correct for my part, 33FJ128GP306A?

I would also like to turn on the code config protection bits that make it so the bootloader can not be written over. I am setting fuses in the bootloader code and using #FUSES NONE in the main application.

The fuses would be something like this
#FUSES BSSSL //Boot Segment Code Protect Standard Security, Large Boot Segment
#FUSES RBS128 //Boot RAM is 128 bytes

My question is how can I tell how big this bootloader block is? I know its done by pages but I can not quite decipher it. Not sure how to correlate this with the datasheet but some help would be appreciated. I can decode the HEX file at this point but the overall addressing of the DSPIC is still a little daunting. I have to choose small, medium or large and I think they break on pages??? I also don't want to screw up the addressing already being done by the bootloader.h file or change it if I don't have to. I am using stock pcd example bootloader.h and its all working well, if the vectors are right that is...

The bootloader reports these variable settings when I print them out as a test.
LOADER_END = 07FF
APPLICATION_START = 0800
APPLICATION_END = 15BFF


Thanks for any more help,
Eric

PS I have convinced myself that there is no need to erase the entire program memory space before bootloading each time. If I bootload a large app and then bootload a small one remnants of the first older one remain in memory. I assume this will not cause a problem and so far has not but it worries me a little. Is this a safe approach ;)

Here is the bootloader as it stands now...
Code:
#include <33FJ128GP306A.h>

//Define Fuses Here Not in Main Application Program
#FUSES NOWDT                              //No Watch Dog Timer
//#FUSES BSSSL                            //Boot Segment Code Protect Standard Security, Large Boot Segment
//#FUSES RBS1024                          //Boot RAM is 1024 bytes
#use delay(clock=22110000, internal)      // works with baud
#use rs232(UART2, baud=115200, stream=COM_PORT, ERRORS)   // works at internal=40MHZ and xtal=22118400 and internal=2211000 w/o BRGH1OK)

//Tells the compiler this is the bootloader
#define _bootloader

#include <pcd_bootloader.h>
#include <loader_pcd.c> //Custom Loader Routine for this DSPIC and D2XX

#org APPLICATION_START
void application(void)
{   
   while(TRUE);
}

int inchar = 0;
void main(void)
{
//Signal that we are in the bootloader
fprintf(COM_PORT, "B\r\n");

//Now wait a short time for command
int16 delay_ctr;
for (delay_ctr=0;delay_ctr<5000;delay_ctr++)
   {
       if (kbhit(COM_PORT))
       {
           //Now there _is_ a character so you can call getc
           inchar = fgetc(COM_PORT);
       }
       else
          delay_us(10);
    }

//Check the character if you got one
   if(inchar == 'U')
   {
      // Enter upload program mode
      // Load the program
      load_program();
      //spin here forevers
      while (1){}
     
   }
   else
   {
      //Run the application...
      application();
   }
}

#int_default
void isr(void)
{
   jump_to_isr(LOADER_END+5);
}
Ttelmah



Joined: 11 Mar 2010
Posts: 19602

View user's profile Send private message

PostPosted: Fri Dec 15, 2017 1:48 am     Reply with quote

Select 'symbolic' in the build options, and compile the bootloader.
Then just look at the start of the assembler listing.
You'll find the table of vectors and where they all point.

You'll find that all the vectors, have been 're-targetted'. Assuming the #build is at 'LOADER_END+1', four locations above the start of the build range.

The 'jump to ISR' function is much overloaded. The original version did 'what it said', and was a simple long jump. Then with the PIC 18's, it was modified and generated two jumps. putting one at the location for high priority interrupts, and the second at the location for standard interrupts. On the PIC24/30/33, it instead loads the entire interrupt vector table, with the specified offset.
ednspace



Joined: 08 Aug 2007
Posts: 10

View user's profile Send private message

PostPosted: Fri Dec 15, 2017 7:49 am     Reply with quote

I am sorry.
I should have included the #BUILD line for the included header file.

Code:
#build (reset=APPLICATION_START,interrupt=APPLICATION_ISR_START)


Code:
 #define APPLICATION_START 0


Code:
#define APPLICATION_ISR_START   (LOADER_END + 5)


I have not changed anything in the include file that came with the PCD example.

I am going to to see if I can select 'symbolic' in the compiler options. I am using the IDE.
Ttelmah



Joined: 11 Mar 2010
Posts: 19602

View user's profile Send private message

PostPosted: Fri Dec 15, 2017 8:31 am     Reply with quote

Options
Project
Output Files
List file
Tick SFR Names, Symbols, Interpret

You'll find the listing file is quite nicely documented once you re-compile.
ednspace



Joined: 08 Aug 2007
Posts: 10

View user's profile Send private message

PostPosted: Fri Dec 15, 2017 8:42 am     Reply with quote

Alright just saw the suggestion above...
I guess you posted while I was typing ;)
let me try what you suggest for compiler options...

(Removed this text to avoid confusion for future reader)


Last edited by ednspace on Fri Dec 15, 2017 9:27 am; edited 2 times in total
Ttelmah



Joined: 11 Mar 2010
Posts: 19602

View user's profile Send private message

PostPosted: Fri Dec 15, 2017 8:52 am     Reply with quote

With the naming/interpret options ticked, you get:
Code:

00006:  DATA    08,08,00       : Trap OSCFAIL at 000808
00008:  DATA    0C,08,00       : Trap ADDRERR at 00080C
0000A:  DATA    10,08,00       : Trap STACKERR at 000810
0000C:  DATA    14,08,00       : Trap MATHERR at 000814
0000E:  DATA    18,08,00       : Trap DMAERR at 000818
00010:  DATA    1C,08,00       : Trap CRYPT_PROGRAM_DONE at 00081C
00012:  DATA    20,08,00       : Trap CRYPT_PROGRAM_DONE at 000820
00014:  DATA    24,08,00       : Int0 EXT0 at 000824
00016:  DATA    28,08,00       : Int1 IC1 at 000828
00018:  DATA    2C,08,00       : Int2 OC1 at 00082C
0001A:  DATA    30,08,00       : Int3 TIMER1 at 000830
0001C:  DATA    34,08,00       : Int4 DMA0 at 000834
0001E:  DATA    38,08,00       : Int5 IC2 at 000838
00020:  DATA    3C,08,00       : Int6 OC2 at 00083C
00022:  DATA    40,08,00       : Int7 TIMER2 at 000840
00024:  DATA    44,08,00       : Int8 TIMER3 at 000844
00026:  DATA    48,08,00       : Int9 SPI1E at 000848
00028:  DATA    4C,08,00       : Int10 SPI1 at 00084C
0002A:  DATA    50,08,00       : Int11 RDA at 000850
0002C:  DATA    54,08,00       : Int12 TBE at 000854
0002E:  DATA    58,08,00       : Int13 ADC1 at 000858
00030:  DATA    5C,08,00       : Int14 DMA1 at 00085C
00032:  DATA    60,08,00       : Int15 CRYPT_PROGRAM_DONE at 000860
00034:  DATA    64,08,00       : Int16 SI2C at 000864
00036:  DATA    68,08,00       : Int17 MI2C at 000868
00038:  DATA    6C,08,00       : Int18 CRYPT_PROGRAM_DONE at 00086C
0003A:  DATA    70,08,00       : Int19 CNI at 000870
0003C:  DATA    74,08,00       : Int20 EXT1 at 000874
0003E:  DATA    78,08,00       : Int21 CRYPT_PROGRAM_DONE at 000878
00040:  DATA    7C,08,00       : Int22 IC7 at 00087C
00042:  DATA    80,08,00       : Int23 IC8 at 000880
00044:  DATA    84,08,00       : Int24 DMA2 at 000884
00046:  DATA    88,08,00       : Int25 OC3 at 000888
00048:  DATA    8C,08,00       : Int26 OC4 at 00088C
0004A:  DATA    90,08,00       : Int27 TIMER4 at 000890
0004C:  DATA    94,08,00       : Int28 TIMER5 at 000894
0004E:  DATA    98,08,00       : Int29 EXT2 at 000898
00050:  DATA    9C,08,00       : Int30 RDA2 at 00089C
00052:  DATA    A0,08,00       : Int31 TBE2 at 0008A0
00054:  DATA    A4,08,00       : Int32 SPI2E at 0008A4
00056:  DATA    A8,08,00       : Int33 SPI2 at 0008A8
00058:  DATA    AC,08,00       : Int34 CRYPT_PROGRAM_DONE at 0008AC
0005A:  DATA    B0,08,00       : Int35 CRYPT_PROGRAM_DONE at 0008B0
0005C:  DATA    B4,08,00       : Int36 DMA3 at 0008B4
0005E:  DATA    B8,08,00       : Int37 IC3 at 0008B8
00060:  DATA    BC,08,00       : Int38 IC4 at 0008BC
00062:  DATA    C0,08,00       : Int39 IC5 at 0008C0
00064:  DATA    C4,08,00       : Int40 IC6 at 0008C4
00066:  DATA    C8,08,00       : Int41 OC5 at 0008C8
00068:  DATA    CC,08,00       : Int42 OC6 at 0008CC
0006A:  DATA    D0,08,00       : Int43 OC7 at 0008D0
0006C:  DATA    D4,08,00       : Int44 OC8 at 0008D4
0006E:  DATA    D8,08,00       : Int45 CRYPT_PROGRAM_DONE at 0008D8
00070:  DATA    DC,08,00       : Int46 DMA4 at 0008DC
00072:  DATA    E0,08,00       : Int47 TIMER6 at 0008E0
00074:  DATA    E4,08,00       : Int48 TIMER7 at 0008E4
00076:  DATA    E8,08,00       : Int49 SI2C2 at 0008E8
00078:  DATA    EC,08,00       : Int50 MI2C2 at 0008EC
0007A:  DATA    F0,08,00       : Int51 TIMER8 at 0008F0
0007C:  DATA    F4,08,00       : Int52 TIMER9 at 0008F4
0007E:  DATA    F8,08,00       : Int53 EXT3 at 0008F8
00080:  DATA    FC,08,00       : Int54 EXT4 at 0008FC
00082:  DATA    00,09,00       : Int55 CRYPT_PROGRAM_DONE at 000900
00084:  DATA    04,09,00       : Int56 CRYPT_PROGRAM_DONE at 000904
00086:  DATA    08,09,00       : Int57 CRYPT_PROGRAM_DONE at 000908
00088:  DATA    0C,09,00       : Int58 CRYPT_PROGRAM_DONE at 00090C
0008A:  DATA    10,09,00       : Int59 CRYPT_PROGRAM_DONE at 000910
0008C:  DATA    14,09,00       : Int60 CRYPT_PROGRAM_DONE at 000914
0008E:  DATA    18,09,00       : Int61 DMA5 at 000918
00090:  DATA    1C,09,00       : Int62 CRYPT_PROGRAM_DONE at 00091C
00092:  DATA    20,09,00       : Int63 CRYPT_PROGRAM_DONE at 000920
00094:  DATA    24,09,00       : Int64 CRYPT_PROGRAM_DONE at 000924
00096:  DATA    28,09,00       : Int65 UART1E at 000928
00098:  DATA    2C,09,00       : Int66 UART2E at 00092C
0009A:  DATA    30,09,00       : Int67 CRYPT_PROGRAM_DONE at 000930
0009C:  DATA    34,09,00       : Int68 DMA6 at 000934
0009E:  DATA    38,09,00       : Int69 DMA7 at 000938
000A0:  DATA    3C,09,00       : Int70 CRYPT_PROGRAM_DONE at 00093C
000A2:  DATA    40,09,00       : Int71 CRYPT_PROGRAM_DONE at 000940
000A4:  DATA    44,09,00       : Int72 CRYPT_PROGRAM_DONE at 000944
000A6:  DATA    48,09,00       : Int73 CRYPT_PROGRAM_DONE at 000948
000A8:  DATA    4C,09,00       : Int74 CRYPT_PROGRAM_DONE at 00094C
000AA:  DATA    50,09,00       : Int75 CRYPT_PROGRAM_DONE at 000950
000AC:  DATA    54,09,00       : Int76 CRYPT_PROGRAM_DONE at 000954
000AE:  DATA    58,09,00       : Int77 CRYPT_PROGRAM_DONE at 000958
000B0:  DATA    5C,09,00       : Int78 CRYPT_PROGRAM_DONE at 00095C
000B2:  DATA    60,09,00       : Int79 CRYPT_PROGRAM_DONE at 000960
000B4:  DATA    64,09,00       : Int80 CRYPT_PROGRAM_DONE at 000964
000B6:  DATA    68,09,00       : Int81 CRYPT_PROGRAM_DONE at 000968
000B8:  DATA    6C,09,00       : Int82 CRYPT_PROGRAM_DONE at 00096C
000BA:  DATA    70,09,00       : Int83 CRYPT_PROGRAM_DONE at 000970
000BC:  DATA    74,09,00       : Int84 CRYPT_PROGRAM_DONE at 000974
000BE:  DATA    78,09,00       : Int85 CRYPT_PROGRAM_DONE at 000978
000C0:  DATA    7C,09,00       : Int86 CRYPT_PROGRAM_DONE at 00097C
000C2:  DATA    80,09,00       : Int87 CRYPT_PROGRAM_DONE at 000980
000C4:  DATA    84,09,00       : Int88 CRYPT_PROGRAM_DONE at 000984
000C6:  DATA    88,09,00       : Int89 CRYPT_PROGRAM_DONE at 000988
000C8:  DATA    8C,09,00       : Int90 CRYPT_PROGRAM_DONE at 00098C
000CA:  DATA    90,09,00       : Int91 CRYPT_PROGRAM_DONE at 000990
000CC:  DATA    94,09,00       : Int92 CRYPT_PROGRAM_DONE at 000994
000CE:  DATA    98,09,00       : Int93 CRYPT_PROGRAM_DONE at 000998
000D0:  DATA    9C,09,00       : Int94 CRYPT_PROGRAM_DONE at 00099C
000D2:  DATA    A0,09,00       : Int95 CRYPT_PROGRAM_DONE at 0009A0
000D4:  DATA    A4,09,00       : Int96 CRYPT_PROGRAM_DONE at 0009A4
000D6:  DATA    A8,09,00       : Int97 CRYPT_PROGRAM_DONE at 0009A8
000D8:  DATA    AC,09,00       : Int98 CRYPT_PROGRAM_DONE at 0009AC
000DA:  DATA    B0,09,00       : Int99 CRYPT_PROGRAM_DONE at 0009B0
000DC:  DATA    B4,09,00       : Int100 CRYPT_PROGRAM_DONE at 0009B4
000DE:  DATA    B8,09,00       : Int101 CRYPT_PROGRAM_DONE at 0009B8
000E0:  DATA    BC,09,00       : Int102 CRYPT_PROGRAM_DONE at 0009BC
000E2:  DATA    C0,09,00       : Int103 CRYPT_PROGRAM_DONE at 0009C0
000E4:  DATA    C4,09,00       : Int104 CRYPT_PROGRAM_DONE at 0009C4
000E6:  DATA    C8,09,00       : Int105 CRYPT_PROGRAM_DONE at 0009C8
000E8:  DATA    CC,09,00       : Int106 CRYPT_PROGRAM_DONE at 0009CC
000EA:  DATA    D0,09,00       : Int107 CRYPT_PROGRAM_DONE at 0009D0
000EC:  DATA    D4,09,00       : Int108 CRYPT_PROGRAM_DONE at 0009D4
000EE:  DATA    D8,09,00       : Int109 CRYPT_PROGRAM_DONE at 0009D8
000F0:  DATA    DC,09,00       : Int110 CRYPT_PROGRAM_DONE at 0009DC
000F2:  DATA    E0,09,00       : Int111 CRYPT_PROGRAM_DONE at 0009E0
000F4:  DATA    E4,09,00       : Int112 CRYPT_PROGRAM_DONE at 0009E4
000F6:  DATA    E8,09,00       : Int113 CRYPT_PROGRAM_DONE at 0009E8
000F8:  DATA    EC,09,00       : Int114 CRYPT_PROGRAM_DONE at 0009EC
000FA:  DATA    F0,09,00       : Int115 CRYPT_PROGRAM_DONE at 0009F0
000FC:  DATA    F4,09,00       : Int116 CRYPT_PROGRAM_DONE at 0009F4
000FE:  DATA    F8,09,00       : Int117 CRYPT_PROGRAM_DONE at 0009F8


Telling you what they all do. Smile
ednspace



Joined: 08 Aug 2007
Posts: 10

View user's profile Send private message

PostPosted: Fri Dec 15, 2017 9:24 am     Reply with quote

AWESOME!!!

I see it now. Thanks! Thats a cool trick.

So is this telling me where they are being moved like.
00006 is the OSCFAIL ISR and its getting moved to 000808?

My main app list file is starting at...


Code:
00800:  GOTO    1EDE           :
*
00830:  GOTO    BDA            :
*
00840:  GOTO    C30            :
*
0089C:  GOTO    C80            :
008A0:  GOTO    D3C            :


and the first few lines show...

Code:
00A0A:  MOV     W5,[W15++]     : Push W5 to TOS
00A0C:  MOV     #C,W5          : W5 = C
00A0E:  REPEAT  #3             : Repeat next instruction (3 + 1) times
00A10:  MOV     [W5++],[W15++] : Push [W5++] to TOS
00A12:  MOV     #0,W9          : W9 = 0
00A14:  BTSC.B  43.0           : Skip if SR.DC = 0
00A16:  MOV     #1,W9          : W9 = 1
00A18:  MOV     W9,[W15++]     : Push W9 to TOS


again I do not see any of the Interrupt Vectors being moved in the main list file which I am sure is correct.

I still wonder how to tell if I have overlap and if main is really able to see the vector space correctly?

When I read the device with the programmer after bootloading I can see my main app starting at 000800 and I can see the GOTOs from the list file like 1EDE they are in the right spot. For the life of me I do not see the ISRs unless they are FFFFFs and just in between. Shouldn't they show up at 000808.

It seems like there is some overlap like 000830 has a goto defined but is also the remapped location for the interrupt Timer1. Or is this just the way it shows up if I am using timer 1?

Thanks so much for your help, it would be nice to really feel like I understand this.
ednspace



Joined: 08 Aug 2007
Posts: 10

View user's profile Send private message

PostPosted: Fri Dec 15, 2017 11:27 am     Reply with quote

Ok I can see the interrupt vectors being mapped in now at the top of program memory when I look at the Memory View from the programmer. They are starting at 00002 and have the remapped values from the list file. Hopefully I am good on vectors but still not quite positive Shocked

I am still trying to figure out code config, but it looks like according to the data sheet and http://ww1.microchip.com/downloads/en/DeviceDoc/70199B.pdf

For standard protection small size looks like the bootloader segment is defined as:

Standard Small 0x000200 0x0007FE

This seems to mesh very well with the way my bootloader is set up. It seems to be starting at 0000200 and the main code starts 000800.

Seems like all I have to do to protect it is turn on these fuses...
Code:
#FUSES WRTB                            //Boot block write protected
#FUSES BSSSS                           //Boot Segment Code Protect Standard Security, Small Boot Segment
#FUSES NORBS                           //No Boot RAM defined


We shall see...
Thanks again for all the help
ednspace



Joined: 08 Aug 2007
Posts: 10

View user's profile Send private message

PostPosted: Fri Dec 15, 2017 12:46 pm     Reply with quote

Well those fuse settings appear to work!!!
I can not read the bootloader area after programming, just get zeros for that section.

Bootloading still works and after bootloading and reading with the programmer I can see the main code that I bootloaded and the boot bootloader segment is still read as zeroes.

The zero section matches my bootloader size EXACTLY!
So, I think I am home free on the code config protection front.

If anyone still feels like humoring me with more info on the Reset Vectors I am all ears.

Or if you spot anything else I may be doing wrong from the above please chime in.

Thanks again all for all your time...
Eric
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