```
NAME:
              GIELO MAR R. BANDOY
COURSE/YR: BSCpE – 3A
              CPE 366 – INTRO TO HDL
SUBJECT:
                                           T FLIP FLOP
12. VHDL CODE T FLIP FLOP:
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;
entity TFlipFlop is
  Port (
    t : in STD_LOGIC;
    clk: in STD_LOGIC;
    rst : in STD_LOGIC;
    q : inout STD_LOGIC
  );
end TFlipFlop;
architecture Behavioral of TFlipFlop is
  signal div : std_logic_vector(22 downto 0);
  signal clkd : std_logic;
begin
  -- Falling edge instead of rising edge
  process(clk)
  begin
```

if falling\_edge(clk) then

div <= div - 1; -- reverse addition

```
end if;
end process;

clkd <= not div(20); -- reverse signal logic

process(clkd, rst)

begin
  if (rst = '0') then -- reverse active-high reset to active-low
        q <= '1'; -- reverse reset value
  elsif (clkd'event and clkd = '0' and t = '0') then -- reverse clock and T logic
        q <= not q;
  else
        q <= q;
  end if;
end process;

end Behavioral;</pre>
```

## TRUTH TABLE OF T FLIP FLOP:

| Clear | Т | Clock | Qn+1 | $\overline{Qn+1}$ |
|-------|---|-------|------|-------------------|
| 1     | 0 | 0     | 0    | Qn                |
| 0     | 1 | ζ     | Qn   | Qn                |

**RTL VIEWER:** 

