📄 cpu_config.c
字号:
/* * TOPPERS/JSP Kernel * Toyohashi Open Platform for Embedded Real-Time Systems/ * Just Standard Profile Kernel * * Copyright (C) 2000-2004 by Embedded and Real-Time Systems Laboratory * Toyohashi Univ. of Technology, JAPAN * Copyright (C) 2001-2004 by Dep. of Computer Science and Engineering * Tomakomai National College of Technology, JAPAN * Copyright (C) 2001-2004 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プロジェクトは·塑ソフトウェアに簇して·その努脱材墙拉も * 崔めて·いかなる瘦沮も乖わないˉまた·塑ソフトウェアの网脱により木 * 儡弄または粗儡弄に栏じたいかなる禄巢に簇しても·その勒扦を砷わないˉ *//* * プロセッサ巴赂モジュ〖ル(H8S脱) */#include "jsp_kernel.h"#include "check.h"#include "task.h"/* * タスクコンテキストでの充哈みマスク */#ifdef SUPPORT_CHG_IPMvolatile IPM task_intmask = 0; /* IPM -> UB¨射规痰し8ビット */#endif /* SUPPORT_CHG_IPM *//* * 润タスクコンテキストでの充哈みマスク */volatile IPM int_intmask = 0;/* * 充哈みネストカウンタ */volatile UB intnest = 1;/* * CPUロック觉轮を山すフラグ * ˇ充哈み敦贿∈カ〖ネル瓷妄布の充哈みのみ∷ * かつ * ˇiscpulocked == TRUE * のときCPUロック觉轮とする。 */volatile BOOL iscpulocked = TRUE;/* * プロセッサ巴赂の介袋步 */void cpu_initialize(void) { /* * 笆布の4つはスタ〖トアップル〖チンで介袋步が貉んでいる。 * ˇ充哈みネストカウンタ intnest = 1; * ˇ润タスクコンテキストの充哈みマスク int_intmask = 0; * ˇタスクコンテキストの充哈みマスク task_intmask = 0; * ∈chg_ipmをサポ〖トする眷圭∷ * ˇCPUロックフラグ iscpulocked = TRUE; */ /* 充哈み扩告モ〖ドの肋年 */ h8s_wrb_reg(SYSCR, SYS_SYSCR); /* 充哈みレベルの介袋步 */ h8s_wrb_reg(IPRA, 0); h8s_wrb_reg(IPRB, 0); h8s_wrb_reg(IPRC, 0); h8s_wrb_reg(IPRD, 0); h8s_wrb_reg(IPRE, 0); h8s_wrb_reg(IPRF, 0); h8s_wrb_reg(IPRG, 0); h8s_wrb_reg(IPRH, 0); h8s_wrb_reg(IPRI, 0); h8s_wrb_reg(IPRJ, 0); h8s_wrb_reg(IPRK, 0);}/* * プロセッサ巴赂の姜位借妄 */void cpu_terminate(void) {}/* * 腮警箕粗略ち * 庙罢祸灌¨ * 筛洁ではdlytimはUINT房だが16ビットしかないので、 * UW房に恃构している。 * sil_dly_nse()は柒婶でsil_dly_nse_long()を钙び叫す。 */void sil_dly_nse(UINT dlytim) { sil_dly_nse_long((UW)dlytim);}#ifdef SUPPORT_CHG_IPM/* * 充哈みマスクの恃构 * * IPMに肋年できる猛は0×MAX_IPMである。 * 充哈みプライオリティレベルが(MAX_IPM+1)笆惧の充哈みはカ〖ネル瓷妄嘲 * 胺いである。 * * IPM が 0 笆嘲の箕にも·タスクディスパッチは瘦伪されないˉ * ディスパッチも敦贿したい眷圭には·loc_cpu によりCPUロック觉轮に * すればよいˉIPM は· * タスクディスパッチによって·糠しく悸乖觉轮になったタスクへ苞き费が * れるˉそのため·タスクが悸乖面に·侍のタスクによって IPM が恃构さ * れる眷圭があるˉJSPカ〖ネルでは·IPM の恃构はタスク毋嘲借妄ル〖チ * ンによっても弹こるのが·これによって胺いが岂しくなる觉斗は警ないと * 蛔われるˉ * IPM の猛によってタスクディスパッチを敦贿したい眷圭には·dis_dspを * 驶脱すればよいˉ */SYSCALL ERchg_ipm(IPM ipm){ ER ercd = E_OK; LOG_CHG_IPM_ENTER(ipm); CHECK_TSKCTX_UNL(); CHECK_PAR(ipm <= MAX_IPM); t_lock_cpu(); task_intmask = ipm; t_unlock_cpu(); exit: LOG_CHG_IPM_LEAVE(ercd) return(ercd);}/* * 充哈みマスクの徊救 */SYSCALL ERget_ipm(IPM *p_ipm){ ER ercd = E_OK; LOG_GET_IPM_ENTER(p_ipm); CHECK_TSKCTX_UNL(); t_lock_cpu(); *p_ipm = task_intmask; t_unlock_cpu(); exit: LOG_GET_IPM_LEAVE(ercd, *p_ipm); return(ercd);}#endif /* SUPPORT_CHG_IPM *//*============================================================================*//* 鼎奶ドキュメントにはない、迫极の婶尸 *//* * 判峡されていない充り哈みが券栏すると钙び叫される */void cpu_experr(EXCSTACK *sp){ UW sp2, pc, ccr, tmp; sp2 = (UW)sp + OFFSET_SP; tmp = sp->pc; ccr = (tmp >> 24U) & 0xff; /* 惧疤1バイト */ pc = tmp & 0x00ffffffUL; /* 布疤3バイト */ syslog(LOG_EMERG, "Unexpected interrupt."); syslog(LOG_EMERG, "PC = 0x%08lx SP = 0x%08lx CCR = 0x%02x", (VP)pc, (VP)sp2, (INT)ccr); syslog(LOG_EMERG, "EXR = 0x%02x", (INT)(sp->exr)); syslog(LOG_EMERG, "ER0 = 0x%08lx ER1 = 0x%08lx ER2 = 0x%08lx ER3 = 0x%08lx", (VP)(sp->er0), (VP)(sp->er1), (VP)(sp->er2), (VP)(sp->er3)); syslog(LOG_EMERG, "ER4 = 0x%08lx ER5 = 0x%08lx ER6 = 0x%08lx", (VP)(sp->er4), (VP)(sp->er5), (VP)(sp->er6)); while(1) ;}/*============================================================================*//* デバッグ脱コ〖ド */#ifdef TEST_CPU_INSNvolatile UB ccr, exr;volatile IPM intmask;void test_cpu_insn(void){ ccr = current_ccr(); set_ccr(0xf); ccr = current_ccr(); exr = current_exr(); set_exr(0x7); exr = current_exr(); intmask = current_intmask(); set_intmask(0x3); intmask = current_intmask(); disint(); enaint(); _disint_();}#endif /* TEST_CPU_INSN */#ifdef TEST_CPU_CONFIGvolatile BOOL b;volatile ER err;volatile IPM ipm;void dummy(void){}void test_cpu_config(void){ b = sense_context(); dummy(); intnest = 1; dummy(); b = sense_context(); dummy(); intnest = 0; dummy(); b = sense_context(); dummy(); b = t_sense_lock(); dummy(); t_lock_cpu(); dummy(); b = t_sense_lock(); dummy(); t_unlock_cpu(); dummy(); b = t_sense_lock(); dummy(); i_lock_cpu(); dummy(); b = i_sense_lock(); dummy(); i_unlock_cpu(); dummy(); b = i_sense_lock(); dummy(); err = chg_ipm(6); dummy(); err = get_ipm(&ipm); dummy(); err = chg_ipm(3); dummy(); err = get_ipm(&ipm); dummy(); err = chg_ipm(8); dummy();}#endif /* TEST_CPU_CONFIG */#ifdef TEST_H8S_SILvolatile UB ddr;void test_h8s_sil(void){ ddr = sil_reb_ddr(IO_PORT7); sil_wrb_ddr(IO_PORT7, 0xff); ddr = sil_reb_ddr(IO_PORT7); sil_anb_ddr(IO_PORT7, 0xf); ddr = sil_reb_ddr(IO_PORT7); sil_orb_ddr(IO_PORT7, 0x80); ddr = sil_reb_ddr(IO_PORT7);}#endif /* TEST_H8S_SIL */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -