osGetConfig.htm 3.04 KB
<HTML>

<HEAD>

<TITLE>HTML 文書</TITLE>

<META NAME="GENERATOR" CONTENT="Internet Assistant for Microsoft Word 2.0j">
</HEAD>

<BODY>

<P>
<B><FONT FACE="Arial">__osGetConfig(3P) <BR>
</FONT></B>
<P>
<B>関数名</B>
<P>
__osGetCause, __osSetCause, __osGetCompare, __osSetCompare, __osGetConfig,
__osSetConfig, __osGetSR, __osSetSR, __osGetFpcCsr, __osSetFpcCsr
<P>
→ 多数のMIPS R4300レジスタにアクセスするための内部ルーチン <BR>

<P>
<B>構文<BR>
</B>
<P>
#include &lt;ultra64.h&gt;
<P>
#include &lt;os_internal.h&gt;<BR>

<P>
u32 __osGetCause(void);
<P>
void __osSetCause(u32 value);
<P>
u32 __osGetCompare(void);
<P>
void __osSetCompare(u32 value);
<P>
<B>u32 __osGetConfig(void);</B>
<P>
void __osSetConfig(u32 value);
<P>
u32 __osGetSR(void);
<P>
void __osSetSR(u32 value);
<P>
u32 __osGetFpcCsr(void);
<P>
u32 __osSetFpcCsr(u32 value);<BR>

<P>
<B>説明<BR>
</B>
<P>
Nintendo64 OSは多数の重要なMIPS R4300レジスタにアクセスするための多くの内部ルーチンを持っています。開発者の努力の繰り返しを軽減するためにそれらのルーチンを以下に示します。開発者はN64システムのオペレーションと衝突しないように極めて注意して”Set”ルーチンを使用しなければなりません。それらのルーチンは元々内部で使用することのみを考慮してデザインされていますので、それらの名前には全て”__”が頭に付きます。R4300レジスタの使用に関するより詳しい資料としては、MIPS
R4300ユーザーズマニュアルを参照してください。さらに、ヘッダファイル”R4300.h”にはR4300レジスタで使用できるbit変数定義が記述されています。
<BR>

<P>
__osGetCauseルーチンはもっとも新しい例外の原因を記録するMIPS R4300
Causeレジスタの現在の値を返します。その対として__osSetCauseは単に新しい値にレジスタをセットします。
<BR>

<P>
__osGetCompareルーチンはR4300 Compareレジスタの現在の値を返します。__osSetCompareは単に新しい値にレジスタをセットします。Compareレジスタがタイマー関数<A HREF="osSetTimer.htm" >osSetTimer</A>(3P),
<A HREF="osStopTimer.htm" >osStopTimer</A>(3P)によって使用されているので、__osSetCompareを使用するときは注意してください。
<BR>

<P>
<B>__osGetConfig</B>ルーチンはR4300 Configレジスタの現在の値を返します。その対として__osSetConfigは単に新しい値にレジスタをセットします。
<BR>

<P>
__osGetSRルーチンはR4300 Statusレジスタの現在の値を返します。その対として、__osSetSRは単に新しい値にレジスタをセットします。スレッドを生成しているとき、<A HREF="osCreateThread.htm">osCreateThread</A>(3P)はスレッドコンテキストを切り替える間R4300
Statusレジスタになる、スレッドのステータスレジスタのカーネルモード、全ての割込、例外レベルをイネーブルしています。
<BR>

<P>
__osGetFpcCsrルーチンはR4300浮動小数点control/statusレジスタの現在の値を返します。その対として__osSetFpcCsrは単に新しい値にセットされる前にこのレジスタの現在の値を返します。システムイニシャライズとスレッド生成中は、この浮動小数点control/statusは0に正規化されていない数値をフラッシュし、Not
a Numbers(NaNs)が生成されるときの無効な例外操作を発生させるためにイネーブルされます。これらの2bitはそれぞれR4300.h中にFPCSR_FS,
FPCSR_EVとして定義されています。<BR>

<P>
<B>参照<BR>
</B>
<P>
<A HREF="osGetTLBASID.htm">__osGetTLBASID</A> (3P)<BR>

</BODY>

</HTML>