📄 sys_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: sys_config.c,v 1.7 2003/07/08 14:57:15 hiro Exp $ *//* * タ〖ゲットシステム巴赂モジュ〖ル∈DVE68K/40脱∷ */#include "jsp_kernel.h"#include <sil.h>#include <dve68k_dga.h>/* * プロセッサ急侍のための恃眶∈マルチプロセッサ滦炳∷ */UINT board_id; /* ボ〖ドID */VP board_addr; /* ロ〖カルメモリの黎片アドレス *//* * タ〖ゲットシステム巴赂の介袋步 */voidsys_initialize(){ /* * プロセッサ急侍のための恃眶の介袋步 */ board_id = ((UINT)(sil_rew_mem((VP) TADR_BOARD_REG0)) & 0x1f); board_addr = (VP)(board_id << 24); /* * 充哈み簇息の介袋步 * * すべての充哈みをマスクˇクリアし·充哈みベクトルを肋年するˉ */ dga_write((VP) TADR_DGA_CSR21, 0); dga_write((VP) TADR_DGA_CSR23, ~0); dga_write((VP) TADR_DGA_CSR19, (TVEC_G0I << 24) | (TVEC_G1I << 16) | (TVEC_SWI << 8) | TVEC_SPRI); /* * アボ〖ト充哈みの肋年∈NMI∷ * * アボ〖ト充哈みの充哈みレベルを肋年し·妥滇をクリアした稿· * マスクを豺近するˉ */ dga_set_ilv((VP) TADR_DGA_CSR24, TBIT_ABTIL, TIRQ_NMI); dga_write((VP) TADR_DGA_CSR23, TBIT_ABT); dga_bit_or((VP) TADR_DGA_CSR21, TBIT_ABT); /* * メモリ挝拌の肋年 * * ロ〖カルメモリのVMEバス惧での黎片アドレスとサイズ∈16MB∷ * し·アクセスを减け烧けるように肋年するˉまた·VMEバスから * 橙磨アドレスアクセスを减け烧けるようにに肋年するˉ */ dga_write((VP) TADR_DGA_CSR4, (UW) board_addr | 0x00ff); dga_write((VP) TADR_DGA_CSR5, 0x0000012fu); /* * インタフェ〖スレジスタ∈IFR∷の肋年 * * インタフェ〖スレジスタのベ〖スアドレスを肋年するˉまた·イ * ンタフェ〖スレジスタ0のサ〖ビスリクエストフラグをクリアˉ * インタフェ〖スレジスタ3にボ〖ドのID戎规を肋年ˉ */ dga_write((VP) TADR_DGA_CSR3, (board_id << 4) | 0x3); dga_write((VP) TADR_DGA_IFR0, 0x80000000u); dga_write((VP) TADR_DGA_IFR3, board_id); /* * ラウンドロビンモ〖ドに肋年∈マルチプロセッサ滦炳∷ */ dga_write((VP) TADR_DGA_CSR1, (dga_read((VP) TADR_DGA_CSR1) & 0xffeffcff) | (1u << 20) | ((board_id % 4) << 8));}/* * タ〖ゲットシステムの姜位 */voidsys_exit(){ dve68k_exit();}/* * タ〖ゲットシステムの矢机叫蜗 */voidsys_putc(char c){ if (c == '\n') { dve68k_putc('\r'); } dve68k_putc(c);}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -