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

Boot Loader with 18LF2620

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



Joined: 11 Nov 2006
Posts: 181
Location: Birmingham, UK

View user's profile Send private message

Boot Loader with 18LF2620
PostPosted: Thu Sep 17, 2015 4:16 am     Reply with quote

Hi
I have not used the idea of a boot loader before. I have downloaded and installed the Microchip software, P1618QP.exe.
First problem: I am using COM16 to communicate with the PIC. It works. However, when I edit the .ini file to say portIndex=16 and then run the exe, it says: Core error: Control array element '16' does not exist. I can't alter the port to a lower value in Device Manager as all are marked as in use. I have tried ascending numbers and these show as COMx in the exe, up to COM4. After that, I get the error. How can I get the program to recognise my com16?
I am using Win7 32 bit Home.
If that hurdle can be overcome, what fuse settings do I need to protect the boot loader code?
Also, the device list doesn't show any LF devices - do I presume this doesn't matter? I am using an 18LF2620 on 3.3V.
Is there anything else I need to know/do please?
Any help much appreciated.
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Fri Sep 18, 2015 9:45 pm     Reply with quote

Quote:
I have not used the idea of a boot loader before. I have downloaded and installed the Microchip software, P1618QP.exe.
First problem: I am using COM16 to communicate with the PIC. It works. However, when I edit the .ini file to say portIndex=16 and then run the exe, it says: Core error: Control array element '16' does not exist. I can't alter the port to a lower value in Device Manager as all are marked as in use. I have tried ascending numbers and these show as COMx in the exe, up to COM4. After that, I get the error. How can I get the program to recognise my com16?
I am using Win7 32 bit Home.

The P1618QP.exe program was released in 2002 along with AN851.
It may not work with Win7. It's a Microchip program, so questions
about it should be posted on their forums. Example of that:
http://www.microchip.com/forums/m146076.aspx

Quote:
Also, the device list doesn't show any LF devices

Device list for what ? I assume P1618QP.exe ? The link above gives
some hint about that. It shows how to change the Device ID in the ini
file. You will have to look up the Device ID for your PIC in the data sheet
or use an ICD or Pickit programmer to read out the Device ID (in MPLAB
or in CCS IDE).
BLL



Joined: 11 Nov 2006
Posts: 181
Location: Birmingham, UK

View user's profile Send private message

Boot loader
PostPosted: Sat Sep 19, 2015 12:02 pm     Reply with quote

Hi both respondents
Since the post, I have also tried CCS's offering, editing bootloader.c for the 18F2620, compiling it and programming it into my PIC. However, when I then run compiled loader.c, it goes so far and then says the PIC is not responding!
The debug file shows that some hundreds of locations have been programmed, but by no means all.
I have tried reducing the baud rate - no better.
I have tried a FTDI USB serial converter instead of my pl2303 one - no better.
It just seems so flaky and unreliable. Does the technique of boot-loading work at all?
I don't know what to do next!
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Sat Sep 19, 2015 2:08 pm     Reply with quote

Quote:
it goes so far and then says the PIC is not responding!

What program are you using to download the application code ?
It is SIOW.exe ?

Do you have the COM port on your PC (which you are using for the
bootloader) set to use XON/XOFF flow control ? This thread has a screenshot:
http://www.ccsinfo.com/forum/viewtopic.php?p=195142

Did you edit the files Ex_Bootloader.c, and Ex_Bootload.c ?
What edits did you make ?

What is your CCS compiler version ?
BLL



Joined: 11 Nov 2006
Posts: 181
Location: Birmingham, UK

View user's profile Send private message

Boot loader
PostPosted: Sun Sep 20, 2015 12:24 pm     Reply with quote

No, I am not using siow, but the program CCS provide. Yes, I have set xon/xoff control. Yes, I did edit both the files you mention. changed the device to 18F2620 and confirmed that the 232 parameters were correct. Set A5 as the pin to detect reload or normal boot.

Brian
Ttelmah



Joined: 11 Mar 2010
Posts: 19590

View user's profile Send private message

PostPosted: Sun Sep 20, 2015 12:36 pm     Reply with quote

It is important to understand that the CPU effectively has to stop working when it programs it's own ROM.

This is why flow control (as PCM_programmer points out), is vital. The bootloader has to be able to stop the incoming data while a block is written, and then start it again to receive the next block.

Bootloader's work fine. Many people here have used them, but you have to set things up correctly to use them.

If you read the comments, in loader.c, you will find that it tells you it uses XON/XOFF, and looking through the file you will see that it stops transmission using XOFF, before it writes, and then turns it on again afterwards. Your comm port needs to be setup to do this.
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Sun Sep 20, 2015 12:53 pm     Reply with quote

