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 によって生成されました。