📄 cpu_defs.h
字号:
/* * TOPPERS/JSP Kernel * Toyohashi Open Platform for Embedded Real-Time Systems/ * Just Standard Profile Kernel * * Copyright (C) 2004 by Embedded and Real-Time Systems Laboratory * Graduate School of Information Science, Nagoya Univ., JAPAN * * 惧淡螟侯涪荚は·笆布の (1)×(4) の掘凤か·Free Software Foundation * によって给山されている GNU General Public License の Version 2 に淡 * 揭されている掘凤を塔たす眷圭に嘎り·塑ソフトウェア∈塑ソフトウェア * を猖恃したものを崔むˉ笆布票じ∷を蝗脱ˇ剩澜ˇ猖恃ˇ浩芹邵∈笆布· * 网脱と钙ぶ∷することを痰浸で钓满するˉ * (1) 塑ソフトウェアをソ〖スコ〖ドの妨で网脱する眷圭には·惧淡の螟侯 * 涪山绩·この网脱掘凤および布淡の痰瘦沮惮年が·そのままの妨でソ〖 * スコ〖ド面に崔まれていることˉ * (2) 塑ソフトウェアを·ライブラリ妨及など·戮のソフトウェア倡券に蝗 * 脱できる妨で浩芹邵する眷圭には·浩芹邵に燃うドキュメント∈网脱 * 荚マニュアルなど∷に·惧淡の螟侯涪山绩·この网脱掘凤および布淡 * の痰瘦沮惮年を非很することˉ * (3) 塑ソフトウェアを·怠达に寥み哈むなど·戮のソフトウェア倡券に蝗 * 脱できない妨で浩芹邵する眷圭には·肌のいずれかの掘凤を塔たすこ * とˉ * (a) 浩芹邵に燃うドキュメント∈网脱荚マニュアルなど∷に·惧淡の螟 * 侯涪山绩·この网脱掘凤および布淡の痰瘦沮惮年を非很することˉ * (b) 浩芹邵の妨轮を·侍に年める数恕によって·TOPPERSプロジェクトに * 鼠桂することˉ * (4) 塑ソフトウェアの网脱により木儡弄または粗儡弄に栏じるいかなる禄 * 巢からも·惧淡螟侯涪荚およびTOPPERSプロジェクトを倘勒することˉ * * 塑ソフトウェアは·痰瘦沮で捏丁されているものであるˉ惧淡螟侯涪荚お * よびTOPPERSプロジェクトは·塑ソフトウェアに簇して·その努脱材墙拉も * 崔めて·いかなる瘦沮も乖わないˉまた·塑ソフトウェアの网脱により木 * 儡弄または粗儡弄に栏じたいかなる禄巢に簇しても·その勒扦を砷わないˉ * * @(#) $Id: cpu_defs.h,v 1.2 2004/09/09 07:19:00 honda Exp $ *//* * プロセッサに巴赂する年盗∈Nios2脱∷ * * このインクル〖ドファイルは·kernel.h と sil.h でインクル〖ドされるˉ * 戮のファイルから木儡インクル〖ドすることはないˉこのファイルをイン * クル〖ドする涟に·t_stddef.h と itron.h がインクル〖ドされるので· * それらに巴赂してもよいˉ */#ifndef _CPU_DEFS_H_#define _CPU_DEFS_H_#define OMIT_SIL_ACCESS#ifndef NIOS2#define NIOS2 /* プロセッサ维疚 */#endif /* * プロセッサに巴赂する年盗 */#ifndef _MACRO_ONLYtypedef UINT INHNO; /* 充哈みハンドラ戎规 */typedef UINT IPM; /* 充哈みマスク */typedef UINT EXCNO; /* CPU毋嘲ハンドラ戎规 *//* * INTNO房と充哈みの敦贿/钓材 */typedef UINT INTNO; /* 充哈み戎规 */extern ER dis_int(INTNO intno) throw(); extern ER ena_int(INTNO intno) throw();/* * タ〖ゲットシステム巴赂のサ〖ビスコ〖ル */typedef UD SYSUTIM; /* 拉墙删擦脱システム箕癸 */extern ER vxget_tim(SYSUTIM *pk_sysutim) throw();/* * 充哈み钓材ビット */#define STATUS_PIE 0x01/* * すべての充哈みを敦贿 */Inline void_disint_(){ UW status; Asm("rdctl %0, status" : "=r" (status)); status &= ~STATUS_PIE; Asm("wrctl status, %0" :: "r" (status));}/* * 充哈みを钓材 */Inline void_enaint_(){ UW status; Asm("rdctl %0, status" : "=r" (status)); status |= STATUS_PIE; Asm("wrctl status, %0" :: "r" (status));}/* * 充哈みロック觉轮の扩告 */#define SIL_PRE_LOC #define SIL_LOC_INT() _disint_()#define SIL_UNL_INT() _enaint_()/* * システムの面们借妄 */Inline voidkernel_abort(){}#endif /* _MACRO_ONLY *//* * プロセッサのエンディアン */#define SIL_ENDIAN SIL_ENDIAN_LITTLE #ifndef _MACRO_ONLY/* * メモリアクセス簇眶 *//* * 8ビット帽疤の粕叫し】今哈み */Inline VBsil_reb_mem(VP mem){ return(__builtin_ldbuio(mem));}Inline voidsil_wrb_mem(VP mem, VB data){ __builtin_stbio(mem, data);}/* * 16ビット帽疤の粕叫し】今哈み */Inline VHsil_reh_mem(VP mem){ return(__builtin_ldhuio(mem));}Inline voidsil_wrh_mem(VP mem, VH data){ __builtin_sthio(mem, data);}#define sil_reh_lem(mem) sil_reh_mem(mem)#define sil_wrh_lem(mem, data) sil_wrh_mem(mem, data)Inline VHsil_reh_bem(VP mem){ VH data; data = __builtin_ldhuio(mem); return(SIL_REV_ENDIAN_H(data));}Inline voidsil_wrh_bem(VP mem, VH data){ __builtin_sthio(mem, SIL_REV_ENDIAN_H(data));}/* * 32ビット帽疤の粕叫し】今哈み */Inline VWsil_rew_mem(VP mem){ return(__builtin_ldwio(mem));}Inline voidsil_wrw_mem(VP mem, VW data){ __builtin_stwio(mem, data);}#define sil_rew_lem(mem) sil_rew_mem(mem)#define sil_wrw_lem(mem, data) sil_wrw_mem(mem, data)Inline VWsil_rew_bem(VP mem){ VW data; data = __builtin_ldwio(mem); return(SIL_REV_ENDIAN_W(data));}Inline voidsil_wrw_bem(VP mem, VW data){ __builtin_stwio(mem, SIL_REV_ENDIAN_W(data));}/* * 腮警箕粗略ち */Inline voidsil_dly_nse(UINT dlytim){ }#endif /* _MACRO_ONLY */#endif /* _CPU_DEFS_H_ */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -