## **DAC121S101**

```
library ieee;
use ieee.std logic 1164.all;
use ieee.numeric std.all;
entity DAC121S101 is
 port (
  VOUT: out real range 0.0 to 3.5;
  SYNC: in std logic;
  SCLK: in std logic;
  DIN: in std logic);
end DAC121S101;
architecture rtl of DAC121S101 is
 signal dato bin, reg desp: std logic vector(15 downto 0) := (others => '0');
 signal cuenta
                      : natural;
                                               := 33 \text{ ns};
 constant tSCLK
                         : time
                                           := 13 \text{ ns};
 constant tL, tH
                       : time
 constant tcs
                      : time
                                           = 3 \text{ ns}:
 constant tsud
                      : time
                                           = 5 \text{ ns};
                                            = 4.5 \text{ ns};
 constant tdhd
                       : time
 constant tSYNC
                         : time
                                               = 20 \text{ ns};
 signal taux1, taux2 : time;
begin
 assert not(taux1 -taux2 <= tSCLK)
  report "VIOLACIÓN DEL TIEMPO PERIODO DE SCLK(tCS)"
  severity error;
 process (SCLK)
  variable aux1, aux2: time;
 begin
  if SCLK'event and SCLK = '0' then
   taux1 \le now;
   taux2 \le taux1;
  if SCLK = '1' then
   aux2 := aux1;
   aux1 := now;
   assert not(aux1-aux2 \leq tL)
    report "VIOLACIÓN DEL TIEMPO A NIVEL BAJO DE SCLK (tL)"
    severity error;
  else
   aux2 := aux1;
   aux1 := now;
   assert not(aux1-aux2 \leq= tH)
    report "VIOLACIÓN DEL TIEMPO A NIVEL ALTO DE SCLK (tH)"
    severity error;
  end if;
```

```
end if:
end process;
process (SYNC)
 variable aux6, aux7: time;
begin
 aux7 := aux6;
 aux6 := now;
 if SYNC'event and SYNC = '0' then
  assert not(aux6-aux7 <= tSYNC)
   report "VIOLACIÓN DE LA DURACIÓN DEL TIEMPO DEL NIVEL ALTO DE SYNC (tSYNC)"
   severity error;
 end if:
 if SYNC'event and SYNC = '1' then
  if SCLK='0' then
    assert not(SCLK'last event <= tcs)</pre>
    report "VIOLACIÓN DEL TIEMPO tCS"
    severity error;
  end if;
  end if;
end process;
process (SCLK, SYNC)
begin
 if SYNC = '1' then
  cuenta \leq 0;
  reg desp \leq (others \Rightarrow '0');
 elsif SCLK'event and SCLK = '0' then
  if cuenta < 16 then
   cuenta <= cuenta+1;
   reg desp <= reg desp(14 downto 0)&DIN;
  end if;
 end if;
end process;
process (cuenta, SYNC, reg desp)
begin
 if SYNC = '0' then
  if cuenta = 16 then
   dato bin <= reg desp;
  end if;
 end if;
end process;
process (dato bin, cuenta)
begin -- process
 if cuenta = 16 then
  case dato bin(15 downto 14) is
   when "00" =>
    VOUT <= real(to integer(unsigned(dato bin(11 downto 0))))*3.3/4096.0;
   when "11" =>
```

```
VOUT <= 3.4;
when others =>
VOUT <= 0.0;
end case;
end if;
end process;
```