1 | # coding: utf-8
|
---|
2 | #
|
---|
3 | # TECS Generator
|
---|
4 | # Generator for TOPPERS Embedded Component System
|
---|
5 | #
|
---|
6 | # Copyright (C) 2008-2018 by TOPPERS Project
|
---|
7 | #--
|
---|
8 | # 上記著作権者は,以下の(1)~(4)の条件を満たす場合に限り,本ソフトウェ
|
---|
9 | # ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
|
---|
10 | # 変・再配布(以下,利用と呼ぶ)することを無償で許諾する.
|
---|
11 | # (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
|
---|
12 | # 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
|
---|
13 | # スコード中に含まれていること.
|
---|
14 | # (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
|
---|
15 | # 用できる形で再配布する場合には,再配布に伴うドキュメント(利用
|
---|
16 | # 者マニュアルなど)に,上記の著作権表示,この利用条件および下記
|
---|
17 | # の無保証規定を掲載すること.
|
---|
18 | # (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
|
---|
19 | # 用できない形で再配布する場合には,次のいずれかの条件を満たすこ
|
---|
20 | # と.
|
---|
21 | # (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
|
---|
22 | # 作権表示,この利用条件および下記の無保証規定を掲載すること.
|
---|
23 | # (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
|
---|
24 | # 報告すること.
|
---|
25 | # (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
|
---|
26 | # 害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
|
---|
27 | # また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
|
---|
28 | # 由に基づく請求からも,上記著作権者およびTOPPERSプロジェクトを
|
---|
29 | # 免責すること.
|
---|
30 | #
|
---|
31 | # 本ソフトウェアは,無保証で提供されているものである.上記著作権者お
|
---|
32 | # よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
|
---|
33 | # に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
|
---|
34 | # アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
|
---|
35 | # の責任を負わない.
|
---|
36 | #
|
---|
37 | #++
|
---|
38 |
|
---|
39 | require_tecsgen_lib "HRPKernelObjectPlugin.rb"
|
---|
40 |
|
---|
41 |
|
---|
42 | #== celltype プラグインの共通の親クラス
|
---|
43 | class HRPHandlerPlugin < HRPKernelObjectPlugin
|
---|
44 |
|
---|
45 | ##
|
---|
46 | # oyama: add to avoid Ruby exception in code generation phase.
|
---|
47 | def new_cell cell
|
---|
48 | domainOption = cell.get_region.get_domain_root.get_domain_type.get_option
|
---|
49 | if (domainOption == "OutOfDomain") || (domainOption != "kernel")
|
---|
50 | cdl_error( "HRP9999 HRP handler '$1' must belong to kernel domain", cell.get_name )
|
---|
51 | end
|
---|
52 | end
|
---|
53 |
|
---|
54 | ##
|
---|
55 | #
|
---|
56 | # file : output file (ex.tecsgen.cfg)
|
---|
57 | # cell :
|
---|
58 | # val :
|
---|
59 | # tab :
|
---|
60 | def print_cfg_cre(file, cell, val, tab)
|
---|
61 | if !val[:id].nil?
|
---|
62 | val[:id] = val[:id].gsub( /(^|[^\$])\$id\$/, "\\1#{@celltype.get_name.to_s}_#{cell.get_name.to_s}" )
|
---|
63 | end
|
---|
64 | # $cbp$の代わり
|
---|
65 | index = cell.get_id - @celltype.get_id_base
|
---|
66 | #cell_CB_name = "#{@celltype.get_global_name}_CB_tab[#{index}]"
|
---|
67 | name_array = cell.get_celltype.get_name_array cell
|
---|
68 | cell_CBP = name_array[8]
|
---|
69 | # CRE_XXXの生成
|
---|
70 | domainOption = cell.get_region.get_domain_root.get_domain_type.get_option
|
---|
71 | if (domainOption == "OutOfDomain") || (domainOption != "kernel")
|
---|
72 | # 無所属 or ユーザドメインに属する場合
|
---|
73 | raise "#{@plugin_arg_str.to_s.downcase} handler #{val[:id]} must belong to kernel domain."
|
---|
74 | elsif @plugin_arg_str == "CONFIG_INT"
|
---|
75 | file.print <<EOT
|
---|
76 | #{tab}CFG_INT( #{val[:interruptNumber]}, { #{val[:attribute]}, #{val[:interruptPriority]} });
|
---|
77 | EOT
|
---|
78 | elsif @plugin_arg_str == "ISR"
|
---|
79 | file.print <<EOT
|
---|
80 | #{tab}CRE_ISR(#{val[:id]}, { #{val[:attribute]}, #{cell_CBP}, #{val[:interruptNumber]}, tISR_start, #{val[:isrPriority]} });
|
---|
81 | EOT
|
---|
82 | elsif @plugin_arg_str == "DEF_INH"
|
---|
83 | name_array = @celltype.get_name_array cell
|
---|
84 | start = @celltype.subst_name( "$id$_start", name_array )
|
---|
85 | file.print <<EOT
|
---|
86 | #{tab}DEF_INH(#{val[:interruptHandlerNumber]}, { #{val[:attribute]}, #{start} });
|
---|
87 | EOT
|
---|
88 | elsif @plugin_arg_str == "DEF_EXC"
|
---|
89 | name_array = @celltype.get_name_array cell
|
---|
90 | start = @celltype.subst_name( "$id$_start", name_array )
|
---|
91 | file.print <<EOT
|
---|
92 | #{tab}DEF_EXC(#{val[:cpuExceptionHandlerNumber]}, { #{val[:attribute]}, #{start} });
|
---|
93 | EOT
|
---|
94 | elsif @plugin_arg_str == "INIT_ROUTINE"
|
---|
95 | file.print <<EOT
|
---|
96 | #{tab}ATT_INI({ #{val[:attribute]}, #{cell_CBP}, tInitializeRoutine_start });
|
---|
97 | EOT
|
---|
98 | elsif @plugin_arg_str == "TERM_ROUTINE"
|
---|
99 | file.print <<EOT
|
---|
100 | #{tab}ATT_TER({ #{val[:attribute]}, #{cell_CBP}, tTerminateRoutine_start });
|
---|
101 | EOT
|
---|
102 | else
|
---|
103 | raise "#{@plugin_arg_str} is unknown option"
|
---|
104 | end
|
---|
105 | end
|
---|
106 |
|
---|
107 | def print_cfg_sac(file, val, acv)
|
---|
108 | if @plugin_arg_str == "CONFIG_INT"
|
---|
109 | # nothing to do
|
---|
110 | elsif @plugin_arg_str == "ISR"
|
---|
111 | # kernel.cdl の tISR で accessPattern1 ~ accessPattern4 が定義されているときの名残。
|
---|
112 | # accessPattern1 が定義されていない場合、こここへは来ない.復活したときに備えて残しておく.
|
---|
113 | # file.puts "SAC_#{@plugin_arg_str}(#{val[:id]}, { #{acv[:accessPattern1]}, #{acv[:accessPattern2]}, #{acv[:accessPattern3]}, #{acv[:accessPattern4]} });"
|
---|
114 | puts "*** Unsupported *** SAC_#{@plugin_arg_str}(#{val[:id]}, { #{acv[:accessPattern1]}, #{acv[:accessPattern2]}, #{acv[:accessPattern3]}, #{acv[:accessPattern4]} });\n"
|
---|
115 | elsif @plugin_arg_str == "DEF_INH"
|
---|
116 | # nothing to do
|
---|
117 | elsif @plugin_arg_str == "DEF_EXC"
|
---|
118 | # nothing to do
|
---|
119 | elsif @plugin_arg_str == "INIT_ROUTINE"
|
---|
120 | # nothing to do
|
---|
121 | elsif @plugin_arg_str == "TERM_ROUTINE"
|
---|
122 | # nothing to do
|
---|
123 | else
|
---|
124 | raise "#{@plugin_arg_str} is unknown option"
|
---|
125 | end
|
---|
126 | end
|
---|
127 |
|
---|
128 | end
|
---|
129 |
|
---|