私は一緒に属している(同じクロックでサンプリングされていますが)論理的に既存の部分のベクトル(つまりパラレルバスではありません)コードを変更する必要があります。ほとんどの意図や目的、配列とベクトルはかなり扱うことができるためVHDL:std_logicの配列の使用とstd_logic_vectorのサブタイプの使用
subtype my_subtype is std_logic_vector(my_width - 1 downto 0);
signal my_signal : my_subtype;
:
以前、彼らは今まで
type my_type is array (my_width - 1 downto 0) of std_logic;
signal my_signal : my_type;
として定義されていた、この目的のために、私はいつもこれを使用します同じですので、私の質問は:
何かのやり方に利点はありますか?優先/標準の方法がありますか?
どちらも機能します。 'ieee.std_logic_1164'パッケージの中の' std_logic_vector'で宣言されたすべての演算子と機能にアクセスできるようになります。もう1つはあなた自身で作成しテストする必要があるということです。それは思いがけないものです。 –
信号はパラレルバスではありませんが、それらは同じ種類のもののコレクションを表していますか?たとえば、8つのステータスLEDは、一貫した「バイト」として解釈されないかもしれませんが、少なくともすべてのステータスLEDです。例えば、書き込み許可、リセット、クロックなど、異なる種類のものについては、ベクトルの代わりにこれらをレコードに入れることができます。 –
@scary_jeffステータスLEDの例と同じです。実際にはすべてのスレーブが同じSCKとCSに接続されています(これは奇妙なハードウェア) – DLnd