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

PIC18F26J50 USB CDC issue
Goto page Previous  1, 2, 3  Next
 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
Donald_X



Joined: 08 Apr 2014
Posts: 9

View user's profile Send private message

PostPosted: Tue Apr 22, 2014 12:55 am     Reply with quote

Hi Ttelmah,
Adjustment of “send_message” function has helped with echo mode - program works fine now. But haven't fix timeout problem.

Do you think it could be caused by the old version of CCS compiler? Is it possible that in my version could be some bug that is causing the problem?

Thanks
Daniel
Ttelmah



Joined: 11 Mar 2010
Posts: 19596

View user's profile Send private message

PostPosted: Tue Apr 22, 2014 3:39 am     Reply with quote

It's possible, but perhaps not totally likely.
Your own diagnosis, suggests that the PIC is actually responding correctly or near correctly, which was more like problems I had with chipset USB drivers.
One thing that might give an intermittent problem is the smoothing of Vusb. This is much more critical than is often thought. If the capacitor is too large, the bus doesn't wake up quickly enough, but too small, and you get tiny 'oddities' in the USB behaviour with unreliable operation. Key is it's HF performance. Something like a 470nF polyester capacitor seems the 'best' solution. 220nF can be a little small (data sheet minimum). Might be worth just changing what you use here and see if it has any effect.
Renjith_Beginow



Joined: 21 May 2014
Posts: 12

View user's profile Send private message

PostPosted: Wed May 21, 2014 6:11 am     Reply with quote

Hiii,
I am using 18F26J50, and i am trying implement USB, but its showing the device not recognized,
Can any one help with a working code and oscillator configuration, i think my oscs configuration is creating pblm
ezflyr



Joined: 25 Oct 2010
Posts: 1019
Location: Tewksbury, MA

View user's profile Send private message

PostPosted: Wed May 21, 2014 6:53 am     Reply with quote

Hi,

First of all, you should tell us your crystal frequency. Then you should post your suspect configuration for us to look at. Without this information, we are only just guessing at what your problem might be!

If you *do* suspect an oscillator problem, connect an LED to an I/O pin of the PIC, and flash it at a known rate, say 1 second On, and 1 second Off. This will either work as expected, or you will observe a gross deviation in the timing. Check it out yourself!

John
Renjith_Beginow



Joined: 21 May 2014
Posts: 12

View user's profile Send private message

PostPosted: Wed May 21, 2014 8:23 am     Reply with quote

Code:
#FUSES NOWDT
#FUSES NODEBUG
#FUSES NOXINST
#FUSES NOPROTECT
#FUSES NOFCMEN
#FUSES NOIESO
#FUSES NOCPUDIV
#FUSES HSPLL
#FUSES PLL1
#FUSES RTCOSC_INT
#use delay(clock=48000000)

The above given is my fuse settings,using external 4MHz crystal and using PLL clock 48MHz.
Renjith_Beginow



Joined: 21 May 2014
Posts: 12

View user's profile Send private message

PostPosted: Wed May 21, 2014 8:25 am     Reply with quote

I have connected an led, its working properly,but settings for usb i think its wrong
Renjith_Beginow



Joined: 21 May 2014
Posts: 12

View user's profile Send private message

PostPosted: Wed May 21, 2014 8:26 am     Reply with quote

This is my code,

Code:
#include <18F26J50.h>

#FUSES NOWDT
#FUSES NODEBUG
#FUSES NOXINST
#FUSES NOPROTECT
#FUSES NOFCMEN
#FUSES NOIESO
#FUSES NOCPUDIV
#FUSES HSPLL
#FUSES PLL1
#FUSES RTCOSC_INT

#use delay(clock=48000000)

  #ZERO_RAM
  #include <stdio.h>
  #include <stdlib.h>
  #define USB_CON_SENSE_PIN PIN_B7  //Voltage level converted
  #include <usb_cdc.h>
#define USB_EXTERNAL_PULLUPS

void main()
{
   int i, j, address, value;
   setup_oscillator(OSC_PLL_ON);
   output_high(pin_c2);   
   enable_interrupts(GLOBAL);
   output_high(pin_c2);
   usb_init_cs();
   
   while(1)
   {
     
      usb_task();
     
      if (usb_enumerated())
      {
            output_high(pin_c2);
            delay_ms(500);
            output_low(pin_c2);
            delay_ms(500);
         if (usb_cdc_kbhit())
         {
            output_high(pin_c2);
            delay_ms(500);
            output_low(pin_c2);
            delay_ms(500);
           
         }
      }
   }         
}
Ttelmah



Joined: 11 Mar 2010
Posts: 19596

View user's profile Send private message

PostPosted: Wed May 21, 2014 9:03 am     Reply with quote

There is a possible disagreement in your fuses.

You have HSPLL selected, which is normally used for a crystal above 4MHz, can overdrive if used at 4Mhz. But then you have PLL1 selected, which only applies with a 4MHz crystal.

Do you have the external pull up?. You have external pull ups selected. You need a 1.5K resistor from D+, to Vusb.

Are you feeding Vusb?.

Get rid of the setup oscillator line. The PLL enable, only applies when using INTOSCPLL mode, where the PLL can be software controlled.

Don't delay in the master loop. If you want to do flashing LED's etc., then use a timer, and handle these with this. There are problems if usb_task is not called at regular intervals. Even with interrupt driven handling, it should be called quite frequently...

When kbhit goes true, you need to read the received character, or the buffer will eventually overflow....
Renjith_Beginow



Joined: 21 May 2014
Posts: 12

View user's profile Send private message

PostPosted: Thu May 22, 2014 12:30 am     Reply with quote

Thank you Ttelmah,
Now I have got connected the usb to PC, but it's unable for me to see the data I am transmitting, what will be the baudrate for the usb to uart ?
My code:
Code:

#include <18F26J50.h>

#FUSES NOWDT
#FUSES NODEBUG
#FUSES NOXINST
#FUSES NOPROTECT
#FUSES NOFCMEN
#FUSES NOIESO
#FUSES NOCPUDIV
#FUSES HSPLL
#FUSES PLL1
#FUSES RTCOSC_INT

#USE fixed_io(c_outputs = PIN_C2, PIN_C3)

#use delay(clock=48000000)

#define CMD_length  20
char msg2[]="Hi Renjith,Its USB";
//A5 old B2 new
#define SL_LED_ON   {output_high( PIN_C2);}
#define SL_LED_OFF  {output_low( PIN_C2);}
#define LED_ON      {output_high( PIN_C2);}
#define LED_OFF     {output_low( PIN_C2);}

#define  USB_CONFIG_BUS_POWER 100   //300mA  (range is 0..500)

#include<usb_desc_cdc.h>
#include <usb_cdc.h>

unsigned long cmd_counter = 0;

void main()
{
   int i, j, address, value;
   setup_oscillator(OSC_PLL_ON);
   output_high(pin_c2);   
   enable_interrupts(GLOBAL);
   output_high(pin_c2);
   usb_init();
   
   while(1)
   {
      usb_cdc_init();
      usb_task();
     
      if (usb_enumerated())
      {
         usb_cdc_connected();
            while(1)
            {
               output_high(pin_c2);
               usb_cdc_puts(msg2);
               delay_ms(100);
               output_low(pin_c2);
               delay_ms(100);
            }
               
         if (usb_cdc_kbhit())
         {
            output_high(pin_c2);
            delay_ms(500);
            output_low(pin_c2);
            delay_ms(500);
           
         }
      }
   }         
}
Ttelmah



Joined: 11 Mar 2010
Posts: 19596

View user's profile Send private message

PostPosted: Thu May 22, 2014 1:00 am     Reply with quote

There isn't a baud rate.

USB to UART runs at the USB speed (limited by packets, timing etc.). When you set the baud rate, all it does is send a packet to the slave device saying 'this is the baud rate being used', so that if it is implementing an external serial connection, the device can change the baud rate on this. The USB communication remains unchanged.

Are you still running with a 4MHz crystal?.

I'd suggest 'not' doing this. Have had problems in the past with the PLL, running from 4Mhz, being slightly unreliable. It appears that if the crystal is a bit overdriven (with HSPLL your's almost certainly _will_ be), you get an asymmetric waveform from the oscillator, that then causes problems with the PLL. By adding a series resistor to the crystal, to bring the drive down, and switching to XTPLL, it is possible to get it working, but is still a fiddle. Running off an 8Mhz crystal, with PLL2 is generally much more reliable.

You also have not got rid of the setup_oscillator line. OSC_PLL_ON, _does not apply with the crystal drive_.

You are also still delaying too much in the loop, and not reading the character if received.
Renjith_Beginow



Joined: 21 May 2014
Posts: 12

View user's profile Send private message

PostPosted: Thu May 22, 2014 4:55 am     Reply with quote

Here I am not using any other device for communication. I am connecting it with PC using tiny bootloader for checking serial. There its showing com6, but not receiving any data. But when i send data from PC, its reaching the controller, for that i have made an led off. But I don't what's the problem. I have written for reading and writing the same data to PC, but its not working. Anyway i will change my crystal to 8MHz ok.
Thank you Ttelmah.

Code:
if (usb_cdc_kbhit())
{
   x=usb_cdc_getc();
   delay_us(50);
   usb_cdc_putc(x);
   output_low(pin_c2);
}
Renjith_Beginow



Joined: 21 May 2014
Posts: 12

View user's profile Send private message

