F MC -8L/8FX ファミリ

F2MC®-8L/8FX ファミリ
8 ビット・マイクロコントローラ
SOFTUNE® アセンブラマニュアル V3 対応
Support Soft Manual
Publication Number CM81-00208
MB90880ÉVÉäÅ[ÉY Cover Sheet
Revision 5.0
Issue Date September 1, 2014
F2MC®-8L/8FX ファミリ
8 ビット・マイクロコントローラ
SOFTUNE® アセンブラマニュアル V3 対応
Support Soft Manual
MB90880ÉVÉäÅ[ÉY Cover Sheet
Support
Soft
Ma nual
はじめに
■ 本書の目的と対象読者
本書は , Spansion SOFTUNE アセンブラの機能および使用方法を説明したものです。
本書は , F2MC-8L/8FX ファミリ マイクロコントローラを使用した応用プログラムを開
発する技術者を対象にしています。本書をご一読ください。
■ 商標
F2MC は , Spansion LLC の登録商標です。
SOFTUNE は , Spansion LLC の登録商標です。
Microsoft,Windows,Windows Media は , 米国 Microsoft Corporation の米国およびその他の
国における登録商標または商標です。
その他の社名および製品名などの固有名詞は , 各社の商標または登録商標です。
■ 本書の全体構成
本書は , 以下に示す 2 部構成となっています。
第 I 部 使用手引き編
この部では , SOFTUNE アセンブラの使用方法について説明します。
第 II 部 文法編
この部では , アセンブラのソースプログラムを記述する際の文法や記述形式につい
て説明します。
付録
付録では , エラーメッセージの一覧 , 制限事項を掲載します。
September 1, 2014, CM81-00208-5
i
Su pp or t
ii
So ft
Manu al
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
目次
第I部
使用手引き編............................................................................................. 1
第1章
概要 ............................................................................................................ 3
1.1
1.2
第2章
SOFTUNE アセンブラ............................................................................................................ 4
アセンブラ文法 ...................................................................................................................... 6
環境変数 , 開発環境のディレクトリ構造 ................................................... 9
2.1
2.2
2.3
2.4
2.5
FETOOL ............................................................................................................................... 10
FELANG ............................................................................................................................... 11
TMP ...................................................................................................................................... 12
INC896 ................................................................................................................................. 13
OPT896 ................................................................................................................................ 14
2.6
開発環境のディレクトリ構造 ............................................................................................... 15
第3章
起動方法................................................................................................... 17
3.1 fasm896s コマンド............................................................................................................... 18
3.2 ファイル指定 ........................................................................................................................ 19
3.3 ファイル名の扱い ................................................................................................................. 20
3.3.1
ファイル名の指定形式 ............................................................................................... 21
3.3.2
ファイル名の省略指定 ............................................................................................... 22
3.4 オプションファイル ............................................................................................................. 23
3.5 オプションファイルに記述できるコメント ......................................................................... 24
3.6 デフォルトオプションファイル ........................................................................................... 25
3.7 終了コード............................................................................................................................ 26
第4章
起動時オプション .................................................................................... 27
4.1 起動時オプションの規則 ...................................................................................................... 28
4.2 起動時オプション一覧.......................................................................................................... 29
4.3 起動時オプションの詳細 ...................................................................................................... 31
4.4 オブジェクトおよびデバッグに関するオプション............................................................... 32
4.4.1
-o, -Xo......................................................................................................................... 33
4.4.2
-g, -Xg......................................................................................................................... 34
4.5 リスティングに関するオプション........................................................................................ 35
4.5.1
-l, -lf, -Xl ...................................................................................................................... 36
4.5.2
-pl, -pw........................................................................................................................ 37
4.5.3
-linf, -lsrc, -lsec, -lcros................................................................................................. 38
4.5.4
-linc, -lexp ................................................................................................................... 40
4.5.5
-tab ............................................................................................................................. 41
4.6 プリプロセッサに関するオプション .................................................................................... 42
4.6.1
-p ................................................................................................................................ 43
4.6.2
-P, -Pf ......................................................................................................................... 44
4.6.3
-D, -U .......................................................................................................................... 45
4.6.4
-I ................................................................................................................................. 46
4.6.5
-H................................................................................................................................ 47
September 1, 2014, CM81-00208-5
iii
Su pp or t
4.6.6
So ft
Manu al
-C................................................................................................................................ 48
4.7 ターゲット依存オプション................................................................................................... 49
4.7.1
-sa, -Xsa ..................................................................................................................... 50
4.7.2
-div_check, -Xdiv_check............................................................................................. 51
4.8 その他のオプション ............................................................................................................. 53
4.8.1
-Xdof ........................................................................................................................... 54
4.8.2
-f ................................................................................................................................. 55
4.8.3
-w................................................................................................................................ 56
4.8.4
-name ......................................................................................................................... 57
4.8.5
-V, -XV ........................................................................................................................ 58
4.8.6
-cmsg, -Xcmsg............................................................................................................ 59
4.8.7
-cwno, -Xcwno ............................................................................................................ 60
4.8.8
-help ........................................................................................................................... 61
4.8.9
-cpu ............................................................................................................................ 62
4.8.10
-kanji ........................................................................................................................... 63
4.8.11
-LBA, -XLBA ............................................................................................................... 64
4.8.12
-OVFW, -XOVFW ....................................................................................................... 66
4.8.13
-cif............................................................................................................................... 68
第5章
5.1
第6章
最適コードチェック機能について ........................................................... 69
fasm896s の最適コードチェック機能 .................................................................................. 70
アセンブルリスト .................................................................................... 73
6.1 全体形式 ............................................................................................................................... 74
6.2 ページの形式 ........................................................................................................................ 76
6.3 インフォメーションリスト................................................................................................... 78
6.4 ソースリスト ........................................................................................................................ 80
6.4.1
プリプロセッサ処理 ................................................................................................... 81
6.4.2
エラー表示 ................................................................................................................. 82
6.4.3
インクルードファイル ............................................................................................... 83
6.4.4
.END, .PROGRAM, .SECTION .................................................................................. 84
6.4.5
.ALIGN, .ORG, .SKIP ................................................................................................. 86
6.4.6
.EXPORT, .GLOBAL, .IMPORT ................................................................................. 87
6.4.7
.EQU........................................................................................................................... 88
6.4.8
.DATA, .BIT, .BYTE, .HALF, .LONG, .WORD, .DATAB ............................................. 89
6.4.9
.FDATA, .FLOAT, .DOUBLE, .FDATAB ..................................................................... 91
6.4.10
.RES, .FRES .............................................................................................................. 92
6.4.11
.SDATA, .ASCII, .SDATAB......................................................................................... 93
6.4.12
.DEBUG...................................................................................................................... 94
6.4.13
.LIBRARY ................................................................................................................... 95
6.4.14
.FORM, .TITLE, .HEADING, .LIST, .PAGE, .SPACE ................................................. 96
6.5
6.6
第 II 部
第7章
7.1
7.2
iv
セクションリスト ................................................................................................................. 99
クロスリファレンスリスト................................................................................................. 100
文法編 ................................................................................................... 101
言語の基本規則 ...................................................................................... 103
文の形式 ............................................................................................................................. 104
文字セット.......................................................................................................................... 106
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
7.3 名前 .................................................................................................................................... 107
7.4 前方参照シンボルと後方参照シンボル............................................................................... 109
7.5 整数定数 ............................................................................................................................. 110
7.6 ロケーションカウンタシンボル ......................................................................................... 111
7.7 文字定数 ............................................................................................................................. 112
7.8 文字列 ................................................................................................................................. 114
7.9 浮動小数点定数 .................................................................................................................. 115
7.10 浮動小数点定数のデータ形式 ............................................................................................. 117
7.11 式 ........................................................................................................................................ 119
7.11.1
項 .............................................................................................................................. 121
7.11.2
オペランド値の範囲 ................................................................................................. 125
7.11.3
演算子....................................................................................................................... 126
7.11.4
名前から算出される値 ............................................................................................. 128
7.11.5
演算子の優先順位..................................................................................................... 131
7.12 コメント ............................................................................................................................. 132
第8章
8.1
8.2
8.3
8.4
8.5
8.6
8.7
セクション ............................................................................................. 133
セクションの記述形式........................................................................................................ 134
セクションのタイプについて ............................................................................................. 136
セクションタイプと属性 .................................................................................................... 139
セクションの配置形式について ......................................................................................... 140
セクションの結合方法........................................................................................................ 142
セクションの分割記述........................................................................................................ 144
ROM 化セクションの書き方 .............................................................................................. 145
第9章
9.1
9.2
機械命令................................................................................................. 147
機械命令の記述形式 ........................................................................................................... 148
オペランドフィールドの記述形式...................................................................................... 149
第 10 章
アセンブラ擬似命令............................................................................... 151
10.1 擬似命令で扱う整数定数の範囲 ......................................................................................... 152
10.2 プログラム構造定義命令 .................................................................................................... 153
10.2.1
.PROGRAM 命令...................................................................................................... 154
10.2.2
.END 命令................................................................................................................. 155
10.2.3
.SECTION 命令 ........................................................................................................ 156
10.3 アドレス制御命令 ............................................................................................................... 158
10.3.1
.ALIGN 命令.............................................................................................................. 159
10.3.2
.ORG 命令 ................................................................................................................ 160
10.3.3
.SKIP 命令 ................................................................................................................ 161
10.4 プログラム結合命令 ........................................................................................................... 162
10.4.1
.EXPORT 命令.......................................................................................................... 163
10.4.2
.GLOBAL 命令 .......................................................................................................... 164
10.4.3
.IMPORT 命令 .......................................................................................................... 165
10.5 シンボル定義命令 ............................................................................................................... 166
10.5.1
.EQU 命令................................................................................................................. 167
10.6 領域定義命令 ...................................................................................................................... 168
10.6.1
.DATA 命令 , .BIT 命令 , .BYTE 命令 , .HALF 命令 , .LONG 命令 , .WORD 命令 ..... 169
10.6.2
.DATAB 命令 ............................................................................................................ 171
10.6.3
.FDATA 命令 , .FLOAT 命令 , .DOUBLE 命令 .......................................................... 172
September 1, 2014, CM81-00208-5
v
Su pp or t
So ft
Manu al
10.6.4
.FDATAB 命令 .......................................................................................................... 174
10.6.5
.RES 命令 ................................................................................................................. 175
10.6.6
.FRES 命令............................................................................................................... 176
10.6.7
.SDATA 命令 , .ASCII 命令 ....................................................................................... 177
10.6.8
.SDATAB 命令 .......................................................................................................... 178
10.6.9
.STRUCT 命令 , .ENDS 命令.................................................................................... 179
10.7 デバッグ情報出力制御命令................................................................................................. 181
10.8 ライブラリファイル指定命令 ............................................................................................. 183
10.9 リスト出力制御命令 ........................................................................................................... 184
10.9.1
.FORM 命令.............................................................................................................. 185
10.9.2
.TITLE 命令............................................................................................................... 186
10.9.3
.HEADING 命令 ........................................................................................................ 187
10.9.4
.LIST 命令................................................................................................................. 188
10.9.5
.PAGE 命令 .............................................................................................................. 190
10.9.6
.SPACE 命令 ............................................................................................................ 191
第 11 章
プリプロセッサ処理............................................................................... 193
11.1 プリプロセッサ .................................................................................................................. 194
11.2 プリプロセッサの基本規則................................................................................................. 197
11.2.1
プリプロセッサ命令の記述形式 ............................................................................... 199
11.2.2
コメント ................................................................................................................... 200
11.2.3
行の継続 ................................................................................................................... 201
11.2.4
整数定数 ................................................................................................................... 202
11.2.5
文字定数 ................................................................................................................... 203
11.2.6
マクロ名 ................................................................................................................... 205
11.2.7
仮引数....................................................................................................................... 206
11.2.8
ローカルシンボル..................................................................................................... 207
11.3 プリプロセッサの式 ........................................................................................................... 208
11.4 マクロ定義.......................................................................................................................... 211
11.4.1
#macro 命令 ............................................................................................................. 212
11.4.2
#local 命令 ................................................................................................................ 213
11.4.3
#exitm 命令............................................................................................................... 215
11.4.4
#endm 命令 .............................................................................................................. 216
11.5 マクロコール命令 ............................................................................................................... 217
11.6 リピート展開 ...................................................................................................................... 218
11.7 条件付きアセンブル命令 .................................................................................................... 220
11.7.1
#if 命令...................................................................................................................... 221
11.7.2
#ifdef 命令................................................................................................................. 222
11.7.3
#ifndef 命令............................................................................................................... 223
11.7.4
#else 命令................................................................................................................. 224
11.7.5
#elif 命令................................................................................................................... 225
11.7.6
#endif 命令................................................................................................................ 227
11.8 マクロ名の置換処理 ........................................................................................................... 228
11.8.1
#define 命令.............................................................................................................. 230
11.8.2
マクロ仮引数の文字列化 (# 演算子 ) ........................................................................ 232
11.8.3
マクロ置換の文字の連結 (## 演算子 ) ...................................................................... 233
11.8.4
#set 命令................................................................................................................... 234
11.8.5
#undef 命令 .............................................................................................................. 235
11.8.6
#purge 命令 .............................................................................................................. 236
vi
CM81-00208-5, September 1, 2014
Support
11.9
11.10
11.11
11.12
11.13
11.14
11.15
Soft
Ma nual
#include 命令 ...................................................................................................................... 237
#line 命令 ............................................................................................................................ 239
#error 命令 .......................................................................................................................... 240
#pragma 命令 ..................................................................................................................... 241
空命令 ................................................................................................................................. 242
既定義マクロ名 .................................................................................................................. 243
C 言語プリプロセッサとの違い ......................................................................................... 245
第 12 章
アセンブラ擬似機械命令........................................................................ 247
12.1 F2MC-8L/8FX ファミリ用アセンブラ擬似機械命令 ........................................................... 248
12.1.1
分岐系擬似機械命令 ................................................................................................. 249
12.1.2
演算系擬似機械命令 ................................................................................................. 250
12.1.3
その他の擬似機械命令 ............................................................................................. 251
12.1.4
最適配置分岐擬似機械命令 ...................................................................................... 253
第 13 章
構造化命令 ............................................................................................. 257
13.1 構造化命令の概要 ............................................................................................................... 258
13.2 構造化プログラム命令........................................................................................................ 259
13.2.1
構造化プログラム命令の条件式 ............................................................................... 260
13.2.2
構造化プログラム命令での生成規則 ........................................................................ 263
13.2.3
構造化プログラム命令の記述形式............................................................................ 264
13.2.4
2 処理選択構文 ......................................................................................................... 265
13.2.5
多処理選択構文 ........................................................................................................ 266
13.2.6
計算型繰返し構文..................................................................................................... 268
13.2.7
終了条件型繰返し構文 ............................................................................................. 270
13.2.8
実行条件型繰返し構文 ............................................................................................. 271
13.2.9
制御移行命令 ............................................................................................................ 272
13.3 式 ( 代入式 , 代入演算式 , インクリメント / デクリメント式 ) ........................................... 274
13.3.1
式の記述形式 ............................................................................................................ 275
13.3.2
代入式....................................................................................................................... 276
13.3.3
代入演算式 ............................................................................................................... 278
13.3.4
インクリメント / デクリメント式 ............................................................................ 282
付録
付録 A
付録 B
付録 C
付録 D
D.1
D.2
D.3
D.4
D.5
D.6
D.7
D.8
D.9
D.10
付録 E
............................................................................................................... 285
エラーメッセージ一覧................................................................................................... 286
制限事項 ........................................................................................................................ 322
拡張ダイレクトアクセス領域バンク番号の取得方法.................................................... 323
SOFTUNE アセンブラと旧版アセンブラの仕様の差異 ................................................ 324
アセンブラ言語の基本規則 ......................................................................................... 325
式処理 ......................................................................................................................... 329
擬似命令...................................................................................................................... 332
マクロ処理 .................................................................................................................. 335
構造化制御命令 ........................................................................................................... 336
機械命令...................................................................................................................... 337
コマンド行の差異 ....................................................................................................... 338
環境変数...................................................................................................................... 339
オプション .................................................................................................................. 340
制限事項の緩和 ........................................................................................................... 342
主な変更内容 ................................................................................................................. 343
September 1, 2014, CM81-00208-5
vii
Su pp or t
索引
viii
So ft
Manu al
............................................................................................................... 345
CM81-00208-5, September 1, 2014
Support
第I部
Soft
Ma nual
使用手引き編
この部では , SOFTUNE アセンブラの使用方法について説明します。
第 1 章 概要
第 2 章 環境変数 , 開発環境の ディレクトリ構造
第 3 章 起動方法
第 4 章 起動時オプション
第 5 章 最適コードチェック機能 について
第 6 章 アセンブルリスト
September 1, 2014, CM81-00208-5
1
Su pp or t
2
So ft
Manu al
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
第1章
概要
この章では , SOFTUNE アセンブラの概要について
説明します。
1.1 SOFTUNE アセンブラ
1.2 アセンブラ文法
September 1, 2014, CM81-00208-5
3
Su pp or t
1.1
So ft
Manu al
SOFTUNE アセンブラ
本アセンブラは , F2MC-8L/8FX ファミリアセンブリ言語で記述されたソースプログ
ラムをアセンブルします。
本アセンブラの処理は大きく分けて , プリプロセッサフェーズとアセンブルフェー
ズの 2 つのフェーズがあります。
■ 概要
本アセンブラは , F2MC-8L/8FX ファミリアセンブリ言語で記述されたソースプログラ
ムをアセンブルします。そして , リロケータブルなオブジェクトとアセンブルリストを
出力します。
本アセンブラの処理は , 大きく分けて , プリプロセッサフェーズとアセンブルフェーズ
の 2 つのフェーズがあります。
本アセンブラの構成を , 図 1.1-1 に示します。
■ プリプロセッサフェーズ
前処理を行います。
前処理とは, マクロ定義, マクロ展開など, テキストを加工する処理のことをいいます。
機能仕様に , C 言語のプリプロセッサ仕様をサポートしました。これにより , プリプロ
セッサ処理に関しては C 言語とのヘッダファイルの共有化が可能です。
C 言語と共有可能な命令は , C 言語のプリプロセッサ命令と , 範囲指定型のコメント記
述 (/* ~ */) のみです。
また , このほかにも , マクロ定義・マクロ展開などのアセンブラ特有の機能もサポート
しています。
前処理を行った結果をファイルに残すことも可能です。
■ アセンブルフェーズ
機械命令 , 擬似命令を翻訳してオブジェクトコードを生成します。
アセンブルフェーズは , 次に示す機能を備えています。
• C 言語に対応したコメント記述
• デバッグ情報出力
• 機械命令の最適化チェック機能
4
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
図 1.1-1 アセンブラの構成
ソースプログラムファイル
fasm896s
プリプロセッサフェーズ
アセンブルフェーズ
前処理結果ファイル
オブジェクトファイル
アセンブルリストファイル
September 1, 2014, CM81-00208-5
5
Su pp or t
So ft
Manu al
アセンブラ文法
1.2
本アセンブラは , IEEE-649 仕様に準拠した言語仕様に加え , ユーザがプログラミン
グしやすいように , さらに機能を拡張してあります。
■ 概要
本アセンブラは , IEEE-649 仕様に準拠した言語仕様に加え , 次の機能を備えています。
• C 言語に対応したコメント記述
• アセンブラ擬似命令
• プリプロセッサ処理
• デバッグ情報出力
● C 言語に対応したコメント記述
アセンブラにおいても , C 言語と同じコメントが記述できます。
【例】
/* ------------------------------Main processing
---------------------------------- */
.SECTION CODE,CODE,ALIGN=2
CALL
_init
/* Initialization processing */
● アセンブラ擬似命令
IEEE-649仕様のアセンブラ擬似命令に加え, リスト制御命令, 領域定義命令などの命令
を追加し , 機能を充実しました。
● プリプロセッサ処理
C 言語のプリプロセッサ仕様をサポートしました。
これにより , プリプロセッサ処理に関しては C 言語とのヘッダファイルの共有化が可
能です。
C 言語と共有化可能な命令は C 言語のプリプロセッサ命令と , 範囲指定型のコメント
記述 (/* ~ */) のみです。
また , このほかにマクロ定義・マクロ展開などのアセンブラ特有の機能もサポートして
います。
【例】
#ifdef
SPC_MODE
#include
"spc.h"
:
#endif
#define
6
SIZE_MAX
256
/* サイズの最大値 */
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
● デバッグ情報出力
オブジェクトにデバッグ情報を含めることができます。
プログラムのデバッグには必要不可欠な機能です。
September 1, 2014, CM81-00208-5
7
Su pp or t
8
So ft
Manu al
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
第2章
環境変数 , 開発環境の
ディレクトリ構造
アセンブラで使用する環境変数と開発環境ディレ
クトリ構造について説明します。
2.1 FETOOL
2.2 FELANG
2.3 TMP
2.4 INC896
2.5 OPT896
2.6 開発環境のディレクトリ構造
September 1, 2014, CM81-00208-5
9
Su pp or t
2.1
So ft
Manu al
FETOOL
開発環境をインストールするディレクトリを指定します。
この環境変数が設定されていない場合は , 起動したアセンブラがあるディレクトリ
の親のディレクトリをインストールディレクトリとみなします。
■ FETOOL
【記述形式】
SET FETOOL= ディレクトリ
【説明】
開発環境をインストールするディレクトリを指定します。
インストールするディレクトリからメッセージファイル , インクルードファイル ,
ライブラリファイルなどの開発環境に必要なファイルがアクセスされます。
開発環境のディレクトリ構造の詳細は , 「2.6 開発環境のディレクトリ構造」を参
照してください。
FETOOL が設定されていない場合は , 起動したアセンブラのあるディレクトリの親
ディレクトリ ( アセンブラがあるディレクトリの位置 \..) をインストールディレク
トリとみなします。
【例】
SET FETOOL=D:\SOFTUNE
10
CM81-00208-5, September 1, 2014
Support
2.2
Soft
Ma nual
FELANG
メッセージの出力形式を指定します。
この環境変数は省略できます。
■ FELANG
【記述形式】
SET FELANG={ASCII|EUC|SJIS}
【説明】
メッセージの出力形式を指定します。
● ASCII を指定した場合
メッセージを ASCII コードで出力します。
メッセージの言語は英語となります。
日本語環境のないシステムの場合は , この形式にしてください。
● EUC を指定した場合
メッセージを EUC コードで出力します。
メッセージの言語は日本語となります。
端末が EUC コードの場合は , この形式にしてください。
● SJIS を指定した場合
メッセージを SJIS コードで出力します。
メッセージの言語は日本語となります。
端末が SJIS コードの場合は , この形式にしてください。
Windows 環境では , 普通この指定で日本語が表示されます。
参考:
この指定で影響を受けるメッセージは , ヘルプメッセージとエラーメッセージです。
この環境変数は省略できます。
省略したときの出力形式は , ASCII になります。
【例】
SET FELANG=ASCII
September 1, 2014, CM81-00208-5
11
Su pp or t
2.3
So ft
Manu al
TMP
アセンブラが使用する作業用のディレクトリを指定します。
この環境変数は省略できます。
■ TMP
【記述形式】
SET TMP= ディレクトリ
【説明】
アセンブラが使用する作業用のディレクトリを指定します。
アクセスできないディレクトリを指定した場合 , 本アセンブラは異常終了します。
この環境変数は省略できます。
省略した場合の作業ディレクトリは , カレントディレクトリです。
【例】
SET TMP=D:\TMP
12
CM81-00208-5, September 1, 2014
Support
2.4
Soft
Ma nual
INC896
インクルードパスを指定します。
#include 命令で指定されたインクルードファイルを検索するパスを指定します。
この環境変数は省略できます。
■ INC896
【記述形式】
SET INC896= パス
【説明】
インクルードパスを指定します。
#include 命令で指定されたインクルードファイルを検索するパスを指定します。
起動時オプションのインクルードパス指定 (-I) で指定されたパスの方を先に検索し
ます。それで見つからなければ , INC896 に設定されているパスを検索します。
この環境変数は省略できます。
【例】
SET INC896=E:\INCLUDE
September 1, 2014, CM81-00208-5
13
Su pp or t
2.5
So ft
Manu al
OPT896
デフォルトオプションファイルのディレクトリを指定します。
この環境変数は省略できます。
■ OPT896
【記述形式】
SET OPT896= ディレクトリ
【説明】
デフォルトオプションファイルのディレクトリを指定します。
デフォルトオプションファイルについての詳細は ,「3.6 デフォルトオプションファ
イル」を参照してください。
この環境変数は省略できます。
省略した場合は , 開発環境ディレクトリ内のデフォルトオプションファイルを参照
します。
開発環境ディレクトリ内のデフォルトオプションファイルは , 次のとおりです。
%FETOOL%\LIB\896\FASM896.OPT
【例】
SET OPT896=D:\USR
14
CM81-00208-5, September 1, 2014
Support
2.6
Soft
Ma nual
開発環境のディレクトリ構造
開発環境のディレクトリ構造について説明します。
■ 開発環境のディレクトリ構造
開発環境は , 次に示すような構造になっています。また , 各ディレクトリには , 次のよ
うなファイルが入っています。
● %FETOOL%\BIN
ロードモジュールのディレクトリです。
C コンパイラ , アセンブラ , リンカ , および Workbench などが入っています。
● %FETOOL%\LIB
ライブラリのディレクトリです。
ライブラリなど付属されるファイルが入っています。
● %FETOOL%\LIB\896
F2MC-8L/8FX 用ライブラリのディレクトリです。
メッセージファイル , ライブラリファイル , およびインクルードファイルなどが入って
います。
● %FETOOL%\LIB\896\INCLUDE
F2MC-8L/8FX 用インクルードファイルのディレクトリです。
C コンパイラの標準インクルードファイルが入っています。
このディレクトリは , #include 命令の検索において最後に検索されます。
開発環境のディレクトリ構造を次に示します。
図 2.6-1 開発環境のディレクトリ構造
%FETOOL%\ ←環境変数"FETOOL"に設定されているディレクトリ
BIN\ ←ロードモジュールを置くディレクトリ
FASM896S.EXE
LIB\ ←ライブラリを置くディレクトリ
896\ ←F2MC-8L/8FXファミリ用のライブラリを置くディレクトリ
ASM896_A.MSG (エラーメッセージファイル: ASCIIコード)
ASM896_E.MSG (エラーメッセージファイル: EUCコード)
ASM896_S.MSG (エラーメッセージファイル: SJISコード)
FASM896.OPT (デフォルトオプションファイル)
INCLUDE\ ←インクルードファイルディレクトリ
インクルードファイル
September 1, 2014, CM81-00208-5
15
Su pp or t
16
So ft
Manu al
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
第3章
起動方法
この章では , アセンブラの起動方法について説明し
ます。
本アセンブラの起動コマンドは , 次のとおりです。
• "fasm896s":F2MC-8L/8FX ファミリ用アセンブ
ラ
3.1 fasm896s コマンド
3.2 ファイル指定
3.3 ファイル名の扱い
3.4 オプションファイル
3.5 オプションファイルに記述できるコメント
3.6 デフォルトオプションファイル
3.7 終了コード
September 1, 2014, CM81-00208-5
17
Su pp or t
3.1
So ft
Manu al
fasm896s コマンド
fasm896s のコマンド形式は , 次のとおりです。
• fasm896s [ 起動時オプション ]… [ ファイル名 ]
■ fasm896s コマンド行
【記述形式】
fasm896s [ 起動時オプション ]… [ ファイル名 ]
【説明】
fasm896s コマンド行には , 起動時オプションとファイル名を指定できます。
起動時オプションとファイル名は , コマンド行のどの位置からでも指定できます。
起動時オプションは複数指定できます。
起動時オプションとファイル名は , それぞれ空白で区切られます。
fasm896s コマンドは , 次の順序で起動時オプションとファイル名を区別します。
1. オプション識別記号で始まるものを起動時オプションと識別します。オプション
識別記号は , ハイフン (-) です。
2. 起動時オプションに引数がある場合は , 次に続く文字を引数とみなします。
3. 起動時オプション以外をファイル名とみなします。
起動時オプションについては , 「第 4 章 起動時オプション」を参照してください。
起動時オプションに "-f オプションファイル名 " と指定すると , -f で指定したファイ
ルを読み込み , そのファイルに記述されている fasm896s オプションを実行します。
この機能により , fasm896s オプションをファイルにしておくことができます。
詳細は , 「3.4 オプションファイル」を参照してください。
起動時オプションとファイル名を省略し , fasm896s コマンド以降に何も指定しな
かった場合は , 起動時オプションの一覧 ( ヘルプメッセージ ) が出力されます。
fasm896s コマンドには , デフォルトオプションファイルという機能があります。
デフォルトオプションファイルに記述してある fasm896s オプションは , 最初に実行
されます。
詳細は , 「3.6 デフォルトオプションファイル」を参照してください。
【例】
fasm896s -f def.opt -l -pw 80 prog.asm
18
CM81-00208-5, September 1, 2014
Support
3.2
Soft
Ma nual
ファイル指定
アセンブルソースファイルを指定します。
アセンブルソースファイルは 1 つのみ指定できます。
拡張子を省略した場合 , ".asm" をファイル名に付加します。
■ ファイル指定
【例】
ファイル指定
fasm896s
fasm896s
fasm896s
fasm896s
test
test.
D:\WORK\test
..\FMC8L\abc.src
アセンブルされるファイル
test.asm
test.
D:\WORK\test.asm
..\FMC8L\abc.src
<注意事項>
ファイルの記述方法については , それぞれの OS のマニュアルをご覧ください。
September 1, 2014, CM81-00208-5
19
Su pp or t
3.3
So ft
Manu al
ファイル名の扱い
本アセンブラにおける , ファイル名の扱いについて説明します。
次の 2 つの項目について説明します。
• ファイル名の指定形式
• ファイル名の省略指定
■ ファイル名の指定形式
本アセンブラは , ファイル名を < パス名 >, < 主ファイル名 > と < 拡張子 > の 3 つで構
成されているものとして扱います。
< 拡張子 > は , ピリオド (.) 以降の文字を示します。
< パス名 >, < 拡張子 > は省略できます。
■ ファイル名の省略指定
ファイル名の各要素が省略された場合のファイル名の扱いについて説明します。
20
CM81-00208-5, September 1, 2014
Support
3.3.1
Soft
Ma nual
ファイル名の指定形式
ファイル名の指定形式について説明します。
本アセンブラでは , ファイル名を < パス名 >, < 主ファイル名 > と < 拡張子 > の 3 つ
で構成されているものとして扱います。
< 拡張子 > は , ピリオド (.) 以降の文字を示します。
< パス名 >, < 拡張子 > は省略できます。
■ ファイル名の指定形式
【記述形式】
[ < パス名 >] < 主ファイル名 > [ < 拡張子 >]
【説明】
ファイル名の詳細は , 各 OS のマニュアルを参照してください。
本アセンブラでは , ファイル名を < パス >, < 主ファイル名 > と < 拡張子 > の 3 つで
構成されているものとして扱います。
< 拡張子 > は , ピリオド (.) 以降の文字を示します。
< パス名 >, < 拡張子 > は省略できます。
省略した場合の扱いについては , 「3.3.2 ファイル名の省略指定」を参照してくださ
い。
Windows 版の場合 , < ドライブ名 > は < パス名 > に含まれます。
【例】
D:\WORK\SRC\TEST.ASM
拡張子
パス名 主ファイル名
September 1, 2014, CM81-00208-5
21
Su pp or t
3.3.2
So ft
Manu al
ファイル名の省略指定
ファイル名の各要素が省略された場合のファイル名の扱いについて説明します。
■ ファイル名の省略指定
ファイル名の各要素が省略された場合のファイル名の扱いについて説明します。
オブジェクトファイルまたはリストファイルの指定にパス名のみを指定した場合は ,
ソースファイル名の主ファイル名を使用します。
● パス名のみを指定した場合
< 指定したパス名 > < ソースファイルの主ファイル名 > < 省略時の拡張子 >
ファイル名省略時の扱いを , 表 3.3-1 に示します。
表 3.3-1 ファイル名省略時の扱い
ファイル名の省略部
パス名
拡張子
扱い
カレント
ソースファイルの拡張子
.asm
オブジェクトファイルの拡張子
.obj
リストファイルの拡張子
.lst
オプションファイルの拡張子
.opt
前処理結果ファイルの拡張子
.as
【例】
fasm896s TEST -o D:\WORK\SRC -lf abc
22
ソースファイル名
: TEST.asm
オブジェクトファイル名
: D:\WORK\SRC\TEST.obj
リストファイル名
: abc.lst
CM81-00208-5, September 1, 2014
Support
3.4
Soft
Ma nual
オプションファイル
オプションファイル機能は , fasm896s オプションをファイルに記述しておき , 一括
指定できます。この機能により , たくさん指定する起動時オプションなどをファイ
ルにすることができます。
オプションファイルの指定は , 起動時オプションの "-f" です。
■ オプションファイル
【記述形式】
-f オプションファイル名
【説明】
オプションファイル機能は , fasm896s オプションをファイルに記述しておき , 一括
指定できます。この機能により , たくさん指定する起動時オプションをファイル化
できます。
オプションファイルの指定は , 起動時オプションの "-f" です。
オプションファイル名に拡張子を省略した場合は , ".opt" を補います。
オプションファイルには , fasm896s オプションが記述できます。
オプションファイルには , コメントが記述できます。
詳細は「3.5 オプションファイルに記述できるコメント」を参照してください。
オプションファイルのネストは , 最大 8 レベルまで可能です。
【例】
オプションフィル:def.opt
-I D:\usr\include
-D SMAP
-l
fasm896s -V -f def.opt test
上の例は,次のように解釈されます。
fasm896s -V -I D:\usr\include -D SMAP -1 test
September 1, 2014, CM81-00208-5
23
Su pp or t
3.5
So ft
Manu al
オプションファイルに記述できるコメント
コメントは , 任意のカラムから始めることができます。
コメントは , シャープ (#) で始まります。行終端までコメントになります。
■ オプションファイルに記述できるコメント
【記述形式】
# コメント
そのほかに次のコメントも使用できます。
/* コメント */
// コメント
; コメント
【説明】
コメントは , 任意のカラムから始めることができます。
コメントは , シャープ (#) で始まります。行終端までコメントになります。
【例】
#
# F2MC8L カスタマイズオプション
#
# インクルードパス
#
-I D:\usr\test\include
# テストインクルード
#
# デファイン
#
-D SMAP
-D VER=2
24
CM81-00208-5, September 1, 2014
Support
3.6
Soft
Ma nual
デフォルトオプションファイル
オプションファイル機能の 1 つですが , 起動時オプション "-f" を指定しなくてもあ
らかじめ指定されているオプションファイルを読み込み実行します。
この機能をデフォルトオプションファイルといいます。
■ デフォルトオプションファイル
デフォルトオプションファイルは , 常にアセンブラ起動時に読み込まれますので , 使用
者の環境にあった起動時オプションをあらかじめ指定しておくことができます。
デフォルトオプションファイル機能を抑止するには , コマンドライン上で起動時オプ
ション "-Xdof" を指定します。
このオプションが指定されると, デフォルトオプションファイルは読み込まれません。
デフォルトオプションファイル名は , 次のように決まっています。
コマンド名
デフォルトオプションファイル名
fasm896s
FASM896.OPT
デフォルトオプションファイルの参照手順を次に示します。
● 環境変数 "OPT896" が設定されている場合
環境変数 "OPT896" で設定されているディレクトリを参照します。
%OPT896%\FASM896.OPT
● 環境変数 "OPT896" が設定されていない場合
開発環境ディレクトリ内のデフォルトオプションファイルを参照します。
%FETOOL%\LIB\896\FASM896.OPT
デフォルトオプションファイルは , なくてもかまいません。
September 1, 2014, CM81-00208-5
25
Su pp or t
3.7
So ft
Manu al
終了コード
本アセンブラが処理を終了して OS へ制御を戻すときの終了コードです。
■ 終了コード
アセンブラが処理を終了して OS へ制御を戻すときの終了コードです。
このコード値により , アセンブラのおおよその処理状態を知ることができます。
表 3.7-1 に終了コードを示します。
表 3.7-1 終了コード
処理状態
正常終了
ウォーニング発生
終了コード
0
0 または 1
エラー発生
2
異常終了
3
<注意事項>
• ウォーニング発生時の終了コードは , -cwno/-Xcwno オプションの指定によります。詳
しくは「4.8.7 -cwno, -Xcwno」を参照してください。
• ウォーニングとエラーが同じに発生した場合は , エラーの終了コードを返します。
• エラーが発生した場合は , オブジェクトファイルは作成されません。
26
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
第4章
起動時オプション
この章では , アセンブラの起動時オプションについ
て説明します。
起動時オプションは , アセンブル処理を制御できま
す。
起動時オプションは , オプション識別記号で識別さ
れます。
オプション識別記号は , ハイフン (-) です。
4.1 起動時オプションの規則
4.2 起動時オプション一覧
4.3 起動時オプションの詳細
4.4 オブジェクトおよびデバッグに関するオプション
4.5 リスティングに関するオプション
4.6 プリプロセッサに関するオプション
4.7 ターゲット依存オプション
4.8 その他のオプション
September 1, 2014, CM81-00208-5
27
Su pp or t
4.1
So ft
Manu al
起動時オプションの規則
起動時オプションの規則について説明します。
■ 起動時オプションの規則
起動時オプション全体に関する仕様について説明します。
説明では , 起動時オプションを単にオプションといいます。
● 同一オプションの複数指定
同じオプションが複数指定されたときは , 最後に指定されたオプションが有効になり
ます。
【例】
fasm896s -o abc test.asm -o def
-o def が有効となり , def.obj というオブジェクトファイルを作ります。
● 複数指定可能オプション
• -D name[=def]
: マクロ名の指定
• -U name
: マクロ名の取り消し
• -I path
: インクルードパスの指定
• -f filename
: オプションファイルの指定
これらのオプションは複数指定可能であり , 指定されたオプションすべてが有効にな
ります。
● オプション指定の位置
オプション指定の位置は , 特別な意味はありません。すなわち , コマンド行のどの位置
で指定しても同じ意味です。
【例】
1.fasm896s -C -name prog test.asm -l
2.fasm896s test.asm -l -name prog -C
1., 2. とも同じ処理が行われます。
● 排他関係と依存関係
オプションの中には , オプション間で排他関係を持つもの , または依存関係を持つもの
があります。これらのオプションが同時に指定されたときは , 最後に指定されたオプ
ションが有効になります。
【例】
fasm896s -lf t1 test.asm -Xl
-Xl が有効になりリストファイルは作成されません。
28
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
起動時オプション一覧
4.2
起動時オプションの一覧を , 表 4.2-1 に示します。
■ 起動時オプション一覧
表 4.2-1 起動時オプション一覧 (1 / 2)
指定形式
機能概要
初期値
オブジェクトおよびデバッグに関するオプション
-o [filename]
オブジェクトファイル名の指定
-Xo
オブジェクトファイルを作らない
-g
デバッグ情報出力
-Xg
デバッグ情報出力の取り消し
出力する
出力しない
リスティングに関するオプション
-l
リストファイル出力
出力しない
-lf filename
リストファイル出力 ( ファイル名指定 )
-Xl
リストファイル出力の取り消し
-pl {0|20-255}
リストの 1 頁の行数
60
-pw {80-1023}
リストの 1 行の桁数
100
-linf {ON|OFF}
インフォメーションリスト出力
ON
-lsrc {ON|OFF}
ソースリスト出力
ON
-lsec {ON|OFF}
セクションリスト出力
ON
-lcros {ON|OFF}
クロスリファレンスリスト出力
OFF
-linc {ON|OFF}
インクルードファイルリスト出力
ON
-lexp {ON|OFF|OBJ}
マクロ展開部リスト出力
OBJ
-tab {0-32}
タブの展開文字数指定
8
プリプロセッサに関するオプション
-p
プリプロセッサを起動させない
-P
プリプロセッサのみの起動
-Pf filename
プリプロセッサのみの起動 ( ファイル名指定 )
-D name[=def]
マクロ名の指定
-U name
マクロ名の取り消し
-I path
インクルードパスの指定
-H
インクルードパスを出力
出力しない
-C
プリプロセッサ出力にコメントを残す
残さない
September 1, 2014, CM81-00208-5
起動する
29
Su pp or t
So ft
Manu al
表 4.2-1 起動時オプション一覧 (2 / 2)
指定形式
機能概要
初期値
ターゲット依存オプション
-sa
アキュムレータ保護コードの出力
出力しない
-Xsa
アキュムレータ保護コードの出力抑止
-div_check
DIVU 命令に対して警告メッセージを出力する
F2MC8L : 出力しない
-Xdiv_check
DIVU 命令に対して警告メッセージを出力しない
F2MC8FX : 出力する
その他のオプション
30
-Xdof
デフォルトオプションファイルの取り消し
-f filename
オプションファイルの指定
-w [0-3]
警告メッセージ出力のレベル指定
-name module-name
モジュール名の指定
-V
起動メッセージ出力
-XV
起動メッセージ出力の取り消し
-cmsg
終了メッセージの出力
-Xcmsg
終了メッセージの出力抑止
-cwno
警告メッセージ出力時終了コード 1 指定
-Xcwno
警告メッセージ出力時終了コード 0 指定
-help
ヘルプメッセージの出力
-cpu MB 番号
ターゲットチップ指定
-kanji[EUC|SJIS]
日本語コード系指定
SJIS
-LBA
.bit 擬似命令の次のラベルをバイトアドレッシン
グとして扱う指定
ビットアドレッシング
-XLBA
.bit 擬似命令の次のラベルをビットアドレッシン
グとして扱う指定
-OVFW
オーバフローを WARNING レベルとしてコードを
生成する指定
-XOVFW
オーバフローをエラーレベルとしてコード生成を
行わなくする指定
-cif CPU 情報ファイ
ル名
参照する CPU 情報ファイルの指定
2
表示しない
出力しない
0 指定
表示しない
エラーとする
CM81-00208-5, September 1, 2014
Support
4.3
Soft
Ma nual
起動時オプションの詳細
起動時オプションはその機能により , 次のように分類します。
• オブジェクトおよびデバッグに関するオプション
• リスティングに関するオプション
• プリプロセッサに関するオプション
• ターゲット依存オプション
• その他のオプション
ここでは , それぞれの起動時オプションの詳細について説明します。
■ オブジェクトおよびデバッグに関するオプション
オブジェクトファイル名の指定やデバッグ情報の出力制御をするオプションです。
■ リスティングに関するオプション
リストファイル名の指定やリスト形式の指定をするオプションです。
■ プリプロセッサに関するオプション
プリプロセッサ処理の動作を指定するオプションです。
■ ターゲット依存オプション
ターゲットチップに依存するオプションです。
■ その他のオプション
その他のオプションとして , オプションファイルの指定 , 警告メッセージ出力のレベル
指定 , モジュール名の指定などがあります。
September 1, 2014, CM81-00208-5
31
Su pp or t
4.4
So ft
Manu al
オブジェクトおよびデバッグに関するオプション
オブジェクトファイル名の指定やデバッグ情報の出力制御をするオプションです。
■ オブジェクトおよびデバッグに関するオプション
オブジェクトおよびデバッグに関するオプションは , 次の 4 種類があります。
32
• -o
: オブジェクトファイル名の指定
• -Xo
: オブジェクトファイルを作らない
• -g
: デバッグ情報出力
• -Xg
: デバッグ情報出力の取り消し
CM81-00208-5, September 1, 2014
Support
4.4.1
Soft
Ma nual
-o, -Xo
-o は , 指定したオブジェクトファイル名でオブジェクトファイルを作成します。
-Xo は , オブジェクトファイルを作成しません。
-o -Xo 両方とも指定がない場合は , ソースファイル名の主ファイル名に拡張子
".obj" を付けたファイルにオブジェクトを出力します。
■ -o
【記述形式】
-o [ オブジェクトファイル名 ]
【説明】
指定したオブジェクトファイル名でオブジェクトファイルを作成します。
オブジェクトファイル名を省略した場合 , またはパス名だけを指定した場合は ,
ソースファイル名の主ファイル名に拡張子 ".obj" を付けたファイルにオブジェクト
を出力します。
詳細は , 「3.3.2 ファイル名の省略指定」を参照してください。
【例】
fasm896s ex1 -o ex1_a
■ -Xo
【記述形式】
-Xo
【説明】
オブジェクトファイルを作成しません。
【例】
fasm896s ex1 -Xo
September 1, 2014, CM81-00208-5
33
Su pp or t
4.4.2
So ft
Manu al
-g, -Xg
-g は , デバッグ情報を出力します。
-Xg は , デバッグ情報を出力しません。
-g オプション指定がない場合は , デバッグ情報を出力しません。
■ -g
【記述形式】
-g
【説明】
オブジェクトファイルにデバッグ情報を出力します。
デバッグ情報を出力することにより , シミュレータデバッガまたはエミュレータデ
バッガによるシンボリックデバッグが可能になります。
高級言語デバッグなどを行う場合は , このオプションを指定してください。
【例】
fasm896s c_test -g
■ -Xg
【記述形式】
-Xg
【説明】
オブジェクトファイルにデバッグ情報を出力しません。
【例】
fasm896s c_test -Xg
34
CM81-00208-5, September 1, 2014
Support
4.5
Soft
Ma nual
リスティングに関するオプション
アセンブルリストファイル名の指定やリスト形式の指定をするオプションです。
■ リスティングに関するオプション
リスティングに関するオプションは次の 12 種類があります。
• -l
: アセンブルリストファイル出力
• -lf
: アセンブルリストファイル出力 ( ファイル名指定 )
• -X
: アセンブルリストファイル出力の取り消し
• -pl
: アセンブルリストの 1 頁の行数
• -pw
: アセンブルリストの 1 行の桁数
• -linf
: インフォメーションリスト出力
• -lsrc
: ソースリスト出力
• -lsec
: セクションリスト出力
• -lcros : クロスリファレンスリスト出力
• -linc
: インクルードファイルリスト出力
• -lexp : マクロ展開部リスト出力
• -tab
September 1, 2014, CM81-00208-5
: タブの展開文字数指定
35
Su pp or t
4.5.1
So ft
Manu al
-l, -lf, -Xl
-l は , アセンブルリストファイルを作成します。
-lf は , 指定したファイル名でアセンブルリストファイルを作成します。
-Xl は , アセンブルリストファイルを作成しません。
-l -lf -Xl の 3 つとも指定がない場合は , アセンブルリストファイルを作りません。
■ -l
【記述形式】
-l
【説明】
アセンブルリストファイルを作成します。
ソースファイル名の主ファイル名に拡張子 ".lst" を付けたファイルにアセンブルリ
ストを出力します。
【例】
fasm896s test -l
■ -lf
【記述形式】
-lf アセンブルリストファイル名
【説明】
指定したアセンブルリストファイル名でアセンブルリストファイルを作成します。
パス名だけを指定した場合は , ソースファイル名の主ファイル名に拡張子 ".lst" を付
けたファイルに出力します。
詳細は , 「3.3.2 ファイル名の省略指定」を参照してください。
【例】
fasm896s test -lf \fasm\src
■ -Xl
【記述形式】
-Xl
【説明】
アセンブルリストファイルを作りません。
【例】
fasm896s test -Xl
36
CM81-00208-5, September 1, 2014
Support
4.5.2
Soft
Ma nual
-pl, -pw
-pl は , アセンブルリストの 1 ページの行数を指定します。
-pw は , アセンブルリストの 1 行の桁数を指定します。
■ -pl
【記述形式】
-pl {0|20 ~ 255}
【説明】
アセンブルリストの 1 ページの行数を指定します。
指定された行数内で 1 ページ分のアセンブルリストが作成されます。
行数は , 20 ~ 255 の範囲で指定できます。
行数に 0 を指定した場合は , 改ページされません。
本オプションの指定がないときの値は , 60 です。
【例】
fasm896s test -pl 0
■ -pw
【記述形式】
-pw {80 ~ 1023}
【説明】
アセンブルリストの 1 行の桁数を指定します。
桁数は , 80 ~ 1023 の範囲で指定できます。
本オプションの指定がないときの値は , 100 です。
【例】
fasm896s test -pw 80
September 1, 2014, CM81-00208-5
37
Su pp or t
4.5.3
So ft
Manu al
-linf, -lsrc, -lsec, -lcros
アセンブルリストは , 大きく次の 4 つに別れています。
• インフォメーションリスト
• ソースリスト
• セクションリスト
• クロスリファレンスリスト
これらのリストをそれぞれ出力するかしないかを指定します。
-linf は , インフォメーションリストを出力するかしないかを指定します。
-lsrc は , ソースリストを出力するかしないかを指定します。
-lsec は , セクションリストを出力するかしないかを指定します。
-lcros は , クロスリファレンスリストを出力するかしないかを指定します。
■ -linf
【記述形式】
-linf {ON|OFF}
ON : インフォメーションリストを出力します。< デフォルト >
OFF: インフォメーションリストを出力しません。
【説明】
インフォメーションリストを出力するかしないかを指定します。
ON/OFF の文字は大文字 / 小文字を区別しません。
本オプションの指定がないときは , ON となります。
【例】
fasm896s test -linf off
■ -lsrc
【記述形式】
-lsrc {ON|OFF}
ON : ソースリストを出力します。< デフォルト >
OFF: ソースリストを出力しません。
【説明】
ソースリストを出力するかしないかを指定します。
ON/OFF の文字は大文字 / 小文字を区別しません。
本オプションの指定がないときは , ON となります。
38
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
【例】
fasm896s test -lsrc on
■ -lsec
【記述形式】
-lsec {ON|OFF}
ON : セクションリストを出力します。< デフォルト >
OFF: セクションリストを出力しません。
【説明】
セクションリストを出力するかしないかを指定します。
ON/OFF の文字は大文字 / 小文字を区別しません。
本オプションの指定がないときは , ON となります。
【例】
fasm896s test -lsec on
■ -lcros
【記述形式】
-lcros {ON|OFF}
ON : クロスリファレンスリストを出力します。
OFF: クロスリファレンスリストを出力しません。< デフォルト >
【説明】
クロスリファレンスリストを出力するかしないかを指定します。
ON/OFF の文字は大文字 / 小文字を区別しません。
本オプションの指定がないときは , OFF となります。
【例】
fasm896s test -lcros on
September 1, 2014, CM81-00208-5
39
Su pp or t
4.5.4
So ft
Manu al
-linc, -lexp
ソースリスト中には , インクルードファイル , マクロ展開部が含まれますが , これら
のリスト出力を制御します。
-linc は , インクルードファイルについてリスト出力を制御します。
-lexp は , マクロ展開部についてリスト出力を制御します。
■ -linc
【記述形式】
-linc {ON|OFF}
ON
: インクルードファイルをリストに出力します。< デフォルト >
OFF
: インクルードファイルをリストに出力しません。
【説明】
インクルードファイルについてリスト出力を制御します。
ON/OFF の文字は大文字 / 小文字を区別しません。
本オプションの指定がないときは , ON となります。
【例】
fasm896s test -linc off
■ -lexp
【記述形式】
-lexp {ON|OFF|OBJ}
ON
: マクロ展開部をリストに出力します。
OFF
: マクロ展開部をリストに出力しません。
OBJ
: オブジェクトコードのみリストに出力します。< デフォルト >
( マクロ展開部のテキスト部はリストには出力しません )
【説明】
マクロ展開部についてリスト出力を制御します。
ON/OFF の文字は大文字 / 小文字を区別しません。
本オプションの指定がないときは , OBJ となります。
【例】
fasm896s test -lexp obj
40
CM81-00208-5, September 1, 2014
Support
4.5.5
Soft
Ma nual
-tab
-tab は , リスト出力時に , タブをスペースで展開するときの文字数を指定します。
■ -tab
【記述形式】
-tab {0 ~ 32}
【説明】
リスト出力時にタブをスペースで展開するときの文字数を指定します。
本オプションの指定がないときは , 8 となります。
【例】
fasm896s test -tab 4
September 1, 2014, CM81-00208-5
41
Su pp or t
4.6
So ft
Manu al
プリプロセッサに関するオプション
プリプロセッサ処理の動作を指定するオプションです。
■ プリプロセッサに関するオプション
プリプロセッサに関するオプションは次の 8 種類があります。
• -p : プリプロセッサを起動させない
• -P : プリプロセッサのみの起動
• -Pf : プリプロセッサのみの起動 ( ファイル名指定 )
• -D : マクロ名の指定
• -U : マクロ名の取り消し
• -I : インクルードパスの指定
• -H : インクルードパスを出力
• -C : プリプロセッサ出力にコメントを残す
42
CM81-00208-5, September 1, 2014
Support
4.6.1
Soft
Ma nual
-p
プリプロセッサを起動させないことを指定します。
-p は , 小文字です。
■ -p
【記述形式】
-p
【説明】
プリプロセッサを起動させないことを指定します。
すなわち , プリプロセッサフェーズを飛ばして直接アセンブルフェーズを行いま
す。
プリプロセッサ処理が行われないので処理時間が少なくなります。
高級言語コンパイラが出力するようなプリプロセッサ命令を含まないアセンブル
ソースをアセンブルする場合に有効です。
【例】
fasm896s test -p
September 1, 2014, CM81-00208-5
43
Su pp or t
4.6.2
So ft
Manu al
-P, -Pf
-P は , プリプロセッサフェーズの前処理結果を出力します。
-Pf は , 指定したファイル名にプリプロセッサフェーズの前処理結果を出力します。
■ -P
【記述形式】
-P
【説明】
プリプロセッサフェーズの前処理結果をファイルに出力します。
ソースファイル名の主ファイル名に拡張子 ".as" を付けたファイルに出力します。
プリプロセッサ処理のみ行い , アセンブルフェーズの処理は行いません。
【例】
fasm896s test -P
■ -Pf
【記述形式】
-Pf 前処理結果ファイル名
【説明】
指定したファイル名にプリプロセッサフェーズの前処理結果を出力します。
パス名だけを指定した場合は , ソースファイル名の主ファイル名に拡張子 ".as" を付
けたファイルに出力します。
詳細は , 「3.3.2 ファイル名の省略指定」を参照してください。
プリプロセッサ処理のみ行い , アセンブルフェーズの処理は行いません。
【例】
fasm896s test -Pf \fasm\src
44
CM81-00208-5, September 1, 2014
Support
4.6.3
Soft
Ma nual
-D, -U
-D は , マクロ名に定義文字の列を定義します。
-U は , -D で指定されたマクロ名を取り消します。
■ -D
【記述形式】
-D マクロ名 [= 定義文字の列 ]
【説明】
マクロ名に定義文字の列を定義します。
"-D マクロ名 " と記述し , "= 定義文字の列 " を省略した場合は , 1 が定義されます。
"-D マクロ名 =" と記述し , 定義文字の列だけ記述がない場合は , 空文字が定義され
ます。
本オプションは , 複数指定が可能です。
本オプションは , #define 命令と等しい機能を持ちます。
【例】
fasm896s test -D OS_TYPE=3 -D WINDOWS
■ -U
【記述形式】
-U マクロ名
【説明】
-D で指定されたマクロ名を取り消します。
-D と -U オプションの両方で , 同じマクロ名が指定されたときは , オプションの順
番に関係なく , マクロ名を取り消します。
本オプションは , 複数指定が可能です。
本オプションは , #undef 命令と等しい機能を持ちます。
【例】
fasm896s test -D ABC=10 -U ABC
September 1, 2014, CM81-00208-5
45
Su pp or t
4.6.4
So ft
Manu al
-I
インクルードパスを指定します。
#include 命令で指定されたインクルードファイルを検索するパスを指定します。
■ -I
【記述形式】
-I インクルードパス
【説明】
インクルードパスを指定します。
#include 命令で指定されたインクルードファイルを検索するパスを指定します。
本オプションは , 複数指定が可能です。指定順に検索されます。
#include 命令については , 「第 II 部 文法編」の「11.9 #include 命令」を参照してく
ださい。
【例】
fasm896s test -I \INCLUDE -I \FFMC8L
46
CM81-00208-5, September 1, 2014
Support
4.6.5
Soft
Ma nual
-H
#include 命令で読み込まれるインクルードファイルのパス名を標準出力に出力しま
す。
パス名は読み込まれる順に 1 行に 1 つずつ出力します。
■ -H
【記述形式】
-H
【説明】
#include 命令で読み込まれるインクルードファイルのパス名を , 標準出力に出力し
ます。
パス名は読み込まれる順に 1 行に 1 つずつ出力します。
インクルードファイルの検索でファイルが見付からなかったパス名は出力しませ
ん。
【例】
fasm896s test -I \INCLUDE -I \FFMC8L -H
September 1, 2014, CM81-00208-5
47
Su pp or t
4.6.6
So ft
Manu al
-C
プリプロセッサ処理で , コメントおよび空白をすべて残します。
本オプションの指定がないときは , コメントおよび空白は 1 つの空白文字に置き換
えられます。
■ -C
【記述形式】
-C
【説明】
プリプロセッサ処理で , コメントおよび空白をすべて残します。
本オプションの指定がないときは , コメントおよび空白は 1 つの空白文字に置き換
えられます。このオプション指定により , アセンブルフェーズの処理の負担を少な
くしています。
【例】
fasm896s test -C
48
CM81-00208-5, September 1, 2014
Support
4.7
Soft
Ma nual
ターゲット依存オプション
ターゲットチップに依存するオプションです。
■ ターゲット依存オプション
ターゲット依存オプションには次の 4 種類があります。
● F2MC-8L/8FX ファミリのみ
• -sa
: アキュムレータ保護コード出力の指定
• -Xsa
: アキュムレータ保護コード出力抑止の指定
• -div_check
:DIVU 命令に対して警告メッセージを出力する指定
• -Xdiv_check :DIVU 命令に対して警告メッセージを出力しない指定
September 1, 2014, CM81-00208-5
49
Su pp or t
4.7.1
So ft
Manu al
-sa, -Xsa
アキュムレータ保護コードの出力に関してのオプションです。
-sa は , アキュムレータ保護コードを出力します。
-Xsa は , アキュムレータ保護コードを出力しません。
■ -sa
【記述形式】
-sa
【説明】
アキュムレータ保護コードの出力を行います。
構造化命令の式の前後でアキュムレータが変更されないように保護コードを出力
します。
【例】
fasm896s test -sa
■ -Xsa
【記述形式】
-Xsa
【説明】
アキュムレータ保護コードの出力を抑止します。
【例】
fasm896s test -sa -Xsa
50
CM81-00208-5, September 1, 2014
Support
4.7.2
Soft
Ma nual
-div_check, -Xdiv_check
-div_check は , DIVU 命令に対して警告メッセージを出力します。
-Xdiv_check は , DIVU 命令に対して警告メッセージを出力しません。
■ -div_check
【記述形式】
-div_check
【説明】
DIVU 命令に対して以下の警告メッセージを出力します。
エラー番号
日
メッセージ
DIVU 命令が検出されました
W1806A
英
DIVU is detected
【例】
fasm896s test -div_check
■ -Xdiv_check
【記述形式】
-Xdiv_check
【説明】
DIVU 命令に対して警告メッセージを出力しません。
【例】
fasm896s test -div_check -Xdiv_check
■ デフォルト動作について
ファミリ種別
デフォルト動作
F2MC-8L ファミリ
-Xdiv_check 指定時と同じ
F2MC-8FX ファミリ
-div_check 指定時と同じ
September 1, 2014, CM81-00208-5
51
Su pp or t
So ft
Manu al
■ DIVU 命令チェック機能について
F2MC-8FXファミリはDIVU命令の動作が従来のF2MC-8Lファミリと異なるためF2MC8L ファミリ用アセンブラソースを F2MC-8FX ファミリ用に流用する場合 , DIVU 命令
が使用されている箇所について問題がないか確認する必要があります。
アセンブラソース内のDIVU命令の使用について調べるには, エディタなどで検索する
ことで可能ですが , -div_check オプションを指定することでアセンブル時に検出できま
す。
52
CM81-00208-5, September 1, 2014
Support
4.8
Soft
Ma nual
その他のオプション
その他のオプションとして , オプションファイルの指定 , 警告メッセージ出力のレベ
ル指定 , およびモジュール名の指定などがあります。
■ その他のオプション
その他のオプションは次の 18 種類があります。
• -Xdof
: デフォルトオプションファイルの取り消し
• -f
: オプションファイルの指定
• -w
: 警告メッセージ出力のレベル指定
• -name
: モジュール名の指定
• -V
: 起動メッセージの表示
• -XV
: 起動メッセージ表示の取り消し
• -cmsg
: 終了メッセージの出力
• -Xcmsg
: 終了メッセージ出力の抑止
• -cwno
: ウォーニング時終了コード 1 指定
• -Xcwno
: ウォーニング時終了コード 0 指定
• -help
: ヘルプメッセージの表示
• -cpu
: ターゲットチップの指定
• -kanji
: 日本語コード系の指定
• -LBA
:.bit 擬似命令の次のレベルをバイトアドレスとして扱う
• -XLBA
:.bit 擬似命令の次のレベルをビットアドレスとして扱う
• -OVFW
: オーバフローを WARNING にする
• -XOVFW : オーバフローを ERROR にする
• -cif
September 1, 2014, CM81-00208-5
: 参照する CPU 情報ファイルの指定
53
Su pp or t
4.8.1
So ft
Manu al
-Xdof
デフォルトオプションファイルの読み込みを取り消します。
本オプションの指定がないときは , デフォルトオプションファイルは常に読み込ま
れます。
■ -Xdof
【記述形式】
-Xdof
【説明】
デフォルトオプションファイルの読み込みを取り消します。
本オプションの指定がないときは , デフォルトオプションファイルは常に読み込ま
れます。
デフォルトオプションファイルに関しては , 「3.6 デフォルトオプションファイル」
を参照してください。
【例】
fasm896s test -Xdof
54
CM81-00208-5, September 1, 2014
Support
4.8.2
Soft
Ma nual
-f
指定したオプションファイルを読み込みます。
オプションファイルには , fasm896s オプションが記述できます。
■ -f
【記述形式】
-f オプションファイル名
【説明】
指定したオプションファイルを読み込みます。
オプションファイル名に拡張子を省略した場合は , 拡張子 ".opt" を補います。
オプションファイルには , fasm896s オプションが記述できます。
本オプションファイルは , 複数指定が可能です。
オプションファイルに関しては , 「3.4 オプションファイル」を参照してください。
【例】
fasm896s test -f test.opt
September 1, 2014, CM81-00208-5
55
Su pp or t
4.8.3
So ft
Manu al
-w
警告メッセージの出力レベルを設定します。
警告レベルに 0 を指定した場合は , 警告メッセージは 1 つも出力されません。
■ -w
【記述形式】
-w [ 警告レベル ]
【説明】
警告メッセージの出力レベルを設定します。
警告レベルに 0 を指定した場合は , 警告メッセージは 1 つも出力されません。
警告レベルを省略した場合は , 2 となります。
本オプションの指定がないときは , 2 となります。
警告レベルと出力される警告メッセージに関しては ,「付録 A エラーメッセージ一
覧」を参照してください。
警告レベルと出力される警告メッセージを次に示します。
表 4.8-1 警告レベルと出力される警告メッセージ
警告レベル
0
1, 2
3
警告メッセージ
すべての警告メッセージを出力しません
エラー番号 W1551A, W1711A 以外の警告メッセージを出力
すべての警告メッセージを出力
【例】
fasm896s test -w 0
■ エラー番号 W1551A
ソースファイルの最後に .END 命令がなかったときに , 警告を出力します。
■ エラー番号 W1711A
.ORG 命令でアドレスが戻ったときに , 警告を出力します。
56
CM81-00208-5, September 1, 2014
Support
4.8.4
Soft
Ma nual
-name
モジュール名を指定します。
モジュール名は , .PROGRAM 命令よりも本オプションで指定した名前が有効になり
ます。
■ -name
【記述形式】
-name モジュール名
【説明】
モジュール名を指定します。
モジュール名は , 名前の規則に従います。
モジュール名は, .PROGRAM命令よりも本オプションで指定した名前が有効になり
ます。
【例】
fasm896s test -name prog
September 1, 2014, CM81-00208-5
57
Su pp or t
4.8.5
So ft
Manu al
-V, -XV
-V は , アセンブラ実行時に , 起動メッセージを表示します。
-XV は , 起動メッセージの表示を取り消します。
-V, -XV 両方とも指定がない場合は , 起動メッセージは表示されません。
■ -V
【記述形式】
-V
【説明】
アセンブラ実行時に , 起動メッセージを表示します。
起動メッセージは , 実行されたアセンブラのバージョン情報とコピーライトを表示
します。
【例】
fasm896s test -V
■ -XV
【記述形式】
-XV
【説明】
起動メッセージの表示を取り消します。
【例】
fasm896s test -V -XV
58
CM81-00208-5, September 1, 2014
Support
4.8.6
Soft
Ma nual
-cmsg, -Xcmsg
-cmsg は , アセンブラ実行時に , 終了メッセージを表示します。
-Xcmsg は , 終了メッセージの表示を取り消します。
-cmsg, -Xcmsg 両方とも指定がない場合は , 終了メッセージは表示されません。
■ -cmsg
【記述形式】
-cmsg
【説明】
アセンブラ実行時に , 終了メッセージを表示します。
【例】
fasm896s test -cmsg
■ -Xcmsg
【記述形式】
-Xcmsg
【説明】
終了起動メッセージの表示を取り消します。
【例】
fasm896s test -cmsg -Xcmsg
September 1, 2014, CM81-00208-5
59
Su pp or t
4.8.7
So ft
Manu al
-cwno, -Xcwno
-cwno は , 警告メッセージ出力時のアセンブラの終了コードを 1 にします。
-Xcwno は , 警告メッセージ出力時のアセンブラの終了コードを 0 にします。
-cwno, -Xcwno 両方とも指定がない場合は , 警告メッセージ出力時のアセンブラの
終了コードは 0 です。
■ -cwno
【記述形式】
-cwno
【説明】
警告メッセージ出力時のアセンブラの終了コードを 1 にします。
【例】
fasm896s test -cwno
■ -Xcwno
【記述形式】
-Xcwno
【説明】
警告メッセージ出力時のアセンブラの終了コードを 0 にします。
【例】
fasm896s test -cwno -Xcwno
60
CM81-00208-5, September 1, 2014
Support
4.8.8
Soft
Ma nual
-help
起動時オプションの一覧を表示します。
これをヘルプメッセージといいます。
■ -help
【記述形式】
-help
【説明】
起動時オプションの一覧を表示します。
これをヘルプメッセージといいます。
本オプションを指定したときは , アセンブル処理を行いません。
【例】
fasm896s test -help
September 1, 2014, CM81-00208-5
61
Su pp or t
4.8.9
So ft
Manu al
-cpu
ターゲットチップの指定を行います。
ターゲットチップには , 使用する製品名を指定します。
■ -cpu
【記述形式】
-cpu ターゲット
ターゲット : 使用する製品名
【説明】
ターゲットチップの指定を行います。
ターゲットには , 使用する製品名を指定します。
【例】
fasm896s test -cpu MB89051
fasm896s test -cpu MB89F051
62
CM81-00208-5, September 1, 2014
Support
4.8.10
Soft
Ma nual
-kanji
日本語コード系の指定を行います。
■ -kanji
【記述形式】
-kanji [EUC|SJIS]
EUC:EUC コード系を指定する。
SJIS: シフト JIS コード系を指定する。
【説明】
ソースプログラム中のコメント , 文字数 , および文字列定数に記述された日本語
コード系を指定します。
本オプションの指定がない場合は , SJIS が指定されたものとみなします。
【例】
fasm896s test -kanji EUC
September 1, 2014, CM81-00208-5
63
Su pp or t
4.8.11
So ft
Manu al
-LBA, -XLBA
-LBA は , .bit などのビットアドレッシングをとる擬似命令の後にラベルの定義のみ
の行が記述された場合に , そのラベルをバイトアドレッシングとして扱います。
-XLBA は , .bit などのビットアドレッシングをとる擬似命令の後にラベルの定義の
みの行が記述された場合に , そのラベルをビットアドレッシングとして扱います。
-LBA, -XLBA 両方とも指定がない場合は , -XLBA が指定された場合と同様の動作に
なります。
■ -LBA
【記述形式】
-LBA
【説明】
.bit, .data.i, .res.i のいずれかの擬似命令が記述された行の直後の行にラベル定義のみ
の行が記述された場合に , そのラベルをバイトアドレスとして処理します。この場
合 , ラベルのアドレスはバイト境界に調整されます。
【例】
fasm896s test -LBA
実行結果は以下のようになります。
000000:0 0
.bit 0
000000:1 0
LBL1:
000001
LBL2:
000001:0 1
.bit 0
.bit 1
■ -XLBA
【記述形式】
-XLBA
【説明】
.bit, .data.i, .res.i のいずれかの擬似命令が記述された行の直後の行にラベル定義のみ
の行が記述された場合に , そのラベルをビットアドレスとして処理します。この場
合 , ラベルのアドレスは直前のビットアドレスの次のビットアドレスになります。
64
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
【例】
fasm896s test -XLBA
実行結果は以下のようになります。
000000:0 0
.bit 0
000000:1 0
LBL1:
000000:
LBL2:
000000:2 1
September 1, 2014, CM81-00208-5
.bit 0
.bit 1
65
Su pp or t
4.8.12
So ft
Manu al
-OVFW, -XOVFW
-OVFW オプションは , 式を記述できるオペランドの演算結果が , そのオペランドサ
イズを超える場合に WARNING メッセージを表示します。
-XOVFW オプションは , 式を記述できるオペランドの演算結果が , そのオペランド
サイズを超える場合に ERROR メッセージを表示します。
■ -OVFW
【記述形式】
-OVFW
【説明】
-OVFWオプションは, 式を記述できるオペランドの演算結果がそのオペランドサイ
ズを超える場合 , 以下のような処理を行います。
式を記述できるオペランドには , 即値 , アドレス値があります。
- WARNING メッセージ (W1541A: 値が範囲外です ) を出力します。
- オブジェクトファイルを出力します。
- オペランドの演算結果をオペランドサイズに合わせてマスクして , 下位ビットの
みを設定してコードを出力します。
- アセンブルリスト出力指定オプション (-l) を指定した場合 , アセンブルリストを
出力します。
以下に本オプションの指定例と , アセンブルリスト出力例を示します。
アセンブルリストを出力する場合は , アセンブルリスト出力指定オプション (-l) を
指定してください。
【例】
fasm896s test -OVFW -l
・出力リスト
アセンブラは, 式の演算を32ビットで行っているため,
~(8008H)の演算結果は, FFFF7FF7Hとなります。
~(8008H)=FFFF7FF7Hは16ビットでマスクされ,
オブジェクトとリストに出力される値は7FF7Hになります。
SN LOC OBJ
<test.asm>
LLINE
SOURCE
=====
:
CO 0000 E47FF7
2 T
MOVW A,#~(8008H)
*** test.asm(2) W1541A: Value out of range (in operand 2)
:
66
-OVFW指定時は, WARNINGが出力されます。
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
■ -XOVFW
【記述形式】
-XOVFW ( デフォルト )
【説明】
-XOVFW オプションは , 式を記述できるオペランドの演算結果がそのオペランドサ
イズを超える場合 , 以下のような処理を行います。
式を記述できるオペランドには , 即値 , アドレス値があります。
- ERROR メッセージ (E4541A: 値が範囲外です ) を出力します。
- オブジェクトファイルは出力しません。
- アセンブルリストには , オペランドの演算結果をオペランドサイズに合わせてマ
スクして , 下位ビットのみを設定してアセンブルリストにコードを出力します。
- アセンブルリスト出力指定オプション (-l) を指定した場合 , アセンブルリストを
出力します。
以下に本オプションの指定例と , アセンブルリスト出力例を示します。
アセンブルリストを出力する場合は , アセンブルリスト出力指定オプション (-l) を
指定してください。
アセンブルリストは , エラー発生時にも出力されます。
【例】
fasm896s test -XOVFW -l
・出力リスト
アセンブラは, 式の演算を32ビットで行っているため,
~(8008H)の演算結果は, FFFF7FF7Hとなります。
~(8008H)=FFFF7FF7Hは16ビットでマスクされ,
リストに出力される値は7FF7Hになります。
SN LOC OBJ
<test.asm>
LLINE
SOURCE
=====
:
CO 0000 E47FF7
2 T
MOVW A,#~(8008H)
*** test.asm(2) E4541A: Value out of range (in operand 2)
:
September 1, 2014, CM81-00208-5
-XOVFW指定時は, ERRORが出力されます。
67
Su pp or t
4.8.13
So ft
Manu al
-cif
-cif は , SOFTUNE Tools が参照する CPU 情報ファイルを指定します。
■ -cif
【記述形式】
-cif CPU 情報ファイル名
CPU 情報ファイル名 : 参照する CPU 情報ファイル名
【説明】
SOFTUNE Tools が参照する CPU 情報ファイルを指定します。
【例】
fasm896s test -cpu MB89603 -cif "C:\SOFTUNE\lib\896\896.csv"
<注意事項>
SOFTUNE Tools は , CPU 情報ファイルを参照して , CPU に関する情報を取得します。
関連するツール間で異なる CPU 情報ファイルを参照した場合 , 作成するプログラムに問
題が発生する可能性があります。
SOFTUNE Tools に標準で添付されている CPU 情報ファイルは , 以下の場所にあります。
インストール先ディレクトリ \lib\896\896.csv
コンパイラ・アセンブラパックを異なるディレクトリにインストールし , SOFTUNE
Workbenchを使用せずにコンパイラ, アセンブラおよびリンケージエディタを使用する場
合, 各ツールに対して同一のCPU情報ファイルを参照するように-cifで指定してください。
68
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
第5章
最適コードチェック機能
について
この章では , アセンブラの最適コードチェック機能
について説明します。
最適コードチェック機能とは , プログラムをさらに
高速に実行できる命令コードに書き換え可能な個
所を検出する機能です。
5.1 fasm896s の最適コードチェック機能
September 1, 2014, CM81-00208-5
69
Su pp or t
5.1
So ft
Manu al
fasm896s の最適コードチェック機能
fasm896s では , プログラムの動作に支障がない範囲で , 次の 1 つの最適化可能なプ
ログラム個所の検出を行います。
• 分岐命令の最適化
■ 分岐命令の最適化
分岐命令に対して分岐先ラベルまでの距離により, 生成する命令の最適化を行います。
最適化対象命令を次に示します (16 ビット分岐拡張命令 )。
● 対象命令 :Bcc16
本最適化は常に行われます。
16 ビット分岐拡張命令に対して行われる最適化です。
16 ビット分岐拡張命令と生成される命令の関係を表 5.1-1 に示します。
表 5.1-1 16 ビット分岐拡張命令から生成される命令 (1 / 3)
分岐拡張命令
BZ16 label
BNZ16 label
BEQ16 label
BNE16 label
BC16 label
BNC16 label
BLO16 label
70
動作
(Z)=1 なら分岐
(Z)=0 なら分岐
(Z)=1 なら分岐
(Z)=0 なら分岐
(C)=1 なら分岐
(C)=0 なら分岐
(C)=1 なら分岐
距離
生成される命令
-128 ~ +127
BZ label
その他
BNZ $+5
JMP label
-128 ~ +127
BNZ label
その他
BZ $+5
JMP label
-128 ~ +127
BEQ label
その他
BNE $+5
JMP label
-128 ~ +127
BNE label
その他
BEQ $+5
JMP label
-128 ~ +127
BC label
その他
BNC $+5
JMP label
-128 ~ +127
BNC label
その他
BC $+5
JMP label
-128 ~ +127
BLO label
その他
BHS $+5
JMP label
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
表 5.1-1 16 ビット分岐拡張命令から生成される命令 (2 / 3)
分岐拡張命令
BHS16 label
BN16 label
動作
(C)=0 なら分岐
(N)=1 なら分岐
距離
-128 ~ +127
BHS label
その他
BLO $+5
JMP label
-128 ~ +127
BN label
その他
BP $+5
JMP label
-128 ~ +127
BP16 label
BLT16 label
BGE16 label
BBC16 bit, label
BBS16 bit, label
BV16 label
BNV16 label
September 1, 2014, CM81-00208-5
(N)=0 なら分岐
(V)xor(N)=1
なら分岐
(V)xor(N)=0
なら分岐
(bit)=0 なら分岐
(bit)=1 なら分岐
生成される命令
BP label
その他
BN $+5
JMP label
-128 ~ +127
BLT label
その他
BGE $+5
JMP label
-128 ~ +127
BGE label
その他
BLT $+5
JMP label
-128 ~ +127
BBC bit, label
その他
BBS bit, $+6
JMP label
-128 ~ +127
BBS bit, label
その他
BBC bit, $+6
JMP label
-128 ~ +122
BN $+7
BLT label
JMP $+5
BGE label
その他
BN $+7
BGE $+10
JMP label
BLT $+5
JMP label
-128 ~ +122
BN $+7
BGE label
JMP $+5
BLT label
その他
BN $+7
BLT $+10
JMP label
BGE $+5
JMP label
(V)=1 なら分岐
(V)=0 なら分岐
71
Su pp or t
So ft
Manu al
表 5.1-1 16 ビット分岐拡張命令から生成される命令 (3 / 3)
分岐拡張命令
BLE16 label
BGT16 label
BLS16 label
BHI16 label
72
動作
距離
生成される命令
-128 ~ +125
BEQ label
BLT label
その他
BEQ $+4
BGE $+5
JMP label
-128 ~ +127
BEQ $+4
BGE label
その他
BEQ $+7
BLT $+5
JMP label
-128 ~ +125
BEQ label
BLO label
その他
BEQ $+4
BHS $+5
JMP label
-128 ~ +127
BEQ $+4
BHS label
その他
BEQ $+7
BLO $+5
JMP label
(Z)or((N)or(V))=1
なら分岐
(Z)or((N)or(V))=0
なら分岐
(Z)or(C)=1
なら分岐
(Z)or(C)=0
なら分岐
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
第6章
アセンブルリスト
この章では , アセンブルリストの内容について説明
します。
6.1 全体形式
6.2 ページの形式
6.3 インフォメーションリスト
6.4 ソースリスト
6.5 セクションリスト
6.6 クロスリファレンスリスト
September 1, 2014, CM81-00208-5
73
Su pp or t
6.1
So ft
Manu al
全体形式
アセンブルリストは , 起動時オプションで "-l" または "-lf" が指定されたときに作成
されます。
アセンブルリストは次の 4 つの部分から構成されています。
• インフォメーションリスト
• ソースリスト
• セクションリスト
• クロスリファレンスリスト
■ 全体形式
アセンブルリストは , 起動時オプションで "-l" または "-lf" が指定されたときに作成さ
れます。
アセンブルリストは次の 4 つの部分から構成されています。
● インフォメーションリスト
起動時の指定内容 , エラー数 , ウォーニング数 , ソースファイル名 , インクルードファ
イル名 , およびオプションファイル名などが出力されます。
● ソースリスト
ソースリストは , ソースプログラムをアセンブルしたときの様々な情報を行単位に出
力します。
エラー情報 , ロケーション , およびオブジェクトデータなどが出力されます。
● セクションリスト
ソースプログラム内で定義されたセクションの名前 , 属性などが出力されます。
● クロスリファレンスリスト
ソースプログラム内で使用されているシンボル名の定義 , および参照されている行番
号を出力します。
■ 起動時オプションとの関係
それぞれのリスト部は , 起動時オプションで出力制御できます。
起動時オプションの詳細は , 「4.5 リスティングに関するオプション」を参照してくだ
さい。
表 6.1-1 にそれぞれのリスト部と起動時オプションとの関係を示します。
74
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
表 6.1-1 リスト部と起動時オプションとの関係
リスト部
起動時オプション
初期値
インフォメーションリスト
-linf {ON|OFF}
ON: 出力する
ソースリスト
-lsrc {ON|OFF}
ON: 出力する
セクションリスト
-lsec {ON|OFF}
ON: 出力する
クロスリファレンスリスト
September 1, 2014, CM81-00208-5
-lcros {ON|OFF}
OFF: 出力しない
75
Su pp or t
6.2
So ft
Manu al
ページの形式
アセンブルリストを構成するページの形式は , 起動時オプションまたは擬似命令で
その大きさを指定できます。
起動時オプションでは , 行数は "-pl", 桁数は "-pw" で指定します。
擬似命令では , 行数は ".FORM LIN", 桁数は ".FORM COL" で指定します。
■ インフォメーションリスト
アセンブルリストを構成するページの形式は , 起動時オプションまたは擬似命令でそ
の大きさを指定できます。
起動時オプションでは , 行数は "-pl", 桁数は "-pw" で指定します。
擬似命令では , 行数は ".FORM LIN", 桁数は ".FORM COL" で指定します。
ヘッダは 4 行あります。
図 6.2-1 にこの関係を示します。
図 6.2-1 ページの形式
ヘッダ
行数
桁数
指定範囲
行数
0,20~255
桁数
60~1023
初期値
60
100
(注意事項)行数に0を指定した場合は改ページされません。
76
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
■ ヘッダの形式
ヘッダは 4 行で構成されています。4 行目は空白行です。
図 6.2-2 ヘッダの形式
[ヘッダ1~2行目の形式]
F2MC-8L/8FX Family SOFTUNE Assembler V30L08
アセンブラ名/バージョン
2003-06-26 15:44:08 Page: 1
アセンブル日時 先頭からの通し頁番号
[ヘッダ3行目の形式]
・インフォメーションリスト
F2MC-8L/8FX Family SOFTUNE Assembler V30L08
2003-06-26 15:44:08 Page: 1
モジュール名
- ASSEMBLE INFORMATION - ( sample )
・ソースリスト
F2MC-8L/8FX Family SOFTUNE Assembler V30L08
*
2003-06-26 15:44:08 Page: 2
モジュール名
- SOURCE LISTING - ( sample )
*:この行は,.TITLE命令または,.HEADING命令で指定された文字列に変更できます。
・セクションリスト
F2MC-8L/8FX Family SOFTUNE Assembler V30L08
2003-06-26 15:44:08 Page: 10
モジュール名
- SECTION LISTING - ( sample )
・クロスリファレンスリスト
F2MC-8L/8FX Family SOFTUNE Assembler V30L08
2003-06-26 15:44:08 Page: 11
- CROSSREFERENCE LISTING - ( sample )
モジュール名
[ヘッダ4行目の形式]
必ず空白行が出力されます。
September 1, 2014, CM81-00208-5
77
Su pp or t
6.3
So ft
Manu al
インフォメーションリスト
アセンブルリストを構成するページの形式は , 起動時オプションまたは擬似命令で
その大きさを指定できます。
■ インフォメーションリスト
【形式 1】
図 6.3-1 インフォメーションリスト ( 形式 1)
___ ______________________________________________________________________
F2MC-8L/8FX Family SOFTUNE Assembler V30L08
- ASSEMBLE INFORMATION - ( sample )
|
2003-06-26 15:44:08 Page: 1
モジュール名
Command line
: fasm896s sample -C -W 2
Total errors
Total warnings
: 0
: 0
There were no errors.
Object file
List file
: sample.obj
: sample.lst
アセンブル時の
コマンド指定
|
|
|
|
|
|
|
|
|
エラーがなかった場合
表示されます。
オブジェクトファイル名
リストファイル名
|
|
|
|
|
CREATE DATE/TIME
|NO NEST
SOURCE-FILE-NAME
|-- ---------
------------------------------------------------------- -------------------------2003-03-01 09:00:00
sample.asm
|
|0
|-- ---------
------------------------------------------------------- --------------------------
|
|
ソースファイル名
|
|
ファイル作成日時
|
|
|
Current path
:
D:\
ファイル追番 |
(0から) |
Include path
:
INC896
= D: \INCLUDE\
Work file path
:
TMP
= D: \TMP\
Default Option file
:
OPT896
= D: \(fasm896.opt)
|
アセンブル時の
カレントディレクトリ
ワークディレクトリ
デフォルトオプション
ファイルディレクトリ
(およびファイル名)
|
|
環境変数名
|NO NEST
OPTION-FILE-NAME
|--------------
------------------------
|0
D:\fasm896.opt
|
------------------------
|
オプション
ファイル名
-l -P -lcros on
| ________________________________________
78
環境変数指定状況
CREATE DATE/TIME
-------------2003-03-0109:00:00
|
|
|
|
ファイル内容
|
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
【形式 2】
図 6.3-2 インフォメーションリスト ( 形式 2)
_______________________________________________________________________
F2MC-8L/8FX Family SOFTUNE Assembler V30L08
- ASSEMBLE INFORMATION - ( sample )
2003-06-26 15:44:08 Page: 1
モジュール名
Command line
: fasm896s sample -C -W 2
|
** Total errors
:
2
( First Line:
22)
|
|
** Total warnings
:
3
( First Line:
7)
|
|
|
|
|
|
エラーかウォーニングが Object file
あったときは, *を表示
List file
|
: - None -
エラーかウォーニングがあったときは,その数と
最初に見つかった行のリスト行番号を表示
|
: sample.lst
|
|
|
|NO NEST
SOURCE-FILE-NAME
CREATE DATE/TIME
|
|-- ------------- ------------------------------------------------------- -------------------------------------- |
sample.asm
|0
2003-03-01 09:00:00
|
|-- ------------- ------------------------------------------------------- -------------------------------------- |
|1*
sample.h
2003-03-01 09:02:00
|
|-- ------------- ------------------------------------------------------- -------------------------------------- |
|
インクルードのネスト状況(*の数がネストの深さを示します)
|
|
|
|
Current path
: D:\WORK\
|
|
Include path
: INC896
= -None- = D:\TOOL\LIB
\896\INCLUDE\
|
|
Work file path
: TMP
= D:\TMP\
|
|
Default Option file
: OPT896
= -None- = D:\TOOL\LIB
\896\(fasm896.opt)\
|
|
|
|
|
|______________________________________________________________________|
オプションファイルエラーが存在しない場合は,
ファイル内容は表示されません。
September 1, 2014, CM81-00208-5
79
Su pp or t
6.4
So ft
Manu al
ソースリスト
ソースリストは , ソースプログラムをアセンブルしたときの様々な情報を行単位に
出力します。
エラー情報 , ロケーション , オブジェクトデータなどが出力されます。
■ ソースリスト
図 6.4-1 ソースリスト
____________________________________________________________________________
F2MC-8L/8FX Family SOFTUNE Assembler V30L08
2003-06-26 15:44:08 Page: 2
- SOURCE LISTING - ( sample )
SN LOC
OBJ
LINE
SOURCE
====
DA 000
------------<DATA>------------
DA 000
ABCD 0123
DA 004
0020 0010
.SECTION DATA.DATA
1
2
CO 000 ------------<CODE>------------
rel:
.DATA.W 0xABCD.0x123
3
.DATA.H
4
.SECTION CODE.CODE
32,16
CO 000
00
5
NOP
CO 001
00
6
NOP
CO 002
00
7
NOP
8
.IMPORT imp
CO 003
0400
I
9
MOV
A,#imp
CO 005
600000
S
10
MOV
A,DATA
CO 008
0400
R
11
MOV
A,#rel
CO 00A
0500
12
MOV
A,0x00
オプションコード値
ロケーション値
(16進数表示)
セクション名の先頭2文字までを
表示します。
ソースプログラム表示
1行に表示できない場合は,複数行に
折り返して表示します。
リスト番号表示
オブジェクトファイル中のリスト行番号に
相当します。
オブジェクトコードに含まれる値の属性を次の優先順位で表示します。
I :外部参照値
S:セクション値
R:相対値
空:絶対値
80
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
プリプロセッサ処理
6.4.1
プリプロセッサで処理された行に対して表示される記号です。
■ プリプロセッサ処理
図 6.4-2 プリプロセッサ処理
SN LOC
:
OBJ
:
LLINE
:
SOURCE
:
:
2
DA 0000 0001
3
4
#ifdef DEF1
X
.DATA 0 /* then */
#else
5
6
.DATA 1 /* else */
#endif
プリプロセッサの処理状況表示
空:通常
プリプロセッサ
X:アセンブル対象外となった行
&:マクロ展開行
September 1, 2014, CM81-00208-5
81
Su pp or t
6.4.2
So ft
Manu al
エラー表示
エラーが発生した行に対して出力されるリスト形式です。
■ エラー表示
図 6.4-3 エラーのリスト形式
SN LOC OBJ
LLINE
:
:
:
DA 0000 0000I
:
SOURCE
:
2
*** sample.asm(2) W1527A: 未定義シンボルです(un_def)
.DATA
un_def
エラー認識番号
ソースファイル中の行番号
(リスト行番号でない)
ソースファイル名
W 1 5 2 7 A
ツール識別子 A:アセンブラ
エラー番号(3桁)
エラーレベル
W1: 警告レベル
E4: 文法エラー
F9: 致命的なエラー(アセンブル異常終了)
82
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
インクルードファイル
6.4.3
#include 命令で読み込まれたファイルに対して出力されるリスト形式です。
■ インクルードファイル
図 6.4-4 インクルードファイルのリスト形式
SN LOC
:
OBJ
:
LLINE
:
SOURCE
:
2
:
#include "sample.h"
=====
<sample.h>
CO0000 00
3=1
NOP
CO0001 00
4=1
NOP
CO0002 00
5=1
NOP
<sample.asm>
=====
インクルードファイル名
インクルードから
戻ったところの
ファイル名
September 1, 2014, CM81-00208-5
インクルードネスト数
最大8まで
-linc off / .LIST NOINCの場合には
この部分は表示しません。
ただし,エラーメッセージは
表示します。
83
Su pp or t
6.4.4
So ft
Manu al
.END, .PROGRAM, .SECTION
プログラム構造定義命令のリスト形式です。
• .END: ソースプログラムの終了
• .PROGRAM: モジュール名の宣言
• .SECTION: セクションの定義
■ .END
図 6.4-5 .END のリスト形式
SN LOC
OBJ
:
:
LLINE
SOURCE
:
:
:
==
25
.END
=> 00000300
25
.END 0x300
25
.END start
または
または
=> 00000010
R
スタートアドレス指定が
ある場合は16進数で表示する。
R:相対値
空:絶対値
なお , .END 命令以降にソースプログラムが書かれていてもアセンブルされません。
また , リストにも表示されません。
■ .PROGRAM
図 6.4-6 .PROGRAM のリスト形式
SN LOC
:
:
OBJ
LLINE
:
MODULE NAME = test_module1
:
9
SOURCE
:
.PROGRAM test _ module1
モジュール名として設定された文字列を表示します。
長い場合は折り返して表示します。
84
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
■ .SECTION
図 6.4-7 .SECTION のリスト形式
SN LOC
:
:
OBJ
LLINE
:
:
SE 0000 ------------<SEC1>-----------:
:
:
:
.SECTION
:
SE 0010 ------------<SEC2>-----------ロケーション
4
SOURCE
19
SEC1,CO DE,ALIGN1
:
.SECTION
SEC2,CODE,LOCATE=0x10
セクション名
セクション名が表示枠より長すぎる場合は,
後部をカットして表示します。
セクション名の先頭2文字を表示します。
September 1, 2014, CM81-00208-5
85
Su pp or t
6.4.5
So ft
Manu al
.ALIGN, .ORG, .SKIP
アドレス制御命令のリスト形式です。
• .ALIGN : 境界整列
• .ORG
: ロケーションカウンタ値の変更
• .SKIP
: ロケーションカウンタ値のインクリメント
■ .ALIGN
図 6.4-8 .ALIGN のリスト形式
SN LOC
:
OBJ
:
LLINE
:
SOURCE
:
CO 0004 - 0001 [3] < [4]
16
:
.ALIGN 4
指定されたALIGN値(10進数)
ALIGN境界までのオフセット値(10進数)
ALIGN前のロケーション
ALIGN後のロケーション
■ .ORG
図 6.4-9 .ORG のリスト形式
SN LOC
:
OBJ
:
LLINE
:
SOURCE
:
CO 0050
16
:
.ORG
0x50
ORG後のロケーション
■ .SKIP
図 6.4-10 .SKIP のリスト形式
SN LOC
:
:
OBJ
LLINE
:
:
CO 002A - 0020 [10]
16
SOURCE
:
.SKIP
10
SKIP値として指定された値(10進数)
SKIP前のロケーション
SKIP後のロケーション
86
CM81-00208-5, September 1, 2014
Support
6.4.6
Soft
Ma nual
.EXPORT, .GLOBAL, .IMPORT
プログラム結合命令は特にリストは変化しません。
• .EXPORT : 外部定義シンボルの宣言
• .GLOBAL : 外部定義・外部参照シンボルの宣言
• .IMPORT : 外部参照シンボルの宣言
■ .EXPORT
図 6.4-11 .EXPORT のリスト形式
SN LOC
:
:
OBJ
:
LLINE
:
SOURCE
:
16
.EXPORT exp1,exp2
■ .GLOBAL
図 6.4-12 .GLOBAL のリスト形式
SN LOC
:
:
OBJ
:
LLINE
:
SOURCE
:
16
.GLOBAL exp1,exp2
■ .IMPORT
図 6.4-13 .IMPORT のリスト形式
SN LOC
:
:
OBJ
LLINE
:
:
16
September 1, 2014, CM81-00208-5
SOURCE
:
.IMPORT imp1,imp2
87
Su pp or t
6.4.7
So ft
Manu al
.EQU
シンボル定義命令のリスト形式です。
• .EQU: シンボルへの値の割り付け
■ .EQU
図 6.4-14 .EQU のリスト形式
SN LOC
:
:
OBJ
LLINE
:
=00000100
:
16
SOURCE
:
sym01:
.EQU
0x100
シンボル値として設定された値(16進数)
88
CM81-00208-5, September 1, 2014
Support
6.4.8
Soft
Ma nual
.DATA, .BIT, .BYTE, .HALF, .LONG, .WORD, .DATAB
領域定義命令 ( 整数 ) のリスト形式です。
• .DATA
: 定数定義 ( 整数 )
• .BIT
: 定数定義 (1 ビット整数 )
• .BYTE
: 定数定義 (8 ビット整数 )
• .HALF
: 定数定義 (16 ビット整数 )
• .LONG
: 定数定義 (32 ビット整数 )
• .WORD : 定数定義 (16 ビット・32 ビット整数 )
• .DATAB : 定数ブロック定義 ( 整数 )
■ .DATA
図 6.4-15 .DATA のリスト形式
SN LOC
:
:
OBJ
LLINE
:
:
SOURCE
:
SE 0000 10
10
.DATA.B 0x10
SE 0001 20 10
11
.DATA.B 0x20,16
SE 0003 00R 00S
12
.DATA.B REL01,SEC1
SE 0005 0010
13
.DATA.H 0x10
SE 0007 0020 0010
14
.DATA.H 0x20,16
SE 000B 0000R 0000S
15
.DATA.H REL01,SEC1
SE 000F 00000010
16
.DATA.L 0x10
SE 0013 00000020 00000010
17
.DATA.L 0x20,16
SE 001B 00000000R 00000000S
18
.DATA.L REL01,SEC1
ロケーション
データの値
複数のデータがある場合
できるだけ多くのデータ値を
横にならべ表示します。
(16進数)
データ値直後の記号
I:外部参照値
S:セクション値
R:相対値
空:絶対値
■ .BIT
.DATA.I と同じリスト形式です。
■ .BYTE
.DATA.B と同じリスト形式です。
■ .HALF
.DATA.H と同じリスト形式です。
September 1, 2014, CM81-00208-5
89
Su pp or t
So ft
Manu al
■ .LONG
.DATA.L と同じリスト形式です。
■ .WORD
.DATA.W と同じリスト形式です。
F2MC-8L/8FX ファミリの場合は , .DATA.H と同じリスト形式です。
■ .DATAB
図 6.4-16 .DATAB のリスト形式
SN LOC
:
:
OBJ
LLINE
:
:
:
SE 0023 [2] 10
10
.DATAB.B 2,0x10
SE 0025 [16] 0020
11
.DATAB.H 16,0x20
SE 0045 [2] 00000010
12
.DATAB.L 2,0x10
SE 004D [2] 00000000
R
13
.DATAB.L 2,REL01
SE 0055 [2] 00
S
14
.DATAB.B 2,SEC1
ロケーション
データ値
(16進数)
折り返し数
(10進数)
90
SOURCE
データ値に含まれる属性
I :外部参照値
S :セクション値
R :相対値
空:絶対値
CM81-00208-5, September 1, 2014
Support
6.4.9
Soft
Ma nual
.FDATA, .FLOAT, .DOUBLE, .FDATAB
領域定義命令 ( 浮動小数点データ ) のリスト形式です。
• .FDATA : 定数定義 ( 浮動小数点数 )
• .FLOAT : 定数定義 (32 ビット浮動小数点数 )
• .DOUBLE : 定数定義 (64 ビット浮動小数点数 )
• .FDATAB : 定数ブロック定義 ( 浮動小数点数 )
■ .FDATA
図 6.4-17 .FDATA のリスト形式
SN LOC
OBJ
:
:
LLINE
:
SOURCE
:
:
SE 0057 3F80000040133333
16
.FDATA.S 0r1.0,0r2.3
SE 005F 3FF0000000000000
17
.FDATA.D 0r1.0
SE 0067 11112222
18
.FDATA.S 0x11112222
SE 006B 1111222233334444
19
.FDATA.D 0x1111222233334444
ロケーション
データの値
複数のデータがある場合できるだけ多くのデータ値を
横にならべ表示します。(16進数)
■ .FLOAT
.FDATA.S と同じリスト形式です。
■ .DOUBLE
.FDATA.D と同じリスト形式です。
■ .FDATAB
図 6.4-18 .FDATAB のリスト形式
SN LOC
:
:
OBJ
LLINE
:
:
SOURCE
:
SE 0073 [2] 3F800000
16
.FDATAB.S2,0r1.0
SE 007B [2] 3FF0000000000000
17
.FDATAB.D2,0r1.0
ロケーション
データ値(16進数)
折り返し数(10進数)
September 1, 2014, CM81-00208-5
91
Su pp or t
6.4.10
So ft
Manu al
.RES, .FRES
領域定義命令 ( データ値なし ) のリスト形式です。
• .RES : 領域定義命令 ( データ値なし : 整数 )
• .FRES : 領域定義命令 ( データ値なし : 浮動小数点数 )
■ .RES
図 6.4-19 .RES のリスト形式
SN LOC
:
:
OBJ
LLINE
:
SOURCE
:
:
CO 0000 [2]B
16
.RES.B
2
CO 002
[5]H
17
.RES.H
5
CO 000C [3]L
18
.RES.L
3+1-1
ロケーション
折り返し数
(10進数)
データサイズ
B:1バイト長
H:2バイト長
L:4バイト長
W:2バイト長
■ .FRES
図 6.4-20 .FRES のリスト形式
SN LOC
:
:
OBJ
:
:
SOURCE
:
CO 0018 [2]S
16
.FRES.S 2
CO 0020 [2]D
17
.FRES.D 2
ロケーション
折り返し数
(10進数)
92
LLINE
データサイズ
S:単精度浮動小数点数データ(領域長:4バイト長)
D:倍精度浮動小数点数データ(領域長:8バイト長)
CM81-00208-5, September 1, 2014
Support
6.4.11
Soft
Ma nual
.SDATA, .ASCII, .SDATAB
領域定義命令 ( 文字列 ) のリスト形式です。
• .SDATA : 文字列定義
• .ASCII
: 文字列定義
• .SDATAB : 文字列ブロック定義
■ .SDATA
図 6.4-21 .SDATA のリスト形式
SN LOC
OBJ
:
:
LLINE
:
SOURCE
:
:
DA 0000 61 62 63 64 65 66 67 68 69 6A
16
.SDATA
"abcdefghijklmnopqrstuv\
6B 6C 6D 6E 6F 70 71 72 73 74
17
wxyz0123456789" /*継続行*/
18
.SDATA "123\xff123","12345\t\n"
DA 0032 31 32 33 09 31 32 33
19
.SDATA
"123\t123","\"",\
DA 0039 22
20
"1234567890"
21
.SDATA "" /* 空文字列*/
75 76 77 78 79 7A 30 31 32 33
34 35 36 37 38 39
DA 0024 31 32 33 FF 31 32 33
DA 002B 31 32 33 34 35 09 0A
DA 003A 31 32 33 34 35 36 37 38 39 30
DA 0044
ロケーション
データ値
1バイトずつ表示します。(16進数)
■ .ASCII
.SDATA と同じリスト形式です。
■ .SDATAB
図 6.4-22 .SDATAB のリスト形式
SN LOC
:
OBJ
:
LLINE
:
:
DA 0044 [2]
DA 0044 [5]
31 32 33 34 35 36 37 38
SOURCE
:
16
.SDATAB 2,"" /* 空文字列*/
17
.SDATAB 5,"12345678901234567890"
39 30 31 32 33 34 35 36 37 38
39 30
ロケーション
データ値
1バイトずつ表示します。(16進数)
September 1, 2014, CM81-00208-5
93
Su pp or t
6.4.12
So ft
Manu al
.DEBUG
デバッグ情報出力制御命令のリスト形式です。
• .DEBUG: デバッグ情報出力の部分指定
■ .DEBUG
図 6.4-23 .DEBUG のリスト形式
SN LOC
:
:
======
:
:
DEBUG INFORMATION Already ON
:
:
94
31
:
DEBUG INFORMATION off -> ON
起動時オプションで,
デバッグ情報出力(-g)
の指定ができない場合は,
"Ignore"と表示されます。
28
:
DEBUG INFORMATION on -> OFF
:
======
LLINE
:
:
======
:
OBJ
40
SOURCE
:
.DEBUG ON
:
.DEBUG OFF
:
.DEBUG ON
ON/OFF状態表示
off -> ON
:本行以降からデバッグ情報出力を開始します。
on -> OFF :本行以降からデバッグ情報出力を抑止します。
Already ON :既にデバッグ情報出力を開始済です。
Already OFF :既にデバッグ情報出力を抑止済です。
CM81-00208-5, September 1, 2014
Support
6.4.13
Soft
Ma nual
.LIBRARY
ライブラリファイル指定命令は特にリストは変化しません。
• .LIBRARY: ライブラリファイルの指定
■ .LIBRARY
図 6.4-24 .LIBRARY のリスト形式
SN LOC
:
:
OBJ
:
LLINE
:
16
September 1, 2014, CM81-00208-5
SOURCE
:
.LIBRARY "sample.lib"
95
Su pp or t
6.4.14
So ft
Manu al
.FORM, .TITLE, .HEADING, .LIST, .PAGE, .SPACE
リスト出力制御命令のリスト形式です。
• .FORM
:1 ページの行数・桁数指定
• .TITLE
: タイトル指定
• .HEADING: タイトルの変更
• .LIST
: アセンブルソースリスト出力の詳細指定
• .PAGE
: 改ページ指定
• .SPACE : 空白行の出力
■ .FORM
図 6.4-25 .FORM のリスト形式
SN LOC
:
:
OBJ
LLINE
:
:
16
SOURCE
:
.FORM LIN=70,COL=80
本行よりリストファイル形式が
70行×80桁として出力されます。
70行
80桁
■ .TITLE
図 6.4-26 .TITLE のリスト形式
SN LOC
:
:
OBJ
LLINE
:
:
16
SOURCE
:
.TITLE "SAMPLE PROGRAM"
先頭ページから
_____________________________________________________________________________
F2MC-8L/8FX Family SOFTUNE Assembler V30L08 2003-06-26 15:44:08 Page: 2
SAMPLE PROGRAM
.TITLEで指定した文字列
SN LOC
:
96
:
OBJ
:
LLINE
:
SOURCE
:
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
■ .HEADING
図 6.4-27 .HEADING のリスト形式
_____________________________________________________________________________
F2MC-8L/8FX Family SOFTUNE Assembler V30L08 2003-06-26 15:44:08
SAMPLE PROGRAM
SN LOC
:
:
OBJ
LLINE
:
:
Page: 2
SOURCE
:
.HEADINGの行で改ページします。次のページからタイトルが変わります。
_____________________________________________________________________________
F2MC-8L/8FX Family SOFTUNE Assembler V30L08 2003-06-26 15:44:08
PROG-1
SN LOC
OBJ
LLINE
Page: 3
SOURCE
.HEADING "PROG-1"
■ .LIST
図 6.4-28 .LIST のリスト形式
SN LOC
:
:
OBJ
LLINE
:
:
SOURCE
:
6
.LIST OFFの行から.LIST ONの
直前の行までは表示されません。
(行番号は進む)
7
; 次の行(8行目)に.LIST OFF
10
.LIST
ON
11
■ .PAGE
図 6.4-29 .PAGE のリスト形式
SN LOC
:
:
OBJ
:
LLINE
:
SOURCE
:
6
7
; 次の行(8行目)に.PAGE
.PAGEの行で改ページします(ただし,ページ先頭が.PAGEの場合は改ページしません)。
September 1, 2014, CM81-00208-5
97
Su pp or t
So ft
Manu al
■ .SPACE
図 6.4-30 .SPACE のリスト形式
SN LOC
:
:
OBJ
:
LLINE
:
5
SOURCE
:
; 次の行(6行目)に.SPACE 2
指定された行数の空白を生成します。
7
98
CM81-00208-5, September 1, 2014
Support
6.5
Soft
Ma nual
セクションリスト
ソースプログラム内で定義されたセクションの名前 , 属性などが出力されます。
■ セクションリスト
図 6.5-1 セクションリスト
___________________________________________________________________________
F2MC-8L/8FX Family SOFTUNE Assembler V30L08 2003-06-26 15:44:08
Page: 10
- SECTION LISTING - ( sample )
モジュール名
NOSECTION-NAME
SIZE ATTRIBUTES
0 SEC1 . . . . . . . . . . . . . . . . . . . . . . . . . 0008 CODE
REL ALIGN=1
1 SEC02 . . . . . . . . . . . . . . . . . . . . . . . . 0008 CODE
REL ALIGN=1
2 ON . . . . . . . . . . . . . . . . . . . . . . . . . . . 0004 CODE
REL ALIGN=1
3 SEC05 . . . . . . . . . . . . . . . . . . . . . . . . 0008 CODE
REL ALIGN=1
4 SEC06 . . . . . . . . . . . . . . . . . . . . . . . . 0008 DATA
REL ALIGN=1
5 SEC07 . . . . . . . . . . . . . . . . . . . . . . . . 0008 CONST
REL ALIGN=1
6 SEC08 . . . . . . . . . . . . . . . . . . . . . . . . 00008 COMMON REL ALIGN=1
7 SEC09 . . . . . . . . . . . . . . . . . . . . . . . . 0008 STACK
REL ALIGN=1
SEC10 . . . . . . . . . . . . . . . . . . . . . . . . 0008 DUMMY
8 SEC11 . . . . . . . . . . . . . . . . . . . . . . . . 0008 CODE
ABS LOCATE=0100
9 SEC12 . . . . . . . . . . . . . . . . . . . . . . . . 0008 CODE
REL ALIGN=1
10 SEC13 . . . . . . . . . . . . . . . . . . . . . . . . 0008 CODE
REL ALIGN=1
11 SEC14 . . . . . . . . . . . . . . . . . . . . . . . . 0008 DATA
ABS LOCATE=0000
12 SEC15 . . . . . . . . . . . . . . . . . . . . . . . . 0008 CONST
REL ALIGN=1
13 SEC16 . . . . . . . . . . . . . . . . . . . . . . . . 0008 COMMON ABS LOCAE=0010
14 SEC17 . . . . . . . . . . . . . . . . . . . . . . . . 0008 STACK
セクション名(出現順)
セクションサイズ
(16進数)
セクション出現番号
0から始まります。
ダミーセクションは番号はありません。
オブジェクトファイル中での
セクション番号に相当します。
September 1, 2014, CM81-00208-5
REL ALIGN=1
セクションタイプ
セクション配置形式
相対セクションならALIGN値を
表示します。
絶対セクションならLOCATE値を
表示します。
ダミーセクションは空白を表示
します。
99
Su pp or t
6.6
So ft
Manu al
クロスリファレンスリスト
ソースプログラム内で使用されているシンボル名の定義 , および参照されている行
番号を出力します。
■ クロスリファレンスリスト
図 6.6-1 クロスリファレンスリスト
__________________________________________________________________________
F2MC-8L/8FX Family SOFTUNE Assembler V30L08 2003-06-26 15:44:08
- CROSSEWFERENCE LISTING - ( sample )
NAME
ATTRIB.
CODE . . . . . . . . . . . . . . . . . . . . .
SECT/ABS
1000 6 #
DATA . . . . . . . . . . . . . . . . . . . . . .
SECT/REL
0000 2 #
DUMMY . . . . . . . . . . . . . . . . . . . .
SECT/DUM
SYM_ABS . . . . . . . . . . . . . . . . . .
ABS
00001000 7 #
SYM_ABS/EXP . . . . . . . . . . . . . .
ABS/EXP
00001000 9 #
SYM_IMP . . . . . . . . . . . . . . . . . .
IMP
SYM_REL . . . . . . . . . . . . . . . . . .
REL
00000000 3 #
SYM_REL/EXP . . . . . . . . . . . . . .
REL/EXP
00000000 5 #
SYM_UNDEFINED . . . . . . . . . . .
UNDEFINED
シンボル値
(16進数)
シンボル名(セクション名も含む)
大文字,小文字,アルファベット
順に表示します。
シンボル種別
ABS
REL
ABS/EXP
REL/EXP
IMP
SECT/ABS
SECT/REL
SECT/DUM
UNDEFINED
STRU/TAG
STRU/MEM
STRU/ABS
STRU/REL
100
Page: 11
VALUE DEFINITION/REFERENCES
11 #
8
1
4
10
参照行番号(リスト行番号)
定義行番号(リスト行番号)
絶対シンボル
相対シンボル
絶対シンボル(外部定義指定)
相対シンボル(外部定義指定)
外部参照シンボル
絶対セクション
相対セクション
ダミーセクション
未定義シンボル
構造体タグ名
構造体要素名
絶対シンボル(構造体変数)
相対シンボル(構造体変数)
CM81-00208-5, September 1, 2014
Support
第 II 部
Soft
Ma nual
文法編
この部では , アセンブラのソースプログラムを記述する際の文法や記述形式につい
て説明します。
第 7 章 言語の基本規則
第 8 章 セクション
第 9 章 機械命令
第 10 章 アセンブラ擬似命令
第 11 章 プリプロセッサ処理
第 12 章 アセンブラ擬似機械命令
第 13 章 構造化命令
September 1, 2014, CM81-00208-5
101
Su pp or t
102
So ft
Manu al
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
第7章
言語の基本規則
この章では , アセンブリ言語を使用してプログラム
を作成する場合の書き方およびその規則について
説明します。
7.1 文の形式
7.2 文字セット
7.3 名前
7.4 前方参照シンボルと後方参照シンボル
7.5 整数定数
7.6 ロケーションカウンタシンボル
7.7 文字定数
7.8 文字列
7.9 浮動小数点定数
7.10 浮動小数点定数のデータ形式
7.11 式
7.12 コメント
September 1, 2014, CM81-00208-5
103
Su pp or t
7.1
So ft
Manu al
文の形式
アセンブラの 1 行は , 次の 5 つのフィールドから構成されます。
• シンボルフィールド
• オペレーションフィールド
• オペランドフィールド
• コメントフィールド
• 継続指示フィールド
1 行には最大 4095 文字まで記述できます。
■ 文の形式
アセンブラの文の形式は , 次のとおりです。
シンボル
フィールド
オペレーション
フィールド
オペランド
フィールド
コメント
フィールド
継続指示
フィールド
各フィールドは省略可能です。
シンボルフィールド , オペレーションフィールド , オペランドフィールドの区切りには ,
1 つ以上の空白またはタブが必要です。
1 行には , 最大 4095 文字まで記述できます。
■ シンボルフィールド
シンボルを記述します。
シンボルは , 先頭カラムから始めるか , または , 任意のカラムから始め最後にコロン (:)
を付けます。
【例】
SYMBOL
SYMBOL:
SYMBOL:
■ オペレーションフィールド
機械命令や擬似命令などのオペレーションニーモニックを記述します。
このフィールドは , 2 カラム目以降に記述します。
シンボルフィールドとの区切りには , 1 つ以上の空白またはタブが必要です。
【例】
.SECTION CODE
NOP
.DATA 100
104
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
■ オペランドフィールド
機械命令や擬似命令などのオペランドを記述します。
オペランドが複数ある場合には , カンマ (, ) で区切って記述します。
オペレーションフィールドとの区切りには , 1 つ以上の空白またはタブが必要です。
【例】
.SECTION
.DATA
.SECTION
MOV
DATA, DATA, ALIGN=4
1, 2, 4
CODE, CODE, ALIGN=2
A, R1
■ コメントフィールド
注釈を記述します。
このフィールドは , 任意のカラムから始めることができます。
セミコロン (;) または 2 個のスラッシュ (//) でコメントが始まり , 行終端までコメント
となります。このコメントを行コメントといいます。
C 言語風に , /* ~ */ で囲ってコメントを記述することもできます。これを範囲コメン
トといいます。範囲コメントは好きな位置にコメントを書くことができます。
【例】
/*---------コメント
------------*/
PUSHW
MOVW
IX
; コメント
A, /* コメント */ SP
// コメント
■ 継続指示フィールド
行の最後にバックスラッシュ (\) を置くことによって次の行に継続できます。
バックスラッシュ (\) の次の文字に改行以外の文字がある場合は , 継続しません。
行の継続は , コメント , 文字定数 , 文字列の途中にも指定できます。
【例】
.DATA
0x01, 0x02, 0x03,
\
0x04, 0x05, 0x06,
; コメント \
0x07, 0x08, 0x09
.SDATA "abcdefghijklmnopqrstuvwxyz\
ABCDEFGHIJKLMNOPQRSTUVWXYZ"
/* 文字列の継続 */
September 1, 2014, CM81-00208-5
105
Su pp or t
7.2
So ft
Manu al
文字セット
アセンブリ言語でプログラムを書く場合に使用できる文字を示します。
• 英字 : 大文字 (A ~ Z), 小文字 (a ~ z)
• 数字 : 0 ~ 9
• 記号 : +-*/% < >| &~=()!^$@#_'":.\; 空白 タブ
■ 文字セット
本アセンブラで使用できる文字セットを表 7.2-1 に示します。
表 7.2-1 文字セット
種別
文字
英字 ( 大文字 )
ABCDEFGHIJKLMNOPQRSTUVWXYZ
英字 ( 小文字 )
abcdefghijklmnopqrstuvwxyz
数字
0123456789
記号
+-*/% < >| &~=()!^
$ @ # _ ' " : . \ ; 空白 タブ
<注意事項>
• バックスラッシュ (\) は端末によっては , 円記号 (¥) で表示される場合があります。
• コメントまたは文字列には, 文字セット以外の記号や日本語コード(SJISコードかEUC
コードのみ ) が記述できます。
106
CM81-00208-5, September 1, 2014
Support
7.3
Soft
Ma nual
名前
名前は , アセンブラにおいて種々のものを識別および参照するために使われます。
名前には , モジュール名 , シンボル , セクション名 , 構造体タグ名 , マクロ名などが
あります。
予約語には , 次のものがあります。
• レジスタ名
: R0 ~ R7, A, T, IX, EP, SP, PC, PS
• サイズ演算子 :SIZEOF, BITADR, BITPOS
■ 名前の規則
• 255 文字以内です。
• 先頭文字は , 英字 , アンダスコア (_) です。
• 2 文字目以降は , 英字 , 数字 , アンダスコア (_) で構成されます。
• 大文字 , 小文字は区別されます。
■ 名前の分類
名前は使用される目的により次のように分類されます。
● モジュール名
.PROGRAM 命令で定義されます。オブジェクトを識別するための名前です。
● シンボル
ある値を割り当てられた名前です。
普通は , シンボルフィールドで定義されます。
分岐先のラベルとして使用したり , データのアドレスに使用したりします。
また , .EQU 命令などで値を割り当てたりします。
● セクション名
.SECTION 命令で定義されます。
セクションを識別するための名前です。
セクション名は , シンボルに割り当てられます。
式の項にセクション名を使用する場合は , リンク後のセクションの先頭アドレスを示
します。
● 構造体タグ名
.STRUCT 命令で定義されます。
構造体を識別する名前です。
● マクロ名
プリプロセッサで使用します。
プリプロセッサについては「第 11 章 プリプロセッサ処理」を参照してください。
September 1, 2014, CM81-00208-5
107
Su pp or t
So ft
Manu al
■ 予約語
予約語は , あらかじめアセンブラに予約されている名前で , ユーザは定義できない名前
です。
予約語の英字は , 大文字 , 小文字とも同じと解釈され区別しません。
予約語には , 次のものがあります。
● レジスタ名 :
R0 ~ R7, A, T, IX, EP, SP, PC, PS
● 演算子
SIZEOF, BITADR, BITPOS
● その他
以下の語は , リンカの予約名となっています。
アセンブラでは , 使用に際してエラーの検出は行いませんが , 使用できません。
• _ROM_ または _RAM_ で始まるセクション名およびシンボル名
108
CM81-00208-5, September 1, 2014
Support
7.4
Soft
Ma nual
前方参照シンボルと後方参照シンボル
アセンブラプログラムにおいて , 機械命令や擬似命令のオペランドに使用するシン
ボルは , 前方参照シンボルか後方参照シンボルかのどちらかの扱いを受けます。
使用したシンボルが , 未定義の場合は , 前方参照シンボル扱いとなります。
使用したシンボルが , 定義済の場合は , 後方参照シンボル扱いとなります。
■ 前方参照シンボルと後方参照シンボル
アセンブラプログラムにおいて , 機械命令や擬似命令のオペランドに使用するシンボ
ルは , 前方参照シンボルか後方参照シンボルかのどちらかの扱いを受けます。
使用したシンボルが , まだ未定義の場合は , 前方参照シンボル扱いとなります。
使用したシンボルが , すでに定義済の場合は , 後方参照シンボル扱いとなります。
【例】
BEQ
aaa
/* BEQ 命令にとって aaa は前方参照シンボル */
BLT
aaa
/* BLT 命令にとって aaa は後方参照シンボル */
aaa:
前方参照シンボルの扱いとなったシンボルは , アセンブラ処理において次のような制
約を受けます。
• 式中に書かれた前方参照シンボルは , その値が絶対値の場合でも式の種類は , 相対
式と同じ扱いになります。したがって , 絶対値のみしか記述できないオペランドに
は記述できません。
■ サイズ演算子について
通常のサイズ演算子は , リンカで算出されるので相対値扱いになりますが , ダミーセク
ションのサイズを算出する場合のみは , アセンブラで算出を行います。
この場合 , 処理の都合上 , サイズ演算子は前方参照シンボル扱いで処理を行います。
サイズ演算子については , 「7.11.4 名前から算出される値」を参照してください。
September 1, 2014, CM81-00208-5
109
Su pp or t
7.5
So ft
Manu al
整数定数
整数定数には , 2 進定数 , 8 進定数 , 10 進定数 , 16 進定数の 4 種類があります。
■ 整数定数
整数定数には , 2 進定数 , 8 進定数 , 10 進定数 , 16 進定数の 4 種類があります。
C 言語の long 型指定 (123L など ), unsigned 型指定 (123U など ) もサポートしています。
■ 2 進定数
2 進法で表された整数定数です。
プリフィックス (B' または 0b) を付けるか , サフィックス (B) を付けて記述します。
プリフィックス(B'または0b), サフィックス(B)は大文字でも小文字でもかまいません。
【例】
B'0101
0b0101
0101B
■ 8 進定数
8 進法で表された整数定数です。
プリフィックス (Q' または 0) を付けるか , サフィックス (Q) を付けて記述します。
プリフィックス (Q' または 0), サフィックス (Q) は大文字でも小文字でもかまいません。
【例】
Q'377
0377
377Q
■ 10 進定数
10 進法で表された整数定数です。
プリフィックス (D') を付けるか , サフィックス (D) を付けて記述します。
プリフィックス , サフィックスは 10 進定数のみ省略可能です。
プリフィックス (D'), サフィックス (D) は大文字でも小文字でもかまいません。
【例】
D'1234567
1234567
1234567D
■ 16 進定数
16 進法で表された整数定数です。
プリフィックス (H' または 0x) を付けるか , サフィックス (H) を付けて記述します。
プリフィックス(H'または0x), サフィックス(H)は大文字でも小文字でもかまいません。
【例】
H'ff
110
0xFF
0FFH
CM81-00208-5, September 1, 2014
Support
7.6
Soft
Ma nual
ロケーションカウンタシンボル
現在のロケーションカウンタを表すシンボルです。
ロケーションカウンタシンボルは , '$' です。
■ ロケーションカウンタシンボル
アセンブラは , アセンブル時のアドレス付けを , ロケーションカウンタを用いて行いま
す。
この現在のロケーションの値をロケーションカウンタシンボルで参照できます。
ロケーションカウンタシンボルは , '$' で表現します。
ロケーションカウンタの値は , 絶対セクションの場合は絶対値 , 相対セクションの場合
は相対値となります。
【例】
BNE
September 1, 2014, CM81-00208-5
$+4
111
Su pp or t
7.7
So ft
Manu al
文字定数
文字定数は文字の値を示します。
文字定数は文字定数要素をシングルクォート (') で囲って記述します。
文字定数要素は , 4 文字まで指定可能です。
■ 文字定数
文字定数は文字定数要素をシングルクォート (') で囲って記述します。
文字定数要素には , 文字 , 拡張表記 , 8 進表記 , 16 進表記があります。
文字定数要素は , 4 文字まで指定可能です。
文字定数は , 256 進法の扱いとなります。
● 文字
バックスラッシュ (\), シングルクォート (') を除くすべての文字と空白文字は単独で文
字定数要素となります。
【例】
'P'
'@A'
'0A”'
● 拡張表記
バックスラッシュ (\) の後に特定の文字を続けて文字定数要素とします。
これを拡張表記とよびます。
拡張表記を表 7.7-1 に示します。
表 7.7-1 拡張表記
文字
文字定数要素
値
\n
\t
\b
\r
\f
\\
\'
\”
\a
\v
\?
0x0A
0x09
0x08
0x0D
0x0C
0x5C
0x27
0x22
0x07
0x0B
0x3F
改行文字
水平タブ文字
後退文字
復帰文字
改ページ文字
バックスラッシュ
シングルクォート
ダブルクォート
警報文字
垂直タブ文字
疑問符
( 注意事項 ) 拡張表記として用いられる文字は , 小文字のみです。
【例】
'\n'
112
'\''
'\”\\'
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
● 8 進表記
文字コードのビットパターンを直接表記して 1 バイトデータを表現します。
8 進表記は , バックスラッシュ (\) の後に 1 から 3 文字の 8 進数字を続けたものです。
【例】 文字定数要素
ビットパターン
'\0'
b'00000000
'\377'
b'11111111
'\53'
b'00101011
'\0123'
b'00001010 → '\012' と '3' に分かれます
● 16 進表記
文字コードのビットパターンを直接表記して 1 バイトデータを表現します。
16 進表記は , バックスラッシュ (\) の後に文字 x ( 小文字 ) と 1 文字か 2 文字の 16 進文
字を続けたものです。
【例】 文字定数要素
ビットパターン
'\x0'
b'00000000
'\xff'
b'11111111
'\x2B'
b'00101011
'\x0A5'
b'00001010 → '\x0A' と '5' に分かれます
September 1, 2014, CM81-00208-5
113
Su pp or t
7.8
So ft
Manu al
文字列
文字列は文字列要素の列をダブルクォート (") で囲って記述します。
■ 文字列
文字列は文字列要素の列をダブルクォート (") で囲って記述します。
文字列要素には , 文字定数要素と同じ形式を使用できます。詳しくは ,「7.7 文字定数」
を参照してください。
文字列要素にダブルクォート (") を記述する場合は , 拡張表記 (\") を使用します。
シングルクォート (') は拡張表記を使用せずにそのまま記述できます。
【例】
"ABCD\n"
"012345\n\0"
"\xff\t\n\0377\0"
<注意事項>
文字列に日本語を記述した場合は , 記述したコード系 (SJIS または EUC) で , そのままオ
ブジェクトへ出力されます。アセンブラ内でコード系の変換は行いません。
114
CM81-00208-5, September 1, 2014
Support
7.9
Soft
Ma nual
浮動小数点定数
浮動小数点定数の表記には , 次の形式があります。
• [0r][+|-]{.d|d[.[d]]} [e[[+|-]d]] d は 10 進数
• [F'][+|-]{.d|d[.[d]]} [e[[+|-]d]]
d は 10 進数
• 0xh
h は 16 進数
• H'h
h は 16 進数
■ 浮動小数点定数の表記
【記述形式 1】
[0r][+|-]{.d|d[.[d]]} [e[[+|-]d]]
[F'][+|-]{.d|d[.[d]]} [e[[+|-]d]]
d は 10 進数
【説明】
浮動小数点定数を値で指定します。
"e" は指数部を指定することを表し , "e" に続く値は指数部となります。
"e" は大文字でもかまいません。
プリフィックス (0r または F') は省略できます。
【例】
0r954
0r-12e+0
415.
F'.5
F'2.0e2
-2.5E-4
【記述形式 2】
0xh
H'h
h は 16 進数
【説明】
浮動小数点定数をビットパターンで直接指定します。
データ長分のビットパターンを 16 進数で指定します。
【例 1】倍精度でマイナス無限大を表す場合
0xFFF0000000000000
【例 2】単精度でマイナス無限大を表す場合
0xFF800000
September 1, 2014, CM81-00208-5
115
Su pp or t
So ft
Manu al
■ 単精度と倍精度の指定
浮動小数点定数が単精度 (32 ビット ) になるか倍精度 (64 ビット ) になるかは , 擬似命
令またはサイズ指定によって決まります。
● 単精度 (32 ビット ) になる場合
1. 浮動小数点定数の擬似命令でサイズ指定が省略されている場合
2. "S" のサイズ指定がある場合
3. .FLOAT 命令の場合
● 倍精度 (64 ビット ) になる場合
1. "D" のサイズ指定がある場合
2. .DOUBLE 命令の場合
【例】
116
.FDATA.S 1.2
/* S のサイズ指定があるので単精度指定 */
.FDATA.D 1.2
/* D のサイズ指定があるので倍精度指定 */
.FDATA 1.2
/* サイズ指定が省略されているので単精度指定 */
.FLOAT 0.1
/* .FLOAT 命令なので単精度指定 */
.DOUBLE 0.1
/* .DOUBLE 命令なので倍精度指定 */
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
7.10 浮動小数点定数のデータ形式
浮動小数点定数のデータ形式は , ANSI/IEEE Std754-1985 の仕様に準拠しています。
浮動小数点定数のデータ形式は次の 2 つがあります。
• 単精度浮動小数点定数のデータ形式
• 倍精度浮動小数点定数のデータ形式
また , 浮動小数点定数で表現可能な範囲を示します。
■ 単精度浮動小数点定数のデータ形式
単精度浮動小数点定数のデータ形式は , 符号 1 ビット , 指数部 8 ビット , 仮数部 23 ビッ
トで構成されています。
31 30
23 22
指数部
0
仮数部
符号部
■ 倍精度浮動小数点定数のデータ形式
倍精度浮動小数点定数のデータ形式は , 符号 1 ビット , 指数部 11 ビット , 仮数部 52 ビッ
トで構成されています。
63 62
52 51
指数部
0
仮数部
符号部
September 1, 2014, CM81-00208-5
117
Su pp or t
So ft
Manu al
■ 浮動小数点定数の表現可能な範囲
表 7.10-1 に浮動小数点定数の表現可能な範囲を示します。
表 7.10-1 浮動小数点定数の表現可能な範囲
精度
118
表現可能範囲
単精度
-3.40282356779733661637e+38
~ -1.17549431578982589985e-38
-0
0
1.17549431578982589985e-38
~ 3.40282356779733661637e+38
倍精度
-1.79769313486231580793e+308
~ -2.22507385850720125958e-308
-0
0
2.22507385850720125958e-308
~ 1.79769313486231580793e+308
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
7.11 式
式は , アドレスやデータ値などを表すところに記述できます。
式には , C 言語風の演算子が用意されています。
■ 式の構文
以下に , 式の構文を BNF 表記で示します。
【文法】
< 式 >::= < 式 >'||' < 式 >
論理 OR 式
::= < 式 >' & &' < 式 >
論理 AND 式
::= < 式 >'|' < 式 >
ビット OR 式
::= < 式 >'^' < 式 >
ビット XOR 式
::= < 式 >' &' < 式 >
ビット AND 式
::= < 式 >{'=='|'!='} < 式 >
等価式
::= < 式 >{' <'|' <='|' >'|' >='} < 式 >
関係式
::= < 式 >{' < <'|' > >'} < 式 >
シフト式
::= < 式 >{'+'|'-'} < 式 >
加法式
::= < 式 >{'*'|'/'|'%'} < 式 >
乗法式
::={'!'|'~'|'+'|'-'|'SIZEOF'} < 式 >
単項式
::='(' < 式 >')'
括弧式
::= < 項 >
< 項 >::={ 数値定数 | 文字定数 | シンボル | ロケーションカウンタ }
<注意事項>
式は整数式のことであり , 浮動小数点定数の式はサポートしていません。
September 1, 2014, CM81-00208-5
119
Su pp or t
So ft
Manu al
■ 式の種類
式はアセンブル時に計算されますが , 相対シンボル , 外部参照シンボル , セクションシ
ンボルは項として残りリンカで処理されます。したがって , 相対シンボル , 外部参照シ
ンボル , セクションシンボルを含む式については , リロケーション情報が生成され式処
理をリンカへ渡します。
式は次のように分類されます。
● 絶対式
• 数値定数 , 文字定数 , 絶対値を持つシンボルのみで構成される式
• 前方参照シンボルを含まない式
• サイズ演算子を含まない式
● 単純相対式
• 相対値を 1 つしか含まない式
• 前方参照シンボルを含まない式
• サイズ演算子を含まない式
● 複合相対式
• 2 つ以上の相対値を含む式
• 外部参照値を含む式
• セクション値を含む式
• 前方参照シンボルを含む式
• サイズ演算子を含む式
単に相対式という場合は , 通常 , 複合相対式を指します。
■ 式の演算精度について
式の演算は , 32 ビットで行っております。したがって , 32 ビットを超える演算は保証
しておりません。注意してください ( エラーにはなりません )。
120
CM81-00208-5, September 1, 2014
Support
7.11.1
Soft
Ma nual
項
項は , 絶対値 , 相対値 , 外部参照値 , セクション値のいずれかを表し , 式で使用でき
ます。
また , 項にはビットアドレス , アドレス規定子を付けることができます。
■ 項の種類
項は次の種類があります。
• 数値定数
• 文字定数
• シンボル ( 絶対 , 相対 , 外部参照 , セクション )
• ロケーションカウンタ ($)
これらの項は , さらに絶対値 , 相対値 , 外部参照値 , セクション値のいずれかの値を持
ちます。
また , これらの項には , ビットアドレス , アドレス規定子を付けることができます。
■ 絶対値
絶対値となる項を次に示します。
• 数値定数
• 文字定数
• .EQU 命令で定義したシンボル
• 絶対セクション内のアドレスを表すシンボル
• 絶対セクション内のロケーションカウンタ
• 絶対セクションのセクションシンボル
• ダミーセクションのサイズを算出するサイズ演算子
■ 相対値
相対値はリンカで解決されるためリロケーション情報を生成します。
相対値となる項を次に示します。
• 相対セクション内のアドレスを表すシンボル
• 相対セクション内のロケーションカウンタ
• ダミーセクション以外のセクションサイズを算出するサイズ演算子
■ 外部参照値
外部参照値はリンカで解決されるためリロケーション情報を生成します。
外部参照となる項を次に示します。
• 外部参照シンボル
September 1, 2014, CM81-00208-5
121
Su pp or t
So ft
Manu al
■ セクション値
セクション値はセクション先頭のアドレスを持ちます。
セクション値はリンカで解決されるためリロケーション情報を生成します。
セクション値は相対セクションのセクションシンボルのみです。
絶対セクションのセクションシンボルは絶対値になります。
■ ビットアドレス
ビットアドレスは , .BIT や .RES.I の命令で定義されるシンボルのほかに , 以下の特殊
な記述方法があります。
【記述形式 1】
: ビットアドレス
ビットアドレスは , メモリ領域にビット単位のロケーションを割り付けたもので
す。
【記述形式 2】
アドレス : ビットポジション
ビットポジションは , 8 以上の数値を指定できます。この場合 , 8 で割った値をアド
レスに加算し , その余りをビットポジションとします。
■ アドレス規定子
オペランドにアドレス規定子を記述できます。
【記述形式】
アドレス規定子 : アドレス
アドレス規定子:{D|E|X}
D:
ダイレクトアドレス指定
E:
エクステンドアドレス指定
X:
拡張ダイレクトアドレス指定
アドレス :
式
アドレス規定子によりオペランドに指定するアドレスが変わります。
- ダイレクトアドレス指定 : アドレスの下位 8 ビットを指定します。
- エクステンドアドレス指定 : 16 ビットアドレスを指定します。
- 拡張ダイレクトアドレス指定 : 式 "( アドレス & 0x007F) + 0x0080" の演算結果の
下位 8 ビットを指定します。この指定は F2MC-8FX ファミリでのみ意味を持ちま
す。
122
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
【制限事項 1】
機械命令オペランドが , ダイレクトアドレス指定 , エクステンドアドレス指定 , また
は拡張ダイレクトアドレス指定のいずれかを指定可能な場合 , オペランドに指定さ
れたシンボルが以下の条件の場合には , アドレス規定子の指定は無視され , 必ずエ
クステンドアドレス指定となります。
- 前方参照シンボルの場合 ( ただし , 外部参照シンボルは除きます )
- セクション外で外部参照宣言されたシンボルの場合
セクション外で外部参照宣言されたシンボルとは , ソースプログラムの先頭から ,
最初に .section 擬似命令が現れるまでの間に .import または .global 擬似命令で外部参
照宣言されたシンボルです。
【制限事項 2】
拡張ダイレクトアドレス指定は , F2MC-8FX ファミリでのみ意味を持つ機能ですが ,
F2MC-8L ファミリで指定してもアセンブラはエラーを検出しませんので , ご注意く
ださい。
【補足 1】
fasm896s はアドレッシングモードを以下のように自動選択します。
表 7.11-1 アドレッシングモードの自動選択
記述形式
即値
シンボル
条件
アドレッシングモード
0x0000 ~ 0x00FF
ダイレクトアドレッシング
0x0100 ~ 0xFFFF
エクステンドアドレッシング
DIR 属性セクションで定義・宣言
ダイレクトアドレッシング
DIR 属性セクション以外で定義・宣言
エクステンドアドレッシング
このため , F2MC-8FX ファミリ用アセンブラソースをアセンブルする際に , 拡張ダ
イレクトアクセス領域バンクが 0 以外の場合 , 0x0080 番地~ 0x00FF 番地を正しく
アクセスできません。このような場合 , アドレス規定子 "E" を用いてエクステンド
アドレッシングを指定してください ( 例 1, 例 2 を参照してください )。
【例 1】
SETDB
#1
/* ダイレクトバンクポインタ =1 */
MOV
A, 0x80
/* ダイレクトアドレスで
*/
/* 0x0100 番地をアクセスします */
MOV
A, E:0x80
/* エクステンドアドレス指定で
*/
/* 0x0080 番地をアクセスします */
September 1, 2014, CM81-00208-5
123
Su pp or t
So ft
Manu al
【例 2】シンボル SYM が DIR セクション属性かつ 0x80 番地の場合
SETDB
#1
/* ダイレクトバンクポインタ =1 */
MOV
A, SYM
/* ダイレクトアドレスで
*/
/* 0x0100 番地をアクセスします */
MOV
/* エクステンドアドレス指定で
A, E:SYM
*/
/* 0x0080 番地をアクセスします */
【補足 2】
拡張ダイレクトアドレスは , ダイレクトバンクポインタが指定されている場合のア
ドレス指定です。ダイレクトバンクポインタと拡張ダイレクトアドレスとマッピン
グ領域の関係は以下のとおりです。ダイレクトバンクポインタが 0 以外の領域に割
り付けられているシンボルを使って , 拡張ダイレクトアドレス指定でアクセスする
場合 , 例 3 のようにします。
表 7.11-2 ダイレクトバンクポインタと拡張ダイレクトアドレスとマッピング領域の
関係
ダイレクトバンク
ポインタ
拡張ダイレクトアドレス
マッピング領域
(16 ビットアドレス )
0
0x0080 ~ 0x00FF
1
0x0100 ~ 0x017F
2
0x0180 ~ 0x01FF
3
0x0080 ~ 0x00FF
0x0200 ~ 0x027F
4
0x0280 ~ 0x02FF
5
0x0300 ~ 0x037F
6
0x0380 ~ 0x03FF
7
0x0400 ~ 0x047F
【例 3】シンボル SYM が 0x0100 番地のとき
SETDB
#1
/* ダイレクトバンクポインタ =1
*/
MOV
A, D:SYM
/* ダイレクトアドレス指定で
*/
/* 0x0000 番地をアクセスします
*/
/* エクステンドアドレス指定で
*/
/* 0x0100 番地をアクセスします
*/
/* 拡張ダイレクトアドレス指定で
*/
MOV
MOV
A, E:SYM
A, X:SYM
/* 0x0100 番地をアクセスします
*/
/* ( コード上は 0x80 番地アクセス ) */
124
CM81-00208-5, September 1, 2014
Support
7.11.2
Soft
Ma nual
オペランド値の範囲
式が記述できるオペランドは , その種類によって記述可能な値の範囲が決まってい
ます。
アセンブラは , オペランドの演算結果が記述可能な値の範囲外であったとき ,
WARNING または ERROR を表示します。
出力されるメッセージが WARNING か ERROR かは , -OVFW, -XOVFW オプション
の指定によって変わります (「4.8.12 -OVFW, -XOVFW」参照 )。
ここでは , オペランド値の範囲について説明します。
■ オペランド値の範囲
オペランド値の範囲例を表 7.11-3 に示します。
オペランドの計算結果が , 表 7.11-3 の範囲外になるとアセンブラは WARNING または
ERROR を表示します。
各オペランドの詳細に関しては , ハードウェアマニュアルを参照してください。
表 7.11-3 オペランド値の範囲例
オペランドの種類
値の範囲
ダイレクトアドレス (dir)
0 ~ 255
オフセット (off)
-128 ~ 127
エクステンドアドレス (ext)
0 ~ 65535
ベクタテーブル番号 (#vct)
0~7
イミディエートデータ (#d8)
-128 ~ 255
イミディエートデータ (#d16)
-32768 ~ 65535
ビットダイレクトアドレス (dir: b)
di: 0 ~ 255/b: 0 ~ 7
分岐相対アドレス (rel)
-128 ~ 127
September 1, 2014, CM81-00208-5
125
Su pp or t
7.11.3
So ft
Manu al
演算子
演算子は , 式の中で使用されます。
論理値は値が 0 以外の場合は真 , 0 の場合は偽として扱います。
演算子には , 次のものがあります。
• 論理演算子
: || & & !
• ビット演算子 : | & ^ ~
• 関係演算子
: == != < <= > >=
• 算術演算子
: + - * / % > > < < +( 単項 ) -( 単項 )
• 名前から値を算出する演算子 : BITADR BITPOS SIZEOF
■ 論理値
論理値は値が 0 以外の場合は真 , 0 の場合は偽として扱います。
■ 論理演算子
論理演算子には , 次のものがあります。
• 式 || 式
: 論理値の OR 演算
• 式&&式
: 論理値の AND 演算
• !式
: 論理値の反転
■ ビット演算子
ビット演算子には , 次のものがあります。
• 式|式
: ビットの OR 演算
• 式&式
: ビットの AND 演算
• 式^式
: ビットの XOR 演算 ( 排他的論理和演算 )
• ~式
: ビットの反転
■ 関係演算子
関係演算子は , 評価が真であれば 1, 偽であれば 0 となります。
関係演算子には , 次のものがあります。
126
• 式 == 式
: 等しい
• 式 != 式
: 等しくない
• 式<式
: 小さい
• 式 <= 式
: 小さいか等しい
• 式>式
: 大きい
• 式 >= 式
: 大きいか等しい
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
■ 算術演算子
算術演算子には , 次のものがあります。
• 式+式
: 加算
• 式-式
: 減算
• 式*式
: 乗算
• 式/式
: 除算
• 式%式
: 剰余算
• 式<<式
: 左シフト
• 式>>式
: 右シフト
• +式
:正
• -式
:負
■ 名前から値を算出する演算子
名前から値を算出する演算子には , 次のものがあります。
詳細は , 「7.11.4 名前から算出される値」を参照してください。
• BITADR シンボル
: ビットシンボルアドレス演算子
• BITPOS シンボル
: ビットポジション番号演算子
• SIZEOF セクション
: サイズ演算子
September 1, 2014, CM81-00208-5
127
Su pp or t
7.11.4
So ft
Manu al
名前から算出される値
アドレッシングやプログラミングで必要となる値を参照するために , 次の特殊な演
算子を用意しています。
• BITADR : ビットシンボルアドレス演算子
• BITPOS : ビットポジション番号演算子
• SIZEOF : サイズ演算子
■ ビットシンボルアドレス演算子 (BITADR 演算子 )
【記述形式】
BITADR ビットシンボル
BITADR ( ビットシンボル )
ビットシンボルは括弧で囲むことができます。
【説明】
ビットシンボルアドレス演算子は , ビットシンボルのアドレスを算出します。
■ ビットポジション番号演算子 (BITPOS 演算子 )
【記述形式】
BITPOS ビットシンボル
BITPOS ( ビットシンボル )
ビットシンボルは括弧で囲むことができます。
【説明】
ビットポジション番号演算子は , ビットシンボルのビットポジション番号を算出し
ます。
128
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
■ セクションサイズ抽出 (SIZEOF 演算子 )
【記述形式】
SIZEOF セクションシンボル
SIZEOF ( セクションシンボル )
セクションシンボルは括弧で囲むことができます。
【説明】
サイズ演算子は , セクションのサイズを算出する演算子です。
したがって , SIZEOF の演算対象となる項は , セクションシンボルのみです。
セクションのサイズは , リンカで算出されるのでサイズ演算子を含む式は相対式と
なります。
ただし , ダミーセクションの場合は , オブジェクトファイルにコードが出力されな
いため , アセンブラでサイズを算出することになります。
この場合 , アセンブラはサイズ演算子を前方参照シンボルが記述された場合と同じ
扱いにして処理を行います。
理由は , セクションが分割記述可能なため , アセンブラ内部の処理 PASS1 が終了す
るまでサイズが分からないためです。
すなわち , サイズ演算子が記述された式は , 値が結果的に絶対値となっても式の種
類は , 相対式と同じ扱いとなります。
【例】
.SECTION
ABC, DATA, ALIGN=1
:
.SECTION
PROGRAM, CODE, ALIGN=1
MOVW
A, #SIZEOF(ABC)
MOVW
A, #SIZEOF(DMY)
:
.SECTION
DATA, DATA, ALIGN=1
.DATA
SIZEOF(PROGRAM), SIZEOF(DMY)
:
.SECTION
DMY, DATA, ALIGN=1
:
September 1, 2014, CM81-00208-5
129
Su pp or t
So ft
Manu al
■ サイズ演算子を含む式が記述できない擬似命令
サイズ演算子を含む式は , 次の擬似命令には記述できません。
機械命令に対しては , すべての式で有効です ( 記述できます )。
• .END 命令の開始アドレス
• .SECTION 命令の境界値と開始アドレス
• .ALIGN 命令の境界値
• .ORG 命令の式
• .SKIP 命令の式
• .EQU 命令の式
• .DATAB 命令の式 1
• .FDATAB 命令の式 1
• .RES 命令の式
• .FRES 命令の式
• .SDATAB 命令の式
• .FORM 命令の行数と桁数
• .SPACE 命令の空白行数
■ ほかのモジュールにあるセクションサイズを得るには
ほかのモジュールにあるセクションのサイズを得るには , 目的のセクションを空セク
ションとして作ります。そして , サイズ演算子を用いることでセクションサイズを算出
できます。
【例】
ほかのモジュールにあるセクション 'S' のサイズを得る場合
130
.SECTION
S, STACK, ALIGN=1 /* セクション 'S' の空セクションを作る */
.SECTION
P, CODE, ALIGN=1
MOVW
A, #SIZEOF(S)
/* セクション 'S' のサイズを得る */
CM81-00208-5, September 1, 2014
Support
7.11.5
Soft
Ma nual
演算子の優先順位
演算子の優先順位は , C 言語に合わせてあります。
■ 演算子の優先順位
表 7.11-4 に演算子の優先順位を示します。
表 7.11-4 演算子の優先順位
優先順位
演算子
結合性
適用される式
1
()
左
括弧
2
!~ + BITADR BITPOS
SIZEOF
右
単項式
3
*/ %
左
乗法式
4
+-
左
加法式
5
<< >>
左
シフト式
6
< <= > >=
左
関係式
7
==!=
左
等価式
8
&
左
ビット AND 式
9
^
左
ビット XOR 式
10
|
左
ビット OR 式
11
&&
左
論理 AND 式
12
||
左
論理 OR 式
【例】
.IMPORT
imp
.DATA
10 + 2 * 3
data_h:
.DATA
imp
> > 8
data_1:
.DATA
imp
& 0xff
September 1, 2014, CM81-00208-5
& 0xff
131
Su pp or t
So ft
Manu al
7.12 コメント
コメントには , 行コメントと範囲コメントがあります。
行コメントは , セミコロン (;) または 2 個のスラッシュ (//) で始まります。
C 言語風に , /* ~ */ で囲ってコメントを記述することもできます。
■ コメント
【記述形式】
/* 範囲コメント */
// 行コメント
; 行コメント
【説明】
コメントは , 任意のカラムから始めることができます。
コメントには , 行コメントと範囲コメントがあります。
行コメントは , セミコロン (;) または 2 個のスラッシュ (//) で始まります。
C 言語風に , /* ~ */ で囲ってコメントを記述することもできます。
これを範囲コメントといいます。
範囲コメントは , 好きな位置にコメントを記述できます。
【例】
/*---------範囲コメント
------------*/
; 行コメント
// 行コメント
.SECTION D1, DATA, ALIGN=2
/* 範囲コメント */ .DATA
// 行コメント
1
.DATA /* 範囲コメント */ 0xff ; 行コメント
132
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
第8章
セクション
メモリ空間を分割し , それぞれのメモリ空間に意味
を付けたのがセクションです。
セクションは , メモリ空間を用途ごとに区分し , 同
じセクション名を持つものどうしを 1 つのグルー
プとして扱います。
セクションは , リンク時に同じセクション名を持つ
ものどうしを集めて結合されます。このように , セ
クションを用いることでメモリ空間を論理的に扱
うことができます。
この章では , セクションの書き方について説明しま
す。
8.1 セクションの記述形式
8.2 セクションのタイプについて
8.3 セクションタイプと属性
8.4 セクションの配置形式について
8.5 セクションの結合方法
8.6 セクションの分割記述
8.7 ROM 化セクションの書き方
September 1, 2014, CM81-00208-5
133
Su pp or t
8.1
So ft
Manu al
セクションの記述形式
.SECTION 命令でセクションの開始を宣言します。
セクションはいくつも分割できます。
セクションタイプによりセクションの種類が決まります。
セクション配置形式によりセクションの配置形式が決まります。
■ セクションの記述形式
【記述形式】
.SECTION セクション名 [, セクションタイプ ][, セクション配置形式 ]
:
テキスト
:
セクションタイプ
:{CODE|DATA|CONST|COMMON|STACK|DUMMY|
IO|IOCOMMON|DIR|DIRCONST|DIRCOMMON}
セクション配置形式
: {ALIGN= 境界値 |LOCATE= 開始アドレス }
境界値
: 式 ( 絶対式 )
開始アドレス
: 式 ( 絶対式 )
【説明】
.SECTION 命令でセクションの開始を宣言します。
最初の .SECTION 命令までの間には , オブジェクトコードを生成する命令やロケー
ションカウンタを更新する命令を記述できません。
セクションはいくつにも分割できます。
詳細は , 「8.6 セクションの分割記述」を参照してください。
■ セクションタイプ
セクションタイプを指定することで , セクションの属性が決まります。
詳細は , 「8.2 セクションのタイプについて」を参照してください。
セクションタイプは , 次の 11 種類があります。
セクションタイプを省略した場合は , CODE となります。
134
• CODE
: コードセクションになります。
• DATA
: データセクションになります。
• CONST
: 初期値付きデータセクションになります。
• COMMON
: 共有セクションになります
• STACK
: スタックセクションになります。
• DUMMY
: ダミーセクションになります。
• IO
:I/O セクションになります。
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
• IOCOMMON
: 共有 I/O セクションになります。
• DIR
: ダイレクトセクションになります。
• DIRCONST
: 初期値付きダイレクトセクションになります。
• DIRCOMMON : 共有ダイレクトセクションになります。
■ セクション配置形式
セクションの配置方法が決まります。
● ALIGN: 相対セクションとなります。
メモリ上での配置アドレスはリンカで決定されます。
境界値で指定されたメモリ境界に配置されます。
● LOCATE: 絶対セクションとなります。
指定された開始アドレスから配置されます。
セクション配置形式を省略した場合は ALIGN=1 となります。
詳細は , 「8.4 セクションの配置形式について」を参照してください。
【例】
.SECTION PROG, CODE, ALIGN=2
/* セクション名
: PROG
*/
/* セクションタイプ
: コードセクション
*/
/* セクション属性
: 相対セクション ( 境界値 2)
*/
:
.SECTION VAL, DATA, LOCATE=0x1000
/* セクション名
: VAL
*/
/* セクションタイプ
: データセクション
*/
/* セクション属性
: 0x1000 番地から配置される絶対セクション
*/
:
September 1, 2014, CM81-00208-5
135
Su pp or t
8.2
So ft
Manu al
セクションのタイプについて
セクションのタイプは , セクションにどのようなデータを置くかで決めます。
■ セクションのタイプについて
セクションのタイプは , セクションにどのようなデータを置くかで決めます。
次にセクションタイプに対して一般的に使われるデータの種類を示します。
● コードセクション (CODE 指定 )
プログラムコードを置きます。
通常 , 機械命令が記述されます。
【例】
.SECTION PROG, CODE, ALIGN=1
start_program:
MOVW
A, #0
PUSHW
A
CALL
_func
● データセクション (DATA 指定 )
初期値のないデータ領域を置きます。
通常 , .RES 命令 , .FRES 命令が記述されます。
【例】
.SECTION VAL, DATA, ALIGN=1
v1:
.RES
1
v2:
.RES.H 2
また , データセクションには , 変更可能な初期値データを置く場合にも使用します。
詳細は , 「8.7 ROM 化セクションの書き方」を参照してください。
【例】
.SECTION INIT, DATA, ALIGN=1
ptbl:
.DATA 10, 11, 12 /* 変更可能なデータ値 */
● 初期値付きデータセクション (CONST 指定 )
変更しない初期値データを置きます。
主に ROM 内に配置するデータ値を記述する場合に指定します。
【例】
.SECTION PARAM, CONST, ALIGN=1
param1:
.DATA 10
param2:
.DATA -1
● 共有セクション (COMMON 指定 )
共有変数や共通領域を確保したい場合に指定します。
136
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
リンカで共有結合されます。
【例】
.SECTION COMval, COMMON, ALIGN=1
val:
.DATA
500
tbl:
.DATAB.B 10, 0xff
● スタックセクション (STACK 指定 )
スタック領域を確保するセクションです。
通常は , .RES 命令で領域を確保します。
【例】
.SECTION STACKAREA, STACK, ALIGN=1
.RES.B 0x1000 /* 4K バイト */
● ダミーセクション (DUMMY 指定 )
このセクションはオブジェクトコードには出力されません。
したがって , ダミーセクション内で意味を持つのは , 定義されたシンボルやダミーセク
ションのサイズを算出する場合のみとなります。
【例】 IO 領域をダミーセクションとして使用する場合】
ヘッダファイル iodef.h
.SECTION IO_MAP, DUMMY, LOCATE=0x100
iodata1:.RES.H 1
iodata2:.RES.H 1
iodata3:.RES.H 1
ソースファイル a.asm
#include "iodef.h" /* IO 定義ファイルを読み込む */
.SECTION P, CODE, ALIGN=2
:
MOVW
A, @iodata2
/* IO から値を読む */
:
ソースファイル b.asm
#include "iodef.h" /* IO 定義ファイルを読み込む */
.SECTION P, CODE, ALIGN=2
:
MOVW
@iodata2, A
/* IO へ値を書く */
:
September 1, 2014, CM81-00208-5
137
Su pp or t
So ft
Manu al
● I/O セクション (IO 指定 )
このセクションは , 各種の入出力ポートが配置されている領域にデータを配置するこ
とを指定します。
● 共有 I/O セクション (IOCOMMON 指定 )
このセクションは , 各種の入出力ポートが配置されている領域にデータを配置するこ
とを指定します。
このセクションは , リンカで共有結合されます。
● ダイレクトセクション (DIR 指定 )
このセクションは , ダイレクトアクセス領域にデータを配置することを指定します。
● 初期値付きダイレクトセクション (DIRCONST 指定 )
このセクションは , ダイレクトアクセス領域に変更しない初期値データを配置するこ
とを指定します。
● 共有ダイレクトセクション (DIRCOMMON 指定 )
このセクションは , ダイレクトアクセス領域にデータを配置することを指定します。
このセクションは , リンカで共有結合されます。
138
CM81-00208-5, September 1, 2014
Support
8.3
Soft
Ma nual
セクションタイプと属性
セクションはオブジェクトへ出力されるとき , セクション情報として内容種別 , 結合
種別 , リード種別 , ライト種別 , 実行種別という 5 つの属性を設定します。
これらの属性は , リンク時に , リンカでチェックされます。
■ セクションタイプと属性
セクションはオブジェクトへ出力されるとき , セクション情報として内容種別 , 結合種
別 , リード種別 , ライト種別 , 実行種別という 5 つの属性を設定します。
これらの属性は , リンク時にリンカでチェックされます。
表 8.3-1 にセクションタイプに対する各属性を示します。
表 8.3-1 セクションタイプに対する各属性
セクションタイプ
内容種別
結合種別
リード
ライト
実行
CODE
コード
連結結合
○
×
○
DATA
データ
連結結合
○
○
×
CONST
コンスタント
連結結合
○
×
×
COMMON
データ
共有結合
○
○
×
STACK
スタック
連結結合
○
○
×
IO
データ (I/O)
連結結合
○
○
×
IOCOMMON
データ (I/O)
共有結合
○
○
×
DIR
ダイレクト
連結結合
○
○
×
DIRCONST
ダイレクト
連結結合
○
×
×
DIRCOMMON
ダイレクト
共有結合
○
○
×
○…可 ×…不可
<注意事項>
ダミーセクションはオブジェクトには出力されませんので属性は持っていません。
September 1, 2014, CM81-00208-5
139
Su pp or t
8.4
So ft
Manu al
セクションの配置形式について
セクションの配置形式は次の 2 種類があります。
• 相対セクション
• 絶対セクション
相対セクションはリンカで配置アドレスが決定されます。
絶対セクションはアセンブラで配置アドレスを指定できます。
■ セクションの配置形式について
セクションの配置形式は次の 2 種類があります。
● 相対セクション (ALIGN 指定 )
相対セクションはリンカで配置アドレスが決定されます。したがって , 相対セクション
内のアドレスを持つシンボルはリンクされるまで値が確定しません。このようなシン
ボルを相対シンボルといいます。
相対セクションは , どこに配置されるかわからない場合に使います。
ほとんどのプログラムは相対セクションで記述して , リンカで配置アドレスを決める
やり方が一般的です。
リンカは , 相対セクションを配置するとき , ALIGN で指定された境界値のメモリ空間
に配置します。
【例】
.SECTION
PROG, CODE, ALIGN=1
_main:
PUSHW
IX
MOVW
A, SP
MOVW
IX, A
PUSHW
A
PUSHW
A
● 絶対セクション (LOCATE 指定 )
絶対セクションはアセンブラで配置アドレスを指定できます。
リンカは , 絶対セクションを LOCATE で指定された開始アドレスからメモリ空間に配
置します。したがって , 絶対セクション内のアドレスを持つシンボルはアドレスが決定
されているので値が確定しています。このようなシンボルを絶対シンボルといいます。
絶対セクションは , EIT ベクタテーブルや IO 領域の定義などに利用できます。
絶対セクションの指定では , 以下の記述ができます。
LOCATE= アドレス
【例】
.SECTION
140
IO, DATA, LOCATE=0x0000
CM81-00208-5, September 1, 2014
Support
timer_cmd:
Soft
/* タイマコマンドアドレス */
.RES
timer_data:
1
/* タイマデータアドレス */
.RES
September 1, 2014, CM81-00208-5
Ma nual
1
141
Su pp or t
8.5
So ft
Manu al
セクションの結合方法
セクションの結合処理は , リンカで行います。
セクションの結合方法は , 連結結合と共有結合の 2 種類があります。
連結結合は , 同じ名前を持つセクションを連続したメモリ空間に結合します。
共有結合は , 同じ名前を持つセクションどうしのメモリ空間を共有します。
■ セクションの結合方法
セクションの結合処理は , リンカで行います。
セクションの結合方法は , 連結結合と共有結合の 2 種類があります。
結合方法は , セクションのセクションタイプで決まります。
表 8.5-1 にセクションタイプと結合方法を示します。
表 8.5-1 セクションタイプと結合方法
セクションタイプ
結合方法
CODE
DATA
CONST
STACK
IO
DIR
連結結合
COMMON
IOCOMMON
DIRCOMMON
共有結合
■ 連結結合
複数のソースプログラムに含まれる同じ名前を持つセクションは , 連続したメモリ空
間に結合されます。ただし , セクションタイプ , セクション配置形式ともに同じ指定で
なければなりません。
142
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
【例】
図 8.5-1 連結結合の例
ソースプログラム
s1.asm
.SECTION A ,CODE,ALIGN=2
2バイト境界
:
:
ソースプログラム
s2.asm
SECTION A ,CODE,ALIGN=2
:
:
s3.asm
ソースプログラム
SECTION A ,CODE,ALIGN=2
:
↑下位アドレス
ソースプログラム
s1.asm
セクションA
ソースプログラム
s2.asm
セクションA
ソースプログラム
s3.asm
セクションA
↓上位アドレス
:
■ 共有結合
複数のソースプログラムに含まれる同じ名前を持つセクションは , 同じメモリ空間を
共有します。
領域の大きさは , もっとも大きなセクションのサイズで確保されます。
【例】
図 8.5-2 共有結合の例
s1.asm
ソースプログラム
.SECTION A,DATA,COMMON
↑下位アドレス
:
:
ソースプログラム
s2.asm
.SECTION A,DATA,COMMON
:
:
ソースプログラム s1.asm
セクションA 最終アドレス
ソースプログラム s2.asm
セクションA 最終アドレス
September 1, 2014, CM81-00208-5
↓上位アドレス
143
Su pp or t
8.6
So ft
Manu al
セクションの分割記述
セクションは , 1 つのソースプログラムの中に同じセクション名を持つ .SECTION
命令を複数個書くことができます。
その場合 , 同じ名前のセクションは連続した 1 つのセクションとして認識されます。
■ セクションの分割記述
セクションは , 1 つのソースプログラムの中に同じセクション名を持つ .SECTION 命令
を複数個書くことができます。
その場合 , 同じ名前のセクションは連続した 1 つのセクションとして認識されます。
最初の .SECTION 命令では , そのセクションの開始を宣言し , 2 つめからのセクション
は最初のセクションの継続を表します。
セクションが継続する場合 , ロケーションカウンタは直前の同じ名前のセクションの
値が継続されます。
分割して書かれた .SECTION 命令には , 異なる指定 ( セクションタイプとセクション配
置形式 ) をすることはできません。
ただし , セクション名が同じであり , 属性が省略された場合には , 以前に定義された指
定を引き継ぎます。
【例】
.SECTION
P, CODE, ALIGN=2
テキスト 1
.SECTION
D, DATA, ALIGN=4
テキスト 2
.SECTION
P, CODE
テキスト 3
.SECTION
D
テキスト 4
上記のソースプログラムは , 下のソースプログラムと同様に解釈されます。
.SECTION
P, CODE, ALIGN=2
テキスト 1
テキスト 3
.SECTION
D, DATA, ALIGN=4
テキスト 2
テキスト 4
144
CM81-00208-5, September 1, 2014
Support
8.7
Soft
Ma nual
ROM 化セクションの書き方
ROM 化するプログラムまたはデータ値の書き方について説明します。
プログラムコードと変更しない初期値データは , そのまま ROM 化しても問題ありま
せんが , 変更可能な初期値データは , リンカの -sc オプションで初期値データを
ROM に置いておき実行時に RAM に転送して使用することを指定する必要がありま
す。
■ ROM 化セクションの書き方
ROM 化するプログラムまたはデータ値は , 次のように分類できます。
1. プログラムコード (CODE セクション )
2. 変更しない初期値データ (CONST セクション )
3. 変更可能な初期値データ (DATA セクション )
1. と 2. は , そのまま ROM 化しても問題ありませんが , 3. は変更可能な値であるため ,
ROM 化したデータを RAM 領域に転送する必要があります。したがって , リンカで初
期値を ROM 領域へ配置し , 実行時に RAM 領域に転送して使用する指定が必要となり
ます。
このようなセクションの名前は , わかりやすいものに決めて置くことをお薦めいたし
ます。
C コンパイラでは , 変更可能な初期値データのセクション名に "INIT" を使っています
ので , アセンブラでも "INIT" を使うとよいでしょう。
■ 初期値データの転送
変更可能な初期値データを ROM から RAM へ転送する方法を説明します。
リンカで , -sc オプションを用いて , ROM-RAM 転送セクション指定を行うと , リンカ
は指定されたセクション名に対して , 次のシンボルを自動的に生成します。
• _ROM_ セクション名
• _RAM_ セクション名
それぞれのシンボルは , ROM 領域と RAM 領域の先頭アドレスを示しています。
ROM 領域 (0xE100 ~ 0xE1FF), RAM 領域 (0x0100 ~ 0x01FF) を指定し , INIT セクショ
ンを ROM-RAM 転送セクションの指定をした場合の例を次に示します。
flnk896s -ro ROM=0xE100/0xE1FF -ra RAM=0x0100/0x01ff
-sc @INIT=ROM, INIT=RAM sample.obj
この場合, _ROM_INIT, _RAM_INITが生成され, _ROM_INITには0xE100が, _RAM_INIT
には 0x0100 が設定されます。
詳細は , 『SOFTUNE リンケージキットマニュアル』を参照してください。
これらのシンボルを用いて , 次の例に示すように ROM-RAM 転送プログラムを作成し ,
スタートアップルーチンに組み込みます。
September 1, 2014, CM81-00208-5
145
Su pp or t
So ft
Manu al
【例】
.IMPORT
_ROM_INIT
/* ROM 側の INIT セクション先頭アドレス */
.IMPORT
_RAM_INIT
/* RAM 側の INIT セクション先頭アドレス */
INIT, DATA, ALIGN=4 /* 変更可能初期値データセクション
.SECTION
ptbl:
.DATA
10, 11, 12
*/
/* ptbl は RAM 側のアドレスを示す
*/
/* 初期値データは ROM 側に配置される
*/
/* ROM-RAM 転送プログラム
*/
:
.SECTION CODE, CODE, ALIGN=2
init_copy:
MOVW
IX, #_ROM_INIT
/* 転送元 (ROM) アドレス
*/
MOVW
EP, #_RAM_INIT
/* 転送先 (RAM) アドレス
*/
MOVW
A, #SIZEOF(INIT)
/* INIT セクションのサイズ
*/
BZ
init_copy_end
/* サイズが 0 なら終了
*/
A, @IX+0
/* 転送元データを読み込む
*/
init_copy_loop:
MOV
MOV
@EP, A
/* 転送先にデータを書き込む
*/
INCW
EP
/* 転送先アドレスを 1 進める
*/
INCW
IX
/* 転送元アドレスを 1 進める
*/
XCH
A, T
/* サイズを A レジスタに読み込む
*/
DECW
A
/* サイズを 1 減らす
*/
BNZ
init_copy_loop
/* サイズが 0 になるまで繰り返す
*/
init_copy_end:
146
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
第9章
機械命令
この章では , 機械命令の記述形式 , 記述上の規則に
ついて説明します。
機械命令およびアドレッシングモードの詳細は , 各
CPU の『インストラクションマニュアル』または
『プログラミングマニュアル』を参照してください。
9.1 機械命令の記述形式
9.2 オペランドフィールドの記述形式
September 1, 2014, CM81-00208-5
147
Su pp or t
9.1
So ft
Manu al
機械命令の記述形式
機械命令の一般的な記述形式と規則について説明します。
■ 機械命令の記述形式
機械命令は , プログラムの実行時に CPU により解釈され実行する命令です。
機械命令の詳細は , 各 CPU の『インストラクションマニュアル』または『プログラミ
ングマニュアル』を参照してください。
機械命令を記述する一般的な記述形式は次のとおりです。
【記述形式】
[ シンボル ]
オペレーション
[ オペランド [, オペランド ]…]
オペレーション : 命令ニーモニック
オペランド
: アドレッシングモード
【説明】
シンボルフィールドにシンボルを書いた場合 , そのシンボルに対して現在のアドレ
スが割り付けられます。
オペレーションフィールドには , 命令ニーモニックを記述します。
オペランドフィールドには , その機械命令に必要なオペランドを記述します。複数
のオペランドを記述する場合は , カンマ (, ) でオペランドを区切ります。
各オペランドには , アドレッシングモードを記述します。
【例】
148
PUSHW
IX
MOVW
A, SP
MOVW
IX, A
PUSHW
A
CALL
_proc0
CM81-00208-5, September 1, 2014
Support
9.2
Soft
Ma nual
オペランドフィールドの記述形式
オペランドフィールドの記述形式について説明します。
■ オペランドフィールドの記述形式
【記述形式】
[ オペランド [, オペランド ]…]
オペランド : アドレッシングモード
【説明】
機械命令のオペランドは各機械命令に記述できるアドレッシングモードが決まっ
ています。
複数のオペランドを持つ機械命令は , カンマ (, ) でオペランドを区切ります。
各機械命令に記述できるアドレッシングモードおよびアドレッシングモードの詳
細は , 各 CPU の『インストラクションマニュアル』または『プログラミングマニュ
アル』参照してください。
■ オペランドの順序
オペランドの順序は機械命令ごとに定められていますが原則は次のとおりです。
● 演算系の命令
演算系の命令では , 第 1 オペランドと第 2 オペランドで演算を行い , その結果を第 1 オ
ペランドに格納します。
第 1 オペランド ← 第 1 オペランド .op. 第 2 オペランド
【例】
ADD
A, #5
/* A ← A + 5 */
● 転送系の命令
転送系の命令では , 第 2 オペランドから第 1 オペランドに転送を行います。
第 1 オペランド ← 第 2 オペランド
【例】
MOV
September 1, 2014, CM81-00208-5
A, R5
/* A ← R5 */
149
Su pp or t
150
So ft
Manu al
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
第 10 章
アセンブラ擬似命令
アセンブラ擬似命令は , 機械命令とは異なりアセン
ブラ自身に対して指示を与える命令です。
アセンブラ擬似命令は , 次の 8 つに分類されます。
• プログラム構造定義命令
• アドレス制御命令
• プログラム結合命令
• シンボル定義命令
• 領域定義命令
• デバッグ情報出力制御命令
• ライブラリファイル指定命令
• リスト出力制御命令
この章では , アセンブラ擬似命令の各記述形式とそ
の機能について説明します。
10.1 擬似命令で扱う整数定数の範囲
10.2 プログラム構造定義命令
10.3 アドレス制御命令
10.4 プログラム結合命令
10.5 シンボル定義命令
10.6 領域定義命令
10.7 デバッグ情報出力制御命令
10.8 ライブラリファイル指定命令
10.9 リスト出力制御命令
September 1, 2014, CM81-00208-5
151
Su pp or t
So ft
Manu al
10.1 擬似命令で扱う整数定数の範囲
擬似命令で整数定数を指定する場合 , ビット (1 ビット ), バイト (8 ビット ), ハーフ
ワード (16 ビット ), ロングワード (32 ビット ), ワード (16 ビット ) の 5 種類のサイ
ズがあります。
サイズの記述がない場合は , ワード (16 ビット ) になります。
■ 擬似命令で扱う整数定数の範囲
擬似命令で整数定数を指定する場合 , 次の 5 種類のサイズがあります。
• ビット (1 ビット )
• バイト (8 ビット )
• ハーフワード (16 ビット )
• ロングワード (32 ビット )
• ワード (16 ビット )
サイズの記述がない場合は , ワード (16 ビット ) になります。
擬似命令で使うサイズ指定子を表 10.1-1 に示します。
表 10.1-1 サイズ指定子
152
サイズ指定子
データサイズ
I( ビット )
1bit
B( バイト )
8bit(1byte)
H( ハーフ )
16bit(2bytes)
L( ロング )
32bit(4bytes)
W( ワード )
16bit(2bytes)
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
10.2 プログラム構造定義命令
プログラム構造定義命令は , ソースプログラムの終了 , モジュール名の宣言 , セク
ション情報の定義などを行う命令です。
■ プログラム構造定義命令
プログラム構造定義命令には , 次の 3 種類があります。
• .PROGRAM
: モジュール名の宣言
• .END
: ソースプログラムの終了
• .SECTION
: セクションの定義
September 1, 2014, CM81-00208-5
153
Su pp or t
10.2.1
So ft
Manu al
.PROGRAM 命令
モジュール名の指定を行います。
モジュール名は , 名前の規則に従います。
.PROGRAM 命令が省略された場合は , オブジェクトファイルの主ファイル名をモ
ジュール名とします。
■ .PROGRAM 命令
【記述形式】
.PROGRAM
モジュール名
【説明】
モジュール名の指定を行います。
モジュール名は , 名前の規則に従います。
.PROGRAM 命令は , ソースプログラム中 , 1 回限り有効です。
.PROGRAM 命令が省略された場合は , オブジェクトファイルの主ファイル名をモ
ジュール名とします。
オブジェクトファイルの主ファイル名が , 名前規則から外れている場合は警告を出
力し , モジュール名に使用できない文字は , アンダバー (_) に置き換えます。
【例】
.PROGRAM
test_name
■ 起動時オプションとの関係
-name を指定した場合 , -name で指定した名前がモジュール名となります。
154
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
.END 命令
10.2.2
ソースプログラムの終了を示します。
.END 命令は省略できます。その場合 , ソースプログラムの最後までアセンブルされ
ます。
開始アドレスを設定できます。
■ .END 命令
【記述形式】
[ 開始アドレス ]
.END
開始アドレス : 式
【説明】
ソースプログラムの終了を示します。
.END 命令は省略できます。その場合 , ソースプログラムの最後までアセンブルされ
ます。
.END 命令以降にソースがある場合は , 以降のソースはアセンブルされません。
開始アドレスが指定されていると , プログラムの開始アドレスを設定します。
プログラムの開始アドレスは , SOFTUNE Workbench でプログラムをロードすると
きに参照し , プログラムカウンタに値を設定するためのものです。
開始アドレスが省略された場合は , 開始アドレスは設定されません。
開始アドレスは , 絶対式か単純相対式でなければなりません。
開始アドレスは , コードセクション内を示していなければなりません。
【例】
.SECTION PROG, CODE, ALIGN=1
start:
:
.END
September 1, 2014, CM81-00208-5
start
155
Su pp or t
10.2.3
So ft
Manu al
.SECTION 命令
セクションの開始を宣言し , セクションのタイプと配置形式を設定します。
■ .SECTION 命令
【記述形式】
セクション名 [, 指定 [, 指定 ]]
.SECTION
指定
:{ セクションタイプ | セクション配置形式 }
セクションタイプ
:{CODE|DATA|CONST|COMMON|STACK|DUMMY|IO
|IOCOMMON|DIR|DIRCOMMON|DIRCONST}
セクション配置形式
:{ALIGN= 境界値 |LOCATE= 開始アドレス }
境界値
: 式 ( 絶対式 )
開始アドレス
: 式 ( 絶対式 )
【説明】
セクションの開始を宣言し , セクションのタイプと配置形式を設定します。
セクション名は , 名前の規則に従います。
セクションタイプ , セクション配置形式は , それぞれ 1 つのみ指定できます。
セクションタイプが省略された場合は , コードセクションとなります。
セクション配置形式が省略された場合は , ALIGN=1 が設定されます。
■ セクションタイプ
セクションタイプを指定します。
詳細は , 「8.2 セクションのタイプについて」を参照してください。
• CODE
: コードセクションになります。
• DATA
: データセクションになります。
• CONST
: 初期値付きデータセクションになります。
• COMMON
: 共有セクションになります。
• STACK
: スタックセクションになります。
• DUMMY
: ダミーセクションになります。
• IO
: I/O セクションになります。
• IOCOMMON
: 共有 I/O セクションになります。
• DIR
: ダイレクトセクションになります。
• DIRCONST
: 初期値付きダイレクトセクションになります。
• DIRCOMMON : 共有ダイレクトセクションになります。
156
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
■ セクション配置形式
セクションの配置方法を指定します。
詳細は , 「8.4 セクションの配置形式について」を参照してください。
● ALIGN= 境界値
相対セクションとなります。
リンカで , 指定された境界にセクションが配置されます。
境界値は , 絶対式でなければなりません。
境界値は , 2 のべき乗値でなければなりません。
● LOCATE= 開始アドレス
絶対セクションとなります。
指定された開始アドレスからセクションが配置されます。
開始アドレスは , 絶対式でなければなりません。
【例】
.SECTION
P, CODE, ALIGN=1
:
.SECTION
D, DATA, LOCATE=0x1000
:
.SECTION
C, CONST, LOCATE=0x2000
:
.SECTION
V, COMMON, ALIGN=1
:
September 1, 2014, CM81-00208-5
157
Su pp or t
So ft
Manu al
10.3 アドレス制御命令
アドレス制御命令は , ロケーションカウンタ値の変更を行う命令です。
■ アドレス制御命令
アドレス制御命令には , 次の 3 種類があります。
158
• .ALIGN
: 境界整列
• .ORG
: ロケーションカウンタ値の変更
• .SKIP
: ロケーションカウンタ値のインクリメント
CM81-00208-5, September 1, 2014
Support
10.3.1
Soft
Ma nual
.ALIGN 命令
現在のロケーションカウンタ値が指定された境界にない場合 , 境界値になるまでロ
ケーションカウンタ値を進めます。
ただし , 境界にある場合は何も行いません。
■ .ALIGN 命令
【記述形式】
.ALIGN
境界値
境界値 : 式 ( 絶対式 )
【説明】
現在のロケーションカウンタ値が指定された境界にない場合 , 境界値になるまでロ
ケーションカウンタ値を進めます。ただし , 境界にある場合は何も行いません。
式は , 絶対式でなければなりません。
式は , 0x8000 以下の正の値でなければなりません。
【条件】
.SECTION 命令の境界値≧ .ALIGN 命令の境界値
( 絶対セクションの場合は , この条件は必要ありません )
【例】
.SECTION
D, DATA, ALIGN=8 /* (8=2^3) */
.DATA.B
0
.ALIGN
8
.DATA.B
0xff
.ALIGN
4
:
September 1, 2014, CM81-00208-5
159
Su pp or t
10.3.2
So ft
Manu al
.ORG 命令
ロケーションカウンタに式の値を設定します。
■ .ORG 命令
【記述形式】
.ORG
式
【説明】
ロケーションカウンタに式の値を設定します。
絶対セクション内で .ORG 命令を使用した場合 , .SECTION 命令で指定した開始アド
レス (LOCATE 指定 ) より前にロケーションカウンタを戻すことはできません。
式は , 絶対式または本命令と同じセクション内のシンボルを値に含む単純相対式で
なければなりません。
【例】
.SECTION
D, DATA, LOCATE=0x100
.DATA
0
.ORG
0x200
.DATA
2
.ORG
0x300
.DATA
3
:
160
CM81-00208-5, September 1, 2014
Support
10.3.3
Soft
Ma nual
.SKIP 命令
ロケーションカウンタを式の数分だけインクリメントします。
■ .SKIP 命令
【記述形式】
.SKIP
式
【説明】
ロケーションカウンタを , 式の数分だけインクリメントします。
式は , 絶対式でなければなりません。
【例】
.SECTION
D, DATA, ALIGN=2
.DATA.H
0x0505
.SKIP
2
.DATA.H
0x1010
:
September 1, 2014, CM81-00208-5
161
Su pp or t
So ft
Manu al
10.4 プログラム結合命令
複数のプログラム間で , シンボルを共有する場合にプログラム結合命令を使用しま
す。
シンボルをほかのプログラムも参照可能にする外部定義の宣言 , ほかのプログラム
のシンボルを参照する外部参照の宣言を行います。
■ プログラム結合命令
プログラム結合命令には , 次の 3 種類があります。
162
• .EXPORT
: 外部定義シンボルの宣言
• .GLOBAL
: 外部定義 / 外部参照シンボルの宣言
• .IMPORT
: 外部参照シンボルの宣言
CM81-00208-5, September 1, 2014
Support
10.4.1
Soft
Ma nual
.EXPORT 命令
プログラム内で定義したシンボルを .EXPORT 命令で指定することによりほかのプ
ログラムでもそのシンボルの参照ができるようになります。
■ .EXPORT 命令
【記述形式】
シンボル [, シンボル ]…
.EXPORT
【説明】
プログラム内で定義したシンボルを .EXPORT 命令で指定することによりほかのプ
ログラムでもそのシンボルの参照ができるようになります。
シンボルは本プログラム中で定義されていなければなりません。
指定可能なシンボルの種類は次のとおりです。
- 絶対値を持つシンボル
- アドレスを持つシンボル
同じシンボルが指定されてもエラーにはなりません。
【例】
-------- プログラム 1 -------.EXPORT
abc1, abc2
:
abc1:
.EQU
5*3
:
abc2:
ADDC
A, R5
-------- プログラム 2 -------.IMPORT
abc1, abc2
:
.DATA
abc1
:
.DATA
abc2
:
September 1, 2014, CM81-00208-5
163
Su pp or t
10.4.2
So ft
Manu al
.GLOBAL 命令
外部定義 , または外部参照するシンボルを宣言します。
本プログラム内で定義されているシンボルは , 外部定義シンボルとなります。
■ .GLOBAL 命令
【記述形式】
シンボル [, シンボル ]…
.GLOBAL
【説明】
外部定義 , または外部参照するシンボルを宣言します。
本プログラム内で定義されているシンボルは , 外部定義シンボルとなります。
指定可能な外部定義シンボルの種類は , 次のとおりです。
- 絶対値を持つシンボル
- アドレスを持つシンボル
本プログラム内で定義されていないシンボルは , 外部参照シンボルとなります。
同じシンボルが指定されてもエラーにはなりません。
【例】
.GLOBAL
abc, sub
/* abc は外部定義シンボル */
/* sub は外部参照シンボル */
:
abc:
164
CALL
sub
CM81-00208-5, September 1, 2014
Support
10.4.3
Soft
Ma nual
.IMPORT 命令
シンボルが , ほかのプログラムで定義されていることを指定します。
■ .IMPORT 命令
【記述形式】
シンボル [, シンボル ]…
.IMPORT
【説明】
シンボルが , ほかのプログラムで定義されていることを指定します。
このシンボルは , ほかのプログラム内で外部定義されていなければなりません。
同じシンボルが指定されてもエラーにはなりません。
【例】
-------- プログラム 1 -------.IMPORT
xyz1, xyz2
:
.DATA
xyz1
:
.DATA
xyz2
-------- プログラム 2 -------.EXPORT xyz1, xyz2
:
xyz1:
.EQU
5*3
:
xyz2:
September 1, 2014, CM81-00208-5
ADDC
A, R5
165
Su pp or t
So ft
Manu al
10.5 シンボル定義命令
シンボル定義命令は , シンボルに値を割り付けます。
■ シンボル定義命令
シンボル定義命令には , 次の 1 種類があります。
• .EQU: シンボルへの値の割り付け
166
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
.EQU 命令
10.5.1
シンボルに , 式の値を割り付けます。
■ .EQU 命令
【記述形式】
シンボル
式
.EQU
【説明】
シンボルに , 式の値を割り付けます。
すでに定義されているシンボルに対して , 値を割り付けることはできません。
式は , 絶対式か単純相対式でなければなりません。
【例】
TEN:
.EQU
10
/* TEN=10 */
ONE:
.EQU
TEN/10
/* ONE=TEN/10 */
val1:
.DATA
0xFFFF0000
val2:
.EQU
val1+2
September 1, 2014, CM81-00208-5
167
Su pp or t
So ft
Manu al
10.6 領域定義命令
領域定義命令は , メモリ領域に定数や領域を確保できます。
■ 領域定義命令
領域定義命令には , 次の 18 種類があります。
168
• .DATA:
定数定義 ( 整数型 )
• .BIT:
定数定義 (1 ビット整数定数 )
• .BYTE:
定数定義 (8 ビット整数定数 )
• .HALF:
定数定義 (16 ビット整数定数 )
• .LONG:
整数定義 (32 ビット整数定数 )
• .WORD:
定数定義 (16 ビット整数定数 )
• .DATAB:
定数ブロック定義 ( 整数定数 )
• .FDATA:
定数定義 ( 浮動小数点定数 )
• .FLOAT:
定数定義 (32 ビット浮動小数点定数 )
• .DOUBLE:
定数定義 (64 ビット浮動小数点定数 )
• .FDATAB:
定数ブロック定義 ( 浮動小数点定数 )
• .RES:
領域定義 ( 整数定数 )
• .FRES:
領域定義 ( 浮動小数点定数 )
• .SDATA:
文字列定義
• .ASCII:
文字列定義
• .SDATAB:
文字列ブロック定義
• .STRUCT:
構造体の定義開始
• .ENDS:
構造体の定義終了
CM81-00208-5, September 1, 2014
Support
10.6.1
Soft
Ma nual
.DATA 命令 , .BIT 命令 , .BYTE 命令 , .HALF 命令 ,
.LONG 命令 , .WORD 命令
式の値をメモリ領域に確保します。
.DATA 命令は , サイズ単位でメモリ領域を確保します。
.BIT 命令は , ビット単位でメモリ領域を確保します。
.BYTE 命令は , バイト単位でメモリ領域を確保します。
.HALF 命令は , ハーフワード単位でメモリ領域を確保します。
.LONG 命令は , ロングワード単位でメモリ領域を確保します。
.WORD 命令は , ワード単位でメモリ領域を確保します。
■ .DATA 命令
【記述形式】
[ シンボル ]
式 [, 式 ]…
.DATA.s
サイズ指定 (s):
I … ビット (1 ビット )
B … バイト (8 ビット )
H … ハーフワード (16 ビット )
L … ロングワード (32 ビット )
W …ワード (16 ビット )
< < デフォルト > >
【説明】
式の値をメモリ領域にサイズ (.s) 単位で確保します。
サイズ (.s) が省略された場合は , ワード指定となります。
式には , 絶対式と相対式が記述できます。
【例】
.DATA.B
0x12, 0x23, 0xa3
.DATA
-1, 0xffff
■ .BIT 命令
【記述形式】
[ シンボル ]
.BIT
式 [, 式 ]…
【説明】
ビット (1 ビット ) 単位でメモリ領域を確保します。
次の定義と同じ意味です。
.DATA.I 式 [, 式 ]…
September 1, 2014, CM81-00208-5
169
Su pp or t
So ft
Manu al
■ .BYTE 命令
【記述形式】
[ シンボル ]
.BYTE
式 [, 式 ]…
【説明】
バイト (8 ビット ) 単位でメモリ領域を確保します。
次の定義と同じ意味です。
.DATA.B 式 [, 式 ]…
■ .HALF 命令
【記述形式】
[ シンボル ]
.HALF
式 [, 式 ]…
【説明】
ハーフワード (16 ビット ) 単位でメモリ領域を確保します。
次の定義と同じ意味です。
.DATA.H 式 [, 式 ]…
■ .LONG 命令
【記述形式】
[ シンボル ]
.LONG
式 [, 式 ]…
【説明】
ロングワード (32 ビット ) 単位でメモリ領域を確保します。
次の定義と同じ意味です。
.DATA.L 式 [, 式 ]…
■ .WORD 命令
【記述形式】
[ シンボル ]
.WORD
式 [, 式 ]…
【説明】
ワード (16 ビット ) 単位でメモリ領域を確保します。
次の定義と同じ意味です。
.DATA.W 式 [, 式 ]…
170
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
.DATAB 命令
10.6.2
指定された数分だけ , 値をメモリ領域にサイズ単位で確保します。
サイズが省略された場合は , ワード指定となります。
■ .DATAB 命令
【記述形式】
[ シンボル ]
式 1, 式 2
.DATAB.s
サイズ指定 (s):
I
…ビット (1 ビット )
B …バイト (8 ビット )
H …ハーフ (16 ビット )
L …ロング (32 ビット )
W …ワード (16 ビット ) < < デフォルト > >
【説明】
式 1 の数分だけ , 式 2 の値をメモリ領域にサイズ (.s) 単位で確保します。
サイズ (.s) が省略された場合は , ワード指定となります。
式 1 は , 絶対式でなければなりません。
式 2 は , 絶対式と相対式が記述できます。
【例】
.DATAB.B
4, 0x12
<注意事項>
.DATAB 命令は , 式 2 を式 1 の数分繰り返して領域を確保するため , 式 1 にあまりにも大
きな値を指定すると処理時間が非常に長くなります。そのため , 式 1 の値は 1048575 以
下にしてください。それ以上はエラーとなります。
September 1, 2014, CM81-00208-5
171
Su pp or t
10.6.3
So ft
Manu al
.FDATA 命令 , .FLOAT 命令 , .DOUBLE 命令
浮動小数点定数をメモリ領域に確保します。
.FDATA 命令は , 型指定で指定された単位でメモリ領域を確保します。
.FLOAT 命令は , 単精度 (4 バイト ) 単位でメモリ領域を確保します。
.DOUBLE 命令は , 倍精度 (8 バイト ) 単位でメモリ領域を確保します。
■ .FDATA 命令
【記述形式】
[ シンボル ]
型指定 (t):
.FDATA.t
浮動小数点定数 [, 浮動小数点定数 ]…
S …単精度浮動小数点定数 , 32 ビット (4 バイト ) < < デフォルト > >
D …倍精度浮動小数点定数 , 64 ビット (8 バイト )
【説明】
浮動小数点定数をメモリ領域に型指定 (.t) 単位で確保します。
浮動小数点定数には , 式や整数定数を指定できません。
型指定 (.t) が省略された場合は , 単精度指定となります。
浮動小数点定数については , 「7.9 浮動小数点定数」を参照してください。
【例】
.FDATA.S
2.1e4
/* 単精度となります */
.FDATA.D
3.2e5
/* 倍精度となります */
.FDATA
4.3e-2
/* 単精度となります */
.FDATA
0xFFFF0000
/* 単精度となります */
■ .FLOAT 命令
【記述形式】
[ シンボル ]
.FLOAT
浮動小数点定数 [, 浮動小数点定数 ]…
【説明】
単精度 (4 バイト ) 単位でメモリ領域を確保します。
次の定義と同じ意味です。
.FDATA.S 浮動小数点定数 [, 浮動小数点定数 ]…
172
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
■ .DOUBLE 命令
【記述形式】
[ シンボル ]
.DOUBLE
浮動小数点定数 [, 浮動小数点定数 ]…
【説明】
倍精度 (8 バイト ) 単位でメモリ領域を確保します。
次の定義と同じ意味です。
.FDATA.D 浮動小数点定数 [, 浮動小数点定数 ]…
September 1, 2014, CM81-00208-5
173
Su pp or t
So ft
Manu al
.FDATAB 命令
10.6.4
指定された数分だけ , 浮動小数点定数をメモリ領域に型指定で指定された単位で確
保します。
型指定が省略された場合は , 単精度指定となります。
■ .FDATAB 命令
【記述形式】
[ シンボル ]
型指定 (t):
.FDATAB.t
式 , 浮動小数点定数
S …単精度浮動小数点定数 , 32 ビット (4 バイト ) < < デフォルト > >
D …倍精度浮動小数点定数 , 64 ビット (8 バイト )
【説明】
式の数分だけ , 浮動小数点定数をメモリ領域に型指定 (.t) 単位で確保します。
型指定 (.t) が省略された場合は , 単精度指定となります。
式は , 絶対式でなければなりません。
浮動小数点定数には , 式や整数定数を指定できません。
【例】
.FDATAB.S
4, 0xFFF00000
.FDATAB.S
12, 0r1.2e10
<注意事項>
.FDATAB 命令は , 浮動小数点定数を式の数分繰り返して領域を確保するため , 式にあまり
にも大きな値を指定すると処理時間が非常に長くなります。そのため , 式の値は 1048575
以下にしてください。それ以上はエラーとなります。
174
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
.RES 命令
10.6.5
指定された数分だけ , メモリ領域をサイズ単位で確保します。
.RES 命令は , 領域を確保するだけでデータは未設定となります。
サイズが省略された場合は , ワード指定となります。
■ .RES 命令
【記述形式】
[ シンボル ]
式
.RES.s
サイズ指定 (s):
I
…ビット (1 ビット )
B …バイト (8 ビット )
H …ハーフワード (16 ビット )
L …ロングワード (32 ビット )
W …ワード (16 ビット ) < < デフォルト > >
【説明】
式の数分だけ , メモリ領域をサイズ (.s) 単位で確保します。
この命令は , 領域を確保するだけでデータは未設定となります。
サイズ (.s) が省略された場合は , ワード指定となります。
式は , 絶対式でなければなりません。
【例】
.RES.H
2
/* ハーフワード (16 ビット )
を 2 つ分確保 */
.RES.B
4
/* バイト (8 ビット )
を 4 つ分確保 */
September 1, 2014, CM81-00208-5
175
Su pp or t
10.6.6
So ft
Manu al
.FRES 命令
指定された数分だけ , メモリ領域を型指定で指定された単位で確保します。
.FRES 命令は , 領域を確保するだけでデータは未設定となります。
型指定省略された場合は , 単精度指定となります。
■ .FRES 命令
【記述形式】
[ シンボル ]
型指定 (t):
.FRES.t
式
S …単精度浮動小数点定数 , 32 ビット (4 バイト ) < < デフォルト > >
D …倍精度浮動小数点定数 , 64 ビット (8 バイト )
【説明】
式の数分だけ , メモリ領域を型指定 (.t) 単位で確保します。
この命令は , 領域を確保するだけでデータは未設定となります。
型指定 (.t) が省略された場合は , 単精度指定となります。
式は , 絶対式でなければなりません。
【例】
176
.FRES.S
2
/* 単精度 (4 バイト ) を 2 つ分確保 */
.FRES.D
4
/* 倍精度 (8 バイト ) を 4 つ分確保 */
CM81-00208-5, September 1, 2014
Support
10.6.7
Soft
Ma nual
.SDATA 命令 , .ASCII 命令
メモリ領域に , 文字列のデータを確保します。
■ .SDATA 命令
【記述形式】
[ シンボル ]
.SDATA
文字列 [, 文字列 ]…
【説明】
メモリ領域に , 文字列のデータを確保します。
文字列の書き方については , 「7.8 文字列」を参照してください。
【例】
.SDATA
"STR", "IN", "G"
→
|S |T |R |I |N |G |
.SDATA
"EF\tXYZ\0"
→
|E |F |09|X |Y |Z |00|
■ .ASCII 命令
【記述形式】
[ シンボル ]
.ASCII
文字列 [, 文字列 ]…
【説明】
.SDATA 命令と命令名が異なるだけで機能は全く同じです。
【例】
.ASCII
September 1, 2014, CM81-00208-5
"GHI\r\n"
→
|G |H |I |0D|0A|
177
Su pp or t
So ft
Manu al
.SDATAB 命令
10.6.8
メモリ領域に , 指定された数分だけ文字列データを確保します。
■ .SDATAB 命令
【記述形式】
[ シンボル ]
.SDATAB
式 , 文字列
【説明】
メモリ領域に , 式の数分だけ文字列データを確保します。
式は , 絶対式でなければなりません。
【例】
.SDATAB
3, "ABCD"
A B C D A B C D A B C D
下位アドレス
上位アドレス
<注意事項>
.SDATAB 命令は , 文字列を式の数分繰り返して領域を確保するため , 式にあまりにも大き
な値を指定すると処理時間が非常に長くなります。そのため , 式の値は 1048575 以下に
してください。それ以上はエラーとなります。
178
CM81-00208-5, September 1, 2014
Support
10.6.9
Soft
Ma nual
.STRUCT 命令 , .ENDS 命令
構造体の名前とその構成要素を定義します。
構造体の開始 (.STRUCT 命令 ) と終了 (.ENDS 命令 ) は , 一致させなければなりません。
構造体の構成要素となる各メンバは領域定義擬似命令を記述します。
■ .STRUCT 命令 , .ENDS 命令
【記述形式】
構造体タグ名
.STRUCT
[ メンバ名 ]
:
領域定義擬似命令
構造体タグ名
.ENDS
式
【説明】
構造体の名前とその構成要素を定義します。
構造体の開始(.STRUCT命令)と終了(.ENDS命令)は, 一致させなければなりません。
構造体の構成要素となる各メンバは , 領域定義擬似命令を記述します。
【例】
ABC:
.STRUCT
m1:
.BIT
0
m2:
.BYTE
2
ABC:
.ENDS
■ 構造体の領域定義
【記述形式】
構造体シンボル
構造体タグ名
<[ 式 [, …]] >
【説明】
構造体タグ名は , この構造体が持つ大きさの領域を確保してくれる領域定義擬似命
令のように機能します。
オペランド欄には構造体の各メンバの値を記述します。
アングルブラケット ( < >) 内の式は , 省略できますが , アングルブラケットそのもの
は省略できません。
式は構造体の各メンバへの初期値を記述します。
初期化しない領域がある場合は , カンマ (, ) だけを記述して式を記述しなければ , そ
の部分は初期化されません。
初期化しないメンバが後に連続している場合には , そのメンバ以降の式を指定する
必要はありません。
September 1, 2014, CM81-00208-5
179
Su pp or t
So ft
Manu al
【例】
ABC:
.STRUCT
m1:
.BIT
0
m2:
.BYTE
2
ABC:
.ENDS
c:
ABC
<0, 2 >
■ 構造体のアクセス
【記述形式】
構造体シンボル . メンバ名
【説明】
構造体シンボルの後にピリオド (.) を付加して構造体メンバ名を続けて記述するこ
とで構造体のメンバを参照できます。
構造体メンバは , 構造体内での 16 ビットオフセットを持ち , 式の中でディスプレー
スメントとしても記述できます。
【例】
180
ABC:
.STRUCT
m1:
.BIT
0
m2:
.BYTE
2
ABC:
.ENDS
c:
ABC
<0, 2 >
MOV
A, c+m2
SETB
c.m1
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
10.7 デバッグ情報出力制御命令
デバッグ情報出力の部分指定を行います。
起動時オプションでデバッグ情報出力 (-g) を指定すると , プログラムで使用されて
いるシンボル情報がオブジェクトへ出力されます。
デバッグ情報出力制御命令は , ON/OFF 指定を行うことで必要な部分だけデバッグ
情報を出力できます。
■ デバッグ情報出力制御命令
デバッグ情報出力制御命令には , 次の 1 種類があります。
• .DEBUG: デバッグ情報出力の部分指定
■ .DEBUG 命令
【記述形式】
.DEBUG
{ON|OFF}
ON : デバッグ情報出力の開始を指定
OFF: デバッグ情報出力の中止を指定
【説明】
デバッグ情報出力の部分指定を行います。
起動時オプションでデバッグ情報出力 (-g) を指定すると , プログラムで使用されて
いるシンボル情報がオブジェクトへ出力されます。
.DEBUG 命令は , ON/OFF 指定を行うことで必要な部分だけデバッグ情報を出力で
きます。
.DEBUG 命令は , ソースプログラム上何回現れてもよく , その都度有効となります。
デバッグ情報出力が ON になっている部分のシンボルについてデバッグ情報が出力
されます。
初期値は , ON になっています。
【例】
.DEBUG
ON
: /* この部分のデバッグ情報は出力されます
.DEBUG
OFF
: /* この部分のデバッグ情報は出力されません
.DEBUG
September 1, 2014, CM81-00208-5
*/
*/
ON
181
Su pp or t
So ft
Manu al
■ 起動時オプションとの関係
-g が指定されている場合のみ .DEBUG 命令が有効となります。
-g が指定されていない場合や -Xg で -g が取り消されている場合は , .DEBUG 命令はす
べて無効となり , デバッグ情報は一切出力されません。
182
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
10.8 ライブラリファイル指定命令
ライブラリファイルを指定します。
■ ライブラリファイル指定命令
ライブラリファイル指定命令には , 次の 1 種類があります。
• .LIBRARY: ライブラリファイルの指定
■ .LIBRARY 命令
【記述形式】
.LIBRARY
" ライブラリファイル名 "
【説明】
リンカで検索するライブラリファイル名の指定を行います。
ライブラリファイルをいくつも指定したい場合は , .LIBRARY 命令を複数記述しま
す。
【例】
.LIBRARY
"liblo.lib"
.LIBRARY
"libstd.lib"
September 1, 2014, CM81-00208-5
183
Su pp or t
So ft
Manu al
10.9 リスト出力制御命令
アセンブルリストの出力形式を指定できます。
■ リスト出力制御命令
ライブラリファイル指定命令には , 次の 6 種類があります。
• .FORM
: 1 頁の行数と桁数指定
• .TITLE
: タイトル指定
• .HEADING: タイトルの指定と変更
184
• .LIST
: アセンブルソースリスト出力の詳細指定
• .PAGE
: 改頁指定
• .SPACE
: 空白行の出力
CM81-00208-5, September 1, 2014
Support
10.9.1
Soft
Ma nual
.FORM 命令
アセンブルリストに出力する 1 頁当たりの行数と桁数を指定します。
行数の値の範囲は , 20 ~ 255 です。0 を指定した場合は , 改頁されません。
桁数の値の範囲は , 80 ~ 1023 です。
初期値は , .FROM LIN=60, COL=100 です。
■ .FORM 命令
【記述形式】
指定 [, 指定 ]
.FORM
指定 :{ 行数 | 桁数 }
行数 :LIN= 式 ( 絶対式 ) {0|20 ~ 255}
桁数 :COL= 式 ( 絶対式 ) 80 ~ 1023
【説明】
アセンブルリストに出力する 1 頁当たりの行数と桁数を指定します。
.FORM命令は, ソースプログラム上に何回現れてもよく, その都度有効となります。
式は , 絶対式でなければなりません。
行数の値の範囲は , 20 ~ 255 です。0 を指定した場合は , 改頁されません。
桁数の値の範囲は , 80 ~ 1023 です。
初期値は , .FORM LIN=60, COL=100 です。
アセンブラは , 指定された行数と桁数内に余白を補って出力します。
【例】
図 10.9-1 .FORM 命令の出力例
ソースプログラム
.FORM
アセンブルリスト
LIN=60, COL=80
80
60
■ 起動時オプションとの関係
-pl を指定した場合 , 行数の指定は無効となります。
-pw を指定した場合 , 桁数の指定は無効となります。
September 1, 2014, CM81-00208-5
185
Su pp or t
10.9.2
So ft
Manu al
.TITLE 命令
アセンブルリストの各頁のヘッダ部に , コメントとして表示するタイトルを指定し
ます。
指定されたタイトル文字は , 先頭頁から出力されます。
.TITLE 命令は , ソースプログラム上で 1 回のみ指定可能です。
■ .TITLE 命令
【記述形式】
" タイトル文字 "
.TITLE
【説明】
アセンブルリストの各ページのヘッダ部に , コメントとして表示するタイトルを指
定します。
指定されたタイトル文字は , 先頭頁から出力されます。
.TITLE 命令は , ソースプログラム上で 1 回のみ指定可能です。
タイトルの長さは 60 文字までです。
【例】
図 10.9-2 .TITLE 命令の出力例
ソースプログラム
.TITLE "TEST PROGRAM"
アセンブルリスト
TEST PROGRAM
TEST PROGRAM
TEST PROGRAM
186
CM81-00208-5, September 1, 2014
Support
10.9.3
Soft
Ma nual
.HEADING 命令
アセンブルリストの各頁のヘッダ部に , コメントとして表示するタイトルを指定し
ます。
指定されたタイトル文字は , 本命令で強制的に改頁されて本頁から出力されます。
.HEADING 命令は , ソースプログラム上で何回でも指定でき , その都度有効となりま
す。
■ .HEADING 命令
【記述形式】
" タイトル文字 "
.HEADING
【説明】
アセンブルリストの各ページのヘッダ部に , コメントとして表示するタイトルを指
定します。
指定されたタイトル文字は , 本命令で強制的に改頁されて本頁から出力されます。
本命令が頁の第 1 行目にあたる場合は , 本頁から出力されます。
.LIST OFF が指定されている場合は , .LIST ON になってから頁の先頭行に出力され
ます。
.HEADING 命令は , ソースプログラム上で何回も指定でき , その都度有効となりま
す。
タイトルの長さは 60 文字までです。
【例】
図 10.9-3 .HEADING 命令の出力例
ソースプログラム
.HEADING "PROGRAM=TEST1\"V1.0L2.0\""
:
.HEADING "PROGRAM=TEST2\"V1.0L2.0\""
アセンブルリスト
PROGRAM=TEST3 "V1.0L2.0"
PROGRAM=TEST2 "V1.0L2.0"
PROGRAM=TEST1 "V1.0L2.0"
:
.HEADING "PROGRAM=TEST3\"V1.0L2.0\""
:
September 1, 2014, CM81-00208-5
187
Su pp or t
So ft
Manu al
.LIST 命令
10.9.4
アセンブルリストの出力形式を詳細に指定します。
.LIST 命令は , ソースプログラム上で何回でも指定でき , その都度有効となります。
.LIST 命令は , ON または OFF 指定がある場合 , .LIST 命令自身は出力されません。
初期値は , .LIST ON, CALL, COND, DEF, EXPOBJ, INC です。
■ .LIST 命令
【記述形式】
.LIST
指定 :
指定 [, 指定 ]…
{ON|OFF}
…アセンブルソースリスト出力制御
{CALL|NOCALL}
…マクロコール命令の出力制御
{COND|NOCOND}
…非テキスト部の出力制御
{DEF|NODEF}
…マクロ命令およびマクロ定義部の出力制御
{EXP|NOEXP|EXPOBJ}
…マクロ展開されたテキストの出力制御
{INC|NOINC}
…インクルードファイルのテキストの出力制御
【説明】
アセンブルリストの出力形式を詳細に指定します。
.LIST 命令は , ソースプログラム上で何回でも指定でき , その都度有効となります。
.LIST 命令は , ON または OFF 指定がある場合 , .LIST 命令自身は出力されません。
初期値は , .LIST ON, CALL, COND, DEF, EXPOBJ, INC, STR です。
.LIST 命令の各指定の意味は次のとおりです。
- ON
: アセンブルソースリストを出力します。
- OFF
: アセンブルソースリストを出力しません。
- CALL
: マクロコール命令をリストに出力します。
- NOCALL : マクロコール命令をリストに出力しません。
- COND
: 非テキスト部 * をリストに出力します。
- NOCOND : 非テキスト部をリストに出力しません。
- DEF
: マクロ定義部 , マクロ命令をリストに出力します。
- NODEF
: マクロ定義部 , マクロ命令をリストに出力しません。
- EXP
: マクロ展開されたテキストをリストに出力します。
- NOEXP
: マクロ展開されたテキストをリストに出力しません。
- EXPOBJ : オブジェクトコードのみリストに出力します ( マクロ展開されたテキ
ストはリストに出力しません )。
188
- INC
: インクルードファイルのテキストをリストに出力します。
- NOINC
: インクルードファイルのテキストをリストに出力しません。
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
*:非テキスト部とは , if 節でアセンブルの対象とならない部分のことです。
【例】
.LIST
ON
:
/* この部分はリストに出力されます
:
*/
:
.LIST
OFF
:
/* この部分はリストに出力されません */
:
:
.LIST
ON
■ 起動時オプションとの関係
● -linc ON を指定した場合
INC/NOINC 指定は無効となり , 常にインクルードファイルのテキストはリストに出力
されます。
● -linc OFF を指定した場合
INC/NOINC 指定は無効となり , 常にインクルードファイルのテキストはリストに出力
されません。
● -lexp ON を指定した場合
EXP/NOEXP/EXPOBJ 指定は無効となり , 常にマクロ展開されたテキストはリストに出
力されます。
● -lexp OFF を指定した場合
EXP/NOEXP/EXPOBJ 指定は無効となり , 常にマクロ展開されたテキストはリストに出
力されません。
● -lexp OBJ を指定した場合
EXP/NOEXP/EXPOBJ 指定は無効となり , 常にマクロ展開されたテキストのオブジェク
トコードのみがリストに出力されます。
September 1, 2014, CM81-00208-5
189
Su pp or t
10.9.5
So ft
Manu al
.PAGE 命令
頁番号を更新してアセンブルリストの印字を次頁から開始します。
頁の先頭行に .PAGE 命令があった場合は , .PAGE 命令は無効となります。
.PAGE 命令自身は出力されません。
■ .PAGE 命令
【記述形式】
.PAGE
【説明】
頁番号を更新してアセンブルリストの印字を次頁から開始します。
頁の先頭行に .PAGE 命令があった場合は , .PAGE 命令は無効となります。
.PAGE 命令自身は出力されません。
【例】
図 10.9-4 .PAGE 命令の出力例
ソースプログラム
アセンブルリスト
ページ n
.DATA 10
.DATA 20
.DATA 10
.PAGE
.DATA 20
.DATA 30
.DATA 40
190
.DATA 30
ページ n+1
.DATA 40
CM81-00208-5, September 1, 2014
Support
10.9.6
Soft
Ma nual
.SPACE 命令
指定された分の空白行を出力します。
値の範囲は , 0 ~ 255 です。
.SPACE 命令自身は , リスト出力されませんが行数はカウントされます。
■ .SPACE 命令
【記述形式】
.SPACE
空白行数
空白行数 : 式 ( 絶対式 )
【説明】
空白行数で指定された分の空白行数を出力します。
式は , 絶対式でなければなりません。
空白行数の値の範囲は , 0 ~ 255 までです。
頁を超える空白行の指定があった場合 , 頁最終行以降の空白行は出力しません。
.SPACE 命令自身は , リスト出力されませんが行数はカウントされます。
【例】
.SPACE
September 1, 2014, CM81-00208-5
4
191
Su pp or t
192
So ft
Manu al
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
第 11 章
プリプロセッサ処理
プリプロセッサ処理では , マクロ展開 , リピート展
開 , 条件アセンブル , マクロ置換 , ファイル読み込
みなどのテキスト処理ができます。
この機能により同じようなテキストを繰り返して
記述を行うアセンブリ言語プログラムを効率よく
プログラミングできます。
プリプロセッサの各命令は C 言語と共有化しやす
いように C コンパイラのプリプロセッサの仕様に
合わせてあります。
ただし , #macro 命令など , C コンパイラにはない ,
アセンブラ独自の仕様も含まれています。
この章では , プリプロセッサの機能と各命令を説明
します。
11.1 プリプロセッサ
11.2 プリプロセッサの基本規則
11.3 プリプロセッサの式
11.4 マクロ定義
11.5 マクロコール命令
11.6 リピート展開
11.7 条件付きアセンブル命令
11.8 マクロ名の置換処理
11.9 #include 命令
11.10 #line 命令
11.11 #error 命令
11.12 #pragma 命令
11.13 空命令
11.14 既定義マクロ名
11.15 C 言語プリプロセッサとの違い
September 1, 2014, CM81-00208-5
193
Su pp or t
So ft
Manu al
11.1 プリプロセッサ
プリプロセッサは , 一般的に前処理プログラムとよばれ , 実際にアセンブルを行う前
にテキストの加工処理を行うプログラムです。
プリプロセッサには , 大きく 4 つの機能があります。
• マクロ定義
• 条件アセンブル
• マクロ名の置換処理
• ファイルの読込み
■ プリプロセッサ
● マクロ定義
複数の命令または , ある処理単位を 1 つの命令で実現したい場合があります。
このような場合にマクロ定義は有効です。
このとき , 定義する命令列のテキスト部分を「マクロボディ」といいます。
マクロコールすることによりマクロボディが展開されます。
このマクロボディには , 機械命令 , 擬似命令 , マクロ名のほかに仮引数 , #local 命令 ,
ローカルシンボルを記述できます。
【例】
#macro
get_timer
#local
loop
addr,reg
loop:
MOV
A,#addr
CMP
A,#0
BEQ
loop
MOV
reg, A
マクロボディ
マクロ定義
#endm
/* get_timerがマクロコール命令 */
/* addr,regl,reg2が仮引数 */
/*loopがローカルシンボル */
get_timer
0x100, R1 /* マクロコール */
__0000000001loop:
194
MOV
A,#0x100
CMP
A,#0
BEQ
__0000000001loop
MOV
R1,A
マクロ展開
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
● 条件アセンブル
例えば , ある条件によりアセンブルしたい命令としたくない命令とがある場合は , 次の
ように書きます。
#if
CPU_TYPE==1
テキスト 1
#else
テキスト 2
#endif
この場合 , CPU_TYPE が 1 であればテキスト 1 が選択されてアセンブルされます。
CPU_TYPE が 1 以外であればテキスト 2 が選択されてアセンブルされます。
条件アセンブルを行う命令を条件付きアセンブル命令といいます。
条件付きアセンブル命令には , #if, #ifdef, #ifndef, #elif, #else, #endif 命令があります。
● マクロ名の置換処理
プリプロセッサの大事な機能として , マクロ名の置換処理があります。
例えば , ある定数値を使う場合 ,
MOV
A, #0xFF
と直接書くよりも , 0xFF を何か意味のある名前に定義して ,
#define IOMASK
MOV
0xFF
A, #IOMASK
と書いた方が , プログラムがわかりやすくなります。
このとき , IOMASK という名前を 0xFF に置き換える ( 置換 ) する機能をマクロ置換と
いいます。
September 1, 2014, CM81-00208-5
195
Su pp or t
So ft
Manu al
● ファイルの読み込み
共通で使う変数やマクロ名を別ファイルにしておいて , 必要なファイルを読み込んで
使用すると便利です。
【例】
ファイル iodef.h
#define IOMASK
#define SETCMD
:
0xFF
1
/* I/O のマスク値 */
/* データセットコマンド */
ファイル com.asm
#include "iodef.h"
:
MOV
A, R2
AND
A, #IOMASK
MOV
R2, A
MOV
MOV
MOV
196
A, #SETCMD
A, R7
@A, T
/* デファイン値の読み込み */
/* データをマスク */
/* データセットコマンドを送る */
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
11.2 プリプロセッサの基本規則
プリプロセッサ命令を使ったプログラムの書き方 , およびその規則について説明し
ます。
■ プリプロセッサ命令の記述形式
プリプロセッサ命令は , すべて先頭に "#" を付加して記述します。
プリプロセッサ命令を次に示します。
#macro
#local
#exitm
#endm
#repeat
#if
#ifdef
#ifndef
#elif
#else
#endif
#define
#set
#undef
#purge
#include
#line
#error
#pragma
#
■ コメント
コメントは , 任意のカラムから始めることができます。
セミコロン (;) または 2 個のスラッシュ (//) で行コメントとなります。
C 言語風に /* ~ */ で囲ってコメントを記述することもできます。
/* ~ */ で囲ったコメントは , 好きな位置にコメントを記述できます。
■ 行の継続
行の最後にバックスラッシュ (\) を置くことによって次の行に継続できます。
継続を意味するバックスラッシュ (\) の位置に次の行の先頭が続きます。
バックスラッシュ (\) の次の文字に改行以外の文字がある場合は , 継続しません。
■ 整数定数
整数定数には , 2 進定数 , 8 進定数 , 10 進定数 , 16 進定数の 4 種類があります。
■ 文字定数
文字定数は文字をシングルクォート (') で囲って記述します。
■ マクロ名
マクロ名は , テキストに出現するたびに定義されている定義文字の列に置き換えたり ,
マクロ展開したりします。
■ 仮引数
仮引数は , マクロ定義 (#macro 命令 ) で定義され , マクロコール命令で引数を設定でき
ます。
September 1, 2014, CM81-00208-5
197
Su pp or t
So ft
Manu al
■ ローカルシンボル
ローカルシンボルは , マクロ展開時に自動的にユニークな名前を生成します。
したがって , マクロボディ内でジャンプシンボルなどをローカルシンボルに定義して
おけば , 何回マクロ展開されてもシンボルの 2 重定義になることはありません。
198
CM81-00208-5, September 1, 2014
Support
11.2.1
Soft
Ma nual
プリプロセッサ命令の記述形式
プリプロセッサ命令は , すべての先頭に "#" を付加して記述します。
第 1 カラムからプリプロセッサ命令の間に空白やコメントを記述してもかまいませ
ん。
ただし , 行コメントを記述した場合は , 行終端までコメント扱いとなります。
■ プリプロセッサ命令の記述形式
【記述形式】
# プリプロセッサ命令 [ パラメタ…]
【説明】
プリプロセッサ命令は , すべて先頭に "#" を付加して記述します。
第 1 カラムからプリプロセッサ命令の間に空白やコメントを記述してもかまいませ
ん。
ただし , 行コメントを記述した場合は , 行終端までコメント扱いとなります。
"#" の後に続くプリプロセッサ命令はマクロ置換の対象にはなりません。
プリプロセッサ命令を次に示します。
#macro
#local
#exitm
#endm
#repeat
#if
#ifdef
#ifndef
#elif
#else
#endif
#define
#set
#undef
#purge
#include
#line
#error
#pragma
#
【例】
#define LINEMAX 255
#ifndef OFF
/* OFF */ #define
OFF
0
/* ON
ON
-1
*/ #define
/* 1 ではない */
#endif
September 1, 2014, CM81-00208-5
199
Su pp or t
11.2.2
So ft
Manu al
コメント
コメントには , 行コメントと範囲コメントがあります。
行コメントは , セミコロン (;) または 2 個のスラッシュ (//) で始まります。
C 言語風に , /* ~ */ で囲ってコメントを記述することもできます。これと範囲コメ
ントといいます。
■ コメント
【記述形式】
/* 範囲コメント */
// 行コメント
; 行コメント
【説明】
コメントは , 任意のカラムから始めることができます。
コメントには , 行コメントと範囲コメントがあります。
行コメントは , セミコロン (;) または 2 個のスラッシュ (//) で始まります。
C 言語風に , /* ~ */ で囲ってコメントを記述することもできます。これを範囲コメ
ントといいます。
範囲コメントは , 好きな位置にコメントを記述できます。
【例】
/*---------コメント
------------*/
#define STRLEN
; 文字の長さ
10
/* test1 */ #if
TEST == 1
// テストモード 1
:
/* test2 */ #elif TEST == 2
/* 特殊なテスト */
:
/* end */
200
#endif
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
11.2.3 行の継続
行の最後にバックスラッシュ (\) を置くことによって , 次の行に継続できます。
継続を意味するバックスラッシュ (\) の位置に次の行の先頭が続きます。
バックスラッシュ (\) の次の文字に改行以外の文字がある場合は , 継続しません。
■ 行の継続
【記述形式】
\ 改行
【説明】
行の最後にバックスラッシュ (\) を置くことによって , 次の行に継続できます。
継続を意味するバックスラッシュ (\) の位置に次の行の先頭が続きます
バックスラッシュ (\) の次の文字に改行以外の文字がある場合は , 継続しません。
行の継続は , コメント , 文字定数 , 文字列の途中にも指定できます。
【例】
.DATA
0x01, 0x02, 0x03, \
0x04, 0x05, 0x06, ; コメント \
0x07, 0x08, 0x09
.SDATA
"abcdefghijklmnopqrstuvwxyz \
ABCDEFGHIJKLMNOPQRSTUVWXYZ"
September 1, 2014, CM81-00208-5
/* 文字列の継続 */
201
Su pp or t
11.2.4
So ft
Manu al
整数定数
整数定数には , 2 進定数 , 8 進定数 , 10 進定数 , 16 進定数の 4 種類があります。
アセンブルフェーズの数値定数と全く同じです。
■ 整数定数
整数定数には , 2 進定数 , 8 進定数 , 10 進定数 , 16 進定数の 4 種類があります。
C 言語の long 型指定 (123L など ), unsigned 型指定 (123U など ) もサポートしています。
● 2 進定数
2 進法で表された整数定数です。
プリフィックス (B' または 0b) を付けるか , サフィックス (B) を付けて記述します。
プリフィックス(B'または0b), サフィックス(B)は大文字でも小文字でもかまいません。
【例】
B'0101
0b0101
0101B
● 8 進定数
8 進法で表された整数定数です。
プリフィックス (Q' または 0) を付けるか , サフィックス (Q) を付けて記述します。プリ
フィックス (Q'), サフィックス (Q) は大文字でも小文字でもかまいません。
【例】
Q'377
0377
377Q
● 10 進定数
10 進法で表された整数定数です。
プリフィックス (D') を付けるか , サフィックス (D) を付けて記述します。
プリフィックス , サフィックスは 10 進定数のみ省略可能です。
プリフィックス (D'), サフィックス (D) は大文字でも小文字でもかまいません。
【例】
D'12345676
1234567
1234567D
● 16 進定数
16 進法で表された整数定数です。
プリフィックス (H' または 0x) を付けるか , サフィックス (H) を付けて記述します。
プリフィックス(H'または0x), サフィックス(H)は大文字でも小文字でもかまいません。
【例】
H'ff
202
0xFF
0FFH
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
文字定数
11.2.5
文字定数は文字の値を示します。
文字定数は文字定数要素をシングルクォート (') で囲って記述します。
アセンブルフェーズの文字定数と全く同じです。
■ 文字定数
文字定数は文字定数要素をシングルクォート (') で囲って記述します。
文字定数要素には , 文字 , 拡張表記 , 8 進表記 , 16 進表記があります。
文字定数要素は , 4 文字まで指定可能です。
文字定数は , 256 進法の扱いとなります。
■ 文字定数要素
● 文字
バックスラッシュ (\), シングルクォート (') を除くすべての文字と空白文字は単独で文
字定数要素となります。
【例】
'P'
'@A'
'0A"'
● 拡張表記
バックスラッシュ (\) の後に特定の文字を続けて文字定数要素とします。
これを拡張表記とよびます。
拡張表記を表 11.2-1 に示します。
表 11.2-1 拡張表記
文字
改行文字
水平タブ文字
後退文字
復帰文字
改ページ文字
バックスラッシュ
シングルクォート
ダブルクォート
警報文字
垂直タブ文字
疑問符
文字定数要素
値
\n
\t
\b
\r
\f
\\
\'
\”
\a
\v
\?
0x0A
0x09
0x08
0x0D
0x0C
0x5C
0x27
0x22
0x07
0x0B
0x3F
( 注意事項 ) 拡張表記として用いられる文字は , 小文字のみです。
【例】
'\n'
September 1, 2014, CM81-00208-5
'\''
'\"\\'
203
Su pp or t
So ft
Manu al
● 8 進表記
文字コードのビットパターンを直接表記して 1 バイトデータを表現します。
8 進表記は , バックスラッシュ (\) の後に 1 から 3 文字の 8 進数字を続けたものです。
【例】
文字定数要素
ビットパターン
'\0'
b'00000000
'\377'
b'11111111
'\53'
b'00101011
'\0123'
b'00001010 → '\012' と '3' に分かれます
● 16 進表記
文字コードのビットパターンを直接表記して 1 バイトデータを表現します。
16 進表記は , バックスラッシュ (\) の後に文字 x( 小文字 ) と 1 文字か 2 文字の 16 進文
字を続けたものです。
【例】
204
文字定数要素
ビットパターン
'\x0'
b'00000000
'\xff'
b'11111111
'\x2B'
b'00101011
'\x0A5'
b'00001010 → '\x0A' と '5' に分かれます
CM81-00208-5, September 1, 2014
Support
11.2.6
Soft
Ma nual
マクロ名
マクロ名は , テキストに出現するたびに定義されている定義文字の列に置き換えた
り , マクロ展開したりします。
なお , C 言語ではマクロ名を識別子とよぶ場合があります。
■ マクロ名の規則
• 255 文字以内です。
• 先頭文字は , 英字 , アンダスコア (_) です。
• 2 文字目以降は , 英字 , 数字 , アンダスコア (_) で構成されます。
• 大文字 , 小文字は区別されます。
【例】
A
Zabcde
ppTRUE
_123456789
■ マクロ名の種類
● デファインマクロ
#define 命令 , #set 命令で定義したマクロ名をいいます。
テキストのどの場所にも記述でき , マクロ名が出現するたびに , 定義されている文字に
置き換えます。
【例】
#define TRUE
1
#define FALSE
0
#define add(a, b)
(a)+(b)
/* この場合 , TREU, FALSE, add がマクロ名となります。*/
● マクロコール命令
#macro 命令で定義したマクロ名をいいます。
行の先頭からマクロコール命令の間には空白とコメントしか記述できません。
ただし , 行コメントの場合は行終端までコメント扱いとなります。
マクロコール命令は定義されているテキストをマクロ展開します。
【例】
#macro
max
a, b, c
:
#endm
/* この場合 , max がマクロ名となります。*/
September 1, 2014, CM81-00208-5
205
Su pp or t
11.2.7
So ft
Manu al
仮引数
仮引数は , マクロ定義 (#macro 命令 ) で定義され , マクロコール命令で引数を設定
できます。
■ 仮引数の名前の規則
仮引数の名前は , 「11.2.6 マクロ名」のマクロ名の規則に準じます。
■ 仮引数の置換規則
仮引数が置換できる場所は , マクロボディ内のみです。
仮引数は , マクロ展開が終了すると効力を失います。
【例】
#macro
mv
reg1 , reg2
MOV
R0, reg2
MOV
reg2 , reg1
mv
R1 , R2
MOV
R0 , R2
MOV
R2 , R1
MOV
reg1, R0
マクロボディ
#endm
/* マクロコール */
マクロ展開
/* ここはマクロボディ外なので,reg1は */
/* 仮引数とは認識されず置換されません。 */
206
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
ローカルシンボル
11.2.8
ローカルシンボルは , マクロ展開時に自動的にユニークな名前を生成します。
したがって , マクロボディ内でのジャンプシンボルなどをローカルシンボル定義し
ておけば , 何回マクロ展開されてもシンボルの 2 重定義になることはありません。
■ ローカルシンボルの名前規則
ローカルシンボルの名前は , 「11.2.6 マクロ名」のマクロ名の規則に準じます。
■ ローカルシンボルの置換規則
ローカルシンボルが置換できる場所は , マクロボディ内のみです。
ローカルシンボルは次の形式で試製されます。
__nnnnn ローカルシンボル
2 個のアンダスコア (_) で始まり 5 桁の数字が続きます。
この 5 桁の数値は , マクロコールされるたびに 1 つ値が増加され , 00001 ~ 65535 まで
の値を生成します。
次に , 5 桁の数値の後にユーザが指定したローカルシンボル名が続きます。
ローカルシンボルは , マクロ展開が終了すると効力を失います。
【例】
#macro
get _timer
#local
loop
addr, reg
#local命令で,loopをローカルシンボル
として定義
loop:
MOV
A,#addr
CMP
A,#0
BEQ
loop
MOV
reg, A
マクロボディ
#endm
get_timer
0x0100, R1
/* マクロコール */
__00001loop
MOV
A, 0x010
CMP
A, #0
BEQ
__00001loop
MOV
R1, A
BRA
loop /* ここはマクロボディ外なので,loopは */
マクロ展開
loopの部分が, __00001loopと置換
されています。
/* ローカルシンボルとは認識されず置換されません。 */
September 1, 2014, CM81-00208-5
207
Su pp or t
So ft
Manu al
11.3 プリプロセッサの式
プリプロセッサの式は , #if, #elif, #set, #repeat 命令で使用されます。
式の演算子などは , C 言語の定数式に準じています。
■ プリプロセッサの式
式に使用できる項を次に示します。
• 整数定数
• 文字定数
• マクロ名
• 仮引数 ( マクロボディのみ )
マクロ名 , 仮引数は , 置き換えられたものが項となります。
未定義のマクロ名があった場合 , 0 に置き換えられて評価されます。
式は定数式のみ記述できます。
アセンブルフェーズの相対シンボル , 絶対シンボル , EQU シンボル , セクションシンボ
ルなどは使用できません。
【例】
#if (MODE
& 0xff) + 1
> 3
:
#endif
■ プリプロセッサの式の演算精度
式の演算は , 32 ビットで行っております。したがって , 32 ビットを超える演算は保証
しておりませんので注意してください ( エラーにはなりません )。
関係式 , 等価式の場合は , 式の評価が真であれば 1, 偽であれば 0 となります。
208
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
■ プリプロセッサの演算子
演算子は , 式の中で使用されます。
式で使用できる演算子を次に示します。
● 単項演算子
!
論理 NOT
真 / 偽の判定
~
NOT
ビットの判定
+
正
-
負
● 2 項演算子
*
乗算
/
除算
%
剰余算
+
加算
-
減算
<<
左算術シフト
>>
右算術シフト
<
関係演算子
小なり
<=
関係演算子
小なりまたは等しい
>
関係演算子
大なり
>=
関係演算子
大なりまたは等しい
==
関係演算子
等しい
!=
関係演算子
等しくない
&
ビット AND
^
ビット XOR
|
ビット OR
&&
論理 AND
||
論理 OR
September 1, 2014, CM81-00208-5
209
Su pp or t
So ft
Manu al
■ プリプロセッサの演算子の優先順位
表 11.3-1 にプリプロセッサの演算子の優先順位を示します。
表 11.3-1 プリプロセッサの演算子の優先順位
優先順位
210
演算子
結合性
適用される式
1
( )
左
括弧
2
! ~ + -
右
単項式
3
* / %
左
乗法式
4
+ -
左
加法式
5
<<
左
シフト式
6
< <=
左
関係式
7
== !=
左
等価式
8
&
左
ビット AND 式
9
^
左
ビット XOR 式
10
|
左
ビット OR 式
11
&&
左
論理 AND 式
12
||
左
論理 OR 式
>>
> >=
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
11.4 マクロ定義
マクロ定義は , #macro 命令 , マクロボディ , #endm 命令で構成されています。
マクロコール時にはマクロ定義で定義されたマクロボディをマクロ展開します。
■ マクロ定義
【記述形式】
マクロ名 [ 仮引数 [, 仮引数 ]…]
マクロボディ
#macro
#endm
【説明】
マクロ定義は , #macro 命令 , マクロボディ , #endm 命令で構成されています。
#macro 命令から #endm 命令までのテキストをマクロボディといいます。
マクロボディは , マクロ名をキーワードとするマクロ定義体に登録され , マクロ名
を記述することで , マクロ名に対応したマクロボディが展開されます。
このキーワードとなったマクロ名を特にマクロコール命令といいます。
マクロボディの展開をマクロ展開といいます。
■ マクロ定義の規則
マクロボディ内でさらにマクロを定義できません。
マクロボディの大きさは最大約 60K バイトです。この大きさを超えるマクロボディは
登録できません。
【例】
#macro
mac
reg, data
MOVW
A, #data
MOV
A, @A
MOV
reg, A
mac
R2, label
MOVW
A, #label
MOV
A, @A
MOV
R2, A
マクロボディ
マクロ定義
#endm
September 1, 2014, CM81-00208-5
/* マクロコール命令 */
マクロ展開
211
Su pp or t
11.4.1
So ft
Manu al
#macro 命令
#macro 命令は , マクロ定義の開始を宣言し , マクロ名と仮引数の定義を行います。
■ #macro 命令
【記述形式】
#macro マクロ名 [ 仮引数 [, 仮引数 ]…]
【説明】
#macro 命令は , マクロ定義の開始を宣言し , マクロ名と仮引数の定義を行います。
#macro 命令で指定したマクロ名は , マクロコール命令として使用します。
マクロコール命令を使用すると , 定義されているマクロボディが展開されます。
■ #macro 命令の規則
• #macro 命令は , 必ず #endm 命令で定義を終了しなければなりません。
• #macro 命令で同じ名前の仮引数を 2 つ以上指定できません。
• ここで定義した仮引数は , このマクロボディ内でのみ有効です。
• 仮引数の置換は , 単語の区切りで区別され , 仮引数と同じ単語を見つけると直ちに
置換されます。
• マクロ名やローカルシンボルと仮引数の名前が同じ場合は , 仮引数の置換が優先さ
れます。
• 仮引数は , 1 つも指定しなくても構いません。
【例】
#macro
mac
r1, r2, data
MOV
A, data
MOV
r2, r1
MOV
r1, A
マクロボディ
#endm
212
mac
R2, R 7, label
MOV
A,label
MOV
R7, R2
MOV
R2, A
/* マクロコール命令 */
マクロ展開
CM81-00208-5, September 1, 2014
Support
11.4.2
Soft
Ma nual
#local 命令
#local 命令で生成されるシンボルをローカルシンボルといいます。
ローカルシンボルは , マクロコールがあるたびに自動的にユニークな名前を生成し
ます。
■ #local 命令
【記述形式】
#local ローカルシンボル [, ローカルシンボル ]…
【説明】
#local 命令は , ローカルシンボルの定義を行います。
#local 命令で生成されるシンボルをローカルシンボルといいます。
ローカルシンボルは , マクロコールがあるたびに自動的にユニークな名前を生成し
ます。
ローカルシンボルは 2 重定義とならないように単一な名前を生成します。
ローカルシンボルの生成規則は , 「11.2.8 ローカルシンボル」を参照してください。
■ #local 命令の規則
• #local 命令は , マクロボディ内でのみ記述できます。
• ローカルシンボルの定義はいくつも指定できます。
• 同じ名前のローカルシンボルを 2 つ以上指定できません。
• ここで定義したローカルシンボルは , このマクロボディ内でのみ有効です。
• ローカルシンボルの生成は , 単語の区切りで区別され , ローカルシンボルと同じ単
語を見つけると直ちにユニークな名前を生成します。
• マクロ名や仮引数とローカルシンボルの名前が同じ場合は , 仮引数の置換が優先し
ます。
September 1, 2014, CM81-00208-5
213
Su pp or t
So ft
Manu al
【例】
#macro
busyloop data
#local
label
MOVW
A, #data
DECW
A
BNE
label
マクロボディ
label:
#endm
busyloop 10
MOVW
/* マクロコール命令 */
A,#10
__00001loop
214
DECW
A
BNE
__00001loop
マクロ展開
CM81-00208-5, September 1, 2014
Support
11.4.3
Soft
Ma nual
#exitm 命令
#exitm 命令は , マクロ展開 , リピート展開に対して強制終了します。
■ #exitm 命令
【記述形式】
#exitm
【説明】
#exitm 命令は , マクロ展開 , リピート展開に対して強制終了します。
■ #exitm 命令の規則
• #exitm 命令は , マクロボディ内でのみ記述できます。
• #exitm 命令は , 条件付きアセンブル命令に対しては意味を持ちません。
• マクロ展開およびリピート展開がネストになっている場合は , #exitm 命令を囲む
もっとも内側の展開処理を終了します。すべての展開を終了するわけではありませ
ん。
• #exitm 命令は , マクロボディにいくつあっても構いません。
【例】
#macro
mac
cnt
NOP
#if
cnt >= 5
マクロボディ
#exitm
#endif
MOV
A,#cnt
mac
4
#endm
/* マクロコール命令 */
NOP
MOV
A, #4
mac
5
NOP
September 1, 2014, CM81-00208-5
マクロ展開
/* マクロコール命令 */
マクロ展開
215
Su pp or t
11.4.4
So ft
Manu al
#endm 命令
マクロ定義の終了を宣言します。
リピート展開も #endm 命令で展開部テキストを終了します。
■ #endm 命令
【記述形式】
#endm
【説明】
マクロ定義の終了を宣言します。
リピート展開も , #endm 命令で展開部テキストを終了します。
したがって , #endm 命令は , #macro 命令または #repeat 命令と常に対になっていなけ
ればなりません。
【例】
#macro
mac
a,b
.DATA
a,b
#endm
#repeat
3
NOP
#endm
NOP
NOP
リピート展開
NOP
216
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
11.5 マクロコール命令
#macro 命令で定義したマクロ名を記述することでマクロ展開を行います。
この機能をマクロコールといい , 特にこのマクロ名をマクロコール命令といいます。
■ マクロコール命令
【記述形式】
マクロコール命令 [ 引数 [, 引数 ]…]
【説明】
#macro 命令で定義したマクロ名を記述することでマクロ展開を行います。
この機能をマクロコールといい , 特にこのマクロ名をマクロコール命令といいま
す。
■ マクロコール命令の規則
• マクロコールするマクロ名を命令フィールドに記述します。
• マクロ命令は , 使用する前にマクロ定義されていなければなりません。
• 引数にカンマ(, )を含める場合は, 括弧()またはアングルブラケット < >で囲みます。
• () で囲んだ場合は , () 自体も引数に含まれます。
• < > で囲んだ場合は , < > 自体は引数に含まれません。
• マクロ定義とマクロコール命令の引数の数は , 一致する必要がありますが , マクロ
コール命令の引数が少ない場合は , 残りの仮引数に空文字が指定されたものとして
処理を行います。
• 引数に空文字を指定したい場合は , カンマ (, ) を続けて書くかアングルブラケットで
単に < > と書きます。
September 1, 2014, CM81-00208-5
217
Su pp or t
So ft
Manu al
11.6 リピート展開
リピート展開は , #repeat 命令と #endm 命令で構成されています。
展開部テキストには , 繰り返し展開したいテキストを記述します。
リピート展開は , #endm 命令の直後 , 繰り返し回数で指定された回数分だけ展開部
テキストを展開します。
■ リピート展開
【記述形式】
#repeat
繰返し回数
展開部テキスト
#endm
繰返し回数 : プリプロセッサ式
【説明】
リピート展開は , #repeat 命令と #endm 命令で構成されています。
展開部テキストには , 繰り返し展開したいテキストを記述します。
リピート展開は , #endm 命令の直後繰り返し回数で指定された回数分だけ展開部テ
キストを展開します。
#repeat 命令から #endm 命令まではマクロ定義と同じ扱いとなります。また , リピー
ト展開もマクロ展開と同じ扱いとなります。
したがって , リスト制御命令でマクロ定義部の出力制御を行うと , このリピート展
開に対しても同様の処理が行われます。
展開部テキストの大きさは最大約 60K バイトです。この大きさを超える展開部テキ
ストは登録できません。
展開部テキストには , #local 命令は記述できません。
【例】
#repeat
1+2
MOVW
A, @A
PUSHW
A
MOVW
A, @A
PUSHW
A
MOVW
A, @A
PUSHW
A
MOVW
A, @A
PUSHW
A
展開部テキスト
マクロ定義と同じ扱い
#endm
218
リピート展開(マクロ定義と同じ扱い)
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
■ #repeat 命令
【記述形式】
#repeat 繰返し回数
繰返し回数 : プリプロセッサ式
【説明】
#repeat 命令は , 展開部テキストの開始を宣言します。
繰返し回数で指定された回数分だけ展開部テキストを展開します。
■ #repeat 命令の規則
• #repeat 命令は , 必ず #endm 命令で定義を終了しなければなりません。
• 繰返し回数に 0 以下の数字が指定された場合は何も展開されません。
September 1, 2014, CM81-00208-5
219
Su pp or t
So ft
Manu al
11.7 条件付きアセンブル命令
条件によってアセンブルするテキストを選択します。
#if 命令 , #ifdef 命令または #ifndef 命令から , #endif 命令までを #if 節といい , 条件
アセンブルの対象テキストを示します。
■ 条件付きアセンブル命令
【記述形式】
#if 命令 |#ifdef 命令 |#ifndef 命令
テキスト
[#else 命令 |#elif 命令 ]
テキスト
#endif 命令
【説明】
#if 命令 , #ifdef 命令または #ifndef 命令から , #endif 命令までを if 節といい , 条件ア
センブルの対象テキストを示します。
if 節には , #else 命令 , #elif 命令を記述できます。
if 節中に , さらに if 節を記述できます。これを if 節のネストといいます。
条件付きアセンブル命令は次の 6 種類です。
- #if 命令
- #ifdef 命令
- #ifndef 命令
- #elif 命令
- #else 命令
- #endif 命令
220
CM81-00208-5, September 1, 2014
Support
11.7.1
Soft
Ma nual
#if 命令
if 節の開始を宣言します。
条件式が真であれば , 本命令から次の条件付きアセンブル命令までアセンブルされ
ます。
条件式が偽であれば , 本命令から対応する #else 命令 , #elif 命令または #endif 命令
までアセンブルされません。
■ #if 命令
【記述形式】
#if 条件式
条件式 : プリプロセッサ式
【説明】
if 節の開始を宣言します。
条件式は 0 が偽 , 0 以外が真です。
真であれば , 本命令から次の条件付きアセンブル命令までアセンブルされます。
偽であれば , 本命令から対応する #else 命令 , #elif 命令または #endif 命令までアセン
ブルされません。
#if 命令は , #endif 命令で終わります。したがって , #if 命令と #endif 命令は必ず対に
なっていなければなりません。
【例】
#define
ABC
1
#if
ABC == 1
.DATA 0
#endif
/* #if 命令の条件式が真であるため .DATA 0 はアセンブルされます。*/
#if
0
.DATA 100
#endif
/* #if 命令の条件式が偽であるため .DATA 100 はアセンブルされません。*/
September 1, 2014, CM81-00208-5
221
Su pp or t
11.7.2
So ft
Manu al
#ifdef 命令
if 節の開始を宣言します。
マクロ名が定義されていれば真 , 定義されていなければ偽となります。
真であれば , 本命令から次の条件付きアセンブル命令までアセンブルされます。
偽であれば , 本命令から対応する #else 命令 , #elif 命令または #endif 命令までアセ
ンブルされません。
■ #ifdef 命令
【記述形式】
#ifdef マクロ名
【説明】
if 節の開始を宣言します。
マクロ名が定義されていれば真 , 定義されていなければ偽となります。
真であれば , 本命令から次の条件付きアセンブル命令までアセンブルされます。
偽であれば , 本命令から対応する #else 命令 , #elif 命令または #endif 命令までアセン
ブルされません。
#ifdef 命令は , #endif 命令で終わります。したがって , #ifdef 命令と #endif 命令は必
ず対になっていなければなりません。
【例】
#define
ON
#ifdef
ON
.DATA
0
#endif
/* #ifdef 命令のマクロ名 (ON) が定義されているので .DATA 0 は ,
*/
/* アセンブルされます。
*/
#ifdef
OFF
.DATA
100
#endif
222
/* #ifdef 命令のマクロ名 (OFF) は定義されていないので .DATA 100 は ,
*/
/* アセンブルされません。
*/
CM81-00208-5, September 1, 2014
Support
11.7.3
Soft
Ma nual
#ifndef 命令
if 節の開始を宣言します。
マクロ名が定義されていれば偽 , 定義されていなければ真となります。
真であれば , 本命令から次の条件付きアセンブル命令までアセンブルされます。
偽であれば , 本命令から対応する #else 命令 , #elif 命令または #endif 命令までアセ
ンブルされません。
#ifndef 命令は , #ifdef 命令と判定が逆の命令です。
■ #ifndef 命令
【記述形式】
#ifndef マクロ名
【説明】
if 節の開始を宣言します。
マクロ名が定義されていれば偽 , 定義されていなければ真となります。
真であれば , 本命令から次の条件付きアセンブル命令までアセンブルされます。
偽であれば , 本命令から対応する #else 命令 , #elif 命令または #endif 命令までアセン
ブルされません。
#ifndef 命令は , #ifdef 命令と判定が逆の命令です。
#ifndef 命令は , #endif 命令で終わります。したがって , #ifndef 命令と #endif 命令は
必ず対になっていなければなりません。
【例】
#define
ON
#ifndef
ON
.DATA
0
#endif
/* #ifndef 命令のマクロ名 (ON) が定義されているので .DATA 0 は ,
*/
/* アセンブルされません。
*/
#ifndefOFF
.DATA
100
#endif
/* #ifndef 命令のマクロ名 (OFF) は定義されていないので .DATA 100 は , */
/* アセンブルされます。
September 1, 2014, CM81-00208-5
*/
223
Su pp or t
11.7.4
So ft
Manu al
#else 命令
#else 命令は , if 節の中に記述します。
#else 命令は , それまでのアセンブル条件を反転します。
■ #else 命令
【記述形式】
#else
【説明】
#else 命令は , if 節の中に記述します。
#else 命令は , それまでのアセンブル条件を反転します。
if 節開始命令 (#if, #ifdef, #ifndef) の条件が真であった場合 , 逆の偽となり本命令から
は , 対応する #endif 命令までアセンブルされません。
if 節開始命令 (#if, #ifdef, #ifndef) の条件が偽であった場合 , 逆の真となり本命令から
は , 対応する #endif 命令までアセンブルされます。
【例】
#define NUM
#if
3
NUM == 3
.SDATA
"ABC"
.SDATA
"DEF"
/* こちらがアセンブルされます。
*/
.SDATA
"==="
/* こちらがアセンブルされます。
*/
.SDATA
"***"
#else
#endif
#ifdef
NUM
#else
#endif
#ifndef
NUM
.SDATA
"NO"
.SDATA
"OK"
#else
/* こちらがアセンブルされます。
*/
#endif
224
CM81-00208-5, September 1, 2014
Support
11.7.5
Soft
Ma nual
#elif 命令
#elif 命令は , if 節の中に記述します。
#elif 命令は , #else 命令と #if 命令を連続して指定するのと同じ機能です。
したがって , 本命令までアセンブル条件が偽の場合のみ有効になります。
■ #elif 命令
#elif 命令は , if 節の中にいくつでも記述できます。
【記述形式】
#elif 条件式
条件式 : プリプロセッサ式
【説明】
#elif 命令は , if 節の中に記述します。
#elif 命令は , #else 命令と #if 命令を連続して指定するのと同じ機能です。
したがって , 本命令までのアセンブル条件が偽の場合のみ有効になります。
● 本命令までのアセンブル条件が真の場合
本命令から対応する #endif 命令までアセンブルされません。
● 本命令までのアセンブル条件が偽の場合
条件式を判定し再度アセンブル条件を決めます。
真の場合 , 本命令の次から条件付きアセンブル命令までアセンブルされます。
偽の場合 , 本命令から対応する #else 命令 , #elif 命令または #endif 命令までアセンブル
されません。
【例】
#define NUM
3
#if
NUM ==
1
.SDATA
"ABC"
NUM ==
2
.SDATA
"DEF"
NUM ==
3
.SDATA
"GHI"
/* こちらがアセンブルされます。
.SDATA
"==="
/* こちらがアセンブルされます。
NUM ==
3
.SDATA
"***"
#elif
#elif
*/
#endif
#ifdef
#elif
NUM
*/
#endif
September 1, 2014, CM81-00208-5
225
Su pp or t
So ft
Manu al
#ifndef NUM
#elif
.SDATA
"NO"
NUM ==
3
.SDATA
"OK"
/* こちらがアセンブルされます。
*/
#endif
/* 下のように条件が偽しかない場合は , 何もアセンブルされません。 */
#if
#elif
NUM ==
10
.SDATA
"??????"
NUM ==
20
.SDATA
"$$$$$$"
#endif
226
CM81-00208-5, September 1, 2014
Support
11.7.6
Soft
Ma nual
#endif 命令
#endif 命令は , 条件アセンブルの終了を示します。
条件アセンブルがネストしている場合は , もっとも内側の #if, #ifdef, #ifndef 命令に
対して終了します。
■ #endif 命令
【記述形式】
#endif
【説明】
#endif 命令は , 条件アセンブルの終了を示します。
条件アセンブルがネストしている場合は , もっとも内側の #if, #ifdef, #ifndef 命令に
対して終了します。
【例】
#ifndef
_IODEF_
#define
_IODEF_
#define
VER
2
#if
VER ==
1
#define
IOBUFNUM
#elif
VER ==
#define
IOBUFNUM
#elif
VER ==
#define
IOBUFNUM
22
#endif
/* #if VER ==
1 の終わり */
#ifdef
IOCH
#undef
IOCH
#endif
/* #ifdef IOCH の終わり */
#define
IOCH
#endif
/* #ifndef _IODEF_ の終わり */
September 1, 2014, CM81-00208-5
/* アセンブルされます */
/* アセンブルされます */
10
2
15
/* アセンブルされます */
3
4
/* アセンブルされます */
227
Su pp or t
So ft
Manu al
11.8 マクロ名の置換処理
#define 命令はマクロ名を定義します。マクロ名は出現するたびに定義されている文
字に置き換わります。
#set 命令はマクロ名に数値を定義します。式の評価結果が設定されます。
#undef 命令はマクロ名を取り消します。
■ マクロ名の置換処理
テキスト中にマクロ名が出現すると , そのマクロ名に定義されている定義文字の列に
置き換わります。これをマクロ置換といいます。
#define 命令 , #set 命令で定義されたマクロ名はすべてのテキストにおいてマクロ置換
ができます。
■ マクロ置換の規則
仮引数とローカルシンボルの置換処理もこの規則に従います。
次に示すところは , マクロ置換の対象にはなりません。
• プリプロセッサ命令の命令名の部分
• コメントの中の文字
• 文字列の中の文字
【例】
#define
ABC
define
#ABC
NUM
10
#define
MSG
any_string
/* #ABC は , #define とは置換されない */
/* MSG は , any_string とは置換されない
/* MSG */
.SDATA
*/
"MSG" /* .SDATA "MSG" は .SDATA "any_string" とは */
/* 置換されない
*/
• マクロ名はバックスラッシュ (\) を先頭に付けてマクロ名であることを明示できま
す。バックスラッシュ (\) は通常省略できます。
【例】
#define
MD
FPU
#define
SYM
start
.PROGRAM
MD
MD\SYM:
228
/* .PROGRAM FPU と置換
*/
と置換
*/
/* FPU start:
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
• マクロ置換によって置き換えられた文字の列の中にマクロ名が存在する場合は , 再
度マクロ置換を行います。最大 255 回までマクロの置換処理を行います。
【例】
#define
NUM
10
#define
ANUM
(NUM+2)
#define
BNUM
ANUM*3
.DATA
September 1, 2014, CM81-00208-5
BNUM
/* .DATA (10+2)*3 と置換 */
229
Su pp or t
11.8.1
So ft
Manu al
#define 命令
#define 命令は , マクロ名に任意の定義文字の列を定義します。
テキスト中にマクロ名を見つけると , 直ちに定義されている定義文字の列に置き換
えます。
#define 命令には , 引数なし #define 命令と引数付き #define 命令の 2 種類がありま
す。
■ 引数なし #define 命令
【記述形式】
#define マクロ名 定義文字の列
【説明】
引数なしのマクロ名を定義します。
マクロ名には定義文字の列が定義されます。
テキスト中にマクロ名を見つけると直ちに定義されている定義文字の列に置き換
えます。
定義文字の列を省略した場合は , 空文字が定義されます。
#define 命令は , マクロ名に対して一度定義した定義文字の列を変更できません。
【例】
#define
DB
.DATA.B
#define
DW
.DATA.W
DB
0, 2
DW
0xffffffff
■ 引数付き #define 命令
【記述形式】
#define マクロ名 ( 仮引数 [, 仮引数 ]…) 定義文字の列
【説明】
引数付きのマクロ名を定義します。
マクロ名の直後に左括弧 "(" があるとき , 引数付きとなります。マクロ名と左括弧
の間に空白やコメントがあってはなりません。
続いて , 仮引数を指定し最後に右括弧 ")" で閉じます。後は , 定義したい文字を記述
します。
テキスト中にマクロ名を見つけると , まず , 形式のチェックを行い , 仮引数に対応す
る引数に置き換えてからテキストへ展開します。
230
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
引数付きのマクロ置換の形式を次に示します。
マクロ名 ( 引数 , [ 引数 ]…)
引数と仮引数の数は同じでなければなりません。
定義文字の列を省略した場合は , 空文字が定義されます。
#define 命令は , マクロ名に対して一度定義した定義文字の列を変更できません。
【例】
#define
NUM
10
#define
eq(a, b)
a==b
#define
ne(a, b)
a!=b
.DATA
eq(NUM, 10)
/* .DATA (10==10) と置換
*/
.DATA
ne(5, NUM)
/* .DATA (5!=10) と置換
*/
.DATA
eq(ne(5, NUM), 1)
/* .DATA ((5!=10)==1) と置換
*/
September 1, 2014, CM81-00208-5
231
Su pp or t
11.8.2
So ft
Manu al
マクロ仮引数の文字列化 (# 演算子 )
仮引数に対応する引数文字が文字列に置き換わります。
■ マクロ仮引数の文字列化 (# 演算子 )
【記述形式】
# 仮引数
【説明】
# 演算子は , 引数付き #define 命令の定義文字列内でのみ適用されます。
仮引数に対応する引数文字が文字列に置き換わります。
引数文字の前後の空白は削除されて文字列化されます。
【例】
#define
MDL(name)
.SDATA
232
#name
MDL(test)
/* .SDATA "test"と置換*/
CM81-00208-5, September 1, 2014
Support
11.8.3
Soft
Ma nual
マクロ置換の文字の連結 (## 演算子 )
## 演算子は , 前後にある文字を連結します。
■ マクロ置換の文字の連結 (## 演算子 )
【記述形式】
文字 ## 文字
【説明】
## 演算子は , #define 命令の定義文字の列内でのみ適用されます。
マクロ置換において , 定義文字列の中で ## 演算子が記述されたとき , ## 演算子は削
除され ## 演算子の前後にある文字が連結されます。
引数付き #define 命令の場合において , 文字列の中で , 仮引数が ## 演算子の直前ま
たは直後にある場合は , 仮引数に対応する実引数に置き換わり実引数が連結されま
す。
## 演算子で連結された文字はマクロ置換の対象となります。
【例】
#define
abcd
10
#define
val
ab##cd
.DATA
val
val2(x)
x##cd
.DATA
val2(ab)
#define
September 1, 2014, CM81-00208-5
/* .DATA 10 と置換 */
/* .DATA 10 と置換 */
233
Su pp or t
11.8.4
So ft
Manu al
#set 命令
式を評価して , その結果をマクロ名に 10 進定数として定義します。
■ #set 命令
【記述形式】
#set マクロ名 式
式 : プリプロセッサ式
【説明】
式を評価して , その結果をマクロ名に 10 進定数として定義します。
#set 命令は , 同じマクロ名に対して何回でも再設定が可能です。
#define 命令との違いは , #set 命令はマクロ名を変数として利用できます。
【例】
#set
CNT
#repeat
3
#set
1
.DATA
CNT
CNT
CNT+1
.DATA
1
.DATA
2
.DATA
3
#endm
リピート展開
上の例で , #set 命令を #define 命令に置き換えると #define CNT CNT+1 となり , マク
ロ置換の段階で CNT がうまく置換できずエラーとなります。
234
CM81-00208-5, September 1, 2014
Support
11.8.5
Soft
Ma nual
#undef 命令
指定されたマクロ名を取り消します。
■ #undef 命令
【記述形式】
#undef マクロ名
【説明】
指定されたマクロ名を取り消します。
仮引数とローカルシンボルに対しては無効です。
取り消されたマクロ名は , #define 命令で再度定義が可能になります。
【例】
#define
ABC
100*2
.DATA
ABC
#undef
ABC
#define
ABC
"***ABC***"
.SDATA
ABC
September 1, 2014, CM81-00208-5
/* .DATA 100*2 と置換 */
/* .SDATA "***ABC***" と置換 */
235
Su pp or t
11.8.6
So ft
Manu al
#purge 命令
マクロ名を開放します。
■ #purge 命令
【記述形式】
#purge
【説明】
すべてのマクロ名を取り消します。
仮引数とローカルシンボルに対しては無効です。
取り消されたマクロ名は , #define 命令で再度定義が可能になります。
【例】
#define
ABC
100*2
#define
DEF
200*3
.DATA
ABC
/* .DATA 100*2 と置換 */
.DATA
DEF
/* .DATA 200*3 と置換 */
ABC
"***ABC***"
.SDATA
ABC
#purge
#define
236
/* .SDATA "***ABC***" と置換 */
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
11.9 #include 命令
指定されたファイルを読み込み , ソースプログラム内に取り込みます。
■ #include 命令
【記述形式】
#include < ファイル名 >
#include " ファイル名 "
#include ファイル名
【形式 1】
【形式 2】
【形式 3】
【説明】
指定されたファイルを読み込み , ソースプログラム内に取り込みます。
このように #include 命令で読み込まれたファイルをインクルードファイルといいま
す。
インクルードファイル内でさらに #include 命令でファイルを読み込むことができま
す。これをインクルードファイルのネストといいます。
ネストは最大 8 レベルまで可能です。
形式によって , ファイルを検索するディレクトリが違います。
<注意事項>
#include 命令のファイル指定が , 相対形式のファイル指定で記述されている場合は , 現在
のソースファイルのあるディレクトリを基準にファイルを検索します。
■ 形式 1 のファイル検索
形式 1 の場合 , 次の順序でファイルを検索します。
1. 起動時オプション (-I) で指定されたディレクトリを検索
2. 環境変数 "INC896" で指定されているディレクトリを検索
3. 開発環境内のインクルードディレクトリを検索
- %FETOOL%\LIB\896\INCLUDE を検索
September 1, 2014, CM81-00208-5
237
Su pp or t
So ft
Manu al
■ 形式 2 と形式 3 のファイル検索
形式 2 と計式 3 の場合 , 次の順序でファイルを検索します。
1. 記述されているファイル名をそのままアクセス
2. 起動時オプション (-I) で指定されたディレクトリを検索
3. 環境変数 "INC896" で指定されているディレクトリを検索
4. 開発環境内のインクルードディレクトリを検索
- %FETOOL%\LIB\896\INCLUDE を検索
【例】
238
#include
<stdio.h >
#include
"stype.h"
#include
stype.h
#include
<sys\iodef.h >
#include
"..\iodef.h"
#include
\usr\local\iodef.h
CM81-00208-5, September 1, 2014
Support
11.10
Soft
Ma nual
#line 命令
#line 命令は , 次の行の行番号を指定された行番号に変更します。
■ #line 命令
【記述形式】
#line 行番号 [ ファイル名 ]
ファイル名 : 文字列
【説明】
#line 命令は , 次の行の行番号を指定された行番号に変更します。
ファイル名が指定された場合は , ファイル名も変更します。
【例】
#line
1000
"test.asm"
この結果, #line命令の次の行番号は1000になり, ファイル名は"test.asm"になります。
September 1, 2014, CM81-00208-5
239
Su pp or t
11.11
So ft
Manu al
#error 命令
#error 命令は , 指定されたメッセージをエラーとして標準出力へ出力します。
#error 命令以降の処理は行いません。
■ #error 命令
【記述形式】
#error エラーメッセージ
【説明】
#error 命令は , 指定されたメッセージをエラーとして標準出力へ出力します。
#error 命令以降の処理は行いません。
【例】
#error
240
Test program miss!
CM81-00208-5, September 1, 2014
Support
11.12
Soft
Ma nual
#pragma 命令
#pragma 命令は , 何も処理を行いません。
■ #pragma 命令
【記述形式】
#pragma 文字の列
【説明】
#pragma 命令は , C 言語のプリプロセッサとの互換のために用意されています。
しかし , アセンブラには意味のない命令なので , アセンブラでは何も処理を行いま
せん。
September 1, 2014, CM81-00208-5
241
Su pp or t
11.13
So ft
Manu al
空命令
空命令は , 何も処理を行いません。
■ 空命令
【記述形式】
#
【説明】
"#" の後ろに改行のみある場合 , 空命令となります。
空命令は , 何も処理を行いません。
【例】
#
#
#
.SECTION
CODE
:
242
CM81-00208-5, September 1, 2014
Support
11.14
Soft
Ma nual
既定義マクロ名
あらかじめ予約されているマクロ名です。
既定義マクロ名は , #undef 命令で取り消すことはできません。
■ 既定義マクロ名
● __LINE__
現在のソース行の行番号の値を 10 進定数に置換します。
【例】現在のソース行が , 101 行目の場合
.DATA __LINE__
/* .DATA 101 と置換 */
● __FILE__
現在のソースファイル名を文字列に置換します。
【例】現在のソースファイル名が , "t1.asm" の場合
.SDATA __FILE__
/* .SDATA "t1.asm" と置換 */
● __DATE__
アセンブルされた日付を次の形式に置換します。
"Mmm dd yyyy"
Mmm は月名の省略形 , dd は日 , yyyy は西暦を示します。
【例】1966 年 8 月 7 日にアセンブルした場合
.SDATA __DATE__
/* .SDATA "Aug
7 1966" と置換 */
● __TIME__
アセンブルされた時刻を次の形式に置換します。
"hh:mm:ss"
hh は時 , mm は分 , ss は秒を示します。
【例】12 時 34 分 56 秒にアセンブルした場合
.SDATA __TIME__
/* .SDATA "12:34:56" と置換 */
● __FASM__
10 進定数 1 に置換します。
【例】
.DATA __FASM__
/* .DATA 1 と置換 */
● __CPU_8L__
10 進定数 1 に置換します。
F2MC-8L ファミリのみ有効です。
September 1, 2014, CM81-00208-5
243
Su pp or t
So ft
Manu al
● __CPU_8FX__
10 進定数 1 に置換します。
F2MC-8FX ファミリのみ有効です。
■ defined マクロ名
● defined( マクロ名 )
すでにマクロ名が定義されている場合は , 10 進定数の 1 に , 定義されていなければ , 10
進定数の 0 に置き換えます。
【例】
.DATA defined(ABC)
/* .DATA 0 と置換 */
#define ABC
.DATA defined(ABC)
244
/* .DATA 1 と置換 */
CM81-00208-5, September 1, 2014
Support
11.15
Soft
Ma nual
C 言語プリプロセッサとの違い
本アセンブラのプリプロセッサと C 言語プリプロセッサの違いについて説明します。
■ C 言語プリプロセッサとの違い
本アセンブラのプリプロセッサにあり , C 言語プリプロセッサにはない機能は次の 8 種
類です。
• #macro 命令
• #local 命令
• #exitm 命令
• #endm 命令
• #repeat 命令
• #set 命令
• #purge 命令
• __FASM__ 既定義マクロ
また , 本アセンブラのプリプロセッサと C 言語プリプロセッサで仕様の違う機能は次
の 1 種類です。
• #pragma 命令
- 本アセンブラのプリプロセッサ : 何も処理をしません。
- C 言語プリプロセッサ :『C 言語マニュアル』を参照してください。
September 1, 2014, CM81-00208-5
245
Su pp or t
246
So ft
Manu al
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
第 12 章
アセンブラ擬似機械命令
本アセンブラでは , アセンブラ擬似機械命令を記述
できます。
アセンブラ擬似機械命令とは , MCU の持つ命令を
組み合わせることによって , 1 つの機械命令のよう
に記述できる命令です。
この章では , アセンブラ擬似機械命令の各記述形式
とその機能について説明します。
12.1 F2MC-8L/8FX ファミリ用アセンブラ擬似機械命令
September 1, 2014, CM81-00208-5
247
Su pp or t
So ft
Manu al
12.1 F2MC-8L/8FX ファミリ用アセンブラ擬似機械命令
F2MC-8L/8FX ファミリ用アセンブラ擬似機械命令として , 3 種類の命令を記述でき
ます。
また , 分岐先までの距離を計算し最適なコードを配置する分岐命令として , 次の種類
の命令を記述できます。
■ F2MC-8L/8FX ファミリ用アセンブラ擬似機械命令
F2MC-8L/8FX ファミリ用アセンブラ擬似機械命令として , 次の種類の命令を記述でき
ます。
• 分岐系擬似機械命令
• 演算系擬似機械命令
• その他の擬似機械命令
また , 分岐先までの距離を計算して最適なコードを配置する分岐命令として , 次の種類
の命令を記述できます。
• 最適配置分岐擬似機械命令
248
CM81-00208-5, September 1, 2014
Support
12.1.1
Soft
Ma nual
分岐系擬似機械命令
分岐系擬似機械命令として , 次の命令を記述できます。
BV, BNV, BLE, BGT, BLS, BHI
■ 分岐系擬似機械命令
分岐系擬似機械命令として , 表 12.1-1 に示す命令を記述できます。
表 12.1-1 分岐系擬似機械命令
記述形式
条件
展開
備考
BV
label
V=1 で分岐
BN
BLT
JMP
BGE
$+7
label
$+5
label
次の命令のアドレスか
ら -128 ~ 122 バイト
の範囲で分岐可能
BNV
label
V=0 で分岐
BN
BGE
JMP
BLT
$+7
label
$+5
label
次の命令のアドレスか
ら -128 ~ 122 バイト
の範囲で分岐可能
BLE
label
(ZorNorV)=1で分岐
BEQ
BLT
label
label
次の命令のアドレスか
ら -128 ~ 125 バイト
の範囲で分岐可能
BGT
label
(ZorNorV)=0で分岐
BEQ
BGE
$+4
label
次の命令のアドレスか
ら -128 ~ 127 バイト
の範囲で分岐可能
BLS
label
(ZorN)=1 で分岐
BEQ
BLO
label
label
次の命令のアドレスか
ら -128 ~ 125 バイト
の範囲で分岐可能
BHI
label
(ZandN)=0
BEQ
BHS
$+4
label
次の命令のアドレスか
ら -128 ~ 127 バイト
の範囲で分岐可能
September 1, 2014, CM81-00208-5
249
Su pp or t
12.1.2
So ft
Manu al
演算系擬似機械命令
演算系擬似機械命令として , 次の命令を記述できます。
NOTA, TESTA
■ 演算系擬似機械命令
演算系擬似機械命令として , 表 12.1-2 に示す命令を記述できます。
表 12.1-2 演算系擬似機械命令
記述形式
250
フラグ変化
展開
備考
NOTA
Z, N
XOR A, #0FFH
A,T 動作は行われません
TESTA
Z, N, V, C
CMP A, #00H
アキュムレータの内容が
0 か判定します
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
その他の擬似機械命令
12.1.3
その他の擬似機械命令として , 次の命令を記述できます。
PUSHAT, POPAT, SETRP, SETRPA, SETDB, SETDBA
■ その他の擬似機械命令
その他の擬似機械命令として , 表 12.1-3 に示す命令を記述できます。
表 12.1-3 その他の擬似機械命令 (1 / 2)
記述形式
フラグ変化
展開
PUSHAT
PUSHW A
XCHW A, T
PUSHW A
POPAT
POPW
XCHW
POPW
SETRP
#imm
備考
この命令の実行後は A と T の内容
は入れ替わります
A
A, T
A
【F2MC-8L ファミリ】
MOVW A, PS
MOVW A, #07FFH
ANDW A
MOVW A, #(imm < <11)
ORW
A
MOVW PS, A
この命令では A と T の内容は保存
されません。
この命令は F2MC-8L ファミリと
F2MC-8FX ファミリで展開が異なり
ます。
【F2MC-8FX ファミリ】
MOV
A, 0x78
AND
A, #3
OR
A, #(imm < < 3)
MOV
0x78, A
September 1, 2014, CM81-00208-5
251
Su pp or t
So ft
Manu al
表 12.1-3 その他の擬似機械命令 (2 / 2)
記述形式
SETRPA
フラグ変化
展開
【F2MC-8L ファミリ】
MOVW A, #001FH
ANDW A
PUSHW A
MOVW A, PS
MOVW A, #07FFH
ANDW A
XCHW A, T
POPW A
CLRC
ROLC
A
ROLC
A
ROLC
A
SWAP
ORW
A
MOVW PS, A
備考
この命令では A と T の内容は保存
されません。
この命令は F2MC-8L ファミリと
F2MC-8FX ファミリで展開が異なり
ます。
【F2MC-8FX ファミリ】
CLRC
ROLC
A
ROLC
A
ROLC
A
MOV
A, 0x78
AND
A, #3
OR
A
MOV
0x78, A
252
SETDB #imm
MOV
AND
OR
MOV
A, 0x78
A, #0xF8
A, #(imm & 7)
0x78, A
この命令では A と T の内容は保存
されません。
この命令は F2MC-8FX ファミリで
のみ有効です。
SETDBA
AND
MOV
AND
OR
MOV
A, #7
A, 0x78
A, #0xF8
A
0x78, A
この命令では A と T の内容は保存
されません。
この命令は F2MC-8FX ファミリで
のみ有効です。
CM81-00208-5, September 1, 2014
Support
12.1.4
Soft
Ma nual
最適配置分岐擬似機械命令
最適配置分岐擬似機械命令は , 分岐先までの距離を計算し , 相対分岐が可能であるか
の判断を行い , 最適なコードを配置する擬似機械命令です。
最適配置分岐擬似機械命令として , 次の命令を記述できます。
Bcc16
■ 最適配置分岐擬似機械命令
最適配置分岐擬似機械命令は , 分岐先までの距離を計算し , 相対分岐が可能であるかの
判断を行い , 最適なコードを配置する擬似機械命令です。
最適配置分岐擬似機械命令として , 表 12.1-4 に示す命令を記述できます。
表 12.1-4 最適配置分岐擬似機械命令 (1 / 3)
分岐拡張命令
BZ16
BNZ16
BEQ16
BNE16
BC16
BNC16
BLO16
BHS16
September 1, 2014, CM81-00208-5
label
label
label
label
label
label
label
label
動作
(Z)=1 なら分岐
(Z)=0 なら分岐
(Z)=1 なら分岐
(Z)=0 なら分岐
(C)=1 なら分岐
(C)=0 なら分岐
(C)=1 なら分岐
(C)=0 なら分岐
距離
-128 ~ +127
生成される命令
BZ
label
その他
BNZ
JMP
$+5
label
-128 ~ +127
BNZ
label
その他
BZ
JMP
$+5
label
-128 ~ +127
BEQ
label
その他
BNE
JMP
$+5
label
-128 ~ +127
BNE
label
その他
BEQ
JMP
$+5
label
BC
label
その他
BNC
JMP
$+5
label
-128 ~ +127
BNC
label
その他
BC
JMP
$+5
label
-128 ~ +127
BLO
label
その他
BHS
JMP
$+5
label
-128 ~ +127
BHS
label
その他
BLO
JMP
$+5
label
-128 ~ +127
253
Su pp or t
So ft
Manu al
表 12.1-4 最適配置分岐擬似機械命令 (2 / 3)
分岐拡張命令
BN16
BP16
BLT16
BGE16
BBC16
BBS16
BV16
BNV16
BLE16
254
label
label
label
label
bit, label
bit, label
label
label
label
動作
(N)=1 なら分岐
(N)=0 なら分岐
(V)xor(N)=1 なら分岐
(V)xor(N)=0 なら分岐
(bit)=0 なら分岐
(bit)=1 なら分岐
(V)=1 なら分岐
(V)=0 なら分岐
(Z)or((N)or(V))=1
なら分岐
距離
生成される命令
-128 ~ +127
BN
label
その他
BP
JMP
$+5
label
BP
label
その他
BN
JMP
$+5
label
-128 ~ +127
BLT
label
その他
BGE
JMP
$+5
label
-128 ~ +127
BGE
label
その他
BLT
JMP
$+5
label
-128 ~ +127
BBC
label
その他
BBS
JMP
$+6
label
-128 ~ +127
BBS
label
その他
BBC
JMP
$+6
label
-128 ~ +122
BN
BLT
JMP
BGE
$+7
label
$+5
label
その他
BN
BGE
JMP
BLT
JMP
$+7
$+10
label
$+5
label
-128 ~ +122
BN
BGE
JMP
BLT
$+7
label
$+5
label
その他
BN
BLT
JMP
BGE
JMP
$+7
$+10
label
$+5
label
-128 ~ +125
BEQ
BLT
label
label
その他
BEQ
BGE
JMP
$+4
$+5
label
-128 ~ +127
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
表 12.1-4 最適配置分岐擬似機械命令 (3 / 3)
分岐拡張命令
BGT16
BLS16
BHI16
September 1, 2014, CM81-00208-5
label
label
label
動作
(Z)or((N)or(V))=0
なら分岐
(Z)or(C)=1 なら分岐
(Z)or(C)=0 なら分岐
距離
生成される命令
-128 ~ +127
BEQ
BGE
$+4
label
その他
BEQ
BLT
JMP
$+7
$+5
label
-128 ~ +125
BEQ
BLO
label
label
その他
BEQ
BHS
JMP
$+4
$+5
label
-128 ~ +127
BEQ
BHS
$+4
label
その他
BEQ
BLO
JMP
$+7
$+5
label
255
Su pp or t
256
So ft
Manu al
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
第 13 章
構造化命令
構造化命令は , 構造化プログラミングを行うために
用意された命令です。
この章では , 構造化命令について説明します。
13.1 構造化命令の概要
13.2 構造化プログラム命令
13.3 式 ( 代入式 , 代入演算式 , インクリメント / デクリメン
ト式 )
September 1, 2014, CM81-00208-5
257
Su pp or t
So ft
Manu al
13.1 構造化命令の概要
構造化命令は , 構造化プログラミングを行うために用意された命令です。
■ 構造化命令の概要
構造化命令は , 構造化プログラミングを行うために用意された命令です。
【例】
.program
"Sample_for_8L"
.import
func
.import
para1
.section
segment1, code
.(R0 = #0)
// 代入式
func1:
.while (R0
<= #10)
.(para1 < <= #1)
CALL
// 構造化プログラム命令
// 代入演算式
func
.(R0++)
// インクリメント式
.endw
ret
.end
258
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
13.2 構造化プログラム命令
構造化プログラム命令には , 2 処理選択 , 多処理選択 , 計算型繰返し , 終了条件型繰
返し , および実行条件型繰返しの 5 つの制御構文命令と , ブレイク , コンティニュー
の 2 つの制御移行命令があります。
構造化プログラム命令の一覧を表 13.2-1 に示します。
■ 構造化プログラム命令の概要
構造化プログラム命令には , 2 処理選択 , 多処理選択 , 計算型繰返し , 終了条件型繰返し ,
および実行条件型繰返しの 5 つの制御構文命令と , ブレイク , コンティニューの 2 つの
制御移行命令があります。
構造化プログラム命令の一覧を表 13.2-1 に示します。
表 13.2-1 構造化プログラム命令一覧
構造化プログラム命令
用途
.if
.else
2 処理選択
.endif
.switch
.case
多処理選択
.default
.endsw
.for
計算型繰返し
.endf
.repeat
終了条件型繰返し
.until
.while
実行条件型繰返し
.endw
.break
ブレイク
.continue
コンティニュー
September 1, 2014, CM81-00208-5
259
Su pp or t
13.2.1
So ft
Manu al
構造化プログラム命令の条件式
構造化プログラム命令は , プログラム制御のための条件式が記述できます。
■ 構造化プログラム命令の条件式
条件式には , コンディションコード条件式 , 比較条件式 , ビット条件式の 3 つの条件式
が用意されています。
また , 前述の 3 つの条件式を最大 8 個まで組み合わせた複合条件式を記述できます。
● コンディションコード条件式
コンディションコード条件式は , CPU のコンディションを表すビットを基本にコン
ディションコードが用意されています。
コンディションコードは , 両端をアングルブラケット ( < >) で囲みます。
コンディションコード条件式で使用可能な条件式を表 13.2-2 に示します。
表 13.2-2 コンディションコード条件式で使用可能な条件式
Z(EQ)
Z==1
NZ(NE)
Z==0
C(LO)
C==1
NC(NS)
C==0
N
N==1
P
N==0
V
V==1
NV
V==0
LT
(VorN)==1
GE
(VorN)==0
LE
((VxorN)orZ)==1
GT
((VxorN)orZ)==0
LS
(CorZ)==1
HI
(CorZ)==0
【例】
.if ( <ne >)
mov
a, r1
.else
mov
a, r2
.endif
260
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
● 比較条件式
比較条件式は , 2 つのオペランドをもち , その比較結果により設定される CPU のコン
ディションを元に判定されます。
比較条件式で使用可能な条件式を表 13.2-3 に示します。
表 13.2-3 比較条件式で使用可能な条件式
==
等しい
!=
等しくない
<
小さい
<=
小さいか等しい
>
大きい
>=
大きいか等しい
<, <=, >, >= の比較条件で , 符号なし比較を行う場合には , 比較式に .u を付加します。
比較条件式のオペランドに記述可能な項を , 表 13.2-4 に示します。
表 13.2-4 比較条件式に記述可能なオペランド
左項
右項
A
dir/#d8/@EP/@IX+off/Ri
@EP
@IX+off
#d8
Ri
【例】
.if (A <= #0)
call
func
.endif
● ビット条件式
ビット条件式は , オペランドのビット状態を判定に使用します。
ビット状態が 1 のときに条件が成立し , 0 のときには条件が不成立と判定します。
"!" を付加すると論理の反転を行います。
【例】
.while (bit_flag)
call
func
.endw
September 1, 2014, CM81-00208-5
261
Su pp or t
So ft
Manu al
● 複合条件式
複合条件式は , 前述の 3 つの条件式を最大 8 個まで組み合わせて , 論理和 (||) または論
理積 ( & &) を判定条件にします。
ビット条件式の後にコンディションコード条件式を用いる場合は , ビット条件式でゼ
ロフラグ (Z) が更新されるので , 注意が必要です。
複合条件式の複合条件は , 論理和と論理積の混在はできません。
複合条件式が使用可能な構造化プログラム命令は次の 3 つです。
• 2 処理選択構文 (.if 構文 )
• 終了条件型繰返し構文 (.repeat 構文 )
• 実行条件型繰返し構文 (.while 構文 )
【例】
.while (bit_flag1
call
& & bit_flag2)
func
.endw
262
CM81-00208-5, September 1, 2014
Support
13.2.2
Soft
Ma nual
構造化プログラム命令での生成規則
構造化プログラム命令で生成されるシンボルと命令文の生成規則について説明しま
す。
■ シンボルの生成規則
構造化プログラム命令では , 次のようにシンボルを生成します。
構造化プログラム命令
シンボル形式
2 処理選択 (.if)
__Innnnn
多処理選択 (.switch)
__Snnnnn
計算型繰返し (.for)
__Fnnnnn
終了条件型繰返し (.repeat)
__Rnnnnn
実行条件型繰返し (.while)
__Wnnnnn
2 個のアンダバー '__' で始まり 5 桁の数値 (10 進数 ) が続きます。
この 5 桁の数値は , シンボルが生成されるたびに 1 つ値が加算され , 00001 ~ 65535 ま
での値を生成します。
■ 命令文の生成規則
構造化プログラム命令により生成される機械命令は , 次に示すように , 構造化プログラ
ム命令のネストに関係なく 1 個のタブコードを前置して生成されます。
機械命令とオペランドの間にも 1 個のタブコードを出力します。
タブコード
機械命令
タブコード
オペランド
改行コード
シンボルを定義する場合には , シンボルにコロン ':' を付加し , シンボルだけを行の第 1
カラム目から生成します。
生成シンボル名 :
September 1, 2014, CM81-00208-5
263
Su pp or t
So ft
Manu al
構造化プログラム命令の記述形式
13.2.3
構造化プログラム命令の基本的な記述形式について説明します。
各構造化プログラム命令の詳細については , 「13.2.4 2 処理選択構文」~「13.2.9
制御移行命令」を参照してください。
■ 構造化プログラム命令の記述形式
【記述形式】
. 命令 ( 条件式 )
【説明】
● 命令
.if, .while などの構造化プログラム命令を記述します。
'. 命令 ' で 1 つの命令です。ピリオド (.) と命令を切り離して記述できません。
各構造化プログラム命令の詳細については , 「13.2.4 2 処理選択構文」~「13.2.9 制御
移行命令」を参照してください。
● 条件式
コンディションコード条件式 , 比較条件式およびビット条件式のいずれかを記述しま
す。
■ 条件式の記述形式
● コンディションコード条件式
( < コンディションコード >)
● 比較条件式
(op1 比較式 op2)
● ビット条件式
([!]op1)
"!" を付加すると , 論理の反転 (0 で条件成立 ) を行います。
264
CM81-00208-5, September 1, 2014
Support
13.2.4
Soft
Ma nual
2 処理選択構文
2 処理選択構文は , 条件式が真の場合には処理 1 が実行され , 条件式が偽の場合には
処理 2 が実行される命令を生成します。
条件式には , コンディションコード条件式 , 比較条件式およびビット条件式が記述で
きます。
■ 2 処理選択構文
【記述形式】
.if ( 条件式 )
処理 1
[.else]
処理 2
.endif
【説明】
2 処理選択構文は , 条件式が真の場合には処理 1 が実行され , 条件式が偽の場合には
処理 2 が実行される命令を生成します。
条件式には , コンディションコード条件式 , 比較条件式 , ビット条件式が記述できま
す。
【例】
.if
mov
( <ne >)
BEQ16
__I00001
a, r0
mov
a, r0
JMP
__I00002
.else
__I00001:
mov
.endif
September 1, 2014, CM81-00208-5
a, r1
mov
a, r1
__I00002:
265
Su pp or t
13.2.5
So ft
Manu al
多処理選択構文
多処理選択構文は , switch オペランドと case オペランドの比較を行い , 等しい場合
には該当する .case 以降に記述された処理を実行し , 異なる場合には次に記述され
ている .case 文の比較を行う命令を生成します。
.case 文は任意の回数記述可能です。
多処理選択構文から抜けるには .break 文を使用します。
■ 多処理選択構文
【記述形式】
.switch ( オペランド 1)
.case ( オペランド n)
処理
[.break]
[.default]
処理
.endsw
【説明】
多処理選択構文は , switch オペランド ( オペランド 1) と case オペランド ( オペラン
ド n) の比較を行い , 等しい場合には該当する .case 以降に記述された処理を実行し ,
異なる場合には次に記述されている .case 文の比較を行う命令を生成します。
.case 文は任意の回数記述可能です。
多処理選択構文から抜けるには , .break 文を使用します。
各オペランドに記述可能な項を表 13.2-5 に示します。
表 13.2-5 オペランドに記述可能な項
switch オペランド
case オペランド
A
dir/#d8/@EP/@IX+off/Ri
dir
@EP
#d8
@IX+off
Ri
266
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
【例】
.switch (A)
.case (#0)
mov
a, r0
.break
.case (#1)
a, r1
.break
.default
BNE16
__S00002
mov
a, r0
JMP
__S00001
CMP
A, #1
BNE16
__S00003
mov
a, r1
JMP
__S00001
mov
a, r0
__S00003:
mov
September 1, 2014, CM81-00208-5
A, #0
__S00002:
mov
.endsw
CMP
a, r0
__S00001:
267
Su pp or t
13.2.6
So ft
Manu al
計算型繰返し構文
計算型繰返し構文は , 条件が成立する間 , 処理を繰り返し実行する命令を生成しま
す。
カウンタの増減方向は , op4 の符号により指定します。
最初から条件が成立していない場合 , 処理は実行されません。
条件は , op1 と op3 の比較で判定されます。
■ 計算型繰返し構文
【記述形式】
.for (op1=op2, 比較式 op3, [{+|-}]op4)
処理
.endf
【説明】
計算型繰返し構文は , 条件が成立する間 , 処理を繰り返し実行する命令を生成しま
す。
カウンタの増減方向は , op4 の符号により指定します。符号を省略すると増分方向
になります。
最初から条件が成立していない場合 , 処理は実行されません。
条件は , op1 と op3 の比較で判定されます。
各オペランドに記述可能な項を表 13.2-6 に示します。
表 13.2-6 オペランドに記述可能な項
op1
A
op2
op3
dir
#d8
@EP
@IX+off
Ri
@A
dir
#d8
@EP
@IX+off
Ri
#d8
#d8
dir
@EP
op4
dir
#d8
@EP
@IX+off
Ri
@IX+off
Ri
268
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
【例】
.for
(A=#0, <=.u #255, +1)
MOV
A, #0
JMP
__F00001
__F00002:
incw
.endf
ep
incw
ep
__F00003:
ADDC
A, #1
__F00001:
CMP
A, #255
BHI16
__F00001
__F00004:
September 1, 2014, CM81-00208-5
269
Su pp or t
13.2.7
So ft
Manu al
終了条件型繰返し構文
終了条件型繰返し構文は , 条件が成立するまで処理を繰り返し実行する命令を生成
します。
条件式には , コンディションコード条件式 , 比較条件式およびビット条件式が記述で
きます。
終了条件型繰返し構文では , 処理を実行後に条件の判定を行うため , 最初から条件が
成立する場合でも , 必ず 1 度は処理が実行されます。
■ 終了条件型繰返し構文
【記述形式】
.repeat
処理
.until ( 条件式 )
【説明】
終了条件型繰返し構文は , 条件が成立するまで処理を繰り返し実行する命令を生成
します。
条件式には , コンディションコード条件式 , 比較条件式およびビット条件式が記述
できます。
終了条件型繰返し構文では , 処理を実行後に条件の判定を行うため , 最初から条件
が成立する場合でも , 必ず 1 度は処理が実行されます。
【例】
.repeat
__R00001:
decw
.until ( <eq >)
ep
decw
ep
__R00002:
BNE16
__R00001
__R00003:
270
CM81-00208-5, September 1, 2014
Support
13.2.8
Soft
Ma nual
実行条件型繰返し構文
実行条件型繰返し構文は , 条件が成立する間 , 処理を繰り返し実行する命令を生成し
ます。
条件式には , コンディションコード条件式 , 比較条件式およびビット条件式が記述で
きます。
実行条件型繰返し構文では , 条件の判定後に処理の実行を行うため , 最初から条件が
成立しない場合は , 1 度も処理は実行されません。
■ 実行条件型繰返し構文
【記述形式】
.while ( 条件式 )
処理
.endw
【説明】
実行条件型繰返し構文は , 条件が成立する間 , 処理を繰り返し実行する命令を生成
します。
条件式には , コンディションコード条件式 , 比較条件式およびビット条件式が記述
できます。
実行条件型繰返し構文では , 条件の判定後に処理の実行を行うため , 最初から条件
が成立しない場合は , 1 度も処理は実行されません。
【例】
.while ( <le >)
JMP
_W00002
__W00001:
incw
.endw
ep
incw
ep
__W00002:
BLE16
_W00001
__W00003:
September 1, 2014, CM81-00208-5
271
Su pp or t
13.2.9
So ft
Manu al
制御移行命令
制御移行命令は , 構文から脱出したり , 繰返し構文の繰返し制御に移行する場合に使
用します。
.break 命令は , その記述が含まれる最も内側の構文から脱出します。
.continue 命令は , その記述が含まれる最も内側の繰返し構文の繰返しへ制御を移行
します。
■ .break 命令
【記述形式】
.break
【説明】
.break 命令は , その記述が含まれる最も内側の構文から脱出します。
多処理選択構文および各種繰返し構文で使用できます。
【例】
.while ( <le >)
JMP
__W00002
__W00001:
incw
incw
ep
.if ( <ne >)
BEQ16
__I00001
.break
JMP
__W00003
.endif
.endw
ep
__I00001:
__W00002:
BLE16
__W00001
__W00003:
272
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
■ .continue 命令
【記述形式】
.continue
【説明】
.continue 命令は , その記述が含まれる最も内側の繰返し構文の繰返し制御に移行し
ます。
各種繰返し構文で使用できます。
【例】
.while ( <le >)
JMP
__W00002
__W00001:
incw
ep
.if ( <ne >)
.continue
.else
incw
ep
BEQ16
__I00001
JMP
__W00002
JMP
__I00002
__I00001:
.break
.endif
.endw
JMP
__W00003
__I00002:
__W00002:
BLE16
__W00001
__W00003:
September 1, 2014, CM81-00208-5
273
Su pp or t
So ft
Manu al
13.3 式 ( 代入式 , 代入演算式 , インクリメント / デクリメント
式)
本アセンブラでは , 構造化プログラム命令に加えて , 式を使用できます。
式には , 代入式・代入演算式・インクリメント / デクリメント式があります。
■ 式の概要
本アセンブラでは , 構造化プログラム命令に加えて , 式を使用できます。
式の種類を表 13.3-1 に示します。
表 13.3-1 式の種類
代入式
右項を左項に代入する式です。
代入演算式
右項と左項で演算を行い , 結果を右項に代入する式です。
インクリメント /
デクリメント式
項の値に 1 を加算または減算し , 項の値とする式です。
使用可能な式の一覧を表 13.3-2 に示します。
表 13.3-2 式の一覧
式
用途
.(op1 = op2)
代入式
.(op1 += op2)
.(op1 -= op2)
.(op1 *= op2)
.(op1 /= op2)
.(op1 %= op2)
代入演算式
.(op1 &= op2)
.(op1 |= op2)
.(op1 ^= op2)
.(op1 < <= op2)
.(op1 > >= op2)
274
.(op++)
インクリメント式
.(op--)
デクリメント式
CM81-00208-5, September 1, 2014
Support
13.3.1
Soft
Ma nual
式の記述形式
式の基本的な記述形式について説明します。
各式の詳細については , 「13.3.2 代入式」~「13.3.4 インクリメント / デクリメン
ト式」を参照してください。
■ 式の記述形式
【記述形式】
.( 式 )
【説明】
式には , 代入式 , 代入演算式 , インクリメント式およびデクリメント式のいずれかを
記述します。
式は , 必ずピリオド (.)+ 括弧 '(' で始まり括弧 ')' で閉じられている必要があります。
各式の詳細については , 「13.3.2 代入式」から「13.3.4 インクリメント / デクリメ
ント式」を参照してください。
September 1, 2014, CM81-00208-5
275
Su pp or t
13.3.2
So ft
Manu al
代入式
代入式は , 右項から左項への代入を行う命令を生成します。
同じデータサイズで代入を行う場合には , 複数 ( 最大 8 個まで ) への代入処理が一度
に記述できます。この場合 , 16 ビット代入と 8 ビット代入の混在はできません。
16 ビットレジスタへ 8 ビット代入を行った場合 , 上位 8 ビットは不定です。
■ 代入式
【記述形式】
.(op1[. データサイズ ] = op2[. データサイズ ] = … = op9)
データサイズ :{b|w}
【説明】
代入式は , 右項から左項への代入を行う命令を生成します。
同じデータサイズで代入を行う場合には , 複数 ( 最大 8 個まで ) への代入処理が一
度に記述できます。
複数への代入処理を一度に記述した場合 , 16 ビット代入と 8 ビット代入の混在はで
きません。
16 ビットレジスタへ 8 ビット代入を行った場合 , 上位 8 ビットは不定です。
【例】
.(R0=R1=#0)
MOV
A, #0
MOV
R1, A
MOV
R0, A
■ デフォルトデータサイズ
代入を行う場合 , 代入先によりデフォルトのデータサイズが異なります。
代入先とデフォルトデータサイズの関係を表 13.3-3 に示します。
表 13.3-3 代入式の代入先とデフォルトデータサイズの関係
276
代入先
データサイズ
EP, IX, PS, SP
16 ビット
その他
8 ビット
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
■ 項に記述可能な種類
代入式の項には , アセンブラのオペランドに記述可能なレジスタやシンボルなど , ほと
んどのものが記述できます。
ただし , 代入先と代入元に同じものを記述できません。
記述できる項の種類を表 13.3-4 に示します。
表 13.3-4 代入式に記述可能な項
8 ビット代入
項
代入先
代入元
レジスタ
A, T, R0 ~ R7, EP, IX, PS, SP*
A, T, R0 ~ R7, EP, IX, PS, SP*
レジスタ間接
@A*, @IX+offset, @EP
@A*, @IX+offset, @EP
アドレス
シンボル , アドレス値
シンボル , アドレス値
即値
# 数値 , # シンボル
16 ビット代入
レジスタ
A, T, EP, IX, PS, SP*
A, T, EP, IX, PS, SP*
レジスタ間接
@A*, @IX+offset, @EP
@A*, @IX+offset, @EP
アドレス
シンボル , アドレス値
シンボル , アドレス値
即値
# 数値 , # シンボル
* 印のついているものは , 複数代入記述には使用できません。
September 1, 2014, CM81-00208-5
277
Su pp or t
13.3.3
So ft
Manu al
代入演算式
代入演算式は , 右項と左項の演算結果を左項への代入を行う命令を生成します。
■ 代入演算式
【記述形式】
.(op1[. データサイズ ] 代入演算記号 op2)
データサイズ :{b|w}
【説明】
代入演算式は , 右項と左項の演算結果を左項への代入を行う命令を生成します。
代入演算記号として記述できるものを表 13.3-5 に示します。
表 13.3-5 使用可能な代入演算子
演算子
算術演算
論理演算
8ビット代入演算
16ビット代入演算
+=
+=
-=
-=
*=
*=
符号なし演算です
/=
符号なし演算です
%=
符号なし演算です
&=
&=
|=
|=
^=
^=
< <=
右項は #1 ~ #7 の即値です
> >=
右項は #1 ~ #7 の即値です
シフト演算
278
備考
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
■ デフォルトデータサイズ
代入演算を行う場合 , 左項によりデフォルトのデータサイズが異なります。
左項とデフォルトデータサイズの関係を表 13.3-6 に示します。
表 13.3-6 代入演算式の左項とデフォルトデータサイズの関係
代入先
データサイズ
EP, IX
16 ビット
その他
8 ビット
■ 項に記述可能な種類
代入演算式の項には , アセンブラのオペランドに記述可能なレジスタやシンボルなど ,
ほとんどのものが記述できます。
記述できる項の種類を表 13.3-7 に示します。
表 13.3-7 代入演算式に記述可能な項
8 ビット代入
項
左項
右項
レジスタ
A, T, R0 ~ R7, EP, IX
A, T, R0 ~ R7, EP, IX
レジスタ間接
@A, @IX+offset, @EP
@A, @IX+offset, @EP
アドレス
シンボル , アドレス値
シンボル , アドレス値
即値
# 数値 , # シンボル
16 ビット代入
レジスタ
A, T, EP, IX
A, T, EP, IX
レジスタ間接
@A, @IX+offset, @EP
@A, @IX+offset, @EP
アドレス
シンボル , アドレス値
シンボル , アドレス値
即値
September 1, 2014, CM81-00208-5
# 数値 , # シンボル
279
Su pp or t
So ft
Manu al
■ 記述例
.(@IX-0 += @IX-1)
.(_sym -= _sym+1)
CLRC
MOV
A, @IX-0
ADDC
A, @IX-1
MOV
@IX-0, A
CLRC
MOV
A, _sym
MOV
A, _sym+1
SUBC
A
MOV
_sym, A
MOVW
A, EP
MOVW
A, #16
MULU
A
MOVW
EP, A
MOV
A, #7
MOVW
A, @EP
XCHW
A, T
DIVU
A
MOVW
@EP, A
MOV
A, #7
MOVW
A, @EP
XCHW
A, T
DIVU
A
XCHW
A, T
MOVW
@EP, A
AND
A, #0x80
.(A |= #0xF0)
OR
A, #0xF0
.(A ^= #0xFF)
XOR
A, #0xFF
.(R0
MOV
A, R0
ROLC
A
ROLC
A
AND
A, #0xFC
.(EP *= #16)
.(@EP /= #7)
.(@EP %= #7)
.(A
&= #0x80)
< <= #2)
CLRC
280
CM81-00208-5, September 1, 2014
Support
.(@A
Soft
> >= #3)
Ma nual
MOV
R0, A
MOV
A, @A
RORC
A
RORC
A
RORC
A
AND
A, #0x1F
CLRC
September 1, 2014, CM81-00208-5
XCH
A, T
MOV
@A, T
281
Su pp or t
13.3.4
So ft
Manu al
インクリメント / デクリメント式
項のインクリメントまたはデクリメントを行う命令を生成します。
8 ビットのインクリメントまたはデクリメントを行う場合 , R0 ~ R7 以外のものは
16 ビットで行われます。
■ インクリメント / デクリメント式
【記述形式】
.(op[. データサイズ ]{++|--})
データサイズ :{b|w}
【説明】
項のインクリメントまたはデクリメントを行う命令を生成します。
インクリメント式は '++' をデクリメント式は '--' を記述します。
8 ビットのインクリメントまたはデクリメントを行う場合 , R0 ~ R7 以外のものは
16 ビットで行われます。したがって , インクリメントまたはデクリメントを行った
結果 8 ビットを超えた場合にフラグは反映されません。
【例】
.(EP++)
INCW
EP
.(@EP--)
MOV
A, @EP
DECW
A
MOV
@EP, A
■ デフォルトデータサイズ
インクリメント / デクリメント式は , 項によりデフォルトのデータサイズが異なりま
す。
項とデフォルトデータサイズの関係を表 13.3-8 に示します。
表 13.3-8 インクリメント / デクリメント式の項デフォルトデータサイズの関係
282
代入先
データサイズ
EP, IX
16 ビット
その他
8 ビット
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
■ 項に記述可能な種類
インクリメント / デクリメント式の項には , アセンブラのオペランドに記述可能なレジ
スタやシンボルなど , ほとんどのものが記述できます。
記述できる項の種類を表 13.3-9 に示します。
表 13.3-9 インクリメント / デクリメント式に記述可能な項
項
8 ビット
16 ビット
レジスタ
A, T, R0 ~ R7, EP, IX
A, T, EP, IX
レジスタ間接
@A, @IX+offset, @EP
@A, @IX+offset, @EP
アドレス
シンボル , アドレス値
シンボル , アドレス値
September 1, 2014, CM81-00208-5
283
Su pp or t
284
So ft
Manu al
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
付録
付録では , エラーメッセージの一覧 , 制限事項を掲
載します。
付録 A エラーメッセージ一覧
付録 B 制限事項
付録 C 拡張ダイレクトアクセス領域バンク番号の取得方法
付録 D SOFTUNE アセンブラと旧版アセンブラの仕様の差
異
付録 E 主な変更内容
September 1, 2014, CM81-00208-5
285
Su pp or t
付録 A
So ft
Manu al
エラーメッセージ一覧
本アセンブラで出力するエラーメッセージの一覧です。
■ エラーメッセージの見方
図 A-1 エラーメッセージの見方
xx101A
Expression too complex
式が複雑すぎて解析できません
エラー認識番号
エラーメッセージ
上段に英語,下段に日本語のメッセージを示します。
x x 1 0 1 A
ツール識別子 A:アセンブラ
エラー番号(3桁)
エラーレベル
W1:警告レベル
E4:文法エラー
F9:致命的エラー(アセンブル強制終了)
<注意事項>
エラーメッセージの枠の下に補足説明が付いている場合があります。
286
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
■ エラーメッセージ一覧
E4101A
Expression too complex
式が複雑すぎて解析できません
【プログラム処置】
式処理を中断します。
E4102A
Missing expression(s)
式の記述がありません
【プログラム処置】
式処理を中断します。
W1103A
Divide by zero
除数 0 の除算です
【プログラム処置】
式処理を中断します。
E4104A
No terms in parentheses
括弧中に項がありません
【プログラム処置】
式処理を中断します。
W1105A
Illegal term in expression
式に不正な項があります
【プログラム処置】
式処理を中断します。
E4106A
Unbalanced parentheses in expression
式の括弧の対応が合いません
【プログラム処置】
式処理を中断します。
September 1, 2014, CM81-00208-5
287
Su pp or t
E4107A
So ft
Manu al
Syntax error
文法に誤りがあります
【プログラム処置】
この命令を無効にします。
E4109A
Nothing macro-name
マクロ名の記述がありません
【プログラム処置】
この命令を無効にします。
E4110A
Nothing include file-name
インクルードファイル名の指定がありません
【プログラム処置】
この命令を無効にします。
E4111A
Cannot open include file
インクルードファイルがありません
【プログラム処置】
この命令を無効にします。
E4112A
Nested include file exceeds 8
インクルードファイルのネストが 8 を超えました
インクルードファイルのネストは 8 レベルまでです。
【プログラム処置】
この命令を無効にします。
288
CM81-00208-5, September 1, 2014
Support
E4114A
Soft
Ma nual
Nested macro-call exceeds 255
マクロコールのネストが 255 を超えました
マクロコールのネストは 255 レベルまでです。
【プログラム処置】
この命令を無効にします。
E4115A
Changed level exceeds 255
置換レベルが 255 を超えました
置換処理のネストは 255 レベルまでです。
【プログラム処置】
マクロ名を空文字に置換えます。
E4116A
Invalid value
不正な値です
整数定数の記述に誤りがあります
【プログラム処置】
不正な文字のみを無視します。
E4117A
Macro name duplicate definition
マクロ名が 2 重定義です
【プログラム処置】
この命令を無視します。
W1118A
Argument duplicate definition
引数が 2 重定義です
【プログラム処置】
この引数を無視します。
September 1, 2014, CM81-00208-5
289
Su pp or t
W1119A
So ft
Manu al
Local-symbol duplicate definition
ローカルシンボルが 2 重定義です
【プログラム処置】
このローカルシンボルを無視します。
W1120A
Too many arguments
引数が多すぎます
【プログラム処置】
多い引数を無視します。
W1121A
Not enough arguments
引数の数が足りません
【プログラム処置】
足りない引数を空文字とします。
E4122A
Missing '('
'(' がありません
【プログラム処置】
この命令を無視します。
E4123A
Unterminated macro-name ')'
マクロ命令の最後に ')' がありません
【プログラム処置】
この命令を無視します。
E4124A
Unterminated comment
コメントの終わりに '*/' がありません
【プログラム処置】
'*/' を補います。
290
CM81-00208-5, September 1, 2014
Support
W1125A
Soft
Ma nual
Unterminated '
文字定数の終わりに ' がありません
【プログラム処置】
行終端までを文字定数とします。
W1126A
Unterminated "
文字列の終わりに " がありません
【プログラム処置】
行終端までを文字列とします。
W1127A
Unterminated ' >'
インクルードファイル名の終わりに ' >' がありません
【プログラム処置】
' >' を補います。
W1128A
Value overflow
値がオーバフローです
32 ビットで表しきれない数が指定されています
【プログラム処置】
下位 32 ビットのみ有効とします。
W1129A
Name too long
名前が長すぎます
名前の文字数が 255 文字を超えています。
【プログラム処置】
超えた分の文字を無効にします。
September 1, 2014, CM81-00208-5
291
Su pp or t
W1130A
So ft
Manu al
String too long
文字列が長すぎます
文字列が 4095 文字を超えています。
【プログラム処置】
超えた分の文字を無効にします。
W1131A
Defined-string too long
定義文字列が長すぎます
定義文字列が 4095 文字を超えています。
【プログラム処置】
超えた分の文字を無効にします。
W1132A
Expanded-string too long
展開文字列が長すぎます
マクロ展開された文字列が 4095 文字を超えています。
【プログラム処置】
超えた分の文字を無効にします。
W1133A
Logical-lines too long
値がオーバフローです
継続行を含めた論理行が 4095 文字を超えています。
【プログラム処置】
超えた分の文字を無効にします。
W1134A
Meaningless description
不要な記述です
【プログラム処置】
この文字を無効にします。
292
CM81-00208-5, September 1, 2014
Support
E4135A
Soft
Ma nual
Has no #if-statement
対応する #if 文がありません
【プログラム処置】
この命令を無効にします。
E4136A
Has no #macro-statement
対応する #macro 文がありません
【プログラム処置】
この命令を無効にします。
W1137A
#endif expected
#endif 文がありません
【プログラム処置】
#endif 文があったものとします。
E4138A
#endm expected
#endm 文がありません
【プログラム処置】
#endm 文があったものとします。
E4140A
Not used macro-statement
この命令はここでは使用できません
【プログラム処置】
この命令を無効にします。
E4141A
Too long macro-body
マクロボディが大きすぎます
【プログラム処置】
このマクロ定義を無効にします。
September 1, 2014, CM81-00208-5
293
Su pp or t
W1142A
So ft
Manu al
Meaningless .CASE
.SWITCH 命令なしに , .CASE 命令が記述されています
【プログラム処置】
この記述を無視します。
W1143A
Meaningless .DEFAULT
.SWITCH 命令なしに , .DEFAULT 命令が記述されています
【プログラム処置】
この記述を無視します。
W1144A
.CASE statement not permitted here
.DEFAULT 命令の後ろに , .CASE 命令が記述されています
【プログラム処置】
この記述を無視します。
W1145A
.ENDSW without .CASE statement
.SWITCH 命令で .CASE 命令の記述がされないまま , .ENDSW 命令が
記述されました
【プログラム処置】
.CASE 命令はないものとして処理を続けます。
W1146A
#PURGE not permitted here
#PURGE 命令がマクロ定義体中で記述されています
【プログラム処置】
この記述を無視します。
W1147A
Data width is not permitted to indicate to last item. Ignored this suffix
最後の項にデータ幅の指定が行われています
【プログラム処置】
データ幅指定の記述を無視します。
294
CM81-00208-5, September 1, 2014
Support
E4148A
Soft
Ma nual
.BREAK not in structured block
構造化制御構文の外に .BREAK 命令が記述されています
【プログラム処置】
この記述を無視します。
E4149A
.CONTINUE not in structured block
構造化制御構文の外に .CONTINUE 命令が記述されています
【プログラム処置】
この記述を無視します。
E4150A
Missing angle bracket
アングルブラケット " <", " >" の対応がとれていません
【プログラム処置】
この記述を無視します。
E4151A
Conditional expression overflow
複合条件式の数が多すぎます
【プログラム処置】
この記述を無視します。
E4152A
& & and || conditional expression exist
複合条件式において論理積条件と論理和条件が混在しています
【プログラム処置】
この記述を無視します。
E4153A
Illegal structured block order
構造化制御命令の記述が正しくありません
【プログラム処置】
この記述を無視します。
September 1, 2014, CM81-00208-5
295
Su pp or t
E4154A
So ft
Manu al
Source item and destination item is the same
代入先と代入元に同じものが記述されています
【プログラム処置】
この記述を無視します。
E4155A
Number of item is overflowed
複数への代入の一括記述で , 代入先が多すぎます
【プログラム処置】
この記述を無視します。
E4501A
Missing expression(s)
式の記述がありません
【プログラム処置】
この命令を無効にします。
E4502A
Out of section
セクションがまだ定義されていません
【プログラム処置】
.SECTION CODE, CODE, ALIGN=1 のセクションを生成します。
E4503A
Invalid directive ( 命令名 )
不正な擬似命令名です ( 命令名 )
【プログラム処置】
この命令を無効にします。
E4504A
Invalid word ( 詳細情報 )
不正な単語です ( 詳細情報 )
【プログラム処置】
区切り記号まで無視します。
296
CM81-00208-5, September 1, 2014
Support
W1505A
Soft
Ma nual
Name too long
名前が長すぎます
名前の文字数が 255 文字を超えています。
【プログラム処置】
超えた分の文字を無効にします。
E4506A
Missing string terminator (")
文字列の終わりの (") がありません
【プログラム処置】
行終端までを文字列とします。
E4507A
Expression too complex
式が複雑すぎて解析不能です
【プログラム処置】
式処理を中断します。
E4510A
Value overflow ( 詳細情報 )
値がオーバフローです ( 詳細情報 )
32 ビットで表しきれない数が指定されています。
【プログラム処置】
下位 32 ビットのみ有効とします。
E4511A
Missing string terminator (')
文字定数の終わりの (') がありません
【プログラム処置】
行終端までを文字定数とします。
September 1, 2014, CM81-00208-5
297
Su pp or t
E4512A
So ft
Manu al
Divide by zero
除数 0 の除算です
【プログラム処置】
式の値を 0 とします。
E4513A
Expression too complex
式が複雑すぎて解析できません
【プログラム処置】
式処理を中断します。
E4514A
Register not permitted in expression ( レジスタ名 )
式にレジスタは指定できません ( レジスタ名 )
【プログラム処置】
式処理を中断します。
E4515A
No terms in parentheses
括弧中に項がありません
【プログラム処置】
式処理を中断します。
E4516A
Illegal term in expression ( 詳細情報 )
式に不正な項があります ( 詳細情報 )
【プログラム処置】
式処理を中断します。
E4517A
Unbalanced parentheses in expression
式の括弧の対応が合いません
【プログラム処置】
式処理を中断します。
298
CM81-00208-5, September 1, 2014
Support
E4518A
Soft
Ma nual
Cannot out this operator ( 詳細情報 )
この演算子はリロケーション情報に出ません ( 詳細情報 )
【プログラム処置】
式の値を 0 とします。
E4519A
Register list symbol not permitted in expression ( 詳細情報 )
式にレジスタリストシンボルは指定できません ( 詳細情報 )
【プログラム処置】
式処理を中断します。
E4520A
String too long
文字列が長すぎます
文字列が 4095 文字を超えています。
【プログラム処置】
超えた分の文字を無効にします。
E4521A
Structured definitions. Invalid directive
構造体定義中なので , この擬似命令は無効です。
【プログラム処置】
この擬似命令を無効にします。
E4522A
Structured definitions. Invalid instruction
構造体定義中なので , 機械命令は無効です。
【プログラム処置】
この機械命令を無効にします。
September 1, 2014, CM81-00208-5
299
Su pp or t
E4524A
So ft
Manu al
Duplicate declaration ( シンボル名 )
2 重宣言です ( シンボル名 )
.GLOBAL, .EXPORT, .IMPORT 命令で宣言されているシンボルです。
【プログラム処置】
宣言を無効にします。
E4525A
Duplicate definition ( シンボル名またはセクション名 )
2 重定義です ( シンボル名またはセクション名 )
【プログラム処置】
このシンボル定義を無効にします。
E4526A
Cannot declare ( シンボル名 )
宣言できません ( シンボル名 )
.GLOBAL, .EXPORT, .IMPORT 命令では宣言できない種類のシンボルです。
【プログラム処置】
宣言を無効にします。
W1527A
Undefined symbol : treats as an external reference symbol ( シンボル名 )
未定義シンボルです : 外部参照シンボルとして扱います ( シンボル名 )
【プログラム処置】
外部参照シンボルとして扱います。
E4528A
Terms other than the section symbol are described in the size operator ( シン
ボル名 )
サイズ演算子にセクションシンボル以外の項が記述されています ( シ
ンボル名 )
【プログラム処置】
式処理を中断します。
300
CM81-00208-5, September 1, 2014
Support
E4529A
Soft
Ma nual
External reference symbol is described in the size operator : Please make and
deal with an empty section by the name ( シンボル名 )
サイズ演算子に外部参照シンボルが記述されています : その名前で空
セクションを作成して対処してください ( シンボル名 )
【プログラム処置】
式処理を中断します。
E4530A
Invalid symbol field ( 詳細情報 )
シンボルの記述方法が不正です ( 詳細情報 )
【プログラム処置】
行終端まで無効にします。
E4531A
Not an absolute expression
式が絶対式でありません
式に外部参照シンボルまたは相対シンボルが記述されています。
【プログラム処置】
この命令を無効にします。
E4532A
Not complex relocatable expression
式が絶対式または単純相対式でありません
式に外部参照シンボルまたは相対シンボルが 2 個以上記述されています。
【プログラム処置】
この命令を無効にします。
E4533A
Forward reference symbol is described in expression
式に前方参照シンボルが記述されています
この命令の式には前方参照シンボルは記述できません。
【プログラム処置】
この命令を無効にします。
September 1, 2014, CM81-00208-5
301
Su pp or t
E4534A
So ft
Manu al
Syntax error in operand ( 詳細情報 )
オペランドの記述に誤りがあります ( 詳細情報 )
【プログラム処置】
この命令を無効にします。
W1535A
Meaningless description ( 詳細情報 )
不要な記述です ( 詳細情報 )
【プログラム処置】
不要な記述を無効にします。
E4536A
Duplicate directive ( 詳細情報 )
2 重指定できない擬似命令です ( 詳細情報 )
【プログラム処置】
最初に指定された命令を有効にします。
E4537A
Reserved word cannot define symbol ( 詳細情報 )
予約語はシンボル定義できません ( 詳細情報 )
【プログラム処置】
行終端まで無効にします。
E4538A
Reserved word cannot be used as a section name ( 詳細情報 )
予約語はセクション名として使用できません ( 詳細情報 )
【プログラム処置】
この命令を無効にします。
302
CM81-00208-5, September 1, 2014
Support
E4539A
Soft
Ma nual
Size operator is described in expression
式にサイズ演算子が記述されています
この命令の式には , サイズ演算子は記述できません。
【プログラム処置】
この命令を無効にします。
E4540A
Conflicting section attribute ( パラメータ名 )
セクション属性が矛盾しています ( パラメータ名 )
【プログラム処置】
この指定のみ無効にします。
W1541A
Value out of range
値が範囲外です
【プログラム処置】
オペランドに記述された式の演算結果 ( 値 ) をオペランドサイズに合わせてマスク
します ( 式については「7.11 式」を参照してください )。
アセンブラは , オブジェクトファイルを出力します。
【補足説明】
リストファイル出力指定オプション (-l) を指定していた場合 , アセンブラはリスト
ファイルを出力します。
リストファイルに出力されるオペランドのコードは , 演算結果をオペランドサイズ
に合わせてマスクした値になります。
本メッセージは, -OVFWオプション指定時にオペランドに記述された式の演算の結
果がそのオペランドサイズを超えた場合に出力されます。
詳細は , 「7.11.2 オペランド値の範囲」を参照してください。
September 1, 2014, CM81-00208-5
303
Su pp or t
E4541A
So ft
Manu al
Value out of range
値が範囲外です
【プログラム処置】
オペランドに記述された式の演算結果 ( 値 ) をオペランドサイズに合わせてマスク
します ( 式については , 「7.11 式」を参照してください )。
アセンブラは , オブジェクトファイルを出力しません。
【補足説明】
リストファイル出力指定オプション (-l) を指定していた場合 , アセンブラはリスト
ファイルを出力します。
リストファイルに出力されるオペランドのコードは , 演算結果をオペランドサイズ
に合わせてマスクした値になります。
本メッセージは , -XOVFW オプション指定時にオペランドに記述された式の演算の
結果がそのオペランドサイズを超えた場合に出力されます。
E4542A
Invalid keyword ( キーワード名 )
キーワード指定が不正です ( キーワード名 )
【プログラム処置】
このキーワード指定のみ無効にします。
E4543A
Invalid kind of register
レジスタの種類が不正です
【プログラム処置】
この命令を無効にします。
E4544A
Invalid register list ( 詳細情報 )
レジスタリスト記述が不正です ( 詳細情報 )
【プログラム処置】
この命令を無効にします。
304
CM81-00208-5, September 1, 2014
Support
W1545A
Soft
Ma nual
Meaningless symbol field ( 詳細情報 )
シンボル部は記述不要です ( 詳細情報 )
【プログラム処置】
シンボルフィールドの記述を無視します。
E4548A
Missing keyword
キーワード名が記述されていません
【プログラム処置】
この命令を無効にします。
E4550A
Location counter overflow
ロケーションカウンタがオーバフローしました
【プログラム処置】
そのまま処理を継続します。
W1551A
Missing .END directive
.END 擬似命令がありませんでした
【プログラム処置】
ファイル終端までをアセンブルの対象とします。
E4552A
Invalid value
不正な値です ( 異なるセクション内のシンボル値が含まれています )
【プログラム処置】
この命令を無効にします。
E4553A
Missing (=) behind keyword ( キーワード名 )
キーワード名の後ろに (=) が記述されていません ( キーワード名 )
【プログラム処置】
このキーワード指定のみ無効にします。
September 1, 2014, CM81-00208-5
305
Su pp or t
E4554A
So ft
Manu al
Duplicate keyword ( キーワード名 )
キーワード名が 2 重定義です ( キーワード名 )
【プログラム処置】
最初に指定されたキーワードを有効にします。
W1555A
Too long module-name
モジュール名が長すぎます
モジュール名が 255 文字を超えています。
【プログラム処置】
超えた分の文字を無効にします。
E4556A
Missing symbol field
シンボル記述がありません
【プログラム処置】
この命令を無効にします。
E4557A
Starting address out of section
開始アドレスがセクション範囲外です
【プログラム処置】
開始アドレスを無効にします。
W1558A
Starting address not in code section
開始アドレスのセクションがコード属性でありません
【プログラム処置】
ダミーセクションの場合のみ開始アドレスを無視します。他のセクションでは開始
アドレスはそのままセットされます。
306
CM81-00208-5, September 1, 2014
Support
E4559A
Soft
Ma nual
Conflicting Size-suffix ( 詳細情報 )
サイズ指定が矛盾しています ( 詳細情報 )
オペレーションサイズとオペランドサイズの指定が異なっています。
【プログラム処置】
オペレーションサイズを有効にします。
E4561A
Floating value underflow ( 詳細情報 )
浮動小数点定数がアンダフローです ( 詳細情報 )
【プログラム処置】
浮動小数点定数を +0 の値にします。
E4562A
Floating value overflow ( 詳細情報 )
浮動小数点定数がオーバフローです ( 詳細情報 )
【プログラム処置】
浮動小数点定数を指定された符号で , 値はこの精度で表すことができる最大の値に
します。
E4565A
Not a power of 2
2 のべき乗値でない値です。
【プログラム処置】
この指定を有効にします。
W1566A
Bigger than alignment size of .SECTION directive
.SECTION 命令の ALIGN 値より大きな値です。
【プログラム処置】
この指定を有効にします。
September 1, 2014, CM81-00208-5
307
Su pp or t
E4567A
So ft
Manu al
Not enough operands
オペランドの数が足りません
【プログラム処置】
この命令を無効にします。
W1568A
Invalid word in module name
モジュール名が不正です
モジュールの名前の規則に反しています。
【プログラム処置】
規則に反する文字を '_' に置き換えたモジュール名とします。
E4570A
Invalid section name ( セクション名 )
セクション名が不正です ( セクション名 )
【プログラム処置】
この命令を無効にします。
E4571A
Smaller value than beginning address set with LOCATE value of .SECTION
directive cannot be set
.SECTION 命令の LOCATE 値で設定されている開始アドレスより小さ
いアドレス値は設定できません
【プログラム処置】
この命令を無効にします。
E4572A
Bigger value than boundary value set with ALIGN value of .SECTION
directive cannot be set
.SECTION 命令の ALIGN 値で設定されている境界値より大きな値は設
定できません
【プログラム処置】
この命令を無効にします。
308
CM81-00208-5, September 1, 2014
Support
E4573A
Soft
Ma nual
Has no statement
対応する命令がありません
【プログラム処置】
この命令を無効にします。
W1574A
It cannot be guaranteed to arrange in a proper boundary. : Please set ALIGN
value of .SECTION directive in 2 or more
適正な境界に配置することを保証できません :.SECTION 命令の
ALIGN 値を 2 以上に設定してください。
【プログラム処置】
この命令を無効にします。
W1575A
It cannot be guaranteed to arrange in a proper boundary. : Please set ALIGN
value of .SECTION directive in 4 or more
適正な境界に配置することを保証できません :.SECTION 命令の
ALIGN 値を 4 以上に設定してください。
【プログラム処置】
この命令を無効にします。
W1576A
It cannot be guaranteed to arrange in a proper boundary. : Please set ALIGN
value of .SECTION directive in 8 or more
適正な境界に配置することを保証できません :.SECTION 命令の
ALIGN 値を 8 以上に設定してください。
【プログラム処置】
この命令を無効にします。
E4600A
Invalid operation mnemonic ( 命令名 )
不正な命令ニーモニック名です ( 命令名 )
【プログラム処置】
この命令を無効にして , NOP 命令を 1 個生成します。
September 1, 2014, CM81-00208-5
309
Su pp or t
E4605A
So ft
Manu al
Invalid Operation-suffix
命令オプションは指定できません
【プログラム処置】
以降のオペレーションフィールドを無視します。
E4606A
Invalid Option-suffix in operation field ( 詳細情報 )
不正な命令オプションです ( 詳細情報 )
【プログラム処置】
この指定のみを無視します。
W1608A
Conflicting Option-suffix in operation field ( 詳細情報 )
命令オプションの指定に矛盾があります ( 詳細情報 )
【プログラム処置】
最初に指定された命令オプションを有効にします。
E4616A
Not enough operands
オペランドの数が足りません
【プログラム処置】
この命令を無視して , NOP 命令を 1 個生成します。
E4617A
Too many operands ( 詳細情報 )
オペランドの数が多すぎます ( 詳細情報 )
【プログラム処置】
多い分のオペランドを無効にします。
E4619A
Unbalanced parentheses (in operand ( 番号 ))
括弧の対応がとれていません (in operand ( 番号 ))
【プログラム処置】
この命令を無視して , NOP 命令を 1 個生成します。
310
CM81-00208-5, September 1, 2014
Support
E4622A
Soft
Ma nual
Format-suffix not permitted ( 詳細情報 )
許されていないフォーマット指定です ( 詳細情報 )
【プログラム処置】
フォーマット指定を無効にします。
E4625A
Invalid Size-suffix ( 文字列 )
サイズ指定が不正です ( 文字列 )
【プログラム処置】
この指定を無効にします。
E4626A
Size-suffix not permitted
許されていないサイズ指定です
【プログラム処置】
サイズ指定を無効にします。
E4629A
Syntax error ( オペランド番号 , 詳細情報 )
構文に誤りがあります ( オペランド番号 , 詳細情報 )
【プログラム処置】
この命令を無効にして , NOP 命令を 1 個生成します。
E4639A
Addressing mode not permitted (in operand ( 番号 ))
許されていないアドレッシングモードです (in operand ( 番号 ))
【プログラム処置】
この命令を無効にして , NOP 命令を 1 個生成します。
E4651A
Floating point data too short (in operand ( 番号 ))
浮動小数点定数が短すぎる (in operand ( 番号 ))
【プログラム処置】
足りないデータ数を 0 で補います。
September 1, 2014, CM81-00208-5
311
Su pp or t
E4652A
So ft
Manu al
Floating point data too long (in operand ( 番号 ))
浮動小数点定数が長すぎる (in operand ( 番号 ))
【プログラム処置】
余分なデータを無視します。
E4654A
Illegal instruction start address ( 詳細情報 )
命令先頭アドレスが不正です ( 詳細情報 )
命令先頭のアドレスが奇数番地です。
【プログラム処置】
命令先頭のアドレスを偶数番地に配置します。
【特記事項】
命令の先頭を偶数番地に配置してください。
E4656A
Nothing operand ( 詳細情報 )
オペランドの記述がありません ( 詳細情報 )
【プログラム処置】
この命令を無効にして , NOP 命令を 1 個生成します。
E4698A
Number of include files exceeds 32766
インクルードファイル数が 32766 個を超えました
【プログラム処置】
アセンブル処理を中断します。
E4699A
Source-line exceeds 65535 lines
ソース行数が 65535 行を越えました
【プログラム処置】
ソース行数を 0 に戻してそのまま処理を続けます。オブジェクトは生成されません。
312
CM81-00208-5, September 1, 2014
Support
W1701A
Soft
Ma nual
Cannot optimize for insufficient memory
メモリ不足のため最適化ができません
【プログラム処置】
分岐命令の最適化は行いません。
E4703A
Cannot put machine-code
遅延スロットにこの命令はおけません
【プログラム処置】
そのまま処理を続行します。
W1704A
It is possible to optimize. : The back and forth instruction is replaced.
最適化できます : 前後の命令を入れ替えます
【プログラム処置】
前後の命令を入れ替えます。
W1705A
It is possible to optimize. : Changes to another instruction.
最適化できます : 別の命令に変更します
【プログラム処置】
別の命令に変更します。
W1706A
It is possible to optimize. : The instruction is deleted.
最適化できます : 命令を削除します
【プログラム処置】
命令を削除します。
W1707A
It is possible to optimize. : The instruction is newly generated.
最適化できます : 命令を新たに生成します
【プログラム処置】
命令を新たに生成します。
September 1, 2014, CM81-00208-5
313
Su pp or t
W1710A
So ft
Manu al
Instruction is written after .END
.END 命令以降に記述があります
【プログラム処置】
.END 命令以降の記述を無視します。
W1711A
Location address backed by .ORG
.ORG 命令でアドレスが戻っています
【プログラム処置】
指定されたアドレスで処理を続けます。
W1712A
This structure field cannot initialized
ストラクチャのこのフィールドは初期化できません
【プログラム処置】
この記述を無視します。
W1713A
Too many initialize data
ストラクチャの初期化データが多く与えられました
【プログラム処置】
この記述を無視します。
W1714A
Section type error
命令の持つアドレスの属性と異なった属性のシンボルを指定していま
す
【プログラム処置】
シンボルの属性を無視して命令を生成します。
314
CM81-00208-5, September 1, 2014
Support
E4715A
Soft
Ma nual
Section type error
命令の持つアドレスの属性と異なった属性のシンボルを指定していま
す
【プログラム処置】
この記述を無視します。
E4716A
.ENDS expected
.ENDS 命令がありません
【プログラム処置】
アセンブラは異常終了します。
W1717A
Mismatch .ENDS
.ENDS 命令と .STRUCT 命令の対応がとれていません
【プログラム処置】
この記述を無視します。
E4750A
Terms other than the bit symbol are described in the bit operator
ビット演算子にビットシンボル以外の項が記述されています
【プログラム処置】
この記述を無視します。
E4756A
Invalid address modifier
アドレス規定子を指定した命令に , 該当する命令がありません
【プログラム処置】
この記述を無視します。
E4758A
Input to @A can not be written in this expression
複数への代入の一括記述式で @A への代入を行っています
【プログラム処置】
この記述を無視します。
September 1, 2014, CM81-00208-5
315
Su pp or t
E4759A
So ft
Manu al
@EP and EP or @IX and IX exist in this expression
複数への代入の一括記述で , レジスタ (EP, IX) への代入が , レジスタ間
接 ( @ EP, @ IX) への代入よりも先に行われています。
【プログラム処置】
この記述を無視します。
W1800A
Not 2 bytes attribute
値が 2 バイト境界でありません
【プログラム処置】
値の下位 1 ビットを 0 にします。
W1801A
Not 4 bytes attribute
値が 4 バイト境界でありません
【プログラム処置】
値の下位 2 ビットを 0 にします。
E4802A
Invalid register
このレジスタは指定できません
【プログラム処置】
この命令を無効にして , NOP 命令を 1 個生成します。
E4803A
Fixed point of double precision is not supported
倍精度の固定小数点定数はサポートしていません
【プログラム処置】
この命令を無効にして , NOP 命令を 1 個生成します。
316
CM81-00208-5, September 1, 2014
Support
W1806A
Soft
Ma nual
DIVU is detected
DIVU 命令が検出されました
【プログラム処置】
そのまま処理を続行します。
【補足説明】
F2MC-8FX ファミリは DIVU 命令の動作が従来の F2MC-8L ファミリと異なるため
F2MC-8L ファミリ用アセンブラソースを F2MC-8FX ファミリ用に流用する場合 ,
DIVU 命令が使用されている箇所について問題がないか確認する必要があります。
本メッセージは , -div_check オプション指定時にアセンブラソース中に DIVU 命令
が検出された場合に出力されます。
本メッセージの出力が不要な場合は , -Xdiv_check オプションを指定してください。
-div_check オプションの詳細は , 「4.7.2 -div_check, -Xdiv_check」を参照してくださ
い。
F9860A
CPU information not found (CPU 名 )
CPU 情報がみつかりません (CPU 名 )
【プログラム処置】
アセンブル処理を中止します。
【特記事項】
-cpu オプションで指定された CPU の情報が , CPU 情報ファイルに登録されていな
い場合に発生します。
-cpu オプションにて指定された CPU の MB 番号を , 今一度ご確認ください。
この指定に誤りが無ければ , 営業部門へご連絡ください。
F9861A
Mismatch CPU information file version
CPU 情報ファイルのバージョンが適合しません
【プログラム処置】
アセンブル処理を中止します。
【特記事項】
読込んだ CPU 情報ファイルのバージョンが古く , 本アセンブラの必要とする情報を
含んでいない場合に発生します。
アセンブラパックを再インストールしてください。
September 1, 2014, CM81-00208-5
317
Su pp or t
F9901A
So ft
Manu al
Insufficient memory ( エラー ID)
メモリが足りません ( エラー ID)
【プログラム処置】
アセンブラは異常終了します。
【特記事項】
メモリを増設していただきますよう , お願いいたします。
F9902A
Internal error ( エラー ID)
内部エラー発生 ! ( エラー ID)
アセンブラの内部処理の矛盾によるエラーです。
【プログラム処置】
アセンブラは異常終了します。
【特記事項】
エラー ID のメモを取り , 開発元に連絡してください。
F9903A
File Write Error ( ファイル種別 )
ファイルの書き込みエラーです ( ファイル種別 )
【プログラム処置】
アセンブラは異常終了します。
【特記事項】
ディスクの容量不足 , または , 書込み禁止のファイルです。これらの事項について
確認してください。
F9904A
File read error ( ファイル種別 )
ファイルの読込みエラーです ( ファイル種別 )
ソースファイル , 作業ファイルのうち , 読込みができなくなったファイルがありま
す。
【プログラム処置】
アセンブラは異常終了します。
【特記事項】
アセンブル途中に , ソースファイルまたはワークファイルが強制的に削除されな
かったかどうか確認してください。
318
CM81-00208-5, September 1, 2014
Support
F9905A
Soft
Ma nual
Cannot open message file
メッセージファイルがオープンできません
【プログラム処置】
アセンブラは異常終了します。
【特記事項】
環境変数を設定するか , メッセージファイルがあるか確認してください。
F9907A
Structured nest level overflow
構造化制御のネストレベルが制限値を超えました
【プログラム処置】
アセンブラは異常終了します。
F9951A
Source filename not specified
ソースファイル名の指定がありません
【プログラム処置】
アセンブラは異常終了します。
F9952A
Cannot open file ( ファイル名 )
ファイルがオープンできません ( ファイル名 )
【プログラム処置】
アセンブラは異常終了します。
F9953A
Invalid option name ( オプション名 )
オプション名に誤りがあります ( オプション名 )
【プログラム処置】
アセンブラは異常終了します。
September 1, 2014, CM81-00208-5
319
Su pp or t
F9954A
So ft
Manu al
Invalid value ( オプション名 )
値が不正です ( オプション名 )
【プログラム処置】
アセンブラは異常終了します。
F9955A
Invalid sub-option name ( オプション名 )
サブオプション名に誤りがあります ( オプション名 )
【プログラム処置】
アセンブラは異常終了します。
F9956A
Invalid option description ( オプション名 )
オプションの指定形式に誤りがあります ( オプション名 )
【プログラム処置】
アセンブラは異常終了します。
F9959A
Nested option file exceeds 8 ( 詳細情報 )
オプションファイルのネストは 8 までです ( 詳細情報 )
【プログラム処置】
アセンブラは異常終了します。
F9960A
Too many file
ソースファイルの指定が多すぎます
複数のファイルはアセンブルできません。
【プログラム処置】
アセンブラは異常終了します。
320
CM81-00208-5, September 1, 2014
Support
F9961A
Soft
Ma nual
-cpu option not specified
-cpu オプションの指定がありません
【プログラム処置】
アセンブラは異常終了します。
September 1, 2014, CM81-00208-5
321
Su pp or t
付録 B
So ft
Manu al
制限事項
アセンブラを使用するときの制限事項を示します。
■ プリプロセッサ処理の制限
• インクルードファイルのネストレベルは最大 8 レベルです。
• 1 つのマクロボディの大きさは最大 64512 バイトです。
• マクロコールのネストレベルは最大 256 レベルです。
• マクロ定義で定義可能な仮引数の数は最大 32767 個です。
• 登録可能なマクロ名の数は無限です ( 使用可能メモリ領域に依存 )。
• 構造化制御構文のネストレベルは最大 40 レベルです。
• 構造化制御構文の複合条件式内の条件式は最大 8 個です。
• 構造化命令の複数への代入の一括記述の代入先は最大 8 個です。
■ アセンブル処理の制限
• アセンブル可能なソースファイルの行数は最大 65535 行です。
• 登録可能なシンボルの数は無限です ( 使用可能メモリ領域に依存 )。
• 1 行に記述可能な文字数は , 継続行も含めて最大 4095 文字です。
• .DATAB 命令 , .FDATAB 命令の式 1 の値は最大 1048575 です。
■ オプションファイルの制限
• オプションファイルの 1 行に記述可能な文字数は , 最大 4095 文字です。
• オプションファイルのネストレベルは最大 8 レベルです。
■ その他の制限
• ソースファイルの主ファイル名の文字数は , 最大 248 文字です。
• モジュール名に 2 バイト文字は使用できません。
322
CM81-00208-5, September 1, 2014
Support
付録 C
Soft
Ma nual
拡張ダイレクトアクセス領域バンク番号の取得方法
F2MC-8FX ファミリで利用可能な拡張ダイレクトアクセス領域のバンク番号の取得
方法について説明します。
■ 拡張ダイレクトアクセス領域バンク番号の取得方法
拡張ダイレクトアクセス領域に定義されたシンボルから , 拡張ダイレクトアクセス領
域バンク番号を取得するためには , 以下のヘッダファイルで定義されているマクロを
使用してください。
• ヘッダファイル :
%FETOOL%\LIB\896\INCLUDE\extdir.inc
• マクロ名 :
EDIRBANK()
【使用例】
#include
<extdir.inc >
:
.IMPORT
DIR0_a
:
.SECTION
CODE, CODE, ALIGN=1
SETDB
#EDIRBANK(DIR0_a)
MOV
A, X:DIR0_a
:
September 1, 2014, CM81-00208-5
323
Su pp or t
付録 D
So ft
Manu al
SOFTUNE アセンブラと旧版アセンブラの仕様の差異
SOFTUNE アセンブラ (FASM896S) と旧版アセンブラ (ASM96) の仕様の差異につい
て説明します。
D.1 アセンブラ言語の基本規則
D.2 式処理
D.3 擬似命令
D.4 マクロ処理
D.5 構造化制御命令
D.6 機械命令
D.7 コマンド行の差異
D.8 環境変数
D.9 オプション
D.10 制限事項の緩和
324
CM81-00208-5, September 1, 2014
Support
D.1
Soft
Ma nual
アセンブラ言語の基本規則
FASM896S と ASM96 のソース行シンタックスの差異について説明します。
■ 文の形式
アセンブラの 1 行は , 以下の形式で構成されます。
• 各フィールドは不要な場合 , 記述を省略できます。
• 各フィールドの区切りには , 1 文字以上の空白 , またはタブを記述します。
• コメントフィールド , 継続指示フィールドに差異があります。
【FASM896S の記述】
シンボル
フィールド
オペレーション
フィールド
オペランド
フィールド
コメント
フィールド
継続指示
フィールド
1 行の長さは最大 4095 文字
【ASM96 の記述】
シンボル
フィールド
オペレーション
フィールド
オペランド
フィールド
コメント
フィールド
1 行の長さは最大 127 文字
■ コメントフィールド
FASM896S
ASM96
セミコロン (;), または 2 個のスラッシュ
(//) でコメントが始まり , その行の終端ま
でをコメントとします。
セミコロン (;) でコメントが始まり , その
行の終端までをコメントとします。
C 言語風に /* */ で囲ったコメントの記述
も可能です。
■ 継続指示フィールド
FASM896S
改行の直前にバックスラッシュ (\) を記
述することにより , 行の内容を継続でき
ます。
September 1, 2014, CM81-00208-5
ASM96
継続行の記述はできません。
325
Su pp or t
So ft
Manu al
■ 文字セット
ソース記述時に使用できる文字を以下に示します。
このほかに , コメント部には漢字コードを含むすべての文字が記述可能です。
種別
文字
英文字 ( 大文字 )
A, B, C, D, E, F, G, H, I, J, K, L, M, N, O, P, Q, R, S, T, U, V, W, X, Y, Z
英文字 ( 小文字 )
a, b, c, d, e, f, g, h, i, j, k, l, m, n, o, p, q, r, s, t, y, v, w, x, y, z
数字
0, 1, 2, 3, 4, 5, 6, 7, 8, 9
特殊文字
+ - * / ( ) ; : ' " , _ . @ # $ ! % & < > = | \ 空白タブ
また , 特殊文字として "~" および "^" は , FASM896S では使用できますが , ASM96 では
使用できません。
■ 名前 ( シンボル , ラベル )
名前を定義 / 記述する場合 , 以下の定義に従います。
FASM896S
名前の規則
英字 , またはアンダバー(_) から記述を開始し , 以降は英
字 , 数字 , アンダバーを使用して定義します。
最大文字列長
大文字 / 小文字の区別
ASM96
255 文字
区別する
31 文字
オプション指定により選
択可能
■ ロケーションカウンタシンボルの記述
使用する文字
326
FASM896S
ASM96
$
*
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
■ 整数定数の記述方法
FASM896S
ASM96
2 進数の記述
B' nnnnnnn
0nnnnnnnB
0Bnnnnnnn
B' nnnnnnn
0nnnnnnnB
8 進数の記述
Q' nnnnnnn
nnnnnnnQ
0nnnnnnn
Q' nnnnnnn
nnnnnnnQ
10 進数の記述
D' nnnnnnn
nnnnnnnD
nnnnnnn
D' nnnnnnn
nnnnnnnD
nnnnnnn
16 進数の記述
H' nnnnnnn
nnnnnnnH
0xnnnnnnn
H' nnnnnnn
nnnnnnnH
FASM896S
ASM96
シングルクォートで
文字を括る
ダブルクォートで
文字を括る
最大文字長
4
2
制御コードの記述
可
不可
拡張表記
\ 記号に続けて記述すること
により , 特殊文字を指定でき
ます。
ダブルクォートを記述する
場合は , 同じ文字を 2 個連続
して記述します。
その他
C 言語風の制御文字を指定で
きます (\n, \t, etc.) 。
数値情報は記述できません。
■ 文字定数
記述方法
September 1, 2014, CM81-00208-5
327
Su pp or t
So ft
Manu al
■ 文字列定数
FASM896S
記述方法
ASM96
ダブルクォートで文字を括る
制御コードの記述
可
不可
拡張表記
\ 記号に続けて記述すること
により , 特殊文字を指定でき
ます。
ダブルクォートを記述する
場合は , 同じ文字を 2 個連続
して記述します。
その他
C 言語風の制御文字を指定で
きます (\n, \t, etc.) 。
数値情報は記述できません。
FASM896S
ASM96
■ 浮動小数点数
記述形式
記述例
328
[0r][+|-]{.d|d[.[d]]}[e[[+|-]d]]
[F' ][+|-]{.d|d[.[d]]}[e[[+|-]d]]
H' h d は 10 進数
0xh h は 16 進数
記述不可
0r-1.34e-20
F' -2.5
-1.2e10
CM81-00208-5, September 1, 2014
Support
D.2
Soft
Ma nual
式処理
式に使用する演算子の種類および優先順位の差異について説明します。
■ 演算子一覧
機能
FASM896S
優先順位の変更
ASM96
()
論理地の否定
!
ビット反転
~
NOT
単項 +
+
単項 -
-
ビットアドレス抽出
bitadr
%
ビットポジション抽出
bitpos
!
セクションサイズ抽出
sizeof
Segsize
乗算
*
除算
/
剰余算
%
加算
+
減算
-
左シフト
<<
SHL
右シフト
>>
SHR
未満 ( 比較 )
<
LT
以下 ( 比較 )
<=
LE
大きい ( 比較 )
>
GT
以上 ( 比較 )
>=
GE
等しい ( 比較 )
==
EQ
不一致 ( 比較 )
!=
NE
ビット AND
&
AND
ビット XOR
^
XOR
ビット OR
|
OR
論理 AND
&&
論理 OR
September 1, 2014, CM81-00208-5
||
329
Su pp or t
So ft
Manu al
■ 演算子の優先順位の差異
機能
優先順位の変更
FASM896S
ASM96
1
1
論理値の否定
2
ビット反転
単項 +
単項 -
2
ビットアドレス抽出
2
ビットポジション抽出
セクションサイズ抽出
乗算
除算
3
3
4
4
5
5
6
6
7
7
ビット AND
8
8
ビット XOR
9
9
ビット OR
10
10
論理 AND
11
論理 OR
12
剰余算
加算
減算
左シフト
右シフト
未満 ( 比較 )
以下 ( 比較 )
大きい ( 比較 )
以上 ( 比較 )
等しい ( 比較 )
不一致 ( 比較 )
330
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
■ 注意事項
機能
演算精度
符号
型付データのサポート
September 1, 2014, CM81-00208-5
FASM896S
ASM96
32ビット長, 指定により符
号あり / なしで演算する。
16 ビット長 , 符号なし。
符合あり / なし
符号なし
あり
なし
331
Su pp or t
D.3
So ft
Manu al
擬似命令
擬似命令の差異について説明します。
■ 擬似命令の差異一覧
表 D.3-1 擬似命令の差異一覧 (1 / 2)
機能
FASM896S
ASM96
.PROGRAM
NAME
.END
END
外部参照シンボル宣言
.IMPORT
EXTRN/EXTERN
外部定義シンボル宣言
.EXPORT
PUBLIC
.SECTION CODE *1
CSEG
I/O 関連領域定義
.SECTION DIR *1
DIRSEG
データ領域定義
.SECTION DATA *1
DSEG
.SECTION STACK *1
SSEG
記述不要
ENDS
ビット単位データ定義
.DATA.I
DBIT
バイト単位データ定義
.DATA.B or .SDATA *2
DB
2 バイト単位データ定義
.DATA.H
DW
4 バイト単位データ定義
.DATA.L
-
ビット単位領域確保
.RES.I
-
バイト単位領域確保
.RES.B
RBIT
2 バイト単位領域確保
.RES.H
RB
4 バイト単位領域確保
.RES.L
RW
単精度浮動小数データ定義
.FDATA.S
-
倍精度浮動小数データ定義
.FDATA.D
-
単精度浮動小数領域確保
.FRES.S
-
倍精度浮動小数領域確保
.FRES.D
-
.STRUCT ~ .ENDS
STRUC ~ ENDS
シンボル定義
.EQU
EQU
シンボル定義
-
SET
オブジェクト名の設定
ソース記述終了宣言
命令領域定義
スタック領域定義
領域定義終了
構造体宣言
332
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
表 D.3-1 擬似命令の差異一覧 (2 / 2)
機能
FASM896S
ASM96
.ALIGN
-
ロケーション調整
.ORG
ORG
リスト書式制御
.LIST
LIST
リスト出力抑止
.LIST
LISTOFF
リスト出力指定
.LIST
LILSTON
リスト改ページ指定
.PAGE
PAGE
リストタイトル指定
.HEADING
TITLE
-
SUBTTL
境界整合
サブタイトル指定
*1 : 付加する属性 (ABS, WORD, COMMON, など ) により実際の対応関係は変化します。
*2 : 文字列データ定義か数値データ定義かによって , どちらかを選択します。
■ セクション ( セグメント ) の定義
FASM896S のセクション定義は , 「10.2.3 .SECTION 命令」に記述されている規則にし
たがって行います。
FASM896S と ASM96 のセクション定義の対応の詳細は以下のようになります。
機能
FASM896S
ASM96
コード部
定義
.SECTION セクション名 , CODE, ALIGN=1
セクション名 CSEG
.SECTION セクション名 , CODE, LOCATE=0
セクション名 CSEG ABS
データ部
定義
.SECTION セクション名 , DATA, ALIGN=1
セクション名 DSEG
.SECTION セクション名 , DATA, LOCATE=0
セクション名 DSEG ABS
.SECTION セクション名 , DATA, ALIGN=1
セクション名 DSEG BYTE
.SECTION セクション名 , CONST, ALIGN=1
セクション名 DSEG ROM
.SECTION セクション名 , COMMON, ALIGN=1
セクション名 DSEG COMMON
.SECTION セクション名 , DIR, ALIGN=1
セクション名 DIRSEG
.SECTION セクション名 , DIR, LOCATE=0
セクション名 DIRSEG ABS
.SECTION セクション名 , DIR, ALIGN=1
セクション名 DIRSEG BYTE
.SECTION セクション名 , DIRCOMMON, ALIGN=1
セクション名 DIRSEG COMMON
DIR部定義
スタック
領域定義
.SECTION セクション名 , STACK, ALIGN=1
SSEG
<注意事項>
ASM96 では , セクション名の記述を省略できます。
September 1, 2014, CM81-00208-5
333
Su pp or t
So ft
Manu al
■ 文字列データ定義
FASM896S
334
ASM96
.SDATA "ABS\n"
DB "ABC", H' 0d, H' 0a
.DATA.B D' 00, D' 05
.SDATA "ABCDE"
.DATA.B D' 00
DB D' 00, D' 05, "ABCDE", ' 00
CM81-00208-5, September 1, 2014
Support
D.4
Soft
Ma nual
マクロ処理
マクロ命令の差異について説明します。
■ マクロ名の差異
機能
FASM896S
ASM96
マクロ定義開始
#MACRO
&MACRO
ローカルシンボル設定
#LOCAL
&LOCAL
マクロシンボル設定
#SET
&SET
マクロシンボル解放
#PURGE
&PURGE
繰返しマクロ定義
#REPEAT
&REPEAT
#IF
&IF
条件マクロ
真
&THEN
偽
#ELSE
&ELSE
条件マクロ終了
#ENDIF
&ENDIF
マクロ定義終了
#ENDM
&ENDM
#INCLUDE
&INCLUDE
ファイルの読込み
September 1, 2014, CM81-00208-5
335
Su pp or t
D.5
So ft
Manu al
構造化制御命令
構造化制御命令の差異について説明します。
■ 構造化制御命令
FASM896S と ASM96 で使用できる構造化制御命令は同じです。
条件式に記述するコンディションコード条件式の記述方法も同じです。
条件式に記述する比較条件式は以下の差異があります。
ASM96
符号あり
336
FASM896S
符号なし
符号あり
符号なし
等しい
==
Z(EQ)
等しくない
!=
NZ(NE)
より小さい
<
<.U
LT
LO
以下
<=
<=.U
LE
LS
より大きい
>
>.U
GT
HI
以上
>=
>=.U
GE
CM81-00208-5, September 1, 2014
Support
D.6
Soft
Ma nual
機械命令
機械命令の記述方法は , ハードウェアマニュアルによって規定されるため , オペラン
ド部の記述方法以外の変更はありません。
■ 機械命令
機械命令の記述方法は , ハードウェアマニュアルによって規定されるため , オペランド
部の記述方法以外の変更はありません。
オペランド部の記述の際については ,「D.1 アセンブラ言語の基本規則」を参照してく
ださい。
September 1, 2014, CM81-00208-5
337
Su pp or t
D.7
So ft
Manu al
コマンド行の差異
コマンド行の差異について説明します。
■ 起動形式
FASM896S
ASM96
fasm896s [ オプション ]…[ ファイル名 ]
asm96 ファイル名 [ オプション ]…
asm96 @ オプションファイル
■ オプション指定
機能
オプション指定の位置
オプションファイルの指定
オプションファイルの複数指定
338
FASM896S
ASM96
どの位置でも可能
ファイル名指定の後
-f オプションファイル
@ オプションファイル
可
不可
CM81-00208-5, September 1, 2014
Support
D.8
Soft
Ma nual
環境変数
環境変数の差異について説明します。
■ 環境変数
FASM896S
ASM96
TMP
TMP
インクルードファイル
検索パス指定
INC896
INC96
インストールパス指定
FETOOL
-
表示文字コード指定
FELANG
-
デフォルトオプションファイル
格納パス指定
OPT896
-
作業用ディレクトリ指定
September 1, 2014, CM81-00208-5
339
Su pp or t
D.9
So ft
Manu al
オプション
オプションの差異について説明します。
■ オプション
表 D.9-1 オプション (1 / 2)
FASM896S
ASM96
-o
O
-Xo
NO
-g/-Xg
DEB, DBG, LO, HI/
NDB
環境変数指定
WD pathname
常に区別
CP/NCP
-W[0-3]
-
-name module
-
リストファイル出力
-l/-Xl
-lf filename
L [filename]
リストの 1 頁の行数
-pl [0|20-255]
PL [40-128]
リストの 1 行の文字数
-pw [80-255]
PW [80-136]
-pl 0
-
インフォメーションリスト出力
-linf [on|off]
-
ソースリスト出力
-lsrc [on|off]
-
セクションリスト出力
-lsec [on|off]
-
クロスリファレンスリスト出力
-lcros [on|off]
XR/NXR
インクルードファイルリスト出力制御
-linc [on|off]
ICL/NCL
マクロ if 文のリスト制御
-
CD/NCD
マクロ定義部のリスト制御
-
DEF/NDEF
マクロコール・構造化制御命令行のリスト制御
-
CL/NCL
構造化制御命令の展開部のリスト制御
-
STR/NSTR
-lexp [on|off]
EXP/NEXP
-p
-
-P/Pf filename
-
オブジェクトファイル名指定
オブジェクトファイル出力抑止
デバッグ情報出力
作業ディレクトリ指定
大文字小文字の区別指定
警告メッセージ出力レベル指定
モジュール名指定
リストの改ページ処理抑止
マクロ展開部のリスト出力制御
プリプロセッサ抑止
プリプロセッサのみ起動
340
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
表 D.9-1 オプション (2 / 2)
FASM896S
ASM96
-D name[=def]
-
-U name
-
インクルードパス表示
-H
-
プリプロセッサ出力へのコメント出力
-C
-
エラー情報ファイルの出力 / 抑止
-
-[NO]EP
ステータスコードのファイル出力
-
-RC
ヘルプの表示
-help
-
ターゲット CPU の指定
-cpu
-
-Xdof
-
-V/-XV
-
マクロ名指定
未定義マクロシンボルへの値付け
デフォルトオプションファイル入力抑止
起動メッセージの表示 / 非表示
September 1, 2014, CM81-00208-5
341
Su pp or t
So ft
Manu al
D.10 制限事項の緩和
制限事項 ( 処理限界 ) の差異について説明します。
■ 制限事項
FASM896S
ASM96
1 行文字数
4095 文字
128 文字
ソースファイル行数
65535 文字
32000 行
シンボル数
無制限
32000 個
名前の長さ
255 文字
31 文字
無制限
マクロ定義数は 512 個
ローカルシンボル数は 256 個
256 レベル
8 レベル
登録可能マクロ名数
マクロのネスト
342
CM81-00208-5, September 1, 2014
Support
付録 E
Soft
Ma nual
主な変更内容
ページ
場所
変更箇所
Revision 4.1
-
-
社名変更および記述フォーマットの変換
Revision 5.0
114
7.8 文字列
■ 文字列
例の社名部分を削除
228
11.8 マクロ名の置換処理
■ マクロ置換の規則
例の社名部分を変更
317
付録 A エラーメッセージ
一覧
エラーコード : F9860A
September 1, 2014, CM81-00208-5
【特記事項】の社名部分を変更
343
Su pp or t
344
So ft
Manu al
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
索引
Symbols
## 演算子
マクロ置換の文字の連結 (## 演算子 ) ...............233
#define 命令
引数付き #define 命令 ...........................................230
引数なし #define 命令 ...........................................230
#elif 命令
#elif 命令 ................................................................225
#else 命令
#else 命令 ...............................................................224
#endif 命令
#endif 命令 .............................................................227
#endm 命令
#endm 命令 .............................................................216
#error 命令
#error 命令 ..............................................................240
#exitm 命令
#exitm 命令 .............................................................215
#exitm 命令の規則 .................................................215
#ifdef 命令
#ifdef 命令 ..............................................................222
#ifndef 命令
#ifndef 命令 ............................................................223
#if 命令
#if 命令 ...................................................................221
#include 命令
#include 命令 ..........................................................237
#line 命令
#line 命令 ................................................................239
#local 命令
#local 命令 ..............................................................213
#local 命令の規則 ..................................................213
#macro 命令
#macro 命令 ............................................................212
#macro 命令の規則 ................................................212
#pragma 命令
#pragma 命令 ..........................................................241
#purge 命令
#purge 命令 .............................................................236
#repeat 命令
#repeat 命令 ............................................................219
#repeat 命令の規則 ................................................219
#set 命令
#set 命令 .................................................................234
#undef 命令
#undef 命令 .............................................................235
# 演算子
マクロ仮引数の文字列化 (# 演算子 ) .................232
.ALIGN
.ALIGN .....................................................................86
.ALIGN 命令
.ALIGN 命令 ..........................................................159
.ASCII
.ASCII .......................................................................93
.ASCII 命令
.ASCII 命令 ............................................................177
September 1, 2014, CM81-00208-5
.BIT
.BIT ........................................................................... 89
.BIT 命令
.BIT 命令 ................................................................ 169
.break 命令
.break 命令 .............................................................. 272
.BYTE
.BYTE ....................................................................... 89
.BYTE 命令
.BYTE 命令 ............................................................ 170
.continue 命令
.continue 命令 .........................................................273
.DATA
.DATA ......................................................................89
.DATAB
.DATAB .................................................................... 90
.DATAB 命令
.DATAB 命令 .........................................................171
.DATA 命令
.DATA 命令 ...........................................................169
.DEBUG
.DEBUG .................................................................... 94
.DEBUG 命令
.DEBUG 命令 .........................................................181
.DOUBLE
.DOUBLE .................................................................91
.DOUBLE 命令
.DOUBLE 命令 ......................................................173
.END
.END ......................................................................... 84
.ENDS 命令
.STRUCT 命令 ,.ENDS 命令 ................................. 179
.END 命令
.END 命令 .............................................................. 155
.EQU
.EQU ......................................................................... 88
.EQU 命令
.EQU 命令 .............................................................. 167
.EXPORT
.EXPORT .................................................................. 87
.EXPORT 命令
.EXPORT 命令 ....................................................... 163
.FDATA
.FDATA .................................................................... 91
.FDATAB
.FDATAB .................................................................91
.FDATAB 命令
.FDATAB 命令 ......................................................174
.FDATA 命令
.FDATA 命令 .........................................................172
.FLOAT
.FLOAT ..................................................................... 91
.FLOAT 命令
.FLOAT 命令 .......................................................... 172
.FORM
.FORM ......................................................................96
345
Su pp or t
.FORM 命令
.FORM 命令 ...........................................................185
.FRES
.FRES ........................................................................92
.FRES 命令
.FRES 命令 .............................................................176
.GLOBAL
.GLOBAL .................................................................87
.GLOBAL 命令
.GLOBAL 命令 ......................................................164
.HALF
.HALF .......................................................................89
.HALF 命令
.HALF 命令 ............................................................170
.HEADING
.HEADING ...............................................................97
.HEADING 命令
.HEADING 命令 ....................................................187
.IMPORT
.IMPORT ...................................................................87
.IMPORT 命令
.IMPORT 命令 ........................................................165
.LIBRARY
.LIBRARY ................................................................95
.LIBRARY 命令
.LIBRARY 命令 .....................................................183
.LIST
.LIST .........................................................................97
.LIST 命令
.LIST 命令 ..............................................................188
.LONG
.LONG .......................................................................90
.LONG 命令
.LONG 命令 ............................................................170
.ORG
.ORG .........................................................................86
.ORG 命令
.ORG 命令 ..............................................................160
.PAGE
.PAGE .......................................................................97
.PAGE 命令
.PAGE 命令 ............................................................190
.PROGRAM
.PROGRAM ..............................................................84
.PROGRAM 命令
.PROGRAM 命令 ...................................................154
.RES
.RES ..........................................................................92
.RES 命令
.RES 命令 ...............................................................175
.SDATA
.SDATA ....................................................................93
.SDATAB
.SDATAB ..................................................................93
.SDATAB 命令
.SDATAB 命令 .......................................................178
.SDATA 命令
.SDATA 命令 .........................................................177
.SECTION
.SECTION .................................................................85
.SECTION 命令
.SECTION 命令 ......................................................156
346
So ft
Manu al
.SKIP
.SKIP ......................................................................... 86
.SKIP 命令
.SKIP 命令 .............................................................. 161
.SPACE
.SPACE ..................................................................... 98
.SPACE 命令
.SPACE 命令 .......................................................... 191
.STRUCT 命令
.STRUCT 命令 ,.ENDS 命令 ................................. 179
.TITLE
.TITLE ......................................................................96
.TITLE 命令
.TITLE 命令 ...........................................................186
.WORD
.WORD ..................................................................... 90
.WORD 命令
.WORD 命令 .......................................................... 170
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
Numerics
B
10 進定数
10 進定数 ................................................................110
16 進定数
16 進定数 ................................................................110
2 処理選択構文
2 処理選択構文 ......................................................265
2 進定数
2 進定数 ..................................................................110
8 進定数
8 進定数 ..................................................................110
BITADR 演算子
ビットシンボルアドレス演算子
(BITADR 演算子 ) ...........................................128
BITPOS 演算子
ビットポジション番号演算子 (BITPOS 演算子 )
..........................................................................128
C
-C
-C .............................................................................. 48
-cif
-cif ............................................................................. 68
-cmsg
-cmsg ......................................................................... 59
-cpu
-cpu ........................................................................... 62
-cwno
-cwno ........................................................................60
C 言語プリプロセッサ
C 言語プリプロセッサとの違い .........................245
D
-D
-D .............................................................................. 45
defined マクロ名
defined マクロ名 ................................................... 244
F
-f
-f ................................................................................ 55
fasm896s
fasm896s コマンド行 .............................................. 18
FELANG
FELANG ................................................................... 11
FETOOL
FETOOL ................................................................... 10
G
-g
-g ...............................................................................34
H
-H
-H .............................................................................. 47
-help
-help ..........................................................................61
I
-I
-I ................................................................................ 46
INC896
INC896 ......................................................................13
September 1, 2014, CM81-00208-5
347
Su pp or t
K
S
-kanji
-kanji .........................................................................63
-sa
L
-l
-l ................................................................................36
-LBA
-LBA .........................................................................64
-lcros
-lcros ..........................................................................39
-lexp
-lexp ..........................................................................40
-lf
-lf ...............................................................................36
-linc
-linc ...........................................................................40
-linf
-linf ............................................................................38
-lsec
-lsec ...........................................................................39
-lsrc
-lsrc ............................................................................38
So ft
Manu al
-sa .............................................................................. 50
SIZEOF 演算子
セクションサイズ抽出 (SIZEOF 演算子 ) ......... 129
SOFTUNE
概要 (SOFTUNE アセンブラ ) ................................. 4
T
-tab
-tab ............................................................................41
TMP
TMP ..........................................................................12
U
-U
-U .............................................................................. 45
V
-V
-V .............................................................................. 58
N
W
-name
-name .........................................................................57
-w
-w .............................................................................. 56
O
X
-o
-o ...............................................................................33
OPT896
OPT896 .....................................................................14
-OVFW
-OVFW ......................................................................66
P
-P
-P ...............................................................................44
-p
-p ...............................................................................43
-Pf
-Pf ..............................................................................44
-pl
-pl ..............................................................................37
-pw
-pw ............................................................................37
R
-Xcmsg
-Xcmsg ......................................................................59
-Xcwno
-Xcwno ......................................................................60
-Xdof
-Xdof ......................................................................... 54
-Xg
-Xg ............................................................................34
-Xl
-Xl ............................................................................. 36
-XLBA
-XLBA ......................................................................64
-Xo
-Xo ............................................................................33
-XOVFW
-XOVFW .................................................................. 67
-Xsa
-Xsa ........................................................................... 50
-XV
-XV ........................................................................... 58
ROM 化セクション
ROM 化セクションの書き方 ..............................145
348
CM81-00208-5, September 1, 2014
Support
Soft
あ
アセンブラ
概要 (SOFTUNE アセンブラ ) .................................4
概要 ( アセンブラ文法 ) ...........................................6
アセンブラ擬似機械命令
F2MC-8L/8FX ファミリ用アセンブラ擬似機械命
令 ......................................................................248
アセンブル
アセンブル処理の制限 .........................................322
アセンブルフェーズ
アセンブルフェーズ .................................................4
アドレス規定子
アドレス規定子 .....................................................122
アドレス制御命令
アドレス制御命令 .................................................158
い
インクリメント
インクリメント / デクリメント式 .....................282
インクルードファイル
インクルードファイル ...........................................83
インフォメーションリスト
インフォメーションリスト .............................76, 78
え
エラー番号
エラー番号 W1551A ...............................................56
エラー番号 W1711A ...............................................56
エラー表示
エラー表示 ...............................................................82
エラーメッセージ
エラーメッセージ一覧 .........................................287
エラーメッセージの見方 .....................................286
演算系擬似機械命令
演算系擬似機械命令 .............................................250
演算子
演算子の優先順位 .................................................131
プリプロセッサの演算子 .....................................209
プリプロセッサの演算子の優先順位 .................210
演算精度
プリプロセッサの式の演算精度 .........................208
お
オブジェクト
オブジェクトおよびデバッグに関するオプション
............................................................................32
オプション
オブジェクトおよびデバッグに関するオプション
............................................................................32
起動時オプション一覧 ...........................................29
起動時オプションの規則 .......................................28
その他のオプション ...............................................53
ターゲット依存オプション ...................................49
プリプロセッサに関するオプション ...................42
リスティングに関するオプション .......................35
September 1, 2014, CM81-00208-5
Ma nual
オプションファイル
オプションファイル .............................................. 23
オプションファイルに記述できるコメント ...... 24
オプションファイルの制限 ................................322
オペランド
オペランドの順序 ................................................149
オペランドフィールド
オペランドフィールド ........................................ 105
オペランドフィールドの記述形式 .................... 149
オペレーションフィールド
オペレーションフィールド ................................104
か
開発環境
開発環境のディレクトリ構造 ..............................15
外部参照値
外部参照値 ............................................................ 121
概要
概要 (SOFTUNE アセンブラ ) ................................. 4
概要 ( アセンブラ文法 ) ...........................................6
空命令
空命令 ....................................................................242
仮引数
仮引数の置換規則 ................................................206
仮引数の名前の規則 ............................................ 206
関係演算子
関係演算子 ............................................................ 126
き
機械命令
機械命令の記述形式 ............................................ 148
擬似命令
擬似命令で扱う整数定数の範囲 ........................ 152
サイズ演算子を含む式が記述できない擬似命令
..........................................................................130
既定義マクロ名
既定義マクロ名 ....................................................243
起動時オプション
起動時オプション一覧 .......................................... 29
起動時オプションとの関係 ..74, 154, 182, 185, 189
起動時オプションの規則 ...................................... 28
行
行の継続 ................................................................ 201
共有結合
共有結合 ................................................................ 143
く
クロスリファレンスリスト
クロスリファレンスリスト ................................100
け
計算型繰返し構文
計算型繰返し構文 ................................................268
継続指示フィールド
継続指示フィールド ............................................ 105
349
Su pp or t
こ
項
項に記述可能な種類 .............................277, 279, 283
項の種類 .................................................................121
構造化プログラム命令
構造化プログラム命令の概要 .............................259
構造化プログラム命令の記述形式 .....................264
構造化プログラム命令の条件式 .........................260
構造化命令
構造化命令の概要 .................................................258
構造体
構造体のアクセス .................................................180
構造体の領域定義 .................................................179
後方参照シンボル
前方参照シンボルと後方参照シンボル .............109
コマンド行
fasm896s コマンド行 ..............................................18
コメント
オプションファイルに記述できるコメント .......24
コメント .........................................................132, 200
コメントフィールド
コメントフィールド .............................................105
さ
サイズ演算子
サイズ演算子について .........................................109
サイズ演算子を含む式が記述できない擬似命令 ...
130
最適化
分岐命令の最適化 ...................................................70
最適配置分岐擬似機械命令
最適配置分岐擬似機械命令 .................................253
算術演算子
算術演算子 .............................................................127
し
式
サイズ演算子を含む式が記述できない擬似命令
..........................................................................130
式の演算精度について .........................................120
式の概要 .................................................................274
式の記述形式 .........................................................275
式の構文 .................................................................119
式の種類 .................................................................120
プリプロセッサの式 .............................................208
プリプロセッサの式の演算精度 .........................208
実行条件型繰返し構文
実行条件型繰返し構文 .........................................271
終了コード
終了コード ...............................................................26
終了条件型繰返し構文
終了条件型繰返し構文 .........................................270
条件式
構造化プログラム命令の条件式 .........................260
条件式の記述形式 .................................................264
条件付きアセンブル命令
条件付きアセンブル命令 .....................................220
初期値データ
初期値データの転送 .............................................145
350
So ft
Manu al
シンボル
シンボルの生成規則 ............................................ 263
シンボル定義命令
シンボル定義命令 ................................................166
シンボルフィールド
シンボルフィールド ............................................ 104
せ
整数定数
擬似命令で扱う整数定数の範囲 ........................ 152
整数定数 ........................................................110, 202
セクション
セクションタイプ ........................................134, 156
セクションタイプと属性 .................................... 139
セクション値 ........................................................ 122
セクションの記述形式 ........................................ 134
セクションの結合方法 ........................................ 142
セクションのタイプについて ............................136
セクションの配置形式について ........................ 140
セクションの分割記述 ........................................ 144
セクション配置形式 ....................................135, 157
セクションサイズ
セクションサイズ抽出 (SIZEOF 演算子 ) ......... 129
他のモジュールにあるセクションサイズを得るに
は ......................................................................130
セクションリスト
セクションリスト ..................................................99
絶対値
絶対値 ....................................................................121
全体形式
全体形式 .................................................................. 74
前方参照シンボル
前方参照シンボルと後方参照シンボル ............109
そ
相対値
相対値 ....................................................................121
ソースリスト
ソースリスト .......................................................... 80
その他
その他のオプション .............................................. 53
その他の制限 ........................................................ 322
その他の擬似機械命令
その他の擬似機械命令 ........................................ 251
た
ターゲット依存
ターゲット依存オプション ..................................49
代入演算式
代入演算式 ............................................................ 278
代入式
代入式 ....................................................................276
多処理選択構文
多処理選択構文 ....................................................266
単精度
単精度と倍精度の指定 ........................................ 116
単精度浮動小数点定数
単精度浮動小数点定数のデータ形式 ................ 117
CM81-00208-5, September 1, 2014
Support
Soft
て
ディレクトリ
開発環境のディレクトリ構造 ...............................15
デクリメント
インクリメント / デクリメント式 .....................282
デバッグ
オブジェクトおよびデバッグに関するオプション
32
デバッグ情報出力制御命令
デバッグ情報出力制御命令 .................................181
デフォルトオプションファイル
デフォルトオプションファイル ...........................25
デフォルトデータサイズ
デフォルトデータサイズ .....................276, 279, 282
な
名前
名前から値を算出する演算子 .............................127
名前の規則 .............................................................107
名前の分類 .............................................................107
は
倍精度
単精度と倍精度の指定 .........................................116
倍精度浮動小数点定数
倍精度浮動小数点定数のデータ形式 .................117
Ma nual
プリプロセッサの演算子 .................................... 209
プリプロセッサの演算子の優先順位 ................ 210
プリプロセッサの式 ............................................ 208
プリプロセッサの式の演算精度 ........................ 208
プリプロセッサフェーズ
プリプロセッサフェーズ ........................................ 4
プリプロセッサ命令
プリプロセッサ命令の記述形式 ........................ 199
プログラム結合命令
プログラム結合命令 ............................................ 162
プログラム構造定義命令
プログラム構造定義命令 .................................... 153
分岐系擬似機械命令
分岐系擬似機械命令 ............................................ 249
分岐命令
分岐命令の最適化 ..................................................70
文の形式
文の形式 ................................................................ 104
文法
概要 ( アセンブラ文法 ) ...........................................6
へ
ヘッダ
ヘッダの形式 .......................................................... 77
ま
ビットアドレス
ビットアドレス .....................................................122
ビット演算子
ビット演算子 .........................................................126
ビットシンボルアドレス演算子
ビットシンボルアドレス演算子 (BITADR 演算子
) .........................................................................128
ビットポジション番号演算子
ビットポジション番号演算子 (BITPOS 演算子 )
..........................................................................128
マクロ置換
マクロ置換の規則 ................................................228
マクロ置換の文字の連結 (## 演算子 ) ............... 233
マクロ仮引数
マクロ仮引数の文字列化 (# 演算子 ) ................. 232
マクロコール命令
マクロコール命令 ................................................217
マクロコール命令の規則 .................................... 217
マクロ定義
マクロ定義 ............................................................ 211
マクロ定義の規則 ................................................211
マクロ名
マクロ名の規則 ....................................................205
マクロ名の種類 ....................................................205
マクロ名の置換処理 ............................................ 228
ふ
め
ファイル
ファイル指定 ...........................................................19
ファイル検索
形式 1 のファイル検索 .........................................237
形式 2 と形式 3 のファイル検索 .........................238
ファイル名
ファイル名の指定形式 ...........................................21
ファイル名の省略指定 ...........................................22
浮動小数点定数
浮動小数点定数の表記 .........................................115
浮動小数点定数の表現可能な範囲 .....................118
プリプロセッサ
プリプロセッサ .....................................................194
プリプロセッサ処理 ...............................................81
プリプロセッサ処理の制限 .................................322
プリプロセッサに関するオプション ...................42
命令文
命令文の生成規則 ................................................263
ひ
September 1, 2014, CM81-00208-5
も
文字定数
文字定数 ........................................................112, 203
文字定数要素 ........................................................ 203
文字セット
文字セット ............................................................ 106
文字列
文字列 ....................................................................114
351
Su pp or t
So ft
Manu al
よ
予約語
予約語 .....................................................................108
ら
ライブラリファイル指定命令
ライブラリファイル指定命令 .............................183
り
リスティング
リスティングに関するオプション .......................35
リスト出力制御命令
リスト出力制御命令 .............................................184
リピート展開
リピート展開 .........................................................218
領域定義命令
領域定義命令 .........................................................168
れ
連結結合
連結結合 .................................................................142
ろ
ローカルシンボル
ローカルシンボルの置換規則 .............................207
ローカルシンボルの名前規則 .............................207
ロケーションカウンタシンボル
ロケーションカウンタシンボル .........................111
論理演算子
論理演算子 .............................................................126
論理値
論理値 .....................................................................126
352
CM81-00208-5, September 1, 2014
Support
Soft
Ma nual
奥付
CM81-00208-5
Spansion • SUPPORT SOFT MANUAL
F2MC®-8L/8FX
8 ビット・マイクロコントローラ
SOFTUNE® アセンブラマニュアル V3 対応
2014 年 9 月 Rev. 5.0
発行
Spansion Inc.
編集
コーポレートコミュニケーション部
September 1, 2014, CM81-00208-5
353
Su pp or t
So ft
Manu al
免責事項
本資料に記載された製品は、通常の産業用 , 一般事務用 , パーソナル用 , 家庭用などの一般的用途 ( ただし、用途の限定はあ
りません ) に使用されることを意図して設計・製造されています。(1) 極めて高度な安全性が要求され、仮に当該安全性が
確保されない場合、社会的に重大な影響を与えかつ直接生命・身体に対する重大な危険性を伴う用途 ( 原子力施設における
核反応制御 , 航空機自動飛行制御 , 航空交通管制 , 大量輸送システムにおける運行制御 , 生命維持のための医療機器 , 兵器シ
ステムにおけるミサイル発射制御等をいう ) 、ならびに (2) 極めて高い信頼性が要求される用途 ( 海底中継器 , 宇宙衛星等を
いう ) に使用されるよう設計・製造されたものではありません。上記の製品の使用法によって惹起されたいかなる請求また
は損害についても、Spansion は、お客様または第三者、あるいはその両方に対して責任を一切負いません。半導体デバイス
はある確率で故障が発生します。当社半導体デバイスが故障しても、結果的に人身事故 , 火災事故 , 社会的な損害を生じさ
せないよう、お客様において、装置の冗長設計 , 延焼対策設計 , 過電流防止対策設計 , 誤動作防止設計などの安全設計をお
願いします。本資料に記載された製品が、外国為替及び外国貿易法、米国輸出管理関連法規などの規制に基づき規制され
ている製品または技術に該当する場合には、本製品の輸出に際して、同法に基づく許可が必要となります。
商標および注記
このドキュメントは、断りなく変更される場合があります。本資料には Spansion が開発中の Spansion 製品に関する情報が
記載されている場合があります。Spansion は、それらの製品に対し、予告なしに仕様を変更したり、開発を中止したりする
権利を有します。このドキュメントに含まれる情報は、現状のまま、保証なしに提供されるものであり、その正確性 , 完全
性 , 実施可能性および特定の目的に対する適合性やその市場性および他者の権利を侵害しない事を保証するものでなく、ま
た、明示 , 黙示または法定されているあらゆる保証をするものでもありません。Spansion は、このドキュメントに含まれる
情報を使用することにより発生したいかなる損害に対しても責任を一切負いません。
Copyright © 2004-2014 Spansion. All rights reserved.
商標:Spansion®, Spansion ロゴ ( 図形マーク ), MirrorBit®, MirrorBit® EclipseTM, ORNANDTM 及びこれらの組合せは、米国・
日本ほか諸外国における Spansion LLC の商標です。第三者の社名・製品名等の記載はここでは情報提供を目的として表記
したものであり、各権利者の商標もしくは登録商標となっている場合があります。
354
CM81-00208-5, September 1, 2014