# 情報科学実験A レポート4

氏名 山久保孝亮

所属 大阪大学基礎工学部情報科学科ソフトウェア科学コース

学籍番号 09B22084

提出日 2024年1月25日

担当教員 繁田 浩功/桝井 晃基

# 1 実験ペアの名前および学籍番号

| 学籍番号     | 名前   |
|----------|------|
| 09B22083 | 安川雄輝 |

表 1: ペアの学籍番号と名前

# 2 送受信回路のステート・マシンの概要図

送受信回路のステート・マシンの概要図は以下の図1,図2のようになった.



遷移する条件が二桁の数字のみのものは、全てSW(9 downto 8)を表す



図 2: 受信回路のステート図

図 1: 送信回路のステート図

# 3 送受信回路の設計内容

#### 3.1 送信回路の設計

以下では図1のそれぞれのステートにおける処理を記述する.

#### 3.1.1 アイドル状態

s0 であるアイドル状態について記述する.32 ビットのベクトルである SW の 8 から 9 ビット目を参照しその値によって次の遷移先を決定する.01 なら s1 に遷移し,11 なら s3 に遷移する。それ以外であれば s0 にとどまり続ける。また,s1 に遷移する際には wadr を 000 に,key2.frag を 0 に,write.in を 0000 に初期化する。これらの変数の具体的な働きは後述する。また,このときに KEY(0) が 0 であるかどうかを判定し 0 であれば key2.frag を 1 としているがこれはテストベンチの KEY の切り替わりをステートの遷移後に計測しているとデータを書き込むのに間に合わなかったので追加した。

#### 3.1.2 書き込み状態

s1である書き込み状態について記述する.KEY(0) が 0 になっている, 即ち KEY(0) が押されると key2.frag という変数が 1 となる. この key2.frag という変数は KEY(2) が押されたことを記憶しておく変数である. そしてこの key2.frag が 1 であれば key2.frag,KEY(3) が押されたかどうかを判定する key3.frag を 0 にして write.in に現在の din の値を格納する.din は ram1 の入力であり一度 write.in に退避させておくことで次のアドレス変更状態にいる際にデータが変更されても書き込むデータ自体は KEY(2) を押したタイミングでのデータであり続けるからである. そしてその後 s2 に遷移する. また,s0 の時と同様に SW o 8 から 9 ビットが o0 であれば s0 に遷移し、以上どの分岐にも当てはまらない場合には s1 にとどまり続ける.

#### 3.1.3 アドレス変更状態

s2 であるアドレス変更状態について記述する.KEY(2) や KEY(3) が押されるとそれぞれの frag の変数が 1 となる. key3\_frag が 1 であるかどうかを判定し,1 であれば key3\_frag を 0 にし wadr を 1 だけ増やす. これにより加算される前の wadr の値に対応するデータの値が確定する. そして分岐に当てはまらなければ s2 にとどまり続ける.

#### 3.1.4 送信開始状態

s3 である送信開始について記述する.SW の 8 から 9 ビットが 00 であれば s0 に遷移する. 次に受信側が送ってくる ready が 1 であるかどうかを判定する. ready が 1 でなければ s3 にとどまり続け以降の判定は行わない.ready が 1 のときは KEY(0) が 0 かどうかを判定する.0 であれば radr を 000 に,count を 1 に初期化して s4 に遷移する.

#### 3.1.5 送信状態

s4である送信状態について記述する. ここではまずクロック生成をしてそのクロックの周期を受信側に伝える処理を行う. 受信側に伝え終わったときに 1 となる変数 finish が 0 であるかどうかを判定し, 0 であれば enable を 1 にしてクロックの生成を開始する. その後生成した clock\_tx が立ち上りでなければ start を 1 にして受信側にクロック生成が開始されたことを伝える. また, このとき送信時に使用するクロックの周期をそろえるために count\_clock というカウンタを用意し, 送信側のクロック周期何回分が生成クロックの周期に対応するのか計測しておく. これは送信側と受信側の情報のやり取りをするタイミングをそろえるためである. clock\_tx が立ち上がりであれば start,enable を 0 にして周期を伝えることとクロック生成終了する. また,finsh を 1 にして送信状態の次の処理を実行する. ところで, 生成クロックの立ち上がりを測定することは clock\_tx\_last という直前の生成クロックの値を格納する変数を用意しておき, 現在の生成クロックの値が 1 で, 直前の値が 0 のときという条件分岐を作って実現した.

