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

Generating assembly in large multi-unit projects

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



Joined: 17 Jun 2019
Posts: 593
Location: Des Moines, Iowa, USA

View user's profile Send private message Visit poster's website

Generating assembly in large multi-unit projects
PostPosted: Tue Feb 25, 2020 11:21 am     Reply with quote

When I do a simple, small test program, I see each file represented by assembly source in the .lst file.

But in a large project here, we haven't been able to find the source in all files. I finally made a simple test program and called it from main():

Code:
void main()
{
   Test();
...


And then Test() exists in a separate file. When I check the resulting list, I find the Test() file in the comments:

Line 463216:
Code:

                         .............................. void Test()
                         .............................. {
                         ..............................    printf ("Test()\r\n");
                         .............................. }
                         ..............................


But there is no source around it. From main(), I see where it's calling:

Code:
                         ..............................    Test();
0E4EE 02684A 000000  CALL    684A           :


...and when I check for 684A, I find source there:

Line 135446:
Code:
*
0684A 200001         MOV     #0,W1          : W1 = 0
0684C 780001         MOV     W1,W0          : W0 = W1
0684E EF6001         CLR.B   1              : W0H = 0
*
06854 E80081         INC     W1,W1          : W1 = W1 + 1
06856 781F81         MOV     W1,[W15++]     : Push W1 to TOS
06858 F83456         PUSH    3456           : PUSH [3456] to TOS
0685A 9FFFE0         MOV.B   W0L,[W15-#2]   : [W15+-2] = W0L
0685C F93456         POP     3456           : POP TOS to [3456]
*
06862 7800CF         MOV     [--W15],W1     : POP TOS to [--W15]
06864 200080         MOV     #8,W0          : W0 = 8
06866 E60800         CPSGT   W1,W0          : Skip if W1 > W0
06868 37FFF1         BRA     684C           : GoTo 684C
0686A 060000         RETURN                 : Return 
                         ..............................
                         ..............................
                         ..............................
                         ..............................
                         ..............................


The asm is a few hundred thousand lines away from the C source, and the C source is surrounded by thousands of lines of ".....".

Is there a trick to get the assembly to be inlined near the C source code in the comments?
_________________
Allen C. Huffman, Sub-Etha Software (est. 1990) http://www.subethasoftware.com
Embedded C, Arduino, MSP430, ESP8266/32, BASIC Stamp and PIC24 programmer.
http://www.whywouldyouwanttodothat.com ?

Using: 24FJ256GA106, 24EP256GP202 and 24FJ64GA002.
temtronic



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

View user's profile Send private message

PostPosted: Tue Feb 25, 2020 11:35 am     Reply with quote

Allen you sure do find things that I've never seen since PCM v2.453 !

As for why the asm code is 'far, far away', that's explained in the manual FAQ or Q&A section. In a nutshell, the single pass compiler has to fit code into available 'bank' spaces and can't overflow. It will rearrange functions to try to maximize complete code in a bank. You'll see posts about 'Out of ROM' with lots of ROM actually left, but you can't put two 5KB functions into one 8KB bank. You also can't 'split' a function over 2 banks.
At least not long time ago.
If you want a listing to appear in 'code space' sequence, import to a program that will sort based on memory address. I did that 4 decades ago while cutting Z80 assembler.
allenhuffman



Joined: 17 Jun 2019
Posts: 593
Location: Des Moines, Iowa, USA

View user's profile Send private message Visit poster's website

PostPosted: Tue Feb 25, 2020 11:39 am     Reply with quote

I found a reference to the out-of-order .lst in the FAQ (something I'd been wondering about):

http://www.ccsinfo.com/faq.php?page=lst_out_of_order

It does make the assembly rather useless when you can't (easily?) figure out what asm belong to what code. Smile

In this case, I'm trying to track down the printfs() that are printing the wrong string, to look at the good vs bad asm and see what the difference is.
_________________
Allen C. Huffman, Sub-Etha Software (est. 1990) http://www.subethasoftware.com
Embedded C, Arduino, MSP430, ESP8266/32, BASIC Stamp and PIC24 programmer.
http://www.whywouldyouwanttodothat.com ?

Using: 24FJ256GA106, 24EP256GP202 and 24FJ64GA002.
temtronic



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

View user's profile Send private message

PostPosted: Tue Feb 25, 2020 11:54 am     Reply with quote

gee Allen, I started PICkin when all PICs had quartz skylights and erase meant time for another 15 minute coffee break Laughing PICs are easy to code in assembler, only 35 instructions, far less than Z80 or 8080s. Sadly today's PICs have more fuses than instructions.
Surely there's some 'fancy' Windoze 'ap' you can import and sort the listing ? Even the old DOS 'sort.exe' might work... Wink
allenhuffman



Joined: 17 Jun 2019
Posts: 593
Location: Des Moines, Iowa, USA

View user's profile Send private message Visit poster's website

PostPosted: Tue Feb 25, 2020 11:55 am     Reply with quote

temtronic wrote:

Surely there's some 'fancy' Windoze 'ap' you can import and sort the listing ? Even the old DOS 'sort.exe' might work... Wink


Not sure that helps. There's no reference around the C source to know what it belongs with. I only found it manually by looking at a CALL then finding that.
_________________
Allen C. Huffman, Sub-Etha Software (est. 1990) http://www.subethasoftware.com
Embedded C, Arduino, MSP430, ESP8266/32, BASIC Stamp and PIC24 programmer.
http://www.whywouldyouwanttodothat.com ?

Using: 24FJ256GA106, 24EP256GP202 and 24FJ64GA002.
temtronic



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

View user's profile Send private message

PostPosted: Tue Feb 25, 2020 1:00 pm     Reply with quote

I was under the impression you wanted the listing to be in same order the physical PIC memory is, not 'splattered all over the place'....
allenhuffman



Joined: 17 Jun 2019
Posts: 593
Location: Des Moines, Iowa, USA

View user's profile Send private message Visit poster's website

PostPosted: Tue Feb 25, 2020 1:45 pm     Reply with quote

temtronic wrote:
I was under the impression you wanted the listing to be in same order the physical PIC memory is, not 'splattered all over the place'....


Well, yes, that would be nice because I had wondered why there were huge gaps -- but in this case, I just want to find the code for a printf() and sprintf() and look at why it's using the wrong string.

Now that I have learned that the gaps are not gaps (necessarily), sorting in Notepad++ works great. I was quite puzzled by seeing things jump around like that.
_________________
Allen C. Huffman, Sub-Etha Software (est. 1990) http://www.subethasoftware.com
Embedded C, Arduino, MSP430, ESP8266/32, BASIC Stamp and PIC24 programmer.
http://www.whywouldyouwanttodothat.com ?

Using: 24FJ256GA106, 24EP256GP202 and 24FJ64GA002.
temtronic



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

View user's profile Send private message

PostPosted: Tue Feb 25, 2020 4:28 pm     Reply with quote

I think it goes back to the 'try to fill each bank with complete code' algorithm for the compiler.
Initially it may try to do it inline but decide it can't fit a complete function or 'chunk' of contiguous code into a bank. It may then attempt to do a 'best fit' approach. I know in the past you could NOT have a function cross a boarder between banks, especilally tables !
Over the years PICs have got bigger so I assume CCS has more 'smarts' in the compiler to figure all this stuff out. To complicate things, there's more 'features' and 'C' compatibilty to deal with. Originally CCS C wasn't 'official' C ( whatever that means.....)
allenhuffman



Joined: 17 Jun 2019
Posts: 593
Location: Des Moines, Iowa, USA

View user's profile Send private message Visit poster's website

PostPosted: Wed Feb 26, 2020 1:30 pm     Reply with quote

temtronic wrote:
I think it goes back to the 'try to fill each bank with complete code' algorithm for the compiler.


Thanks! I really need to start doing a series on PIC/CCS on my site. I think there's some great "newbies need to know this" stuff I've learned here that would have been great to know when I started and "[spam]-u-me'd" it was a normal C compiler.
_________________
Allen C. Huffman, Sub-Etha Software (est. 1990) http://www.subethasoftware.com
Embedded C, Arduino, MSP430, ESP8266/32, BASIC Stamp and PIC24 programmer.
http://www.whywouldyouwanttodothat.com ?

Using: 24FJ256GA106, 24EP256GP202 and 24FJ64GA002.
temtronic



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

View user's profile Send private message

PostPosted: Wed Feb 26, 2020 1:43 pm     Reply with quote

Well.. there's no such thing as a 'normal C compiler', never has, never will be. Every mfr of a compiler has their 'quirks' and of course there is no official, died in the wool, cast in granite C language. Everything 'evolves'.
CCS does a darn good job of getting THEIR version of 'C' to run in PICs and obviously CCS C won't run in an Ardunio.
I'm not a trained C programmer, rather I've muddled through, self taught since PCM 2.534+-. My programs may not be coded in 'official C' practices, but they work.
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