📄 cpu_config.c
字号:
/* * 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 * * 惧淡螟侯涪荚は·笆布の (1)×(4) の掘凤か·Free Software Foundation * によって给山されている GNU General Public License の Version 2 に淡 * 揭されている掘凤を塔たす眷圭に嘎り·塑ソフトウェア∈塑ソフトウェア * を猖恃したものを崔むˉ笆布票じ∷を蝗脱ˇ剩澜ˇ猖恃ˇ浩芹邵∈笆布· * 网脱と钙ぶ∷することを痰浸で钓满するˉ * (1) 塑ソフトウェアをソ〖スコ〖ドの妨で网脱する眷圭には·惧淡の螟侯 * 涪山绩·この网脱掘凤および布淡の痰瘦沮惮年が·そのままの妨でソ〖 * スコ〖ド面に崔まれていることˉ * (2) 塑ソフトウェアを·ライブラリ妨及など·戮のソフトウェア倡券に蝗 * 脱できる妨で浩芹邵する眷圭には·浩芹邵に燃うドキュメント∈网脱 * 荚マニュアルなど∷に·惧淡の螟侯涪山绩·この网脱掘凤および布淡 * の痰瘦沮惮年を非很することˉ * (3) 塑ソフトウェアを·怠达に寥み哈むなど·戮のソフトウェア倡券に蝗 * 脱できない妨で浩芹邵する眷圭には·肌のいずれかの掘凤を塔たすこ * とˉ * (a) 浩芹邵に燃うドキュメント∈网脱荚マニュアルなど∷に·惧淡の螟 * 侯涪山绩·この网脱掘凤および布淡の痰瘦沮惮年を非很することˉ * (b) 浩芹邵の妨轮を·侍に年める数恕によって·TOPPERSプロジェクトに * 鼠桂することˉ * (4) 塑ソフトウェアの网脱により木儡弄または粗儡弄に栏じるいかなる禄 * 巢からも·惧淡螟侯涪荚およびTOPPERSプロジェクトを倘勒することˉ * * 塑ソフトウェアは·痰瘦沮で捏丁されているものであるˉ惧淡螟侯涪荚お * よびTOPPERSプロジェクトは·塑ソフトウェアに簇して·その努脱材墙拉も * 崔めて·いかなる瘦沮も乖わないˉまた·塑ソフトウェアの网脱により木 * 儡弄または粗儡弄に栏じたいかなる禄巢に簇しても·その勒扦を砷わないˉ * * @(#) $Id: cpu_config.c,v 1.23 2004/06/27 13:15:48 honda Exp $ *//* * プロセッサ巴赂モジュ〖ル∈SH3/4脱∷ */#include <s_services.h>#include "jsp_kernel.h"#include "check.h"#include "task.h"/* * タスクコンテキストでの充哈みマスク */#ifdef SUPPORT_CHG_IPMUW task_intmask;#endif /* SUPPORT_CHG_IPM *//* * 润タスクコンテキストでの充哈みマスク */UW int_intmask;/* * 充り哈みハンドラ/庭黎刨の悼击テ〖ブル */FP int_table[0x50];VW int_plevel_table[0x50];/* * CPU毋嘲ハンドラの悼击テ〖ブル */FP exc_table[(0x1E0 >> 5) + 1];/* * プロセッサ巴赂の介袋步 */voidcpu_initialize(){ int i; /* * タスクコンテキストでの充哈みマスクの介袋步 */#ifdef SUPPORT_CHG_IPM task_intmask = 0x0000; #endif /* SUPPORT_CHG_IPM */ /* * int_table[],int_plevel_table[]の介袋步 * 踏判峡の充哈み券栏箕にcpu_interrup()が钙び叫されるように * no_reg_interrup()を判峡する * ディフォルトのint_plevel_table[]の充哈み庭黎刨はMAX_IPM - 1 * とするˉ */ for(i = 0; i < 0x50; i++){ int_table[i] = no_reg_interrupt; int_plevel_table[i] = 0x40000000 | (MAX_IPM - 1) << 4; } #ifndef GDB_STUB /* * 充り哈みコントロ〖ラの介袋步 */#if defined(SH7750) sil_wrh_mem((VP)ICR, 0x0000); sil_wrh_mem((VP)IPRA, 0x0000); sil_wrh_mem((VP)IPRB, 0x0000); sil_wrh_mem((VP)IPRC, 0x0000);#else /* SH7708 || SH7709 || SH7709A || SH7729R || SH7727 */ sil_wrh_mem((VP)ICR0, 0x0000); sil_wrh_mem((VP)IPRA, 0x0000); sil_wrh_mem((VP)IPRB, 0x0000);#if defined(SH7709) || defined(SH7709A) || defined(SH7729R) || defined(SH7727) sil_wrh_mem((VP)ICR1, 0x4000); sil_wrh_mem((VP)ICR2, 0x0000); sil_wrh_mem((VP)PINTER, 0x0000); sil_wrh_mem((VP)IPRC, 0x0000); sil_wrh_mem((VP)IPRD, 0x0000); sil_wrh_mem((VP)IPRE, 0x0000); sil_wrb_mem((VP)IRR0, 0x0000); sil_wrb_mem((VP)IRR1, 0x0000); sil_wrb_mem((VP)IRR2, 0x0000);#endif /* SH7709 || SH7709A */ #endif /* SH7750 */ /* * ベクタベ〖スレジスタ〖の介袋步 */ set_vbr(BASE_VBR); #endif /* GDB_STUB */}/* * プロセッサ巴赂の姜位借妄 */voidcpu_terminate(){}/* * Trapa笆嘲の毋嘲で判峡されていない毋嘲が券栏すると钙び叫される */voidcpu_expevt(VW expevt,VW spc,VW ssr,VW pr){ syslog(LOG_EMERG, "Unregistered Expevt error occurs."); syslog(LOG_EMERG, "Expevt = %08x SPC = %08x SR = %08x PR=%08X", expevt,spc,ssr,pr); while(1);}/* * 踏判峡の充哈みが券栏した眷圭に钙び叫される */voidcpu_interrupt(VW intevt, VW intevt2,VW spc,VW ssr){ syslog(LOG_EMERG, "Unregistered Interrupt occurs.");#if defined(SH7709) || defined(SH7709A) || defined(SH7729R) || defined(SH7727) syslog(LOG_EMERG, "INTEVT = %08x INTEVT2 = %08x SPC = %08x SR = %08x ", intevt,intevt2,spc,ssr);#else /* SH7708 || SH7750 */ syslog(LOG_EMERG, "INTEVT = %08x SPC = %08x SR = %08x ",intevt,spc,ssr);#endif while(1);}#ifdef SUPPORT_CHG_IPM/* * 充哈みマスクの恃构 * * chg_ipm を蝗って IPM を MAX_IPM ∈NMI スタブリモ〖トブレ〖ク 笆嘲 * のすべての充哈みを敦贿∷笆惧に恃构することはできないˉNMI スタブリ * モ〖トブレ〖ク笆嘲のすべての充哈みを敦贿したい眷圭には、loc_cpu に * よりCPUロック觉轮にすればよいˉIPM が 0 笆嘲の箕にも·タスクディス * パッチは瘦伪されないˉIPM は·タスクディスパッチによって·糠しく悸 * 乖觉轮になったタスクへ苞き费がれるˉそのため·タスクが悸乖面に·侍 * のタスクによって IPM が恃构される眷圭があるˉJSPカ〖ネルでは·IPM * の恃构はタスク毋嘲借妄ル〖チンによっても弹こるので·これによって胺 * いが岂しくなる觉斗は警ないと蛔われるˉIPM の猛によってタスクディス * パッチを敦贿したい眷圭には·dis_dsp を驶脱すればよいˉ */SYSCALL ERchg_ipm(IPM ipm){ ER ercd; LOG_CHG_IPM_ENTER(ipm); CHECK_TSKCTX_UNL(); CHECK_PAR(0 <= ipm && ipm <= MAX_IPM - 1); t_lock_cpu(); task_intmask = (ipm << 4); ercd = E_OK; t_unlock_cpu(); exit: LOG_CHG_IPM_LEAVE(ercd); return(ercd);}/* * 充哈みマスクの徊救 */SYSCALL ERget_ipm(IPM *p_ipm){ ER ercd; LOG_GET_IPM_ENTER(p_ipm); CHECK_TSKCTX_UNL(); t_lock_cpu(); *p_ipm = (task_intmask >> 4); ercd = E_OK; t_unlock_cpu(); exit: LOG_GET_IPM_LEAVE(ercd, *p_ipm); return(ercd);}#endif /* SUPPORT_CHG_IPM */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -