View previous topic :: View next topic |
Author |
Message |
lindermat
Joined: 21 Nov 2011 Posts: 11
|
CCS USB code won't print an int32 long signed or unsigned |
Posted: Thu Feb 02, 2012 11:03 am |
|
|
Hi all,
I'm using the CCS supplied USB CDC software functions along with the driver on my PC and everything works fine except it crashes when printing an int32. (signed or unsigned) I've tried %Lu and %Ld, but neither work. %X does work however, which is strange.
I'd like to print the values in decimal and not hex. Is this a bug or am I doing something wrong?
Thanks, |
|
|
PCM programmer
Joined: 06 Sep 2003 Posts: 21708
|
|
Posted: Thu Feb 02, 2012 11:20 am |
|
|
Post your PIC, compiler version, and a short program that shows the
problem. The program should have an #include, #fuses, #use delay()
statements, and a main().
Example of compiler version numbers:
http://www.ccsinfo.com/devices.php?page=versioninfo |
|
|
lindermat
Joined: 21 Nov 2011 Posts: 11
|
|
Posted: Thu Feb 02, 2012 12:54 pm |
|
|
I can't really post it since has a lot of company information, (and it's in many different files), but the parts you asked for are below:
Code: |
#include <24FJ256GB210.h>
//#device ICD=2
//#fuses DEBUG // Debug mode for use with ICD
#fuses NODEBUG // No debug mode
#fuses NOWDT // Watch Dog timer disabled
#fuses NOWINDIS // Watch Dog Timer in Window mode
#fuses NOJTAG // JTAG disabled
#fuses NOIOL1WAY // Allows multiple configuration of peripheral pins
#fuses CKSFSM // Clock Switching is enabled, fail Safe clock monitor is enabled
#fuses PLL6 // Divide primary oscillator 24MHz input by 6 to get 4MHz
#fuses NOPROTECT // Code NOT protected from reading
#fuses ICSP1 // Use ICSP port 1
#fuses WPDIS // All Flash memory may be erased or written
#use delay(clock=32MHz, crystal=24MHz)
#use fast_io(ALL)
#use I2C(master, slow, sda = PIN_A15, scl = PIN_A14, force_hw, stream = I2C1)
#use I2C(master, slow, sda = PIN_A3, scl = PIN_A2, force_hw, stream = I2C2)
#use I2C(master, slow, sda = PIN_G0, scl = PIN_G1, force_hw, stream = I2C3)
#pin_select SDI1 = PIN_F8 // Data Out from SPI configuration memory (into the PIC)
#pin_select SDO1 = PIN_F3 // Data In to SPI configuration memory (out from the PIC)
#pin_select SCK1OUT = PIN_F2 // Serial CLocK signal to SPI configuration memory
#use SPI(master, di = PIN_F8, do = PIN_F3, clk = PIN_F2, force_hw, stream = SPI1, sample_rise, BITS = 8)
#pin_select OC2 = PIN_D5 // For output compare module PWM to the circulation fan (CH1_LOAD)
#pin_select OC3 = PIN_D4 // For output compare module PWM to the condensor fan (CH2_LOAD)
#include <defines.c>
#include <variables.c>
#include <ISRs.c>
#include <serial_flash.c>
#include <Gen2 Rev-.h>
#include <usb_cdc.h>
#include <string.h>
#include <input_output.c>
void main(void)
{ |
And finally the print statement:
Code: | printf(usb_cdc_putc, "\r\nPower cycle number = 0x%X", Read_Int32_From_Page(POWER_CYCLE_OFFSET, READ_POINTER)); |
Which works with the %X, but not %Lu or %Ld |
|
|
PCM programmer
Joined: 06 Sep 2003 Posts: 21708
|
|
Posted: Thu Feb 02, 2012 1:26 pm |
|
|
Quote: |
printf(usb_cdc_putc, "\r\nPower cycle number = 0x%X", Read_Int32_From_Page(POWER_CYCLE_OFFSET, READ_POINTER)); |
The first thing I would try is to break up this complex statement into
two smaller statements. See if it then works. Example:
Code: |
void main()
{
int32 result;
.
.
.
result = Read_Int32_From_Page(POWER_CYCLE_OFFSET, READ_POINTER);
printf(usb_cdc_putc, "\r\nPower cycle number = %lu", result);
while(1);
}
|
|
|
|
lindermat
Joined: 21 Nov 2011 Posts: 11
|
|
Posted: Thu Feb 02, 2012 2:01 pm |
|
|
Good idea, I thought that might work, but no luck.
It still locks up on %Lu but %X is ok. |
|
|
PCM programmer
Joined: 06 Sep 2003 Posts: 21708
|
|
Posted: Thu Feb 02, 2012 2:19 pm |
|
|
I don't have the PCD compiler to test, but you could try a couple more
things.
1. Try using sprintf() with %lu, which should put the output into an array.
Then display the array contents with "%s".
2. I suppose it's possible that CCS just wants "%L" for an int32 with PCD.
The manual doesn't say that, but that's another thing I would try.
I can't really do much more, because I don't have the compiler to test or
analyze the problem. |
|
|
FvM
Joined: 27 Aug 2008 Posts: 2337 Location: Germany
|
|
Posted: Fri Feb 03, 2012 12:35 am |
|
|
Did you try to increase the default stack size? |
|
|
lindermat
Joined: 21 Nov 2011 Posts: 11
|
|
Posted: Fri Feb 03, 2012 10:37 am |
|
|
Yes, that was it! It works now. (I also got the same reply from the official CCS support) Thank you everyone for your prompt replies! |
|
|
spilz
Joined: 30 Jan 2012 Posts: 220
|
|
Posted: Fri Mar 30, 2012 3:16 am |
|
|
Hey!
I have the same problem to print int32.
what was your solution?
using sprintf?
increase the default stack size?
using "%L" ?
can you share the solution please
thanks |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19591
|
|
Posted: Fri Mar 30, 2012 3:46 am |
|
|
Increasing the stack size.
This is _required_ by 90% of code using %f, %l etc..
CCS defaults to having the stack so small that several of the default printf operators won't work....
It is just about the commonest problem on PCD.
Best Wishes |
|
|
spilz
Joined: 30 Jan 2012 Posts: 220
|
|
Posted: Fri Mar 30, 2012 6:31 am |
|
|
Thanks for your quick reply
I'm sorry, but I don't really understand "how to do"
I guess the sprintf method schould work, but i would avoid to use a string as tempory variable. |
|
|
jeremiah
Joined: 20 Jul 2010 Posts: 1358
|
|
Posted: Fri Mar 30, 2012 6:56 am |
|
|
look at the #build pre processor directive in the compiler manual. It has instructions on how to set the stack size. |
|
|
|