📄 sys_support.s
字号:
/* * 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-2005 by Industrial Technology Institute, * Miyagi Prefectural Government, JAPAN * Copyright (C) 2001-2004 by Dep. of Computer Science and Engineering * Tomakomai National College of Technology, JAPAN * Copyright (C) 2001-2004 by Kunihiko Ohnaka * * 惧淡螟侯涪荚は·笆布の (1)×(4) の掘凤か·Free Software Foundation * によって给山されている GNU General Public License の Version 2 に淡 * 揭されている掘凤を塔たす眷圭に嘎り·塑ソフトウェア∈塑ソフトウェア * を猖恃したものを崔むˉ笆布票じ∷を蝗脱ˇ剩澜ˇ猖恃ˇ浩芹邵∈笆布· * 网脱と钙ぶ∷することを痰浸で钓满するˉ * (1) 塑ソフトウェアをソ〖スコ〖ドの妨で网脱する眷圭には·惧淡の螟侯 * 涪山绩·この网脱掘凤および布淡の痰瘦沮惮年が·そのままの妨でソ〖 * スコ〖ド面に崔まれていることˉ * (2) 塑ソフトウェアを·ライブラリ妨及など·戮のソフトウェア倡券に蝗 * 脱できる妨で浩芹邵する眷圭には·浩芹邵に燃うドキュメント∈网脱 * 荚マニュアルなど∷に·惧淡の螟侯涪山绩·この网脱掘凤および布淡 * の痰瘦沮惮年を非很することˉ * (3) 塑ソフトウェアを·怠达に寥み哈むなど·戮のソフトウェア倡券に蝗 * 脱できない妨で浩芹邵する眷圭には·肌のいずれかの掘凤を塔たすこ * とˉ * (a) 浩芹邵に燃うドキュメント∈网脱荚マニュアルなど∷に·惧淡の螟 * 侯涪山绩·この网脱掘凤および布淡の痰瘦沮惮年を非很することˉ * (b) 浩芹邵の妨轮を·侍に年める数恕によって·TOPPERSプロジェクトに * 鼠桂することˉ * (4) 塑ソフトウェアの网脱により木儡弄または粗儡弄に栏じるいかなる禄 * 巢からも·惧淡螟侯涪荚およびTOPPERSプロジェクトを倘勒することˉ * * 塑ソフトウェアは·痰瘦沮で捏丁されているものであるˉ惧淡螟侯涪荚お * よびTOPPERSプロジェクトは·塑ソフトウェアに簇して·その努脱材墙拉も * 崔めて·いかなる瘦沮も乖わないˉまた·塑ソフトウェアの网脱により木 * 儡弄または粗儡弄に栏じたいかなる禄巢に簇しても·その勒扦を砷わないˉ * * @(#) $Id: sys_support.S,v 1.12 2005/11/07 01:49:53 honda Exp $ *//* * タ〖ゲットシステム巴赂モジュ〖ル アセンブリ咐胳婶 */#define _MACRO_ONLY#include "jsp_kernel.h"/* * システム巴赂の介袋步ル〖チン */ .h8300h .text .align 2 .global _hardware_init_hook_hardware_init_hook: /* * リリ〖スでは、嘲婶DRAMを铜跟にする。 * ∈嘲婶DRAMを蝗脱する眷圭∷ */#ifdef ROM mov.b #0xff, r1l mov.l #H8P1DDR, er0 mov.b r1l, @er0 /* enable A0 - A7 */ add.b #(H8P2DDR - H8P1DDR), r0l mov.b r1l, @er0 /* enable A8 - A15 */ add.b #(H8P3DDR - H8P2DDR), r0l mov.b r1l, @er0 /* enable D8 - D15 */ mov.b #H8P5DDR_A16, r0h mov.b r0h, @H8P5DDR /* Enable A16 */#endif /* #ifdef ROM */ /* * Ethernetデバイスを蝗脱する眷圭、ここでCS1を肋年しないと * デバイスが疙瓢侯する。 */#if defined(ROM) || defined(INMEM_ONLY) mov.b #H8P8DDR0, r0h mov.b r0h, @H8P8DDR /* Enable CS1/CS2 */#endif /* defined(ROM) || defined(INMEM_ONLY) */#ifdef ROM mov.b #H8PBDDR_UCAS, r0h mov.b r0h, @H8PBDDR /* Enable UCAS */ /* DRAM: 2,048/32ms: 32ms / 2,048 = 15.625us */ /* 20MHz / 8 / 39 = 1 / 15.6us */ mov.b #((32*(CPU_CLOCK/1000))/(8*2048)), r0h mov.b r0h, @H8RTCOR mov.b #H8RTMCSR_CKS1, r0h mov.b r0h, @H8RTMCSR /* clock / 8 */ mov.b #(H8DRCRB_RCYCE | H8DRCRB_MXC1), r0h mov.b r0h, @H8DRCRB /* column address: 10 bit, A23 - A10 */ /* * ロットにより蝗脱されている嘲婶RAMが佰なる * ˇ泣惟澜 HM5117800 * ˇOKI澜 M5117805D * * 尉滦炳にするため、 * ˇBE ビット♂1 * ˇRDMビット♂0 * * 拒嘿は(toppers-users 1375)を徊救 * */ mov.b #(H8DRCRA_BE | H8DRCRA_DRAS0), r0h mov.b r0h, @H8DRCRA mov.l #(CPU_CLOCK / 1000), er0 /* Wait for DRAM stable */_hw_init_hock_1: dec.l #1, er0 bne _hw_init_hock_1#endif /* #ifdef ROM */ rts
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -