```
Code:
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;
ENTITY hw1_alu IS
 Port (
  A: IN STD_LOGIC_VECTOR(3 downto 0);
 B: IN STD_LOGIC_VECTOR(3 downto 0);
  sel: IN STD_LOGIC_VECTOR(2 downto 0);
 Q: OUT STD_LOGIC_VECTOR(3 downto 0);
 cout : OUT STD_LOGIC ;
     overflow: OUT STD_LOGIC
);
END hw1_alu;
ARCHITECTURE hw1_alu_a of hw1_alu IS
SIGNAL s1: STD_LOGIC_VECTOR(4 downto 0);
SIGNAL s2 : STD_LOGIC_VECTOR(3 downto 0);
BEGIN
PROCESS(A,B,sel)
BEGIN
CASE sel IS
--AND
WHEN "000" =>
```

 $Q \leq A AND B$ ;

WHEN "001" =>

 $Q \leq A OR B$ ;

--OR

--ADD

```
WHEN "010" =>
s1(0) \le '0';
Q(0) \le A(0) XOR B(0) XOR s1(0);
s1(1) \le (A(0) \text{ AND } B(0)) \text{ OR } (A(0) \text{ AND } s1(0)) \text{ OR } (s1(0) \text{ AND } B(0));
Q(1) \le A(1) XOR B(1) XOR s1(1);
s1(2) \le (A(1) \text{ AND } B(1)) \text{ OR } (A(1) \text{ AND } s1(1)) \text{ OR } (s1(1) \text{ AND } B(1));
Q(2) \le A(2) \text{ XOR } B(2) \text{ XOR } s1(2);
s1(3) \le (A(2) \text{ AND } B(2)) \text{ OR } (A(2) \text{ AND } s1(2)) \text{ OR } (s1(2) \text{ AND } B(2));
Q(3) \le A(3) XOR B(3) XOR s1(3);
s1(4) \le (A(3) \text{ AND } B(3)) \text{ OR } (A(3) \text{ AND } s1(3)) \text{ OR } (s1(3) \text{ AND } B(3));
cout <= s1(4);
--SUB
WHEN "011" =>
s2 \le NOT B;
s1(0) \le '1';
Q(0) \le A(0) XOR s2(0) XOR s1(0);
s1(1) \le (A(0) \text{ AND } s2(0)) \text{ OR } (A(0) \text{ AND } s1(0)) \text{ OR } (s1(0) \text{ AND } s2(0));
Q(1) \le A(1) XOR s2(1) XOR s1(1);
s1(2) \le (A(1) \text{ AND } B(1)) \text{ OR } (A(1) \text{ AND } s1(1)) \text{ OR } (s1(1) \text{ AND } s2(1));
Q(2) \le A(2) XOR s2(2) XOR s1(2);
s1(3) <= (A(2) AND s2(2)) OR (A(2) AND s1(2)) OR (s1(2) AND s2(2));
Q(3) \le A(3) XOR s2(3) XOR s1(3);
s1(4) \le (A(3) \text{ AND } s2(3)) \text{ OR } (A(3) \text{ AND } s1(3)) \text{ OR } (s1(3) \text{ AND } s2(3));
cout <= s1(4);
--ASR
WHEN "100" =>
Q(0) \le A(1);
Q(1) \le A(2);
Q(2) \le A(3);
Q(3) \le A(3);
```

```
--ASL
WHEN "101" =>
Q(0) \le '0';
Q(1) \le A(0);
Q(2) \le A(1);
Q(3) \le A(2);
if A(2) /= A(3) then
overflow \leq A(2) XOR A(3);
end if;
--CSR
WHEN "110" =>
Q(0) \le A(1);
Q(1) \le A(2);
Q(2) \le A(3);
Q(3) \le A(0);
--CSL
WHEN "111" =>
Q(0) \le A(3);
Q(1) \le A(0);
Q(2) \le A(1);
Q(3) \le A(2);
WHEN OTHERS =>
Q \le "0000";
END CASE;
```

END PROCESS;

END hw1\_alu\_a;

## Waveform:



