source: EcnlProtoTool/trunk/asp3_dcre/arch/arm_gcc/common/core_kernel.trb@ 270

Last change on this file since 270 was 270, checked in by coas-nagasima, 7 years ago

mruby版ECNLプロトタイピング・ツールを追加

  • Property svn:eol-style set to native
  • Property svn:mime-type set to text/x-ruby
File size: 4.6 KB
Line 
1# -*- coding: utf-8 -*-
2#
3# TOPPERS/ASP Kernel
4# Toyohashi Open Platform for Embedded Real-Time Systems/
5# Advanced Standard Profile Kernel
6#
7# Copyright (C) 2015 by FUJI SOFT INCORPORATED, JAPAN
8# Copyright (C) 2015,2016 by Embedded and Real-Time Systems Laboratory
9# Graduate School of Information Science, Nagoya Univ., JAPAN
10#
11# 上記著作権者
12は,以下の(1)~(4)の条件を満たす場合に限り,本ソフトウェ
13# ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
14# 変・再é…
15å¸ƒï¼ˆä»¥ä¸‹ï¼Œåˆ©ç”¨ã¨å‘¼ã¶ï¼‰ã™ã‚‹ã“とを無償で許諾する.
16# (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
17# 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
18# スコード中に含まれていること.
19# (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
20# 用できる形で再é…
21å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œå†é…
22å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨
23# 者
24マニュアルなど)に,上記の著作権表示,この利用条件および下記
25# の無保証規定を掲載すること.
26# (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
27# 用できない形で再é…
28å¸ƒã™ã‚‹å ´åˆã«ã¯ï¼Œæ¬¡ã®ã„ずれかの条件を満たすこ
29# と.
30# (a) 再é…
31å¸ƒã«ä¼´ã†ãƒ‰ã‚­ãƒ¥ãƒ¡ãƒ³ãƒˆï¼ˆåˆ©ç”¨è€…
32マニュアルなど)に,上記の著
33# 作権表示,この利用条件および下記の無保証規定を掲載すること.
34# (b) 再é…
35å¸ƒã®å½¢æ…
36‹ã‚’,別に定める方法によって,TOPPERSプロジェクトに
37# 報告すること.
38# (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
39# 害からも,上記著作権者
40およびTOPPERSプロジェクトをå…
41è²¬ã™ã‚‹ã“と.
42# また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
43# 由に基づく請求からも,上記著作権者
44およびTOPPERSプロジェクトを
45# å…
46è²¬ã™ã‚‹ã“と.
47#
48# 本ソフトウェアは,無保証で提供されているものである.上記著作権者
49お
50# よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
51# に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
52# アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
53# の責任を負わない.
54#
55# $Id: core_kernel.trb 662 2016-02-27 02:33:51Z ertl-hiro $
56#
57
58#
59# パス2の生成スクリプトのコア依存部(ARM用)
60#
61
62#
63# 有効なCPU例外ハンドラ番号
64#
65$EXCNO_VALID = [ 0, 1, 2, 3, 4, 5 ]
66
67#
68# DEF_EXCで使用できるCPU例外ハンドラ番号
69#
70$EXCNO_DEFEXC_VALID = [ 0, 1, 2, 3, 5 ]
71
72#
73# ターゲット非依存部のインクルード
74#
75IncludeTrb("kernel/kernel.trb")
76
77#
78# 割込みハンドラテーブル
79#
80$kernelCfgC.comment_header("Interrupt Handler Table")
81
82$kernelCfgC.add("FP _kernel_inh_table[TNUM_INHNO] = {")
83$INHNO_VALID.each_with_index do |inhnoVal, index|
84 $kernelCfgC.add(",") if index > 0
85 $kernelCfgC.append("\t/* 0x#{sprintf("%03x", inhnoVal)} */ ")
86 if $cfgData[:DEF_INH].has_key?(inhnoVal)
87 $kernelCfgC.append("(FP)(#{$cfgData[:DEF_INH][inhnoVal][:inthdr]})")
88 else
89 $kernelCfgC.append("(FP)(_kernel_default_int_handler)")
90 end
91end
92$kernelCfgC.add
93$kernelCfgC.add2("};")
94
95#
96# 割込み要求ライン設定テーブル
97#
98if $USE_INTCFG_TABLE
99 $kernelCfgC.comment_header("Interrupt Configuration Table")
100
101 $kernelCfgC.add("const uint8_t _kernel_intcfg_table[TNUM_INTNO] = {")
102 $INTNO_VALID.each_with_index do |intnoVal, index|
103 $kernelCfgC.add(",") if index > 0
104 $kernelCfgC.append("\t/* 0x#{sprintf("%03x", intnoVal)} */ ")
105 if $cfgData[:CFG_INT].has_key?(intnoVal)
106 $kernelCfgC.append("1U")
107 else
108 $kernelCfgC.append("0U")
109 end
110 end
111 $kernelCfgC.add
112 $kernelCfgC.add2("};")
113end
114
115#
116# CPU例外ハンドラテーブル
117#
118$kernelCfgC.comment_header("CPU Exception Handler Table")
119
120$kernelCfgC.add("const FP _kernel_exc_table[TNUM_EXCNO] = {")
121$EXCNO_VALID.each_with_index do |excnoVal, index|
122 $kernelCfgC.add(",") if index > 0
123 $kernelCfgC.append("\t/* #{excnoVal} */ ")
124 if $cfgData[:DEF_EXC].has_key?(excnoVal)
125 $kernelCfgC.append("(FP)(#{$cfgData[:DEF_EXC][excnoVal][:exchdr]})")
126 else
127 $kernelCfgC.append("(FP)(_kernel_default_exc_handler)")
128 end
129end
130$kernelCfgC.add
131$kernelCfgC.add2("};")
Note: See TracBrowser for help on using the repository browser.