LeoSeek.htm
1.94 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
63
64
65
66
67
68
69
70
71
72
73
74
75
<HTML>
<HEAD>
<TITLE>HTML 文書</TITLE>
<META NAME="GENERATOR" CONTENT="Internet Assistant for Microsoft Word 2.03j">
</HEAD>
<BODY>
<P>
<B><FONT FACE="Arial">LeoSeek (3P) <BR>
</FONT></B>
<P>
<B>関数名<BR>
</B>
<P>
LeoSeek
<P>
→ 64DDに対してのシークコマンドの発行<BR>
<P>
<B>構文<BR>
</B>
<PRE>
<FONT SIZE=4>#include <PR/leo.h>
s32 LeoSeek(LEOCmd *<U>cmdBlock</U>, u32 <U>lba</U>, OSMesgQueue *<U>mq</U>);
</FONT>
</PRE>
<P>
<B>説明<BR>
</B>
<P>
<B>注意:</B>64DD関係の命令はすべて、rom DMA(ドライブ内ROM対象のDMAを含む)が行
われていない、また行われないという仮定で設計されています。そのための注意点に関
しては、64DDプログラミングマニュアル「第12章 禁止事項、注意事項のまとめ」を
参照してください。 <BR>
<P>
<B>LeoSeek</B>は64DDのヘッドを <U>lba</U> で指定した位置に移動(シーク)させます。
<BR>
<P>
引数で与えるコマンドブロック <U>cmdBlock</U> には何も設定する必要はありません。
この関数は処理を終了すると待ち行列<U>mq</U>にエラーコードを返します。エラーが
起こる可能性があるので、プログラマは必ずこのエラーコードをチェックしなければい
けません。
<BR>
<P>
返ってくる可能性のあるエラーとその原因、対処法は64DDプログラミングマニュアル
「第10章 エラー処理シーケンス」を参照して下さい。<BR>
<P>
返り値は、leo マネージャがまだ作成されていないとき -1、作成されていれば
0 となります。通常はチェックする必要はありません。<BR>
<P>
<B>例</B>
<P>
<PRE>
<FONT FACE="Courier">LEOCmd cmdBlock;</FONT>
<FONT FACE="Courier">u32 error;</FONT>
<FONT FACE="Courier">.....</FONT>
<FONT FACE="Courier">LeoSeek(&cmdBlock, 20, &diskQ);</FONT>
<FONT FACE="Courier">osRecvMesg(&diskQ, (OSMesg *)&error, OS_MESG_BLOCK);<BR>
</FONT>
</PRE>
<B>参照<BR>
</B>
<P>
<A HREF="LeoCreateLeoManager.htm">Leo*CreateLeoManager</A>(3P)
<BR>
<HR>
<P>
<A HREF="64dd_INDEX.htm">64DDのマニュアルページのメニューへ</A>
<P>
<A HREF="../n64man.htm">N64のマニュアルページのトップメニューへ</A>
<P>
</BODY>
</HTML>