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

PIC16F716 4MhZ Clock delay_us wrong timing

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



Joined: 10 Nov 2010
Posts: 4
Location: UK

View user's profile Send private message

PIC16F716 4MhZ Clock delay_us wrong timing
PostPosted: Wed Nov 10, 2010 9:21 am     Reply with quote

Hi all i am new on the forum,
My name is Michael.

I have a problem with my PIC16F716 i am using a 4Mhz oscillator i defined that on the beginning of the software.


When i am trying to make 1us delay by delay_us(1), it is making aprox. 5us delay.. Can i do anything about that ?

Thank you for your help.
Regards,
Michael.
SherpaDoug



Joined: 07 Sep 2003
Posts: 1640
Location: Cape Cod Mass USA

View user's profile Send private message

PostPosted: Wed Nov 10, 2010 9:33 am     Reply with quote

Show us a complete compilable program that demonstrates the problem. Try to keep it under a dozen lines or so. Also tell us the version of your compiler (4.xxx).
_________________
The search for better is endless. Instead simply find very good and get the job done.
michael_s



Joined: 10 Nov 2010
Posts: 4
Location: UK

View user's profile Send private message

PostPosted: Wed Nov 10, 2010 10:00 am     Reply with quote

Hi thank you for the answer, there is a code I am using, it is just a sketch because I just start playing with PIC so I am fresh Smile.

Regards.
Code:

/******************************************************************************/
// Filename:      main.c                                                
// Compiler:      CCS PIC compiler                                             
// Micro:         PIC 16F716                                               
// Authors:                                        
// Revision:                                                   
/******************************************************************************/

/******************************************************************************/

#include <16F716.h>

#use     delay(clock=4000000,crystal)         // Osc freq = 4MHz
#use     fast_io(A)                        // I/O direction not set for each I/O instruction
#use     fast_io(B)

#fuses   XT,NOWDT,NOBROWNOUT,PUT,PROTECT    //Fuse bits settings


#include "definitions.h"         //Include Header File with all definitions and declarations
#include "initialization.h"         //Initialize PIC - system all hardware counters ETC...



/*****************************************************************************
            PROTOTYPE DEFINITION
******************************************************************************/

void Initialize (void);               // Initialize all system I/O etc...
void default_states (void);            // Initialize all variables and default port states on powewr up



///////////////////////
// HALF SECOND DELAY///
///////////////////////
void WaitHalfSec (void)
   {
        delay_ms(500);
   }



/////////////////////////////
// ONE SECOND DELAY//////////
/////////////////////////////
void WaitSec (void)
   {
        delay_ms(1000);
   }




//       ///  /////////  //  //     //
////    ////  //     //  //  ////   //
/////  // //  //     //  //  // //  //
// // //  //  /////////  //  // //  //
//  //    //  //     //  //  //  // //
//        //  //     //  //  //  // //
//        //  //     //  //  //   ////
 


/************************************************************************/
/***********          Main program starts here.               ***********/
/************************************************************************/

void main()

{
   Initialize();      // Initialize the PIC (all hardware Timers etc...)   
   default_states();   // Initialize all variables on the system
   disable_interrupts (GLOBAL);

   

   
   

      while (true)   // this is main loop
            {

      
      delay_us(1);
      output_toggle(LED);
      
                        

            }   


}

/************************************************************************/
/***********          Main program finish here.               ***********/
/************************************************************************/






// Include additional code.
#include "interupts_handlers.h"   // All procedures regarding Interrupts External or Internal
#include "default_states.h"         //Set all defaults states of ports.


PS. I just run the program without any delay
Just wrote inside the main loob While(TRUE)
Code:
output_bit(LED,1);
output_bit(LED,0);

And the status of the LED line is changing for high for 3 us and for low for 5us. The time should be much shorter isn't it ?
Ttelmah



Joined: 11 Mar 2010
Posts: 19552

View user's profile Send private message

PostPosted: Wed Nov 10, 2010 10:30 am     Reply with quote

That is not the delay taking 5uSec, but the loop, and I/O.

Your processor is basically running at 1MIPS.
When you perform an input or output operation using 'standard_io' (the default), the code will update the TRIS register, and then the actual I/O register. So the 'output_toggle' will be two instructions.
The delay, will be coded as a single 'nop' instruction.
The loop, will be a simple 'jump', but these take two instruction times.

So, 5 instruction times, = 5uSec.

The delay is only taking 1uSec, as programmed, but the other code takes 4uSec to execute...

You can prove this by the simple expedient of removing the delay. Loop takes 4uSec without the delay present.

All instructions take time. In this case most are just one or two processor cycles. Try something like dividing two float numbers, and the time can leap into the mSecs...

Best Wishes
michael_s



Joined: 10 Nov 2010
Posts: 4
Location: UK

View user's profile Send private message

PostPosted: Wed Nov 10, 2010 10:41 am     Reply with quote

Wow Smile

Thank You for answer, can I find anywhere the table with time each instruction taking ?

Regards.
Michael
Ttelmah



Joined: 11 Mar 2010
Posts: 19552

View user's profile Send private message

PostPosted: Wed Nov 10, 2010 10:50 am     Reply with quote

No.....
Do a search here. The easiest way is to use the MPLAB simulator and stopwatch function to time how long the code takes. The timings of the assembler instructions are in the data sheet for the chip. Problem is that a 'C' instruction, can take different times, according to where the data is stored, relative to the last value used, and will take different times for each different data type. There might easily be something over fifty 'possible' times for just one instruction....

Best Wishes
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Wed Nov 10, 2010 12:49 pm     Reply with quote

This thread explains how to use the stopwatch feature in MPLAB:
http://www.ccsinfo.com/forum/viewtopic.php?t=38351
michael_s



Joined: 10 Nov 2010
Posts: 4
Location: UK

View user's profile Send private message

PostPosted: Wed Nov 10, 2010 2:03 pm     Reply with quote

Ok thank for all of you for a help...
If there is anything like a CCS PIC tutorial for dummies Smile ??
I would start doing things properly Smile

Regards,
Michael.
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