PostPosted: Fri May 23, 2014 3:10 am     Reply with quote

I have got communication with PC but data is not continuously receiving by system, after one or two characters, commnication loss, but connection will be there, What will be the reason.
Code:

#include <18F26J50.h>

#FUSES NOWDT
#FUSES NODEBUG
#FUSES NOXINST
#FUSES NOPROTECT
#FUSES NOFCMEN
#FUSES NOIESO
#FUSES NOCPUDIV
#FUSES HSPLL
#FUSES PLL2
#FUSES RTCOSC_INT

#USE fixed_io(c_outputs = PIN_C2, PIN_C3)

#define USB_CONFIG_HID_TX_SIZE   8
#define USB_CONFIG_HID_RX_SIZE   8


#use delay(clock=48000000)

#define CMD_length  20
char msg2[]="Hi Renjith,Its USB";
//A5 old B2 new
#define SL_LED_ON   {output_high( PIN_C2);}
#define SL_LED_OFF  {output_low( PIN_C2);}
#define LED_ON      {output_high( PIN_C2);}
#define LED_OFF     {output_low( PIN_C2);}

#define  USB_CONFIG_BUS_POWER 100   //300mA  (range is 0..500)

#include<usb_desc_cdc.h>
#include <usb_cdc.h>

unsigned long cmd_counter = 0;

#define USB_CON_SENSE_PIN PIN_B7

char x;
char out_data[USB_CONFIG_HID_TX_SIZE];
char in_data[USB_CONFIG_HID_RX_SIZE]; 

void usb_debug_task(void) {
   static int8 last_connected;
   static int8 last_enumerated;
   int8 new_connected;
   int8 new_enumerated;

   new_connected = usb_attached();
   new_enumerated = usb_enumerated();

   
 last_connected = new_connected;
   last_enumerated = new_enumerated;
}

void main(void)
{
   int i, j, address, value;
   memset(in_data, 0x00, USB_CONFIG_HID_RX_SIZE);
   memset(out_data, 0x00, USB_CONFIG_HID_TX_SIZE); 
   setup_oscillator(OSC_PLL_ON);
   output_high(pin_c2);
   enable_interrupts(GLOBAL);
   output_high(pin_c2);
   usb_init();
   delay_us(100);
   usb_cdc_init();
   delay_us(100);
   while(1)
   {
      usb_task();
      usb_debug_task();
      if (usb_enumerated())
      {
        output_high(pin_c2);
       //usb_put_packet(1, out_data, USB_CONFIG_HID_TX_SIZE, USB_DTS_TOGGLE);
               
         if (usb_cdc_kbhit())
      {
         output_low(pin_c2);
         x=usb_cdc_getc();
         delay_us(50);
         usb_cdc_putc(x);
         delay_us(50);
          if (usb_cdc_put_buffer_nextin && usb_cdc_put_buffer_free())
            {
               usb_cdc_flush_out_buffer();
            }
         delay_us(50);
           
         }
      }
   }         
}
temtronic



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

View user's profile Send private message

PostPosted: Fri May 23, 2014 5:22 am     Reply with quote

just jumping in here but...
...if I'm reading your code right...

I'd edit the delay_us(50); lines to delay_ms(100); for testing

50 microseconds is mighty fast...might be way too fast for either the PIC or the PC to deal with(you don't KNOW which yet). By slowing down the 'loop'(rcv---xmt) you stand a chance of seeing characters on the PC screen.

When I test any serial link, I go 'turtle slow' to confirm hardware and software is working, then up it to 'human' then to 'rabbit' when I am convinced I can.

hth
jay
ezflyr



Joined: 25 Oct 2010
Posts: 1019
Location: Tewksbury, MA

View user's profile Send private message

PostPosted: Fri May 23, 2014 6:50 am     Reply with quote

Hi Renjith_Beginow,



You need to seriously step back and re-evaluate your appraoach! Your current code is a mix of CDC and HID implementations, so clearly you aren't trying to understand what's going on, but rather you are just throwing random code at the problem trying to get something to work......

Seriously, take a look at the CCS supplied USB CDC examples (usb_cdc_serial2.c is a good place to start!) and begin there. These examples work as supplied, and you can build on them from there!

Your 'franken-code' is never going to work as written.....

John

PS Learn to use the 'Code' buttons. No one is going to take you seriously unless you can do that basic function......
Ttelmah



Joined: 11 Mar 2010
Posts: 19596

View user's profile Send private message

PostPosted: Fri May 23, 2014 7:11 am     Reply with quote

It is Franken-code.... Like the title...)

Thinks leap out like:

usb_cdc_put_buffer_nextin, which is a count, being used in a logic test...

This looks to be copied from the putempty macro, where there is an ==0 being omitted in what is pasted.....
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 Previous  1, 2, 3  Next
Page 2 of 3

 
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