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

usb connection lost on bootloader

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



Joined: 05 Oct 2016
Posts: 120

View user's profile Send private message

usb connection lost on bootloader
PostPosted: Mon Jun 24, 2019 4:43 am     Reply with quote

Hello everyone,

I have a usb code that receieves a char 'a' and sends 'k'. The code works just fine.

However when i upload the code with bootloader windows loses connection. I use the ccs example usb bootloader.

I checked the bootloader hex and it works. I have uploaded a simple led blink with bootloader and there were no problems. When i add usb, things get complicated and after a while i lose usb connection.

This is the code that works on normal but gets stuck on bootloader. Any ideas?

Code:
#if !defined(__PCH__)
 #error USB CDC Library requires PIC18
#endif

#include <18F4550.h>
#DEVICE ADC=10
#fuses HSPLL,NOWDT,NOMCLR,PROTECT,NOLVP,NODEBUG,NOBROWNOUT,USBDIV,PLL5,CPUDIV1,VREGEN
#use delay(clock=48000000)
#include <usb_bootloader.h> //this line exist only in bootloader version
#include "usb_cdc.h"

#define rp_getc usb_cdc_getc
#define rp_putc usb_cdc_putc

int   value;

void main()
{
  usb_init_cs();
  usb_cdc_init();

  while (true)
   {
      usb_task();
      value = rp_getc();
      delay_ms(20);
      if(value=='a')
      {
         rp_putc('k');
      }

   }
}
Ttelmah



Joined: 11 Mar 2010
Posts: 19496

View user's profile Send private message

PostPosted: Mon Jun 24, 2019 6:24 am     Reply with quote

No...

The file "usb_bootloader.h"

Needs to be included both in the bootloader, _and_ in the code you are going
to load _with_ the bootloader. The difference is that in the bootloader
it needs the #define _bootloader before it is loaded.

Without this loaded, the code will not be compiled located suitably to
use the bootloader.

Hopefully your comment that it only exists means you are loading it?.

Then next question, are your fuses the same in the bootloader code?.
They need to be. The best way to handle the fuses is to take the bootloader
fuses and include then as a 'comment' at the top of your code, and then
use #FUSES NONE. The main code cannot change the bootloader fuses
and this ensures you know what is happening!...


Last edited by Ttelmah on Mon Jun 24, 2019 6:32 am; edited 1 time in total
doguhanpala



Joined: 05 Oct 2016
Posts: 120

View user's profile Send private message

PostPosted: Mon Jun 24, 2019 6:32 am     Reply with quote

Ttelmah wrote:
No...

The file "usb_bootloader.h"

Needs to be included both in the bootloader, _and_ in the code you are going
to load _with_ the bootloader. The difference is that in the bootloader
it needs the #define _bootloader before it is loaded.

Without this loaded, the code will not be compiled located suitably to
use the bootloader.


Thank you for answer Ttelmah,

"usb_bootloader.h" is included in bootloader too. I've checked the example code and it also has the #define _bootloader line.

the problem still continues.
Ttelmah



Joined: 11 Mar 2010
Posts: 19496

View user's profile Send private message

PostPosted: Mon Jun 24, 2019 6:35 am     Reply with quote

Are you sure the same code is reliable if loaded without the bootloader?.

Classic things that can give 'long term' USB problems are a poor capacitor
on the Vusb line (this should be a 0.47uF polyester ideally).
Also the long delay could cause an issue. If multiple characters arrive
only one is being accepted every 20mSec. Very easy to cause overflow
problems handling like this.
There shouldn't really be a delay at all. The code will only send when
a character is received, so 'why delay'?.
doguhanpala



Joined: 05 Oct 2016
Posts: 120

View user's profile Send private message

PostPosted: Mon Jun 24, 2019 7:17 am     Reply with quote

Hello Ttelmah,

I have checked and you are right. The first one is not stable. I have shared the wrong verision of code. This is the right version. This works without bootloader. I have checked for a few minutes and there were no connection loss at all. When i add bootloader to it, Putty cant create a serial connection to board.

The difference is

Code:
usb_cdc_init();
  usb_init();


lines.

I have checked the example code. It has the usb_init_cs() line. I dont know what that does but could one of the usb function overlap another?

Code:
#if !defined(__PCH__)
 #error USB CDC Library requires PIC18
#endif

#include <18F4550.h>
#DEVICE ADC=10
#fuses HSPLL,NOWDT,NOMCLR,PROTECT,NOLVP,NODEBUG,NOBROWNOUT,USBDIV,PLL5,CPUDIV1,VREGEN
#use delay(clock=48000000)
//#include <usb_bootloader.h>
#include "usb_cdc.h"

#define rp_getc usb_cdc_getc
#define rp_putc usb_cdc_putc

int   value;

void main()
{
  usb_cdc_init();
  usb_init();

  while (true)
   {
      usb_task();
      value = rp_getc();
      delay_ms(20);
      if(value=='a')
      {
         output_high(PIN_D5);
         rp_putc('k');
      }

   }
}


thank you for your answer.
Ttelmah



Joined: 11 Mar 2010
Posts: 19496

View user's profile Send private message

PostPosted: Mon Jun 24, 2019 7:59 am     Reply with quote

usb_init_cs checks for the 'connection sense' line being pulled high before
initialising the USB. usb_init initialises it 'without question'.

Connection sense is actually _required_ by USB (if you want to meet the
'specs'), if the device is not actually powered by the USB bus. The reason
is that on modern kit, the CPU can switch off power to the USB bus
to save power, and requires the stuff attached to detect this and reset
when the power comes back on.
doguhanpala



Joined: 05 Oct 2016
Posts: 120

View user's profile Send private message

PostPosted: Mon Jun 24, 2019 8:11 am     Reply with quote

Ttelmah wrote:
usb_init_cs checks for the 'connection sense' line being pulled high before
initialising the USB. usb_init initialises it 'without question'.

Connection sense is actually _required_ by USB (if you want to meet the
'specs'), if the device is not actually powered by the USB bus. The reason
is that on modern kit, the CPU can switch off power to the USB bus
to save power, and requires the stuff attached to detect this and reset
when the power comes back on.


Thank you so much. I still could not figure out why Putty can't create a serial connection on bootloader. Assuming some codes are overlapping.

In bootloader there are some usb connection lines like usb_isr polling and usb_init_cs(). There are usb related codes on my own hex. Could the codes i use might be overlapping or conflict with each other?

And lastly, any ideas why the working code gets broken on bootloader?

I am stuck at this for a few days. Sorry for my dumb questions. Thank you so much!
Ttelmah



Joined: 11 Mar 2010
Posts: 19496

View user's profile Send private message

PostPosted: Mon Jun 24, 2019 1:19 pm     Reply with quote

No, they don't 'overlap'.
Unless your bootloader is larger that the standard one.

The bootloader does assume you have CS implemented.
doguhanpala



Joined: 05 Oct 2016
Posts: 120

View user's profile Send private message

PostPosted: Wed Jun 26, 2019 6:54 am     Reply with quote

Ttelmah wrote:


The bootloader does assume you have CS implemented.


So should i use usb_init_cs() instead of usb_init() ?

I tried that but still no luck.
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