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

ASM codes appear before C statements in .lst file.

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



Joined: 10 Jan 2013
Posts: 68

View user's profile Send private message

ASM codes appear before C statements in .lst file.
PostPosted: Fri Apr 19, 2013 2:22 pm     Reply with quote

"Sometimes" ASM codes appear before C statements in the .lst file in (V4.130).
I saw this problem when I compiled my bigger code.
Then I had a hard time trying to Reproduce it on a short code for posting here. Finally I succeeded!
What's wrong? Is it OK?

Code:
#include <16F873A.h>
#FUSES NOWDT                   //No Watch Dog Timer
#FUSES HS                      //High speed Osc (> 4mhz for PCM/PCH) (>10mhz for PCD)
#FUSES NOPUT                   //No Power Up Timer
#FUSES NOPROTECT               //Code not protected from reading
#FUSES NODEBUG                 //No Debug mode for ICD
#FUSES NOBROWNOUT              //No brownout reset
#FUSES NOLVP                   //No low voltage prgming, B3(PIC16) or B5(PIC18) used for I/O
#FUSES NOCPD                   //No EE protection
#FUSES NOWRT                   //Program memory not write protected
#use delay(clock=20000000)
#use rs232(baud=9600, UART1)

#byte CCP1CON  =0x17
#byte T2CON    =0x12
#byte PR2      =0x92
#byte CCPR1L   =0x15
#byte CCP2CON   = getenv("SFR:CCP2CON")


Code:

#include "ccp.h"
void main()
{
set_tris_c(0xf0);
printf ("start:\r\n");
if (!input(pin_c7))
{
  output_low(pin_b0);
}
output_high(pin_b0);
printf ("\r\n%X%X%X%X\r\n" ,PR2,T2CON,CCP1CON,CCPR1L);
while(true);
}


Code:

.................... {
008E:  MOVLW  F0
008F:  MOVWF  TRISC
0090:  BCF    STATUS.RP0
0091:  MOVWF  @TRIS_C
.................... set_tris_c(0xf0);
0092:  MOVLW  04
0093:  BSF    STATUS.RP1
0094:  MOVWF  EEADR
0095:  MOVLW  00
0096:  MOVWF  EEADRH
0097:  BCF    STATUS.RP1
0098:  GOTO   @PSTRINGC7_9600_62_63
.................... printf ("start:\r\n");
0099:  BSF    @TRIS_C.7
009A:  MOVF   @TRIS_C,W
009B:  BSF    STATUS.RP0
009C:  MOVWF  TRISC
009D:  BCF    STATUS.RP0
009E:  BTFSC  PORTC.RC7
009F:  GOTO   0A4
.................... if (!input(pin_c7))
.................... {
00A0:  BSF    STATUS.RP0
00A1:  BCF    TRISB.TRISB0
00A2:  BCF    STATUS.RP0
00A3:  BCF    PORTB.RB0
....................   output_low(pin_b0);
.................... }
00A4:  BSF    STATUS.RP0
00A5:  BCF    TRISB.TRISB0
00A6:  BCF    STATUS.RP0
00A7:  BSF    PORTB.RB0
.................... output_high(pin_b0);
Ttelmah



Joined: 11 Mar 2010
Posts: 19592

View user's profile Send private message

PostPosted: Sat Apr 20, 2013 2:26 am     Reply with quote

The C lines are only put in at all as a 'this is roughly the code for this' aid. In many cases parts of the code will be many lines away. Why the assembler sometimes gets in front, is indeterminate, but it makes no difference to the result.
It depends on compiler version, and optimisation level.
Your example doesn't locate like this on earlier of later versions. However the code generated is the same, so it isn't a problem.

Best Wishes
notbad



Joined: 10 Jan 2013
Posts: 68

View user's profile Send private message

PostPosted: Sat Apr 20, 2013 10:48 am     Reply with quote

Thank you
I did a little more tests and as it seems, This happens when the last directive in the .h file ends with a parentheses and there is no "carriage return-line feed" at the end. At least that's so in my case.
Ttelmah



Joined: 11 Mar 2010
Posts: 19592

View user's profile Send private message

PostPosted: Sun Apr 21, 2013 1:47 am     Reply with quote

I'd guess it counts 'lines', by counting the line feeds, and if you have a line at the end of the include that doesn't have a line feed, it gets one line out on it's 'count' of which line in the source file, corresponds to the code block.

Best Wishes
ckielstra



Joined: 18 Mar 2004
Posts: 3680
Location: The Netherlands

View user's profile Send private message

PostPosted: Sun Apr 21, 2013 4:20 am     Reply with quote

Now you have found the reason why, it is easy to create a workaround. Either way, it is good practice to terminate the last line in your files with a newline.

Somehow I configured my MPLAB to always ensure that the header file ends with an empty line. If the last line is not terminated with an CR/LF, than this is added by MPLAB on saving.

Note that many other compilers like Visual Studio and GCC generate a warning when the last line of a header file contains code because it is a known issue to generate problems down the line of compiler tools.
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