3 * Toyohashi Open Platform for Embedded Real-Time Systems/
4 * Just Standard Profile Kernel
6 * Copyright (C) 2000-2003 by Embedded and Real-Time Systems Laboratory
7 * Toyohashi Univ. of Technology, JAPAN
9 * 上記著作権者は,以下の (1)〜(4) の条件か,Free Software Foundation
10 * によって公表されている GNU General Public License の Version 2 に記
11 * 述されている条件を満たす場合に限り,本ソフトウェア(本ソフトウェア
12 * を改変したものを含む.以下同じ)を使用・複製・改変・再配布(以下,
14 * (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
15 * 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
17 * (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
18 * 用できる形で再配布する場合には,再配布に伴うドキュメント(利用
19 * 者マニュアルなど)に,上記の著作権表示,この利用条件および下記
21 * (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
22 * 用できない形で再配布する場合には,次のいずれかの条件を満たすこ
24 * (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
25 * 作権表示,この利用条件および下記の無保証規定を掲載すること.
26 * (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
28 * (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
29 * 害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
31 * 本ソフトウェアは,無保証で提供されているものである.上記著作権者お
32 * よびTOPPERSプロジェクトは,本ソフトウェアに関して,その適用可能性も
33 * 含めて,いかなる保証も行わない.また,本ソフトウェアの利用により直
34 * 接的または間接的に生じたいかなる損害に関しても,その責任を負わない.
36 * @(#) $Id: sys_config.c,v 1.1 2009/01/31 05:27:37 suikan Exp $
40 * ターゲットシステム依存モジュール(DVE68K/40用)
43 #include "jsp_kernel.h"
45 #include <dve68k_dga.h>
48 * プロセッサ識別のための変数(マルチプロセッサ対応)
50 UINT board_id; /* ボードID */
51 VP board_addr; /* ローカルメモリの先頭アドレス */
62 board_id = ((UINT)(sil_rew_mem((VP) TADR_BOARD_REG0)) & 0x1f);
63 board_addr = (VP)(board_id << 24);
68 * すべての割込みをマスク・クリアし,割込みベクトルを設定する.
70 dga_write((VP) TADR_DGA_CSR21, 0);
71 dga_write((VP) TADR_DGA_CSR23, ~0);
72 dga_write((VP) TADR_DGA_CSR19, (TVEC_G0I << 24) | (TVEC_G1I << 16)
73 | (TVEC_SWI << 8) | TVEC_SPRI);
78 * アボート割込みの割込みレベルを設定し,要求をクリアした後,
81 dga_set_ilv((VP) TADR_DGA_CSR24, TBIT_ABTIL, TIRQ_NMI);
82 dga_write((VP) TADR_DGA_CSR23, TBIT_ABT);
83 dga_bit_or((VP) TADR_DGA_CSR21, TBIT_ABT);
88 * ローカルメモリのVMEバス上での先頭アドレスとサイズ(16MB)
89 * し,アクセスを受け付けるように設定する.また,VMEバスから
90 * 拡張アドレスアクセスを受け付けるようにに設定する.
92 dga_write((VP) TADR_DGA_CSR4, (UW) board_addr | 0x00ff);
93 dga_write((VP) TADR_DGA_CSR5, 0x0000012fu);
98 * インタフェースレジスタのベースアドレスを設定する.また,イ
99 * ンタフェースレジスタ0のサービスリクエストフラグをクリア.
100 * インタフェースレジスタ3にボードのID番号を設定.
102 dga_write((VP) TADR_DGA_CSR3, (board_id << 4) | 0x3);
103 dga_write((VP) TADR_DGA_IFR0, 0x80000000u);
104 dga_write((VP) TADR_DGA_IFR3, board_id);
107 * ラウンドロビンモードに設定(マルチプロセッサ対応)
109 dga_write((VP) TADR_DGA_CSR1, (dga_read((VP) TADR_DGA_CSR1)
110 & 0xffeffcff) | (1u << 20) | ((board_id % 4) << 8));