質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
アセンブリ言語

アセンブリ言語とは、機械語を人間にわかりやすい形で記述した低水準言語です。

x86

x86はIntel 8086 CPU シリーズの命令セットアルキテクチャーです。

Q&A

解決済

1回答

988閲覧

NASM 構文 リアルモードでファージャンプできない

kazuyakazuya

総合スコア193

アセンブリ言語

アセンブリ言語とは、機械語を人間にわかりやすい形で記述した低水準言語です。

x86

x86はIntel 8086 CPU シリーズの命令セットアルキテクチャーです。

0グッド

1クリップ

投稿2020/10/27 05:03

NASM ファージャンプするための構文
NASMを使ってブートローダーを作成しそれをVM上で動かしているのですが
構文がわからないためファージャンプできません。(リアルモード時)

例えば0x7E00へファージャンプしたい場合
ベース:0x0000 × 0x10
オフセット:0x7E00

ベース + オフセット = 0x7E00

NASMの構文にて上記アドレスへファージャンプを行うにはどのように書けばいいのでしょう?

ちなみに機械語を配置すればファージャンプできるので
いままで以下の方法でリアルモードにてファージャンプしていました。

(これはジャンプじゃなくてコールだった)
DB 0x9A
DD 0x7E00
DD 0x0000
リンク内容

イメージ説明

ファージャンプするにはどのような構文を書けばいいのでしょうか?

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

例えば0x7E00へファージャンプしたい場合

FreeDOS 1.2に同梱のNASM(ver.2.12.02) で確認しましたが、以下のコードになります。

; 絶対指定 0:7e00h にFARジャンプ jmp 0:7e00h

FreeDOS 1.2のDEBUGコマンドで実行した例です。CS:IPの値を見ると、0:7e00hにジャンプしたことが分かります。

イメージ説明

ちなみにメモリ間接指定でのFARジャンプは、以下のようになります。x86のリセット番地であるffffh:0 にFARジャンプさせる雑なサンプルです。ハードウェアの必要なリセットは置いてけぼりかもしれませんが、とりあえず見た目、ソフトウェア的には無事にリセットしているように見えます。

; メモリ間接指定 ; entry番地に収めたセグメント:オフセット ffffh:0 にFARジャンプする例 mov word [entry], 0 mov word [entry + 2], 0ffffh jmp far [entry] entry dw(2)

投稿2020/10/28 14:58

dodox86

総合スコア9183

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kazuyakazuya

2020/10/29 09:11

あれ。。。こちらでもできました そのパターンは試したつもりだったのですが・・・ まぁいいや ありがとうございました
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問