- Timestamp:
- May 22, 2019, 10:03:37 PM (5 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
azure_iot_hub/trunk/asp3_dcre/tecsgen/tecslib/plugin/HRP2KernelObjectPlugin.rb
-
Property svn:mime-type
changed from
text/x-ruby
totext/x-ruby;charset=UTF-8
r388 r389 6 6 # Copyright (C) 2008-2017 by TOPPERS Project 7 7 #-- 8 # ä¸è¨èä½æ¨©è 9 ã¯ï¼ä»¥ä¸ã®(1)ï½(4)ã®æ¡ä»¶ãæºããå ´åã«éãï¼æ¬ã½ããã¦ã§ 10 # ã¢ï¼æ¬ã½ããã¦ã§ã¢ãæ¹å¤ãããã®ãå«ãï¼ä»¥ä¸åãï¼ã使ç¨ã»è¤è£½ã»æ¹ 11 # å¤ã»åé 12 å¸ï¼ä»¥ä¸ï¼å©ç¨ã¨å¼ã¶ï¼ãããã¨ãç¡åã§è¨±è«¾ããï¼ 13 # (1) æ¬ã½ããã¦ã§ã¢ãã½ã¼ã¹ã³ã¼ãã®å½¢ã§å©ç¨ããå ´åã«ã¯ï¼ä¸è¨ã®èä½ 14 # 権表示ï¼ãã®å©ç¨æ¡ä»¶ããã³ä¸è¨ã®ç¡ä¿è¨¼è¦å®ãï¼ãã®ã¾ã¾ã®å½¢ã§ã½ã¼ 15 # ã¹ã³ã¼ãä¸ã«å«ã¾ãã¦ãããã¨ï¼ 16 # (2) æ¬ã½ããã¦ã§ã¢ãï¼ã©ã¤ãã©ãªå½¢å¼ãªã©ï¼ä»ã®ã½ããã¦ã§ã¢éçºã«ä½¿ 17 # ç¨ã§ããå½¢ã§åé 18 å¸ããå ´åã«ã¯ï¼åé 19 å¸ã«ä¼´ãããã¥ã¡ã³ãï¼å©ç¨ 20 # è 21 ããã¥ã¢ã«ãªã©ï¼ã«ï¼ä¸è¨ã®èä½æ¨©è¡¨ç¤ºï¼ãã®å©ç¨æ¡ä»¶ããã³ä¸è¨ 22 # ã®ç¡ä¿è¨¼è¦å®ãæ²è¼ãããã¨ï¼ 23 # (3) æ¬ã½ããã¦ã§ã¢ãï¼æ©å¨ã«çµã¿è¾¼ããªã©ï¼ä»ã®ã½ããã¦ã§ã¢éçºã«ä½¿ 24 # ç¨ã§ããªãå½¢ã§åé 25 å¸ããå ´åã«ã¯ï¼æ¬¡ã®ããããã®æ¡ä»¶ãæºããã 26 # ã¨ï¼ 27 # (a) åé 28 å¸ã«ä¼´ãããã¥ã¡ã³ãï¼å©ç¨è 29 ããã¥ã¢ã«ãªã©ï¼ã«ï¼ä¸è¨ã®è 30 # ä½æ¨©è¡¨ç¤ºï¼ãã®å©ç¨æ¡ä»¶ããã³ä¸è¨ã®ç¡ä¿è¨¼è¦å®ãæ²è¼ãããã¨ï¼ 31 # (b) åé 32 å¸ã®å½¢æ 33 ãï¼å¥ã«å®ããæ¹æ³ã«ãã£ã¦ï¼TOPPERSããã¸ã§ã¯ãã« 34 # å ±åãããã¨ï¼ 35 # (4) æ¬ã½ããã¦ã§ã¢ã®å©ç¨ã«ããç´æ¥çã¾ãã¯éæ¥çã«çãããããªãæ 36 # 害ãããï¼ä¸è¨èä½æ¨©è 37 ããã³TOPPERSããã¸ã§ã¯ããå 38 責ãããã¨ï¼ 39 # ã¾ãï¼æ¬ã½ããã¦ã§ã¢ã®ã¦ã¼ã¶ã¾ãã¯ã¨ã³ãã¦ã¼ã¶ããã®ãããªãç 40 # ç±ã«åºã¥ãè«æ±ãããï¼ä¸è¨èä½æ¨©è 41 ããã³TOPPERSããã¸ã§ã¯ãã 42 # å 43 責ãããã¨ï¼ 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 # 免責すること. 44 30 # 45 # æ¬ã½ããã¦ã§ã¢ã¯ï¼ç¡ä¿è¨¼ã§æä¾ããã¦ãããã®ã§ããï¼ä¸è¨èä½æ¨©è 46 ã 47 # ãã³TOPPERSããã¸ã§ã¯ãã¯ï¼æ¬ã½ããã¦ã§ã¢ã«é¢ãã¦ï¼ç¹å®ã®ä½¿ç¨ç®ç 48 # ã«å¯¾ããé©åæ§ãå«ãã¦ï¼ãããªãä¿è¨¼ãè¡ããªãï¼ã¾ãï¼æ¬ã½ããã¦ã§ 49 # ã¢ã®å©ç¨ã«ããç´æ¥çã¾ãã¯éæ¥çã«çãããããªãæ害ã«é¢ãã¦ãï¼ã 50 # ã®è²¬ä»»ãè² ããªãï¼ 31 # 本ソフトウェアは,無保証で提供されているものである.上記著作権者お 32 # よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的 33 # に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ 34 # アの利用により直接的または間接的に生じたいかなる損害に関しても,そ 35 # の責任を負わない. 51 36 # 52 37 # $Id$ 53 38 #++ 54 39 55 # Region ã¯ã©ã¹ã«ã¡ã½ããã追å40 # Regionクラスにメソッドを追加 56 41 =begin 57 42 class Region … … 70 55 =end 71 56 72 # Cell ã¯ã©ã¹ã«ã¤ã³ã¹ã¿ã³ã¹å¤æ°ã¨ã¡ã½ããã追å57 # Cellクラスにインスタンス変数とメソッドを追加 73 58 =begin 74 59 class Cell … … 86 71 end 87 72 88 # set_referenced_cell ã«ããã»ãããã73 # set_referenced_cellにしたほうがよい 89 74 # def set_referenced_region( region, port_name ) 90 75 def set_referenced_cell( cell, port_name ) … … 140 125 =end 141 126 142 #== celltype ãã©ã°ã¤ã³ã®å 143 ±éã®è¦ªã¯ã©ã¹ 127 #== celltype プラグインの共通の親クラス 144 128 class HRP2KernelObjectPlugin < CelltypePlugin 145 129 # @@obj_hash = {} 146 130 147 131 #@celltype:: Celltype 148 #@option:: String : ãªãã·ã§ã³æåå132 #@option:: String :オプション文字列 149 133 def initialize( celltype, option ) 150 134 super 151 # ããããã®ã«ã¼ãã«ãªãã¸ã§ã¯ãã解æ対象ã»ã«ã¿ã¤ãã«è¿½å135 # それぞれのカーネルオブジェクトを解析対象セルタイプに追加 152 136 HRP2KernelObjectPlugin.set_celltype(celltype) 153 137 end 154 138 155 139 #=== HRP2KernelObjectPlugin#print_cfg_cre 156 # å種ã«ã¼ãã«ãªãã¸ã§ã¯ãã®CRE_*ã®åºå 157 # file:: FILE: åºåå 158 ãã¡ã¤ã« 159 # val :: string: ã«ã¼ãã«ãªãã¸ã§ã¯ãã®å±æ§ã®è§£æçµæ 160 # tab :: string: ã¤ã³ãã³ãç¨ã®tab 140 # 各種カーネルオブジェクトのCRE_*の出力 141 # file:: FILE: 出力先ファイル 142 # val :: string: カーネルオブジェクトの属性の解析結果 143 # tab :: string: インデント用のtab 161 144 def print_cfg_cre(file, cell, val, tab) 162 145 raise "called virtual method print_cfg_cre in #{@celltype.get_name} plugin" … … 164 147 165 148 #=== HRP2KernelObjectPlugin#print_cfg_sac 166 # å種ã«ã¼ãã«ãªãã¸ã§ã¯ãã®SAC_*ã®åºå 167 # file:: FILE: åºåå 168 ãã¡ã¤ã« 169 # val :: string: ã«ã¼ãã«ãªãã¸ã§ã¯ãã®å±æ§ã®è§£æçµæ 170 # acv :: string: ã¢ã¯ã»ã¹ãã¯ã¿ 149 # 各種カーネルオブジェクトのSAC_*の出力 150 # file:: FILE: 出力先ファイル 151 # val :: string: カーネルオブジェクトの属性の解析結果 152 # acv :: string: アクセスベクタ 171 153 def print_cfg_sac(file, val, acv) 172 154 raise "called virtual method print_cfg_sac in #{@celltype.get_name} plugin" … … 174 156 175 157 #=== HRP2KernelObjectPlugin#get_entry_ports_name_list 176 # ã«ã¼ãã«ãªãã¸ã§ã¯ãã®å種ã¢ã¯ã»ã¹ã®ç¨®å¥ã®åãå£åãåå¾158 # カーネルオブジェクトの各種アクセスの種別の受け口名を取得 177 159 def get_entry_ports_name_list() 178 160 raise "called virtual method get_entry_ports_name_list in #{@celltype.get_name} plugin" … … 186 168 puts "===== begin #{@celltype.get_name.to_s} plugin =====" 187 169 188 # 対象ã¨ãªããã¹ã¦ã®ã»ã«ã«ã¤ãã¦ãåãå£ã«çµåããã¦ãã189 # ã»ã«ã®æå±ãã¡ã¤ã³ã解æ170 # 対象となるすべてのセルについて、受け口に結合されている 171 # セルの所属ドメインを解析 190 172 if !HRP2KernelObjectPlugin.isChecked() 191 173 HRP2KernelObjectPlugin.check_referenced_cells() … … 194 176 end 195 177 196 # 追è¨ããããã« AppFile ã使ãï¼æåã³ã¼ãå¤æãããªãï¼178 # 追記するために AppFile を使う(文字コード変換されない) 197 179 file2 = AppFile.open( "#{$gen}/tecsgen.cfg" ) 198 180 file2.print "\n/* Generated by #{self.class.name} */\n\n" … … 201 183 if cell.is_generate? 202 184 puts "===== begin check my domain #{cell.get_name} =====" 203 # attrã®å¤ãããã·ã¥ã«å 204 ¥ãã 185 # attrの値をハッシュに入れる 205 186 val = {} 206 187 @celltype.get_attribute_list.each{ |a| … … 209 190 val[a.get_name] = [] 210 191 if j = cell.get_join_list.get_item(a.get_name) 211 # ã»ã«çææã«åæåããå ´å192 # セル生成時に初期化する場合 212 193 j.get_rhs.each { |elem| 213 194 val[a.get_name] << elem.to_s 214 195 } 215 196 elsif i = a.get_initializer 216 # ã»ã«ã¿ã¤ãã®åæåå¤ã使ãå ´å197 # セルタイプの初期化値を使う場合 217 198 i.each { |elem| 218 199 val[a.get_name] << elem.to_s … … 223 204 else 224 205 if j = cell.get_join_list.get_item(a.get_name) 225 # ã»ã«çææã«åæåããå ´å206 # セル生成時に初期化する場合 226 207 val[a.get_name] = j.get_rhs.to_s 227 208 elsif i = a.get_initializer 228 # ã»ã«ã¿ã¤ãã®åæåå¤ã使ãå ´å209 # セルタイプの初期化値を使う場合 229 210 val[a.get_name] = i.to_s 230 211 else … … 233 214 end 234 215 } 235 # generate.rb ãåèã«236 # $id$ ãç½®æ216 # generate.rbを参考に 217 # $id$を置換 237 218 if val[:id].nil? != true 238 219 puts val[:id] … … 240 221 val[:id] = @celltype.subst_name( val[:id], @celltype.get_name_array( cell ) ) 241 222 end 242 # $cbp$ ã®ä»£ãã223 # $cbp$の代わり 243 224 index = cell.get_id - @celltype.get_id_base 244 225 cell_CB_name = "#{@celltype.get_global_name}_CB_tab[#{index}]" … … 246 227 cell_domain_type = cell.get_region.get_domain_root.get_domain_type 247 228 248 # CRE_XXX/DEF_XXX ã®çæ229 # CRE_XXX/DEF_XXXの生成 249 230 if cell_domain_type.get_option.to_s != "OutOfDomain" 250 # ä¿è·ãã¡ã¤ã³ã«å±ããå ´å231 # 保護ドメインに属する場合 251 232 if !HRP2KernelObjectPlugin.include_region(cell_domain_root.get_name.to_s) 252 # ãã®ä¿è·ãã¡ã¤ã³ã®.cfgãçæããã¦ããªãå ´å233 # その保護ドメインの.cfgが生成されていない場合 253 234 HRP2KernelObjectPlugin.set_region_list(cell_domain_root.get_name.to_s) 254 235 puts "~~~~~ #{cell_domain_root.get_name.to_s} is registered!" … … 271 252 file3.close 272 253 else 273 # ç¡æå±ã®å ´å254 # 無所属の場合 274 255 puts "~~~~~ #{cell_domain_root.get_name.to_s} is OutOfDomain" 275 256 print_cfg_cre(file2, cell, val, "") … … 277 258 278 259 puts "===== end check my domain #{cell.get_name} =====" 279 # SAC_XXX ã®çæ260 # SAC_XXXの生成 280 261 if !val[:accessPattern].nil? 281 262 puts "===== begin check regions #{cell.get_name} =====" … … 284 265 285 266 #ep = [ :eTaskActivate, :eTaskControl, :eTaskManage, :eTaskRefer ] 286 # åã«ã¼ãã«ãªãã¸ã§ã¯ãã®åãå£åãåå¾267 #各カーネルオブジェクトの受け口名を取得 287 268 # ep = get_entry_ports_name_list() 288 269 i = 0 289 270 acv = [] 290 # ã¢ã¯ã»ã¹è¨±å¯ãã¯ã¿ã®çæ271 # アクセス許可ベクタの生成 291 272 val[:accessPattern].each { |acptnx| 292 # ã¢ã¯ã»ã¹è¨±å¯ãã¿ã¼ã³ã®çæ273 # アクセス許可パターンの生成 293 274 if acptnx != "OMIT" 294 275 acv << acptnx … … 309 290 p acv 310 291 311 # å種SACã®çæ292 #各種SACの生成 312 293 domainOption = cell_domain_type.get_option 313 294 # if cell.get_region.get_region_type == :DOMAIN 314 295 if domainOption != "OutOfDomain" 315 # ä¿è·ãã¡ã¤ã³ã«å±ããå ´å296 # 保護ドメインに属する場合 316 297 file3 = AppFile.open( "#{$gen}/tecsgen_#{cell.get_region.get_name.to_s}.cfg" ) 317 298 print_cfg_sac(file3, val, acv) 318 299 file3.close 319 300 else 320 # ç¡æå±ã®å ´å301 # 無所属の場合 321 302 print_cfg_sac(file2, val, acv) 322 303 end … … 331 312 end 332 313 333 # ã«ã¼ãã«ãªãã¸ã§ã¯ãã»ã«ã¿ã¤ãã®ç®¡ç334 # HRP2KernelObjectPlugin ã¯ã©ã¹ã«å¯¾ãã¦ã¡ã½ããå¼åºããè¡ããã¨ãæ³å®314 # カーネルオブジェクトセルタイプの管理 315 # HRP2KernelObjectPluginクラスに対してメソッド呼出しを行うことを想定 335 316 @@checked = false 336 317 @@celltype_list = [] … … 355 336 printf "===== check call port : " 356 337 # p p.get_name.to_s 357 next if j.nil? # æªçµåã®å ´å338 next if j.nil? # 未結合の場合 358 339 if @@celltype_list.include?(j.get_celltype) 359 340 # j.get_cell.set_referenced_region(cell.get_region) -
Property svn:mime-type
changed from
Note:
See TracChangeset
for help on using the changeset viewer.