22#define T0_COUNT ((volatile unsigned int *)0x10000000)
23#define T0_MODE ((volatile unsigned int *)0x10000010)
24#define T0_COMP ((volatile unsigned int *)0x10000020)
25#define T0_HOLD ((volatile unsigned int *)0x10000030)
27#define T1_COUNT ((volatile unsigned int *)0x10000800)
28#define T1_MODE ((volatile unsigned int *)0x10000810)
29#define T1_COMP ((volatile unsigned int *)0x10000820)
30#define T1_HOLD ((volatile unsigned int *)0x10000830)
34#define T2_COUNT ((volatile unsigned int *)0x10001000)
35#define T2_MODE ((volatile unsigned int *)0x10001010)
36#define T2_COMP ((volatile unsigned int *)0x10001020)
38#define T3_COUNT ((volatile unsigned int *)0x10001800)
39#define T3_MODE ((volatile unsigned int *)0x10001810)
40#define T3_COMP ((volatile unsigned int *)0x10001820)
43#define K_T2_COUNT ((volatile unsigned int *)0xB0001000)
44#define K_T2_MODE ((volatile unsigned int *)0xB0001010)
45#define K_T2_COMP ((volatile unsigned int *)0xB0001020)
47#define Tn_MODE(CLKS, GATE, GATS, GATM, ZRET, CUE, CMPE, OVFE, EQUF, OVFF) \
48 (u32)((u32)(CLKS) | ((u32)(GATE) << 2) | \
49 ((u32)(GATS) << 3) | ((u32)(GATM) << 4) | \
50 ((u32)(ZRET) << 6) | ((u32)(CUE) << 7) | \
51 ((u32)(CMPE) << 8) | ((u32)(OVFE) << 9) | \
52 ((u32)(EQUF) << 10) | ((u32)(OVFF) << 11))
55#define kBUSCLK (147456000)
56#define kBUSCLKBY16 (kBUSCLK / 16)
57#define kBUSCLKBY256 (kBUSCLK / 256)
58#define kHBLNK_NTSC (15734)
59#define kHBLNK_PAL (15625)
60#define kHBLNK_DTV480p (31469)
61#define kHBLNK_DTV1080i (33750)
63typedef u64 (*timer_alarm_handler_t)(s32 id, u64 scheduled_time, u64 actual_time,
void *arg,
void *pc_value);
69extern void _ps2sdk_init_timer_impl(
void);
70extern void _ps2sdk_init_timer(
void);
71extern void _ps2sdk_deinit_timer_impl(
void);
72extern void _ps2sdk_deinit_timer(
void);
74extern s32 InitTimer(s32 in_mode);
75extern s32 EndTimer(
void);
76extern s32 GetTimerPreScaleFactor(
void);
77extern s32 StartTimerSystemTime(
void);
78extern s32 StopTimerSystemTime(
void);
79extern void SetNextComp(u64 time);
80extern u64 iGetTimerSystemTime(
void);
81extern u64 GetTimerSystemTime(
void);
82extern s32 iAllocTimerCounter(
void);
83extern s32 AllocTimerCounter(
void);
84extern s32 iFreeTimerCounter(s32
id);
85extern s32 FreeTimerCounter(s32
id);
86extern s32 iGetTimerUsedUnusedCounters(u32 *used_counters, u32 *unused_counters);
87extern s32 GetTimerUsedUnusedCounters(u32 *used_counters, u32 *unused_counters);
88extern s32 iStartTimerCounter(s32
id);
89extern s32 StartTimerCounter(s32
id);
90extern s32 iStopTimerCounter(s32
id);
91extern s32 StopTimerCounter(s32
id);
92extern u64 SetTimerCount(s32
id, u64 timer_count);
93extern u64 iGetTimerBaseTime(s32
id);
94extern u64 GetTimerBaseTime(s32
id);
95extern u64 iGetTimerCount(s32
id);
96extern u64 GetTimerCount(s32
id);
97extern s32 iSetTimerHandler(s32
id, u64 scheduled_time, timer_alarm_handler_t callback_handler,
void *arg);
98extern s32 SetTimerHandler(s32
id, u64 scheduled_time, timer_alarm_handler_t callback_handler,
void *arg);
99extern void TimerBusClock2USec(u64 clocks, u32 *seconds_result, u32 *microseconds_result);
100extern u64 TimerUSec2BusClock(u32 seconds, u32 microseconds);
101extern float TimerBusClock2Freq(s64 clocks);
102extern u64 TimerFreq2BusClock(
float timer_frequency);
103extern u32 cpu_ticks(
void);
106static inline u64 NSec2TimerBusClock(u64 usec) {
108 return ((((kBUSCLK / 1000) * 65536ULL) / 1000000) * usec) >> 16;
111static inline u64 USec2TimerBusClock(u64 usec) {
113 return ((((kBUSCLK / 1000) * 1024) / 1000) * usec) >> 10;
116static inline u64 MSec2TimerBusClock(u64 msec) {
117 return (kBUSCLK / 1000) * msec;
120static inline u64 Sec2TimerBusClock(u64 sec) {
121 return kBUSCLK * sec;