1 | # -*- coding: utf-8 -*-
|
---|
2 | #
|
---|
3 | # パス3の生成スクリプトのチップ依存部(BCM2837用)
|
---|
4 | #
|
---|
5 | IncludeTrb("arm64_gcc/common/core_check.trb")
|
---|
6 |
|
---|
7 | #
|
---|
8 | # 割込みハンドラテーブルに関するチェック
|
---|
9 | #
|
---|
10 | # DEF_INHで登録した割込みハンドラのみチェックする.逆に言うと,コンフィ
|
---|
11 | # ギュレータで生成した割込みハンドラや,default_int_handlerのチェックは
|
---|
12 | # 行わない.
|
---|
13 | #
|
---|
14 | inhinib_entry = SYMBOL("_kernel_inhinib_entry")
|
---|
15 | $cfgData[:DEF_INH].each do |key, params|
|
---|
16 | inthdr = PEEK(inhinib_entry, $sizeof_FP)
|
---|
17 |
|
---|
18 | # 割込みハンドラの先頭番地のチェック
|
---|
19 | if (inthdr & ($CHECK_FUNC_ALIGN - 1)) != 0
|
---|
20 | error_wrong_id("E_PAR", params, :inthdr, :inhno, "not aligned")
|
---|
21 | end
|
---|
22 | if $CHECK_FUNC_NONNULL && inthdr == 0
|
---|
23 | error_wrong_id("E_PAR", params, :inthdr, :inhno, "null")
|
---|
24 | end
|
---|
25 |
|
---|
26 | inhinib_entry += $sizeof_FP
|
---|
27 | end
|
---|
28 |
|
---|
29 | #
|
---|
30 | # CPU例外ハンドラテーブルに関するチェック
|
---|
31 | #
|
---|
32 | # DEF_EXCで登録したCPU例外ハンドラのみチェックする.逆に言うと,
|
---|
33 | # default_exc_handlerのチェックは行わない.
|
---|
34 | #
|
---|
35 | excinib_entry = SYMBOL("_kernel_excinib_entry")
|
---|
36 | $cfgData[:DEF_EXC].each do |key, params|
|
---|
37 | exchdr = PEEK(excinib_entry, $sizeof_FP)
|
---|
38 |
|
---|
39 | # CPU例外ハンドラの先頭番地のチェック
|
---|
40 | if (exchdr & ($CHECK_FUNC_ALIGN - 1)) != 0
|
---|
41 | error_wrong_id("E_PAR", params, :exchdr, :excno, "not aligned")
|
---|
42 | end
|
---|
43 | if $CHECK_FUNC_NONNULL && exchdr == 0
|
---|
44 | error_wrong_id("E_PAR", params, :exchdr, :excno, "null")
|
---|
45 | end
|
---|
46 |
|
---|
47 | excinib_entry += $sizeof_FP
|
---|
48 | end
|
---|