osInvalDCache.htm
1.71 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
<HTML>
<HEAD>
<TITLE>HTML 文書</TITLE>
<META NAME="GENERATOR" CONTENT="Internet Assistant for Microsoft Word 2.0j">
</HEAD>
<BODY>
<P>
<B><FONT FACE="Arial">osInvalDCache(3P) <BR>
</FONT></B>
<P>
<B>関数名<BR>
</B>
<P>
osInvalDCache
<P>
→ CPUデータキャッシュラインの無効化 <BR>
<P>
<B>構文<BR>
</B>
<P>
#include <ultra64.h>
<P>
void osInvalDCache(void *vaddr, s32 nbytes);<BR>
<P>
<B>説明<BR>
</B>
<P>
MIPS R4300 CPUは8Kbyteのダイレクトマップされたデータキャッシュを16byteのラインサイズで実行します。キャッシュは物理メモリに直接書き込みを行わないので、キャッシュラインは物理メモリ上に新しいデータが存在し、使わなくなったデータを廃棄するような場合には、すぐに無効にしなければなりません。<B>osInvalDCache</B>コールは[vaddr,
vaddr+nbytes)に含まれる全てのデータキャッシュラインを無効にします。与えられたアドレスvaddrは、ダイレクトマップされるかCPU
TLB経由でマッピングされたCPU仮想アドレスでなければなりません。もしvaddrがキャッシュライン境界に並べられないとき、そしてnbytesがキャッシュラインサイズの倍数でないときは、少し大きな範囲が無効化されます。
<BR>
<P>
このルーチンは、より新しいプログラムデータが以前にCPUがリードまたはライトしたアドレスロケーションにおいてダイレクトメモリアクセスデバイス(DMA)から物理アドレスにコピーされるというシチュエーションに、もっとも共通的に使用されます。この場合、キャッシュデータは物理メモリに関係のあるデータではなくなり、従ってそれらのアドレスに結合されたキャッシュラインはそれらのデータロケーションにアクセスすることを先に無効化しておかなければなりません。
<BR>
<P>
<B>参照<BR>
</B>
<P>
<A HREF="osMapTLB.htm">osMapTLB</A>(3P), <A HREF="osInvalICache.htm">osInvalICache</A>(3P),
<P>
<A HREF="osWritebackDCache.htm">osWritebackDCache</A>(3P)<BR>
</BODY>
</HTML>