|
|
cpu_insn.h説明を見る。00001 /* 00002 * TOPPERS/FDMP Kernel 00003 * Toyohashi Open Platform for Embedded Real-Time Systems/ 00004 * Function Distributed Multiprocessor Kernel 00005 * 00006 * Copyright (C) 2005 by Embedded and Real-Time Systems Laboratory 00007 * Graduate School of Information Science, Nagoya Univ., JAPAN 00008 * 00009 * 上記著作権者は,以下の (1)〜(4) の条件か,Free Software Foundation 00010 * によって公表されている GNU General Public License の Version 2 に記 00011 * 述されている条件を満たす場合に限り,本ソフトウェア(本ソフトウェア 00012 * を改変したものを含む.以下同じ)を使用・複製・改変・再配布(以下, 00013 * 利用と呼ぶ)することを無償で許諾する. 00014 * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作 00015 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー 00016 * スコード中に含まれていること. 00017 * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使 00018 * 用できる形で再配布する場合には,再配布に伴うドキュメント(利用 00019 * 者マニュアルなど)に,上記の著作権表示,この利用条件および下記 00020 * の無保証規定を掲載すること. 00021 * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使 00022 * 用できない形で再配布する場合には,次のいずれかの条件を満たすこ 00023 * と. 00024 * (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著 00025 * 作権表示,この利用条件および下記の無保証規定を掲載すること. 00026 * (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに 00027 * 報告すること. 00028 * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損 00029 * 害からも,上記著作権者およびTOPPERSプロジェクトを免責すること. 00030 * 00031 * 本ソフトウェアは,無保証で提供されているものである.上記著作権者お 00032 * よびTOPPERSプロジェクトは,本ソフトウェアに関して,その適用可能性も 00033 * 含めて,いかなる保証も行わない.また,本ソフトウェアの利用により直 00034 * 接的または間接的に生じたいかなる損害に関しても,その責任を負わない. 00035 * 00036 * @(#) $Id: cpu_insn.h,v 1.2 2005/05/30 03:06:32 honda Exp $ 00037 */ 00038 00039 #ifndef _CPU_INSN_H_ 00040 #define _CPU_INSN_H_ 00041 00042 #include <nios2.h> 00043 00044 Inline UW 00045 current_status(void) 00046 { 00047 UW status; 00048 Asm("rdctl %0, status" : "=r" (status)); 00049 return(status); 00050 } 00051 00052 Inline UW 00053 current_estatus(void) 00054 { 00055 UW status; 00056 Asm("rdctl %0, estatus" : "=r" (status)); 00057 return(status); 00058 } 00059 00060 Inline UW 00061 current_bstatus(void) 00062 { 00063 UW status; 00064 Asm("rdctl %0, bstatus" : "=r" (status)); 00065 return(status); 00066 } 00067 00071 Inline UW 00072 current_ipending(void) 00073 { 00074 UW status; 00075 Asm("rdctl %0, ipending" : "=r" (status)); 00076 return(status); 00077 } 00078 00079 Inline UW 00080 current_ienable(void) 00081 { 00082 UW status; 00083 Asm("rdctl %0, ienable" : "=r" (status)); 00084 return(status); 00085 } 00086 00087 Inline void 00088 set_status(UW status) 00089 { 00090 Asm("wrctl status, %0" :: "r" (status)); 00091 } 00092 00093 Inline void 00094 set_ienable(UW ienable) 00095 { 00096 Asm("wrctl ienable, %0" :: "r" (ienable)); 00097 } 00098 00099 Inline void 00100 disint(void) 00101 { 00102 set_status(current_status() & ~STATUS_PIE); 00103 } 00104 00105 Inline void 00106 enaint() 00107 { 00108 set_status(current_status() | STATUS_PIE); 00109 } 00110 00111 #endif /* _CPU_INSN_H_ */ Copyright © 2006 by TAKAGI Nobuhisa. このページは Mon Apr 3 23:49:12 2006 に Doxygen によって生成されました。 |