そのあとすぐにデータの送信を開始する. 送信したデータの個数を表す count\_send という変数が 8 かどうかを判定することで 7 以下である場合は同じ処理が繰り返されるようにした. 7 以下である場合は送信側のクロックが何回立ち上がったかを記憶する clock という変数が先ほど計測した count\_clock から 1 引いた値と同じになったタイミングでデータを送信する. 今回送信するデータと実機の 7 セグメントデコーダの対応は以下の通りである.

| 7セグメントデコーダの番号 | 送信するデータ                    |
|---------------|----------------------------|
| HEX0          | 何も送信しないので常に 0 を表示          |
| HEX1          | 送信するデータ                    |
| HEX2          | 何も送信しないので常に 0 を表示          |
| HEX3          | 送信するデータのアドレス               |
| HEX4          | 何も送信しないので常に 0 を表示          |
| HEX5          | GPIO <sub>-</sub> 1(5) の内容 |

表 2: 7セグメントデコーダの送信するデータの対応表

#### 3.1.6 送信終了状態

s5である送信終了状態について記述する.SWの8から9ビットが00であればradr,clk\_tx\_last,count,count\_send,count\_clk を初期化して s0 に遷移する. それ以外の時は s5 にとどまり続ける.

### 3.2 受信回路の設計

以下では図2のそれぞれのステートにおける処理を記述する.

#### 3.2.1 待機状態

s0 である待機状態では SW の 8 から 9 ビットの値によって state を遷移させる.11 のときは s1 に遷移し 10 のときは s5 に遷移する.

#### 3.2.2 アイドル状態

s1 であるアイドル状態では ready 信号を 1 にして送信側の start が 1 になるのを待つ状態である.

#### 3.2.3 受信開始状態

s2 である受信開始状態では

#### 3.2.4 受信中状態

s3 である受信中状態では

#### 3.2.5 受信終了状態

s4 である受信終了状態では

#### 3.2.6 データ表示状態

s5であるデータ表示状態では

# 4 テストベンチによる動作確認内容・結果

テストベンチは配布されていたものをそのまま利用した.

### 4.1 送信回路の動作結果

#### 4.1.1 データ書き込みの動作

以下の図はデータ書き込みを行う際の波形である. 以下でその詳細を記述する. 白く囲まれた一番上の段



図 3: データ書き込みの際の波形

の一番左のビットである KEY(3) が 0 になったときに状態が s2 に遷移し, 直前の状態である s1 のときの din の値が write\_in にコピーされていることがわかる. また, オレンジで囲った処理により KEY(2) が変更されると状態が s1 へ遷移し,wadr の値が 1 増やされていることがわかる. これらの操作は合計で 8 回行われているため 8 回分のデータを書き込むことができている.

## 4.1.2 データ送信の動作

以下の図はデータ送信時の波形である. 以下でその詳細について述べる. 水色で囲んだ部分から状態が s4



図 4: データ送信の際の波形

に遷移した後に enable と start が同じタイミング 1 となっている. また, この期間は clock\_tx の一周期分となっているため正しい. また白色に囲んだ部分から一つ前の radr の値が enter\_3 に, オレンジに囲んだ部分から一つ前の dout の値が enter\_1 に入っている. これは先ほど書き込んだデータを同じアドレスで出力できている.

### 4.2 受信回路の動作結果

# 5 非同期通信回路作成における注意点などの考察

今回の課題を通して非同期通信回路を作成するにあたって注意しなければならない点は以下の 2 点であると考えた.

- 1. クロックを生成し終えてからデータを送信するまでのタイミングを合わせること.
- 2. アドレスが 000 に戻ったときに 000 に格納されているデータが変化してしまう.

以下でその詳細について述べる.

- 1. 今回の実験の仕様から,KEY(2) が押されると SW の下位 4 ビットの値の送信を開始する状態に遷移し、そのあと KEY(3) を押すとクロックを生成する. そして最後にデータを送信するが、クロック生成を終えてからデータを送信する間を制御するボタンが設定されていない. 今回の課題では設計内容で記述した通りクロック生成が終了した後すぐにデータを送信したが、この部分は送信側と受信側できちんとあらかじめ決めておく必要がある.
- 2. RAM にデータを書き込む際は書き込むためのアドレスの値が変化したとき, 最後に入力に入っていた値が格納される. 即ちアドレスが変更された瞬間に変更される前のアドレスに格納されるデータが確定し, 現在のアドレスが指す RAM の内容は常に変動しているということである. 今回のアドレスは3 ビットのベクトルを1 ずつ増やしていくことでアドレスを実現したが,111 の状態で1を加算すると000 に戻ってしまっていた. したがって, 最初に000 のアドレスにデータを格納した後に111 までデータを格納すると, アドレスが000 まで戻ってしまうため000 のアドレスに格納されている値が変化してしまう.

### 6 教員・TA による動作確認時刻

1月25日18時15分