TIMER.H 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. /*
  2. THE COMPUTER CODE CONTAINED HEREIN IS THE SOLE PROPERTY OF PARALLAX
  3. SOFTWARE CORPORATION ("PARALLAX"). PARALLAX, IN DISTRIBUTING THE CODE TO
  4. END-USERS, AND SUBJECT TO ALL OF THE TERMS AND CONDITIONS HEREIN, GRANTS A
  5. ROYALTY-FREE, PERPETUAL LICENSE TO SUCH END-USERS FOR USE BY SUCH END-USERS
  6. IN USING, DISPLAYING, AND CREATING DERIVATIVE WORKS THEREOF, SO LONG AS
  7. SUCH USE, DISPLAY OR CREATION IS FOR NON-COMMERCIAL, ROYALTY OR REVENUE
  8. FREE PURPOSES. IN NO EVENT SHALL THE END-USER USE THE COMPUTER CODE
  9. CONTAINED HEREIN FOR REVENUE-BEARING PURPOSES. THE END-USER UNDERSTANDS
  10. AND AGREES TO THE TERMS HEREIN AND ACCEPTS THE SAME BY USE OF THIS FILE.
  11. COPYRIGHT 1993-1998 PARALLAX SOFTWARE CORPORATION. ALL RIGHTS RESERVED.
  12. */
  13. /*
  14. * $Source: f:/miner/source/bios/rcs/timer.h $
  15. * $Revision: 1.8 $
  16. * $Author: john $
  17. * $Date: 1994/12/10 12:27:23 $
  18. *
  19. * Header for timer functions
  20. *
  21. * $Log: timer.h $
  22. * Revision 1.8 1994/12/10 12:27:23 john
  23. * Added timer_get_approx_seconds.
  24. *
  25. * Revision 1.7 1994/12/10 12:10:25 john
  26. * Added types.h.
  27. *
  28. *
  29. *
  30. *
  31. * Revision 1.6 1994/12/10 12:07:06 john
  32. * Added tick counter variable.
  33. *
  34. * Revision 1.5 1994/11/15 12:04:15 john
  35. * Cleaned up timer code a bit... took out unused functions
  36. * like timer_get_milliseconds, etc.
  37. *
  38. * Revision 1.4 1994/04/28 23:50:08 john
  39. * Changed calling for init_timer. Made the function that the
  40. * timer calls be a far function. All of this was done to make
  41. * our timer system compatible with the HMI sound stuff.
  42. *
  43. * Revision 1.3 1994/02/17 15:57:12 john
  44. * Changed key libary to C.
  45. *
  46. * Revision 1.2 1994/01/18 10:58:34 john
  47. * Added timer_get_fixed_seconds
  48. *
  49. * Revision 1.1 1993/07/10 13:10:41 matt
  50. * Initial revision
  51. *
  52. *
  53. */
  54. #ifndef _TIMER_H
  55. #define _TIMER_H
  56. #include "types.h"
  57. #include "fix.h"
  58. //==========================================================================
  59. // This installs the timer services and interrupts at the rate specified by
  60. // count_val. If 'function' isn't 0, the function pointed to by function will
  61. // be called 'freq' times per second. Should be > 19 and anything around
  62. // 2-3000 is gonna start slowing down the system. Count_val should be
  63. // 1,193,180 divided by your target frequency. Use 0 for the normal 18.2 Hz
  64. // interrupt rate.
  65. #define TIMER_FREQUENCY 1193180
  66. extern void timer_init();
  67. extern void timer_close();
  68. extern void timer_set_rate(int count_val);
  69. extern void timer_set_function( void _far * function );
  70. //==========================================================================
  71. // These functions return the time since the timer was initialized in
  72. // some various units. The total length of reading time varies for each
  73. // one. They will roll around after they read 2^32.
  74. // There are milliseconds, milliseconds times 10, milliseconds times 100,
  75. // and microseconds. They time out after 1000 hrs, 100 hrs, 10 hrs, and
  76. // 1 hr, respectively.
  77. extern fix timer_get_fixed_seconds(); // Rolls about every 9 hours...
  78. extern fix timer_get_fixed_secondsX(); // Assume interrupts already disabled
  79. extern fix timer_get_approx_seconds(); // Returns time since program started... accurate to 1/120th of a second
  80. //NOT_USED extern unsigned int timer_get_microseconds();
  81. //NOT_USED extern unsigned int timer_get_milliseconds100();
  82. //NOT_USED extern unsigned int timer_get_milliseconds10();
  83. //NOT_USED extern unsigned int timer_get_milliseconds();
  84. //NOT_USED extern unsigned int timer_get_millisecondsX(); // Assume interrupts disabled
  85. //==========================================================================
  86. // Use to access the BIOS ticker... ie... i = TICKER
  87. #define TICKER (*(volatile int *)0x46C)
  88. #define USECS_PER_READING( start, stop, frames ) (((stop-start)*54945)/frames)
  89. #endif
  90.