source: asp3_tinet_ecnl_arm/trunk/asp3_dcre/cfg/SRecord.rb@ 352

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

arm向けASP3版ECNLを追加

  • Property svn:eol-style set to native
  • Property svn:mime-type set to text/x-ruby;charset=UTF-8
File size: 6.6 KB
Line 
1# -*- coding: utf-8 -*-
2#
3# TOPPERS Configurator by Ruby
4#
5# Copyright (C) 2015,2016 by Embedded and Real-Time Systems Laboratory
6# Graduate School of Information Science, Nagoya Univ., JAPAN
7# Copyright (C) 2015 by FUJI SOFT INCORPORATED, JAPAN
8#
9# 上記著作権者は,以下の(1)~(4)の条件を満たす場合に限り,本ソフトウェ
10# ア(本ソフトウェアを改変したものを含む.以下同じ)を使用・複製・改
11# 変・再配布(以下,利用と呼ぶ)することを無償で許諾する.
12# (1) 本ソフトウェアをソースコードの形で利用する場合には,上記の著作
13# 権表示,この利用条件および下記の無保証規定が,そのままの形でソー
14# スコード中に含まれていること.
15# (2) 本ソフトウェアを,ライブラリ形式など,他のソフトウェア開発に使
16# 用できる形で再配布する場合には,再配布に伴うドキュメント(利用
17# 者マニュアルなど)に,上記の著作権表示,この利用条件および下記
18# の無保証規定を掲載すること.
19# (3) 本ソフトウェアを,機器に組み込むなど,他のソフトウェア開発に使
20# 用できない形で再配布する場合には,次のいずれかの条件を満たすこ
21# と.
22# (a) 再配布に伴うドキュメント(利用者マニュアルなど)に,上記の著
23# 作権表示,この利用条件および下記の無保証規定を掲載すること.
24# (b) 再配布の形態を,別に定める方法によって,TOPPERSプロジェクトに
25# 報告すること.
26# (4) 本ソフトウェアの利用により直接的または間接的に生じるいかなる損
27# 害からも,上記著作権者およびTOPPERSプロジェクトを免責すること.
28# また,本ソフトウェアのユーザまたはエンドユーザからのいかなる理
29# 由に基づく請求からも,上記著作権者およびTOPPERSプロジェクトを
30# 免責すること.
31#
32# 本ソフトウェアは,無保証で提供されているものである.上記著作権者お
33# よびTOPPERSプロジェクトは,本ソフトウェアに関して,特定の使用目的
34# に対する適合性も含めて,いかなる保証も行わない.また,本ソフトウェ
35# アの利用により直接的または間接的に生じたいかなる損害に関しても,そ
36# の責任を負わない.
37#
38# $Id$
39#
40
41#
42# Sレコードファイル処理クラス
43#
44
45#
46# Sレコードファイルを変数に読み込み,要求された番地のデータを返す.
47#
48# @sRecDataは,先頭番地をキーとし,そこからのデータ(ヘキサダンプ形式)
49# を値とブロックが格納されたハッシュである.連続するブロックは,1つのブ
50# ロックにまとめて格納するものとする(そうしないと,データの取出しやサー
51# チが面倒になる).
52#
53class SRecord
54 def initialize(fileName)
55 @sRecData = {}
56 File.open(fileName) do |file|
57 prevAddress = 0
58 prevData = ""
59 file.each do |line|
60 # データレコードにより分岐
61 case line.slice(0, 2)
62 when "S1"
63 # データ長(アドレス分[2byte]+チェックサム分1byteを減算)
64 length = line.slice(2, 2).hex - 2 - 1
65
66 # アドレス(4文字=2byte)
67 address = line.slice(4, 4).hex
68
69 # データ(この時点では文字列で取っておく)
70 data = line.slice(8, length * 2)
71 when "S2"
72 # データ長(アドレス分[3byte]+チェックサム分1byteを減算)
73 length = line.slice(2, 2).hex - 3 - 1
74
75 # アドレス(6文字=3byte)
76 address = line.slice(4, 6).hex
77
78 # データ(この時点では文字列で取っておく)
79 data = line.slice(10, length * 2)
80 when "S3"
81 # データ長(アドレス分[4byte]+チェックサム分1byteを減算)
82 length = line.slice(2, 2).hex - 4 - 1
83
84 # アドレス(8文字=4byte)
85 address = line.slice(4, 8).hex
86
87 # データ(この時点では文字列で取っておく)
88 data = line.slice(12, length * 2)
89 else
90 address = nil
91 end
92
93 if !address.nil?
94 # データを格納する
95 if address == prevAddress + prevData.size / 2
96 prevData << data
97 else
98 set_data(prevAddress, prevData) if prevData.size > 0
99 prevAddress = address
100 prevData = data
101 end
102 end
103 end
104 set_data(prevAddress, prevData) if prevData.size > 0
105 end
106 end
107
108 # データ取得
109 def get_data(address, size)
110 endAddress = address + size
111 @sRecData.each do |block, blockData|
112 if (block <= address && endAddress <= block + blockData.size / 2)
113 offset = (address - block) * 2
114 return(blockData[offset, size * 2])
115 end
116 end
117 return(nil)
118 end
119
120 # データ書込み
121 def set_data(address, data)
122 endAddress = address + data.size / 2
123 @sRecData.each do |block, blockData|
124 nEndBlock = block + blockData.size / 2
125
126 if nEndBlock < address || endAddress < block
127 # 重なりがない
128 elsif address < block
129 # 新規データの方が先頭番地が小さい
130 # ここでは endAddress >= block が成立している
131 offset = (endAddress - block) * 2
132 data << blockData[offset..-1]
133 @sRecData.delete(block)
134 else
135 # 登録済みデータの方が先頭番地が小さいか同じ
136 offset = (address - block) * 2
137 address = block
138 blockData[offset, data.size] = data
139 data = blockData
140 @sRecData.delete(block)
141 end
142 end
143 @sRecData[address] = data
144 end
145
146 # 値としてのデータ取得
147 def get_value(address, size, signed)
148 targetData = get_data(address, size)
149 if targetData.nil?
150 return(nil)
151 else
152 if $endianLittle
153 # リトルエンディアンの場合,バイトオーダーを逆にする
154 reverseData = ""
155 # 後ろから2文字ずつ抜き出し,並び替える
156 while targetData.size > 0
157 reverseData << targetData[-2, 2]
158 targetData.slice!(-2, 2)
159 end
160 returnData = reverseData.hex
161 else
162 returnData = targetData.hex
163 end
164
165 # 負の数の処理
166 if signed && (returnData & (1 << (size * 8 - 1))) != 0
167 returnData -= (1 << (size * 8))
168 end
169 return(returnData)
170 end
171 end
172end
Note: See TracBrowser for help on using the repository browser.