3 * Toyohashi Open Platform for Embedded Real-Time Systems/
4 * Just Standard Profile Kernel
6 * Copyright (C) 2000-2003 by Embedded and Real-Time Systems Laboratory
7 * Toyohashi Univ. of Technology, JAPAN
9 * 上記著作権者は,以下の (1)〜(4) の条件か,Free Software Foundation
10 * によって公表されている GNU General Public License の Version 2 に記
11 * 述されている条件を満たす場合に限り,本ソフトウェア(本ソフトウェア
12 * を改変したものを含む.以下同じ)を使用・複製・改変・再配布(以下,
14 * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
15 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
17 * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
18 * 用できる形で再配布する場合には,再配布に伴うドキュメント(利用
19 * 者マニュアルなど)に,上記の著作権表示,この利用条件および下記
21 * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
22 * 用できない形で再配布する場合には,次のいずれかの条件を満たすこ
24 * (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
25 * 作権表示,この利用条件および下記の無保証規定を掲載すること.
26 * (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
28 * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
29 * 害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
31 * 本ソフトウェアは,無保証で提供されているものである.上記著作権者お
32 * よびTOPPERSプロジェクトは,本ソフトウェアに関して,その適用可能性も
33 * 含めて,いかなる保証も行わない.また,本ソフトウェアの利用により直
34 * 接的または間接的に生じたいかなる損害に関しても,その責任を負わない.
36 * @(#) $Id: cpu_insn.h,v 1.1 2009/01/31 05:27:37 suikan Exp $
40 * プロセッサの特殊命令のインライン関数定義(M68040用)
47 * ステータスレジスタ(SR)の現在値の読出し
54 Asm("move.w %%sr, %0" : "=g"(sr));
59 * ステータスレジスタ(SR)の現在値の変更
64 Asm("move.w %0, %%sr" : : "g"(sr));
73 Asm("or.w #0x0700, %sr");
82 Asm("and.w #~0x0700, %sr");
86 * ベクタベースレジスタ(VBR)の現在値の読出し
93 Asm("movec.l %%vbr, %0" : "=r"(vbr));
103 Asm("movec.l %0, %%vbr" : : "r"(vbr));
107 * レディキューサーチのためのビットマップサーチ関数
109 * ビットマップの下位16ビットを使用し,最下位ビットを最低優先度に対応
112 #define CPU_BITMAP_SEARCH
113 #define PRIMAP_BIT(pri) (0x8000u >> (pri))
116 bitmap_search(UINT bitmap)
121 * このコードは,bitmap(UINT型)が32ビットであることを仮定し
124 Asm("bfffo %1{16,16}, %0" : "=d"(offset) : "g"(bitmap));
128 #endif /* _CPU_INSN_H_ */