00001
00002
00003 #ifndef SS_TIME_LIB_H
00004 #define SS_TIME_LIB_H
00005
00006 #ifdef __cplusplus
00007 extern "C" {
00008 #endif
00009
00010 #define EDT_SSTM_COUNTS 0x04010080
00011 #define EDT_SSTM_SECS 0x04010084
00012 #define EDT_SSTM_SET 0x04010088
00013 #define EDT_SSTM_ADJ_VALUE 0x0301008C
00014 #define EDT_SSTM_CMD 0x0101008F
00015
00016 #define EDT_SSTM_COPY 0x01
00017 #define EDT_SSTM_LATCH 0x02
00018 #define EDT_SSTM_COPY_ADJ 0x04
00019
00020 #define EDT_SSTM_ADJ_EN 0x10
00021 #define EDT_SSTM_ADJ_PLUS 0x20
00022 #define EDT_SSTM_CMD_LOCK 0x80
00023
00024 #define EDT_SSTM_ZERO_OFFSET_MAX 100
00025
00026 #define EDT_SSTM_MAX_ADJ 0xffffff
00027
00028 #define USECS_FACTOR (1000000.0 / (double) (1 << 20))
00029
00030
00086 EDTAPI void edt_sstm_setup(EdtDev *edt_p, char *bitfile);
00087
00088 EDTAPI void edt_sstm_strobe(EdtDev *edt_p, unsigned int bits);
00089
00090
00091
00092
00093
00094 EDTAPI void edt_sstm_latch_time(EdtDev *edt_p);
00095
00096
00097
00098
00099
00100 EDTAPI u_int edt_sstm_get_seconds(EdtDev *edt_p);
00101
00102
00103
00104
00105
00106 EDTAPI u_int edt_sstm_get_counts(EdtDev *edt_p);
00107
00108
00109
00110
00111
00112
00113
00114 EDTAPI u_int edt_sstm_get_usecs(EdtDev *edt_p);
00115
00116
00117
00118
00119
00120 EDTAPI void edt_sstm_get_time_parts(EdtDev *edt_p, u_int *seconds, u_int *usecs);
00121
00122
00123
00124
00125
00126
00127 EDTAPI double edt_sstm_timestamp(EdtDev *edt_p);
00128
00129
00130
00131
00132
00133
00134 EDTAPI int edt_sstm_get_adjust_enabled(EdtDev *edt_p);
00135
00136
00137
00138
00139
00140
00141 EDTAPI int edt_sstm_get_adjust_sign(EdtDev *edt_p);
00142
00143
00144
00145
00146
00147 EDTAPI u_int edt_sstm_get_adjust_ticks(EdtDev *edt_p);
00148
00149
00150
00151
00152
00153
00154
00155
00156
00157 EDTAPI void edt_sstm_set_secs(EdtDev *edt_p, unsigned int second);
00158
00159
00160
00161
00162
00163
00164 EDTAPI void edt_sstm_set(EdtDev *edt_p, unsigned int second);
00165
00166
00167
00168
00169
00170
00171
00172
00173 EDTAPI void edt_sstm_set_to_sys(EdtDev *edt_p);
00174
00175
00176
00177
00178
00179 EDTAPI void edt_sstm_set_to_sys_error(EdtDev *edt_p, int error);
00180
00181
00182
00183
00184
00185 EDTAPI void edt_sstm_disable_adjust(EdtDev *edt_p);
00186
00187
00188
00189
00190
00191 EDTAPI void edt_sstm_enable_adjust(EdtDev *edt_p);
00192
00193
00194
00195
00196
00197 EDTAPI void edt_sstm_set_adj_sign(EdtDev *edt_p, int positive);
00198
00199
00200
00201
00202
00203
00204
00205
00206
00207 EDTAPI void edt_sstm_set_adj_ticks(EdtDev *edt_p, int ticks, int positive);
00208
00209
00210
00211
00212
00213
00214
00215 EDTAPI double edt_sstm_sys_error(EdtDev *edt_p);
00216
00217
00218
00219
00220
00221
00222
00223
00224
00225 EDTAPI double edt_sstm_measure_drift(EdtDev *edt_p);
00226
00227
00228
00229 EDTAPI int edt_sstm_ticks_from_drift(double drift);
00230
00231
00232
00233
00234 EDTAPI void edt_sstm_set_adj_from_drift(EdtDev *edt_p, double drift);
00235
00236 EDTAPI void edt_sstm_set_drift_sampling(int seconds, int samples);
00237
00238 EDTAPI int edt_sstm_get_adj_sample_secs();
00239
00240 EDTAPI int edt_sstm_get_adj_samples();
00241
00242
00243
00244
00245
00246
00247
00248
00249
00250 EDTAPI double edt_sstm_calc_convergence(EdtDev *edt_p,
00251 int revert_secs,
00252 double drift_ticks);
00253
00254
00255
00256
00257
00258
00259
00260
00261 EDTAPI double edt_sstm_adjust(EdtDev *edt_p,
00262 double converge,
00263 double drift,
00264 int *active);
00265
00266
00267
00268
00269
00270 EDTAPI void edt_sstm_iterate_adjust(EdtDev *edt_p,
00271 int revert_secs,
00272 int maxiterations,
00273 int tolerance,
00274 int *active);
00275
00276 EDTAPI void
00277 edt_sstm_print_loop(EdtDev *edt_p, int interval, int total_time);
00278
00279
00280
00281
00282
00283
00284
00285
00286
00287
00288 typedef struct {
00289 EdtDev *edt_p;
00290 int check_interval;
00291 int revert_seconds;
00292 int iterations;
00293 int max_error;
00294 int tolerance;
00295 int active;
00296 int done;
00297 int loops;
00298 thread_t thread;
00299 } EdtSSTimeAdjuster;
00300
00301
00302
00303
00304
00305
00306
00307
00308
00309
00310
00311
00312 EDTAPI EdtSSTimeAdjuster *
00313 edt_sstm_launch_adjuster(EdtDev *edt_p,
00314 int check,
00315 int revert,
00316 int iterations,
00317 int max_usec_error,
00318 int tolerance,
00319 int loops);
00320
00321
00322 EDTAPI void
00323 edt_sstm_adjuster_stop(EdtSSTimeAdjuster *adj_p);
00324
00325
00326 EDTAPI void
00327 edt_sstm_adjuster_start(EdtSSTimeAdjuster *adj_p);
00328
00334 EDTAPI char * edt_printable_time(double sys_t, char *buf);
00335
00336 #ifndef WIN32
00337
00338 #define edt_sys_timestamp edt_timestamp
00339
00340 #else
00341
00342 EDTAPI double edt_sys_timestamp();
00343
00344 #endif
00345
00346
00347
00348 #ifdef __cplusplus
00349 }
00350 #endif
00351
00352
00353
00354 #endif