source: azure_iot_hub/trunk/asp3_dcre/tecsgen/tecslib/plugin/HRPHandlerPlugin.rb@ 389

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

ビルドが通るよう更新

  • Property svn:eol-style set to native
  • Property svn:mime-type set to text/x-ruby;charset=UTF-8
File size: 6.2 KB
Line 
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
39require_tecsgen_lib "HRPKernelObjectPlugin.rb"
40
41
42#== celltype プラグインの共通の親クラス
43class 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]} });
77EOT
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]} });
81EOT
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} });
87EOT
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} });
93EOT
94 elsif @plugin_arg_str == "INIT_ROUTINE"
95 file.print <<EOT
96#{tab}ATT_INI({ #{val[:attribute]}, #{cell_CBP}, tInitializeRoutine_start });
97EOT
98 elsif @plugin_arg_str == "TERM_ROUTINE"
99 file.print <<EOT
100#{tab}ATT_TER({ #{val[:attribute]}, #{cell_CBP}, tTerminateRoutine_start });
101EOT
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
128end
129
Note: See TracBrowser for help on using the repository browser.