![]() |
![]() |
![]() |
![]() |
![]() |
This version of this document is no longer maintained. For the latest documentation, see http://www.qnx.com/developers/docs. |
Calibrate before calling nanospin*()
#include <time.h> int nanospin_calibrate( int disable );
libc
Use the -l c option to qcc to link against this library. This library is usually included automatically.
The nanospin_calibrate() function performs the calibration for the nanospin()* family of delay functions. The first time that you call nanospin(), nanospin_ns(), or nanospin_ns_to_count(), the C library invokes nanospin_calibrate() with an argument of 0 (interrupts enabled), unless you call it directly first.
![]() |
If you don't directly invoke nanospin_calibrate(),
the first
nanospin*() call in a process will have an overly long delay.
The nanospin*() functions are designed for use with hardware that requires short time delays between accesses. You should use them to delay only for times less than a few milliseconds. For longer delays, use the POSIX timer_*() functions. |
Interrupts occurring during nanospin_calibrate() can throw off its timings. If disable is 0 (zero), you can prevent this situation by:
If disable is 1 (one), the code disables interrupts around the calibration loop(s). The calling thread is still responsible for obtaining I/O privilege before calling nanospin_calibrate().
Busy-wait for 100 nanoseconds:
#include <time.h>
#include <sys/syspage.h>
int disable = 0;
unsigned long time = 100;
...
/* Wake up the hardware, then wait for it to be ready. */
if ( (nanospin_calibrate( disable )) == EOK )
nanospin_count( nanospin_ns_to_count( time ) );
else
printf ("Didn't calibrate successfully.\n");
/* Use the hardware. */
...
| Safety: | |
|---|---|
| Cancellation point | No |
| Interrupt handler | No |
| Signal handler | Yes |
| Thread | Yes |
nanospin(), nanospin_count(), nanospin_ns(), nanospin_ns_to_count(), timer_create()
![]() |
![]() |
![]() |
![]() |