Quote:
I am not using siow, but the program CCS provide

I'm not that familiar with the CCS IDE. I use their command line
compilers with MPLAB vs. 8.92. What program does CCS provide ?
What's the name of the program ? How do you run it ?
I had always thought it was SIOW.exe.
jeremiah



Joined: 20 Jul 2010
Posts: 1358

View user's profile Send private message

PostPosted: Sun Sep 20, 2015 3:45 pm     Reply with quote

I have the IDE version and it is SIOW.exe for me as well.
BLL



Joined: 11 Nov 2006
Posts: 181
Location: Birmingham, UK

View user's profile Send private message

18F2620 boot loader
PostPosted: Mon Sep 21, 2015 3:47 am     Reply with quote

Hi all
I am still getting nowhere with this. In case I am doing something stupid, here is what I have done:

1). Modified ex_bootloader.c for 18F2620 and 10MHz oscillator:
Code:

#include <18F2620.h>
#fuses HS,NOWDT,NOPROTECT,NOLVP
#use delay(clock=10000000)
#use rs232(baud=9600, xmit=PIN_C6, rcv=PIN_C7)  // Jumpers: 8 to 11, 7 to 12
#endif

and changed the pin to cause boot load from B5 to A5 (my prog uses B5, but A5 is unused) :
Code:

void main(void)
{
 if(!input(PIN_A5))
  {
   load_program();
  }

2). Modified bootloader.c:

Code:
if(!input(PIN_A5))
 real_load_program();

Compiled and programmed into 18LF2620

In Device Manager in Windows, turned off FIFO.

Used siow.exe:

Port is COM14, flow control set to both TX and RX, xon/xoff

Selected 'Download Software' and selected my .hex file.
Almost immediately, it says "Timeout while downloading". It's still on line 1.

The port works fine transmitting and receiving data when I just put my program into the PIC, so I don't see any problems there.

Brian
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Mon Sep 21, 2015 12:10 pm     Reply with quote

Make sure you have this circuit on pin A5:
Code:
           +3.3v
            |
            <
            > 4.7K       
            <         ___  Switch 
To          |        _|_|_
PIC -----------------o   o------
pin                            |             
A5                            --- GND
                               -   
 

Or, at a minimum, make sure you have a pull-up resistor on Pin A5.

Then try using Teraterm to download your program to the PIC.
See this post:
http://www.ccsinfo.com/forum/viewtopic.php?t=40920&start=1
BLL



Joined: 11 Nov 2006
Posts: 181
Location: Birmingham, UK

View user's profile Send private message

18LF2620 boot loader
PostPosted: Tue Sep 22, 2015 9:23 am     Reply with quote

Hi, both respondents. Pin A5 has a 13K pullup resistor to +3.3V and a switch to ground. I have double checked with a meter that the pin is at 3.3V with the switch open and 0V, when closed.

I tried tera term and I thought that had cracked it, but alas no!
It starts transferring bytes very slowly and stops at 3% (2895 bytes). The transfer speed is a lightning 181 bytes/sec!! It then just stops. Worse, if you exit tera term and try again or use any app which uses com14, tera term says com14 is not available. The other program I use says access denied. The only solution is to reboot and then you get one chance, which stops at 3.4% and mucks up the port!!

I emphasise that if I load my app straight into the PIC, it works and so does the serial port without problems!

I just don't know what to do next!
Ttelmah



Joined: 11 Mar 2010
Posts: 19590

View user's profile Send private message

PostPosted: Tue Sep 22, 2015 11:13 am     Reply with quote

Whoa a sec.

An application compiled for use with a bootloader, _should not work if loaded directly into the PIC_. It _requires_ the relocation components contained in the bootloader to actually work.

It rather suggests to me, that you are not correctly compiling the application to use the bootloader.

Look at ex_bootload.c
This shows how the application needs to be compiled to load with the bootloader.

If you try to load an application built to load at the bottom of memory, with the bootloader present, of course it will fail. It can't write to the area where the bootloader sits.....
Ttelmah



Joined: 11 Mar 2010
Posts: 19590

View user's profile Send private message

PostPosted: Tue Sep 22, 2015 1:36 pm     Reply with quote

You should not jump off onto another thread.

You are missing the point. I do not refer you to ex_bootloader.c. I am pointing you to ex_bootload.c

Note the lack of the 'er'. Big difference.

ex_bootloader.c, is the bootloader.

ex_bootload.c, shows you how to compile your program to load with the bootloader.

You need to compile your program like this (note the change in the #define from bootloader.c, and that it still includes the .h file to relocate the code).

A normal program will _not_ load with the bootloader. The program itself needs to be compiled with the settings to work with the bootloader. If your program loads and runs when programmed normally, it is _not_ suitable for use with the bootloader.
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