it-swarm.dev

I / Oポートアドレスとデータはどのように送信されますか?

まず第一に、これはハードウェアレベルの質問であり、x86アセンブリの「in」および「out」コマンドに非常に密接に関連していると言いたいです。

かなり前から検索してきましたが、アドレスやデータの送信方法はまだわかりません。 8086は最初にアドレスを送信し、次にデータを送信しますか?その場合、8086が16ビットアドレスと8ビットアドレスのどちらを送信しているかをレシーバはどのようにして知るのでしょうか。

それとは別に、8255がどのように機能するか、および「ポート60H」などの特定のポートをどのように受け入れるかについても学びたいと思います。

読んでくれてありがとう! :D

2
Myrl

8086プロセッサについて述べたように、8086を参照して説明します。

8086は16ビットプロセッサ(16ビットデータバスの意味:キャリーアウトまたはキャリーインの物理ラインの数は16ラインのALUサイズの場合もあります)および20ビットアドレスバス(20ビットアドレスバスの意味:アドレスを実行するための物理的な行数は20です。これらの行は8086ピンにすぎません。

8086ピンの数を節約するために、16データバスラインと16アドレスラインが多重化されます(マシンサイクルの最初の部分では、16ラインがアドレスバスとして機能し、後でデータバスラインとして機能します)。そのため、ピン数が削減されます。

今、あなたの主な質問の答え:Case:1(8086はメモリ内のバイトにアクセスしたい)8086は2 ^ 20(アドレスバスサイズ)の場所をアドレス指定でき、各場所はバイト(8ビットのデータ)を保持し、(2 ^ 10 x 2 ^ 10 = 1024(1K)x1024(1K)=> 1M)最終的には1MByteになるはずです

メモリ:USBドライブ(2GB、4GBなど)のように、1MBのメモリチップに1024Kのメモリロケーションがあり、各ロケーションに8ビットのデータユニット容量があるとすると、各メモリロケーションにはアドレスがあり、ロケーションにはバイト(8ビット)が保持されます。

8086プロセッサが最初にアドレスのバイトにアクセスする場合は、アドレスを1MBのメモリチップに送信します(0x20002)場所と言います。この1MBのメモリチップは、8086アドレスバスとデータバスに接続されています。それは以下のようです

  1. 1MBメモリチップへのアドレスバス上の8086アドレス
  2. 1MBのメモリチップは、アドレスバス(0x20002)でアドレスを受け取ります
  3. 8086はしばらくの間、メモリ待機時間と同期します(メモリはプロセッサよりも遅い場合があります)
  4. 1MBのメモリチップは、データバスライン上の要求されたバイトを8086に送信します
  5. 8086が受信バイトを読み取る

メモリが合計1MB(512KB + 512KB)の2つの512KBチップのようなメモリチップのスタックである場合、別のケースがあります。この場合、各メモリチップには19本のアドレスラインがあります(512K = 512 x 1024 => 2 ^ 9 x 2 ^ 10)メモリを有効にするCHIP SELECTと呼ばれる1つの重要なライン両方のメモリチップアドレスラインは8086アドレスバスに接続されていますが、8086には20本のアドレスラインがあるため、1本のライン512KBチップを有効にする512Kメモリチップのチップセレクトラインを接続するために使用されます。ここで、1つのアドレスラインには2つの状態があります:0または1

  1. 0:1つのメモリを選択するために使用されるChip-A-521KB + 19アドレスライン
  2. 1:2番目のメモリを選択するために使用されますChip-B-521KB + 19アドレスライン

256バイト容量(2 ^ 8)のメモリサイズの場合、8つのアドレスラインとチップセレクトラインがあります

上記の場合、8086の8本のアドレスラインが256バイトのメモリチップに接続されていますが、リーマはメモリチップのチップ選択ラインに接続されていますNORゲートの出力がすべて1の場合入力がゼロです

ここでは、8086の20行のアドレス行(A19-A0)を考えてみましょう。

  1. アドレスラインA7-A0は256バイトのメモリチップに接続されています
  2. リーミングアドレスライン、つまりA19からA8は、14入力を介してメモリチップのチップセレクトラインに接続されますNORすべての入力がゼロの場合、出力が1のゲートie(A19-A8 = 0x0 00)
  3. 上記の手順は、アドレスデコードと呼ばれます4。 256バイトのメモリチップのアドレス範囲は(A7-A0 => 0x00から0xFF)ですが、8086には20本のアドレスラインがあるため、リーミングラインは256バイトのメモリチップのチップセレクトにNORゲート最終アドレス範囲は0x000 00から0x000 FFであり、この方法で256バイトのメモリチップがアドレス指定されます。

このようにして、プロセッサはアドレスとデータバスの助けを借りてメモリチップからデータにアクセスします

ケース:2(一部のデバイスは8086にデータを送信する場合があります)ここで説明するのは非常に複雑ですが、すぐにこの質問に追加します

最後に約8255を参照してください intel 8255 Wikiページ

2