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

Compiler V5.0 --> not enough RAM

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



Joined: 23 Apr 2009
Posts: 42

View user's profile Send private message

Compiler V5.0 --> not enough RAM
PostPosted: Tue Oct 08, 2013 7:45 am     Reply with quote

Since i changed to V5 of the compiler my old projects seem not to compile anymore,

Executing: "C:\Program Files (x86)\PICC\Ccsc.exe" +FM "Jaga_DBE_Basic.c" #__DEBUG=1 +ICD +DF +LN +T +A +M -Z +Y=9 #__12F683=TRUE
Error[74] Jaga_DBE_Basic.c 826 : Not enough RAM for all variables
1 Errors, 0 Warnings.
Build Failed.
Halting build on first failure as requested.
BUILD FAILED: Tue Oct 08 15:40:01 2013

While with V4 compiler this program worked OK.
I must say that in V4 the program memory was at 98%


is there a way to solve this problem? (other than getting a bigger processor Smile )

Code:

#include <12F683.h>
#define sVersion "0.8"

#device adc=10
#FUSES NOWDT                    //No Watch Dog Timer
#FUSES INTRC_IO                 //Internal RC Osc, no CLKOUT
#FUSES NOCPD                    //No EE protection
#FUSES NOPROTECT                //Code not protected from reading
#FUSES NOMCLR                   //Master Clear pin used for I/O
#FUSES NOPUT                         //Power Up Timer
#FUSES BROWNOUT               // brownout reset
#FUSES NOIESO                     //Internal External Switch Over mode enabled
#FUSES NOFCMEN                    //Fail-safe clock monitor enabled

#use delay(clock=8000000)
#use fast_io(A)
alan



Joined: 12 Nov 2012
Posts: 357
Location: South Africa

View user's profile Send private message

PostPosted: Tue Oct 08, 2013 7:50 am     Reply with quote

Get rid of the DEBUG, might save enough RAM.

Regards
RF_Developer



Joined: 07 Feb 2011
Posts: 839

View user's profile Send private message

Re: Compiler V5.0 --> not enough RAM
PostPosted: Tue Oct 08, 2013 8:17 am     Reply with quote

koenbielen wrote:

Error[74] Jaga_DBE_Basic.c 826 : Not enough RAM for all variables

I must say that in V4 the program memory was at 98%


The error message is that its running out of RAM, NOT program memory. Remember on PICs they are very different memory spaces.

You need to through your code and minimise the number of variables, both global and local. On most PICs there is no data stack so all local variables have to be statically allocated in RAM. That's why PICs can't really do recursion or re-entry into routines.

You need to make sure all variables are the minimum size to fit the required data. There's no point in having int32 when the values go from 0 to 100. Clearly int8 would do. Reduce the number of floats or replace them with carefully scaled 16 and 8 bit integers. As a bonus, the code will run faster and will generally be more precise.

Reduce the number of temporary variables.

Ensure all structures are arranged so as to allow easy alignment. int32s and int16s need to start on even byte boundaries. This means

Code:

struct
{
    int8 a;
    int32 b;
    int16 c;
}


may take up more space per instance than:

Code:

struct
{
    int32 b;
    int16 c;
    int8 a;
}


Do not pass strings in RAM.

Make all strings and buffers the bare minimum size to contain all the data they need to contain. Avoid copying strings and buffers where possible: two copies take up more RAM than one. Use pointers to point at sub-strings etc. though, of course, pointers carry their own risks.

Don't use dynamic allocation of memory: no malloc etc.

There's a lot of other things other folk will tell you about.

However, in almost the whole history of computing, simply getting a bigger processor, with more RAM/speed/whatever, has been the simplest and generally the best option. The PIC12F683 has just 128 bytes or RAM. That's the lot, not even enough for half this message. Let's face it, it's tiny, even by 1950's standards.
gpsmikey



Joined: 16 Nov 2010
Posts: 588
Location: Kirkland, WA

View user's profile Send private message

PostPosted: Tue Oct 08, 2013 9:13 am     Reply with quote

Yes, but his point was that the same code failed to build on V5, but did build on V4.xxx (although it was at 98%). Something about V5 is allocating the PIC RAM somewhat differently so that it goes over the edge. Granted, he should not be that close to the limit, but in this case, V5 appears to not optimize the RAM usage like V4.xxx was. That said, I get nervous when I pass about 70% RAM usage :-)

mikey
_________________
mikey
-- you can't have too many gadgets or too much disk space !
old engineering saying: 1+1 = 3 for sufficiently large values of 1 or small values of 3
Ttelmah



Joined: 11 Mar 2010
Posts: 19504

View user's profile Send private message

PostPosted: Tue Oct 08, 2013 9:21 am     Reply with quote

No, you are fractionally missing the point. He reports the program memory was at 98%, but it is the _RAM_ that is being complained about in the failure. Generally, I have seen V5, use slightly less RAM, but slightly more ROM. Since he doesn't say what was being reported in V4, for RAM, we are 'guessing'. For all we know, V4, could have been saying the RAM was at 100%, with no spare at all....

Best Wishes
gpsmikey



Joined: 16 Nov 2010
Posts: 588
Location: Kirkland, WA

View user's profile Send private message

PostPosted: Tue Oct 08, 2013 12:47 pm     Reply with quote

Ah, you're right - I did miss the fact he said "Program memory" - it has been one of those mornings. He may have meant RAM, but did say Program memory. I had read it as RAM. Sigh Rolling Eyes

mikey
_________________
mikey
-- you can't have too many gadgets or too much disk space !
old engineering saying: 1+1 = 3 for sufficiently large values of 1 or small values of 3
Ttelmah



Joined: 11 Mar 2010
Posts: 19504

View user's profile Send private message

PostPosted: Tue Oct 08, 2013 1:09 pm     Reply with quote

I think we have all been there sometimes...
I call it "straining up under the bear". Seems to describe things perfectly sometimes. Smile

I've seen several programs get a tiny touch larger in ROM, but nothing get bigger in RAM with V5. The default should be *=8, with this compiler and chip, so all the RAM should be available. If he is using interrupts, might be worth trying CCS4 mode, though normally CCS5 saves RAM.

Posting the .sym file from the V4 compile might give us a clue.

Best Wishes
koenbielen



Joined: 23 Apr 2009
Posts: 42

View user's profile Send private message

DBEBUG
PostPosted: Wed Oct 09, 2013 1:14 am     Reply with quote

Hi,

When I removed the debug as Alan replied the problem was solved. Idea

RF Developer, thank you for the info. I will optimize my code.

Thank you everyone.

byby
Ttelmah



Joined: 11 Mar 2010
Posts: 19504

View user's profile Send private message

PostPosted: Wed Oct 09, 2013 1:49 am     Reply with quote

The debugger uses about 20% of the RAM, so turning it off, gives a lot more space.
How is the ROM usage, given you were so close on the previous compiler?.

Best Wishes
epalite



Joined: 06 Apr 2008
Posts: 16

View user's profile Send private message

PostPosted: Tue Dec 03, 2013 3:02 am     Reply with quote

Hi all,

the v5 (v5.015/016) uses significantly more ROM space. So, what special does it do compared with v4? Anyone can shed the light?

Thanks!
oxo



Joined: 13 Nov 2012
Posts: 219
Location: France

View user's profile Send private message

PostPosted: Tue Dec 03, 2013 7:36 am     Reply with quote

<joke>

It needs extra space for all the new bugs they have introduced.

</joke>
Ttelmah



Joined: 11 Mar 2010
Posts: 19504

View user's profile Send private message

PostPosted: Tue Dec 03, 2013 8:07 am     Reply with quote

#opt compress

Usually gives smaller sizes than V4. Smile

The optimiser default has been shifted to have a slightly higher priority on 'speed'.

Best Wishes
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