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

Button command response slow

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



Joined: 03 Oct 2012
Posts: 242
Location: chennai

View user's profile Send private message

Button command response slow
PostPosted: Fri Dec 28, 2012 6:46 am     Reply with quote

When i use the below program, and once button pressed in the hardware, it increments very fast in the display. It happens because of debounce. But when i change the line

sprintf (msg,"%LU", i); to

sprintf (msg,"%6LU", i);

and once pressed, it increments very slow. Why is it so?

Code:
#include <18F2520.h>
#fuses HS,NOWDT,NOPROTECT,NOLVP
#use delay(clock=6144000)
#define EN     PIN_A1
#define RS     PIN_A2
 
#define line1  (0x80)
#define line2  (0xC0)
#define KEY1     PIN_C0

void lcd_cmd(CHAR a);  // function declaration
void lcd_print(CHAR rstr[]);
CHAR msg[50];
int16 i=0;
 

void main()
{
   output_low (RS); //set LCD to command mode 
   lcd_cmd (0x38); //set LCD to 2x8 LINE DISPLAY (8 bit) 
   lcd_cmd (0x01); //clear LCD screen 
   lcd_cmd (0x02); //move cursor to home position
   lcd_cmd (0x0e); //set cursor to blinking
   lcd_cmd (0x06); //move cursor right side automatically by 1 
 
   WHILE (1)
   {
          if ( input(key1)==0 )
          {
             i++;         
          }
         
          output_low (RS); //set LCD to command mode   
          lcd_cmd (LINE2); 
          sprintf (msg,"%LU", i);               
          lcd_print (msg);         
   } 
}
 
void lcd_cmd(CHAR a)  // TO enaable LCD microcontroler  // function definition
{
   output_b (a);
   delay_ms (10);
   output_high (EN);
   delay_ms (10);
   output_low (EN);
}
 
void lcd_print(CHAR rstr[])
{
   INT i;
 
   FOR (i=0; rstr[i]!='\0'; i++)
   {
      output_high (rs); //set LCD to data mode
      lcd_cmd (rstr[i]); //printing the charact to display LCD
   }
}
temtronic



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

View user's profile Send private message

PostPosted: Fri Dec 28, 2012 7:06 am     Reply with quote

comment.
dump the listings for the two programs and compare the amount of code the compiler generates for the 2 print functions.
you should then see why.

hth
jay
hemnath



Joined: 03 Oct 2012
Posts: 242
Location: chennai

View user's profile Send private message

PostPosted: Wed Jan 02, 2013 5:36 am     Reply with quote

this is the asm code i got . Please explain. i dont know assembly

Code:

....................           sprintf (msg,"%6LU", i);                 
01A4:  CLRF   3A
01A6:  MOVLW  05
01A8:  MOVWF  39
01AA:  MOVLW  01
01AC:  MOVWF  3B
01AE:  MOVLW  20
01B0:  MOVWF  45
01B2:  RCALL  0048
01B4:  DECFSZ 3B,F
01B6:  BRA    01AE
01B8:  MOVLW  00
01BA:  MOVWF  FE9
01BC:  MOVFF  38,3D
01C0:  MOVFF  37,3C
01C4:  BRA    0064


....................           sprintf (msg,"%LU", i);                 
01A6:  CLRF   3A
01A8:  MOVLW  05
01AA:  MOVWF  39
01AC:  MOVLW  10
01AE:  MOVWF  FE9
01B0:  MOVFF  38,3C
01B4:  MOVFF  37,3B
01B8:  BRA    0066
Mike Walne



Joined: 19 Feb 2004
Posts: 1785
Location: Boston Spa UK

View user's profile Send private message

PostPosted: Wed Jan 02, 2013 7:15 am     Reply with quote

The microchip data sheet usually includes the asm instruction set.

The second code fragment is linear, i.e. runs straight through.

The first includes a loop.

The instruction "01B6: BRA 01AE" is braching back several times to the instruction "01AE: MOVLW 20".

The loop also includes the call "01B2: RCALL 0048" which will also take time.

You could get MPLAB to tell you how many instruction cycles each code fragment takes to execute.

Mike
ckielstra



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

View user's profile Send private message

PostPosted: Wed Jan 02, 2013 8:28 am     Reply with quote

First of all, learning assembly code will pay off. It is easy to learn, much easier than C, and it allows you to understand underlying problems like why some commands in C take much longer than other commands.

Even without knowing assembly language you can test the time difference between your to programs using the Stopwatch function in the MPLAB Simulator as indicated by Mike.

But then... why do you care?
You said that the counter increases by switch bouncing effects. Shouldn't you just fix this bouncing problem?
dorinm



Joined: 07 Jan 2006
Posts: 38

View user's profile Send private message

PostPosted: Sun Jan 06, 2013 9:32 am     Reply with quote

what do you mean "very slow"? 10/s? 1/s? how many increments? I assume (from your code) that 1 digit number takes ~20ms to "print", 2 digit ~40ms ... su 6digit will take ~120msec (compared to 1 digit 20msec, you actually CAN see slower increment, if this is what you ask, when you ask the printf to format to a 6 digit (space is also a char and will be printed, right? Smile ))
...?
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