View previous topic :: View next topic |
Author |
Message |
stinky
Joined: 05 Mar 2012 Posts: 99 Location: Central Illinois
|
New Computer at Work, Previous projects won't compile now |
Posted: Mon Mar 05, 2012 11:40 am |
|
|
The PCM compiler was installed on my work machine before I started working on it so I have never installed the PCM compiler myself.
I've received a new work machine and I have installed MPLAB, the MPLAB CCS Plugin, and CCS.
I had a CD on file that contained the CCS setup program, the pcm.crg file, and a text file that "documents" how to install the program.
I tried my best, and I can open existing mplab workspaces or I can use project wizard to make a new workspace but I cannot get my programs to compile.
At compile time I see these errors:
>>> Warning 207 "720025E-M4.c" Line 1214(44,45): Code has no effect
*** Error 71 "720025E-M4.c" Line 1356(1,2): Out of ROM, A segment or the program is too large MOMENTARY_MODE
Seg 00031-006FF, 0082 left, need 00CB
Seg 00000-00003, 0000 left, need 00CB
Seg 00004-00030, 0000 left, need 00CB
1 Errors, 1 Warnings.
I have changed nothing in the code. It compiles on the previous machine.
UPDATE:
I tried a different project, it successfully compiles however it takes up 69% of my ROM space where as the previous machine only takes up 54%.
Does that mean anything to you guys?
Thanks |
|
|
asmboy
Joined: 20 Nov 2007 Posts: 2128 Location: albany ny
|
|
Posted: Mon Mar 05, 2012 1:30 pm |
|
|
What version is your compiler? |
|
|
stinky
Joined: 05 Mar 2012 Posts: 99 Location: Central Illinois
|
|
Posted: Mon Mar 05, 2012 2:03 pm |
|
|
The new machine has 4.107 installed. The old machine has 4.007 installed. |
|
|
asmboy
Joined: 20 Nov 2007 Posts: 2128 Location: albany ny
|
|
Posted: Mon Mar 05, 2012 2:14 pm |
|
|
1- is it possible you have mixed up your DEVICE headers ??
2- when you look at the line number and section of your code that is id'd as doing nothing WHAT IS it actually??
This seems like the core problem is a version difference and you are maybe not using the compiler you think you are.
Of the code that DID compile - what version is implanted in the head of the .LST file ??? |
|
|
stinky
Joined: 05 Mar 2012 Posts: 99 Location: Central Illinois
|
|
Posted: Mon Mar 05, 2012 2:38 pm |
|
|
asmboy wrote: | 1- is it possible you have mixed up your DEVICE headers ?? |
I don't believe so. The code that did compile successfully programmed onto a pic.
asmboy wrote: | 2- when you look at the line number and section of your code that is id'd as doing nothing WHAT IS it actually?? |
Checking a variable stored in EEPROM, and writing to if necessary:
if(read_eeprom(EE_6_LOCATION) != CSELECT);
WriteToEE(EE_6_LOCATION,CSELECT);
This particular line is in a string of similar functions that did not produce
the same error.
asmboy wrote: | This seems like the core problem is a version difference and you are maybe not using the compiler you think you are.
Of the code that DID compile - what version is implanted in the head of the .LST file ??? |
The top line of the .LST file reads:
CCS PCM C Compiler, Version 4.107, 52612 05-Mar-12 14:02
I'm inclined to agree with you. But I'm not sure how I can get the 4.007 version back when the only one I have locally is 4.107. Will CCS give me access to the old compiler? |
|
|
asmboy
Joined: 20 Nov 2007 Posts: 2128 Location: albany ny
|
|
Posted: Mon Mar 05, 2012 2:43 pm |
|
|
if i was in your shoes - i would contact CCS support and make the request. |
|
|
stinky
Joined: 05 Mar 2012 Posts: 99 Location: Central Illinois
|
|
Posted: Mon Mar 05, 2012 3:07 pm |
|
|
I will take your advice.
I used beyond compare to look at the header files from the different
compilers and there are more differences than I would like to have seen.
Thanks for spending some time with me asmboy! |
|
|
PCM programmer
Joined: 06 Sep 2003 Posts: 21708
|
|
Posted: Mon Mar 05, 2012 7:38 pm |
|
|
Quote: | The new machine has 4.107 installed. The old machine has 4.007 installed.
>>> Warning 207 "720025E-M4.c" Line 1214(44,45): Code has no effect
if(read_eeprom(EE_6_LOCATION) != CSELECT);
WriteToEE(EE_6_LOCATION,CSELECT);
This particular line is in a string of similar functions that did not produce
the same error.
|
You really don't want to go back to vs. 4.007. It's allowing bugs to
get into your final code by not warning you of common mistakes.
Look closely at your if() statement above. What does it have on the end
of it ? What will this do to the if() statement ? Hint: The warning in
vs. 4.107 is correct. You really need to be using vs. 4.107 or later.
Or you need to run a lint program on your source code.
Quote: |
I used beyond compare to look at the header files from the different
compilers and there are more differences than I would like to have seen. |
That's because they added more features to the built-in functions in
the 100 versions between 4.007 and 4.107. They also have corrected
a lot of bugs. |
|
|
stinky
Joined: 05 Mar 2012 Posts: 99 Location: Central Illinois
|
|
Posted: Tue Mar 06, 2012 8:24 am |
|
|
Hey PCM programmer!
Good catch. That line of code has been in use on v 4.007 for at least 16 months and the compiler never caught it.
Any thoughts on why v 4.107 is consuming more space to compile the same code? |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19589
|
|
Posted: Tue Mar 06, 2012 8:41 am |
|
|
Without knowing what libraries you used, no.
However I'm astonished you had a project so large that actually worked with .007. This was so far before almost any feature of the compiler worked 'right', that it is quite amazing....
I's suspect the most likely thing is that more stuff is being 'inlined'. The compiler now tends to do this to give better speed, unless space is getting short.
Best Wishes |
|
|
stinky
Joined: 05 Mar 2012 Posts: 99 Location: Central Illinois
|
|
Posted: Tue Mar 06, 2012 9:20 am |
|
|
Ttelmah:
I didn't know the state of 4.007 was so bad.
I don't believe I've got anything fancy in here as far as libraries. I have my own header file that sets the #fuses, maps constants to pin numbers, and defines some macros. Aside of that, just the standard PIC header file.
I tried using the #separate command on a handful of functions and when I go to build I did not see a change in the amount of space needed.
re: astonishment.
I have another program, compiled under 4.007, that hit 91%. Works well. |
|
|
PCM programmer
Joined: 06 Sep 2003 Posts: 21708
|
|
Posted: Tue Mar 06, 2012 5:24 pm |
|
|
Quote: | I don't believe I've got anything fancy in here as far as libraries |
In this case, "libraries" means #use statements, and also it means
any CCS driver files (.c and/or .h) that are in #include statements
in your program.
Quote: |
c:\program files\picc\drivers
|
Post all the #use statements, and post a list of the driver files that you're using.
Also, tell us if you are using any special control statements such as #build, #org, and #rom. |
|
|
stinky
Joined: 05 Mar 2012 Posts: 99 Location: Central Illinois
|
|
Posted: Thu Mar 08, 2012 12:59 pm |
|
|
PCM programmer:
"#use" statements:
Code: | #use fast_io(A)
#use fast_io(B)
#use delay (clock=8000000)
|
"#include" and misc:
Code: | #include "720025E.h"
#ID CHECKSUM
#include <16F819.h>
#device adc=8
|
"#ROM" statement:
Code: | #ROM 0x2100 = {LOCKOUT,2,2,2,2,0,2,0}
|
And some "#ASM" in my main line:
Code: |
//setup_timer_0(RTCC_INTERNAL|RTCC_DIV_1);
#ASM
movlw 0x01
movwf 0x10
#ENDASM
|
There is only one .C file that contains the Mainline and routines.
The 720025.h file is the one that contains my #fuses, constants,
and macros. |
|
|
PCM programmer
Joined: 06 Sep 2003 Posts: 21708
|
|
Posted: Thu Mar 08, 2012 1:41 pm |
|
|
I don't see anything there that would cause your code size to increase
greatly between versions. What about other CCS functions ? Do you
use any of these compiler features:
Flash memory:
write_program_memory()
read_program_memory()
write_program_eeprom()
read_program_eeprom()
Floating point:
Do you use floating point math ? Do you have any floating point
variables declared ? Do you have printf statements that print floating point ? What floating point operators do you use ?
The compiler error message refers to, I assume, a function called
momentary_mode(). What's in that function ?
Quote: |
A segment or the program is too large MOMENTARY_MODE |
|
|
|
stinky
Joined: 05 Mar 2012 Posts: 99 Location: Central Illinois
|
|
Posted: Fri Mar 09, 2012 10:49 am |
|
|
I'm not using any of those compiler features you mentioned.
I've stuck to all integer math.
The only things in the function momentary_mode() are looking
at user pressed switches and performing logic with them.
I just went for a shotgun approach. I added a #separate command
to each function in the program and it successfully compiled.
All I've read about this is that it saves space at the sacrifice of speed.
I will begin testing the code like this but do you have any words of wisdom or warnings about what this could do? |
|
|
|