📄 vr5500.h
字号:
/* * TOPPERS/JSP Kernel * Toyohashi Open Platform for Embedded Real-Time Systems/ * Just Standard Profile Kernel * * Copyright (C) 2000-2003 by Embedded and Real-Time Systems Laboratory * Toyohashi Univ. of Technology, JAPAN * Copyright (C) 2000-2003 by Industrial Technology Institute, * Miyagi Prefectural Government, JAPAN * * 惧淡螟侯涪荚は·笆布の (1)×(4) の掘凤か·Free Software Foundation * によって给山されている GNU General Public License の Version 2 に淡 * 揭されている掘凤を塔たす眷圭に嘎り·塑ソフトウェア∈塑ソフトウェア * を猖恃したものを崔むˉ笆布票じ∷を蝗脱ˇ剩澜ˇ猖恃ˇ浩芹邵∈笆布· * 网脱と钙ぶ∷することを痰浸で钓满するˉ * (1) 塑ソフトウェアをソ〖スコ〖ドの妨で网脱する眷圭には·惧淡の螟侯 * 涪山绩·この网脱掘凤および布淡の痰瘦沮惮年が·そのままの妨でソ〖 * スコ〖ド面に崔まれていることˉ * (2) 塑ソフトウェアを·ライブラリ妨及など·戮のソフトウェア倡券に蝗 * 脱できる妨で浩芹邵する眷圭には·浩芹邵に燃うドキュメント∈网脱 * 荚マニュアルなど∷に·惧淡の螟侯涪山绩·この网脱掘凤および布淡 * の痰瘦沮惮年を非很することˉ * (3) 塑ソフトウェアを·怠达に寥み哈むなど·戮のソフトウェア倡券に蝗 * 脱できない妨で浩芹邵する眷圭には·肌のいずれかの掘凤を塔たすこ * とˉ * (a) 浩芹邵に燃うドキュメント∈网脱荚マニュアルなど∷に·惧淡の螟 * 侯涪山绩·この网脱掘凤および布淡の痰瘦沮惮年を非很することˉ * (b) 浩芹邵の妨轮を·侍に年める数恕によって·TOPPERSプロジェクトに * 鼠桂することˉ * (4) 塑ソフトウェアの网脱により木儡弄または粗儡弄に栏じるいかなる禄 * 巢からも·惧淡螟侯涪荚およびTOPPERSプロジェクトを倘勒することˉ * * 塑ソフトウェアは·痰瘦沮で捏丁されているものであるˉ惧淡螟侯涪荚お * よびTOPPERSプロジェクトは·塑ソフトウェアに簇して·その努脱材墙拉も * 崔めて·いかなる瘦沮も乖わないˉまた·塑ソフトウェアの网脱により木 * 儡弄または粗儡弄に栏じたいかなる禄巢に簇しても·その勒扦を砷わないˉ */#ifndef _VR5500_H_ #define _VR5500_H_ /* CP0ハザ〖ドのための箕粗苍ぎ NOP_FOR_CP0_HAZARD *//* VR5500ではCP0ハザ〖ドはMIPS3コアが冉们してくれるために年盗を乖う 涩妥がない。*/#define NOP_FOR_CP0_HAZARD/* TLB のエントリの呵络猛 */#define TMAX_TLB 47/* TLB VPN2猛 */#define TLB_VPN2 0x2000/* キャッシュ炭吾 */#define Index_Store_Tag_I 0x8+0x0#define Index_Store_Tag_D 0x8+0x1/* キャッシュのラインサイズ(バイト帽疤) */#define D_CACHE_LINE_SIZE 0x20 /* 8ワ〖ド */#define I_CACHE_LINE_SIZE 0x20 /* 8ワ〖ド *//*============================================================================*//* * GDB STUB / PARTNER-Jシステムコ〖ル / 木儡钙叫し コンソ〖ル钙叫しル〖チン * (PARTNER-J はテストしていません。) *//* * gdb stub によるコンソ〖ル叫蜗 *//* a0($4) = 0xfe00, a1($5) = 叫蜗したいキャラクタ を洛掐して、 SYSCALL 毋嘲を券栏させる。 */#ifndef _MACRO_ONLY/* この簇眶を钙び叫す箕には、ステ〖タスレジスタのEXLビット = 0 で钙び叫すこと。 なお、附哼、カ〖ネルでは、バナ〖山绩箕、シリアル叫蜗箕に钙叫を乖っている。*/Inline void stub_putc(int c) { Asm(" move $5, %0; \ li $4, 0xfe00; \ syscall; \ nop" :: "r"(c) : "$4","$5" );}#endif /* _MACRO_ONLY */#ifdef GDB_STUB#define vr5500_putc(c) stub_putc(c)#else /* GDB_STUB */#define vr5500_putc(c) tl16pir552_write_por( (VP) UART_CH01, THR, (UB) c )#endif /* GDB_STUB *//* * PARTNER-J のシステムコ〖ルによるコンソ〖ル叫蜗∈テストしていません。∷ */#ifndef _MACRO_ONLYInline void partner_putc(int c) { Asm(" move $2, %0; \ li $1, 0xfe00; \ jal SYSCALL; \ nop" :: "r"(c) : "$1","$2" );}#endif /* _MACRO_ONLY */#ifdef PARTNER_J /* PARTNER_J の眷圭 *#define vr5500_putc(c) partner_putc(c)#else /* GDB_STUB */#define vr5500_putc(c) tl16pir552_write_por( (VP) UART_CH01, THR, (UB) c )#endif /* GDB_STUB */#ifndef _MACRO_ONLYInline voidvr5500_exit() {}#endif /* _MACRO_ONLY */#endif /* _VR5500_H_ */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -