osSetTimer.htm
1.7 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
<HTML>
<HEAD>
<TITLE>HTML 文書</TITLE>
<META NAME="GENERATOR" CONTENT="Internet Assistant for Microsoft Word 2.0j">
</HEAD>
<BODY>
<P>
<B><FONT FACE="Arial">osSetTimer(3P) <BR>
</FONT></B>
<P>
<B>関数名<BR>
</B>
<P>
osSetTimer, osStopTimer
<P>
→ インターバル/カウントダウンタイマのセット、ストップ
<BR>
<P>
<B>構文<BR>
</B>
<P>
#include <ultra64.h>
<P>
<B>int osSetTimer(OSTimer *timer, OSTime countdown,
OSTime interval, OSMesgQueue *mq, OSMesg msg);</B>
<P>
void osStopTimer(OSTimer *timer); <BR>
<P>
<B>説明<BR>
</B>
<P>
<B>osSetTimer</B>コールはtimerによって指定されたタイマの値をセットします。このコールはカウントダウンタイマとインターバルタイマの両方をサポートしています。もしcountdownが0でなければ、それは次のタイマ終了の時間を示します。もし、intervalが0でなければ、それはタイマが終了したときのタイマのリロードに使用する値を指定します。メッセージmsgはタイマが終了したときに,指定されたメッセージ待ち行列mqの最後にコピーします。
<BR>
</FONT>
<P>
osStopTimerコールは指定されたインターバルタイマをストップします。<B>osSetTimer</B>コールでカウントダウンタイマのみが許可されている場合は、osStopTimerをコールする必要は生じません。
<BR>
<P>
カウントダウンとインターバルの両方ともCPUカウントレジスタサイクルで表現されます。このタイマは45.875Mhzでインクリメントされ、1サイクルあたりおよそ21.33nsに相当します。カウンタサイクルとnsまたはμsとのコンバートのためのマクロの使用法については<A HREF="OS_CYCLES_TO_NSEC.htm">OS_CYCLES_TO_NSEC</A>(3P)を参照してください。
<BR>
</FONT>
<P>
総合的なシステムパフォーマンスの低下を防ぐための注意として、時間値は50μs以下にするべきではありません。
<BR>
<P>
<B>参照<BR>
</B>
<P>
<A HREF="osGetTime.htm">osGetTime(3P)</A><BR>
</BODY>
</HTML>