1 #ifndef _MINIX_SYSUTIL_H 2 #define _MINIX_SYSUTIL_H 1 3 4 #include <minix/ipc.h> 5 #include <sys/cdefs.h> 6 7 /* Extra system library definitions to support device drivers and servers. 8 * 9 * Created: 10 * Mar 15, 2004 by Jorrit N. Herder 11 * 12 * Changes: 13 * May 31, 2005: added printf, kputc (relocated from syslib) 14 * May 31, 2005: added getuptime 15 * Mar 18, 2005: added tickdelay 16 * Oct 01, 2004: added env_parse, env_prefix, env_panic 17 * Jul 13, 2004: added fkey_ctl 18 * Apr 28, 2004: added report, panic 19 * Mar 31, 2004: setup like other libraries, such as syslib 20 */ 21 22 /*==========================================================================* 23 * Miscellaneous helper functions. 24 *==========================================================================*/ 25 26 /* Environment parsing return values. */ 27 #define EP_BUF_SIZE 128 /* local buffer for env value */ 28 #define EP_UNSET 0 /* variable not set */ 29 #define EP_OFF 1 /* var = off */ 30 #define EP_ON 2 /* var = on (or field left blank) */ 31 #define EP_SET 3 /* var = 1:2:3 (nonblank field) */ 32 #define EP_EGETKENV 4 /* sys_getkenv() failed ... */ 33 34 extern int env_argc; 35 extern char **env_argv; 36 37 void env_setargs(int argc, char *argv[]); 38 int env_get_param(const char *key, char *value, int max_size); 39 int env_prefix(char *env, char *prefix); 40 void env_panic(const char *key); 41 int env_parse(const char *env, const char *fmt, int field, 42 long *param, long min, long max); 43 44 #define fkey_map(fkeys, sfkeys) fkey_ctl(FKEY_MAP, (fkeys), (sfkeys)) 45 #define fkey_unmap(fkeys, sfkeys) fkey_ctl(FKEY_UNMAP, (fkeys), (sfkeys)) 46 #define fkey_events(fkeys, sfkeys) fkey_ctl(FKEY_EVENTS, (fkeys), (sfkeys)) 47 int fkey_ctl(int req, int *fkeys, int *sfkeys); 48 49 struct timespec; 50 51 int printf(const char *fmt, ...); 52 void kputc(int c); 53 __dead void panic(const char *fmt, ...) 54 __attribute__((__format__(__printf__,1,2))); 55 void panic_hook(void); 56 void __panic_hook(void); 57 int getuptime(clock_t *ticks, clock_t *realtime, time_t *boottime); 58 clock_t getticks(void); 59 int tickdelay(clock_t ticks); 60 int tsc_calibrate(void); 61 u32_t sys_hz(void); 62 double getidle(void); 63 void util_stacktrace(void); 64 int micro_delay(u32_t micros); 65 u32_t tsc_64_to_micros(u64_t tsc); 66 u32_t tsc_to_micros(u32_t low, u32_t high); 67 u32_t tsc_get_khz(void); 68 u32_t micros_to_ticks(u32_t micros); 69 time_t clock_time(struct timespec *tv); 70 #if defined(__arm__) 71 void read_frclock(u32_t *frclk); 72 u32_t delta_frclock(u32_t base, u32_t cur); 73 #endif 74 void read_frclock_64(u64_t *frclk); 75 u64_t delta_frclock_64(u64_t base, u64_t cur); 76 u32_t frclock_64_to_micros(u64_t tsc); 77 void ser_putc(char c); 78 void get_randomness(struct k_randomness *, int); 79 u32_t sqrt_approx(u32_t); 80 81 int stime(time_t *_top); 82 83 #define asynsend(ep, msg) asynsend3(ep, msg, 0) 84 int asynsend3(endpoint_t ep, message *msg, int flags); 85 int asyn_geterror(endpoint_t *dst, message *msg, int *err); 86 int senda_reload(void); 87 88 #define ASSERT(c) if(!(c)) { panic("%s:%d: assert %s failed", __FILE__, __LINE__, #c); } 89 90 /* timing library */ 91 #define TIMING_CATEGORIES 20 92 93 #define TIMING_POINTS 20 /* timing resolution */ 94 #define TIMING_CATEGORIES 20 95 #define TIMING_NAME 10 96 97 struct util_timingdata { 98 char names[TIMING_NAME]; 99 unsigned long lock_timings[TIMING_POINTS]; 100 unsigned long lock_timings_range[2]; 101 unsigned long binsize, resets, misses, measurements; 102 unsigned long starttimes[2]; /* nonzero if running */ 103 }; 104 105 typedef struct util_timingdata util_timingdata_t; 106 107 #endif /* _MINIX_SYSUTIL_H */ 108 109