-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathprogramRotateLeftLoop.vhd
39 lines (34 loc) · 1.31 KB
/
programRotateLeftLoop.vhd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
-- Ian Tibbetts and Ryan Newell
-- Project 5 programRotateLeftLoop.vhd
-- Due: Mar 21, 2014
library ieee;
use ieee.std_logic_1164.all;
use ieee.numeric_std.all;
entity programRotateLeftLoop is
port (
addr : in std_logic_vector (7 downto 0);
data : out std_logic_vector (9 downto 0));
end entity;
architecture rtl of programRotateLeftLoop is
begin
data <=
-- ON
"0001110000" when addr = "00000000" else -- move all 1's into LR
-- SHIFT_LEFT
"0000010000" when addr = "00000001" else -- move LR to ACC
"0101000000" when addr = "00000010" else -- shift ACC left
"0001000000" when addr = "00000011" else -- move ACC to LR
-- DO_20
"0010100100" when addr = "00000100" else -- set low 4 bits of ACC
"0011100001" when addr = "00000101" else -- set high 4 bits of ACC
"0110000100" when addr = "00000110" else -- move ACC into LOOP
-- ROTATE_LEFT
"0000010000" when addr = "00000111" else -- move LR to ACC
"0111000000" when addr = "00001000" else -- rotate ACC left
"0001000000" when addr = "00001001" else -- move ACC to LR
-- LOOP
"0100110101" when addr = "00001010" else -- decrement loop register by 1
"1100001101" when addr = "00001011" else -- break when LOOP is zero
"1000000111" when addr = "00001100" else -- branch unconditional to top of loop otherwise
"1000000000"; -- branch to beginning when no more instructions
end rtl;