PUC-Minas - Ciência da Computação

ARQ1 - Guia 09

Período: 03-07/10/2011

Tema: Introdução à linguagem Verilog Atividade: Circuitos sequenciais – Memórias

Todos os circuitos deverão ser simulados no Logisim.

01.) Projetar e descrever em Verilog e Logisim um módulo para implementar uma memória RAM 1x4
(1 endereço para 4 bits)
usando flip-flops do tipo JK como registradores de dados.
Ver sugestão abaixo.



## DICA:

Supor que a escrita ocorrerá na borda de subida do *clock*, enquanto a leitura poderá ocorrer a partir da borda de descida do mesmo.

- 02.) Projetar e descrever em Verilog e Logisim um módulo para implementar uma memória RAM 1x8 (1 endereço para 8 bits) usando duas memórias RAM 1x4.
- 03.) Projetar e descrever em Verilog e Logisim um módulo para implementar uma memória RAM 4x8 (1 endereço para 8 bits) usando quatro memórias RAM 1x8.
- 04.) Projetar e descrever em Verilog e Logisim um módulo para implementar uma memória RAM 1x8
  (1 endereço para 8 bits)
  usando flip-flops do tipo JK como registradores de dados.
- 05.) Projetar e descrever em Verilog e Logisim um módulo para implementar uma memória RAM 8x8 (1 endereço para 8 bits) usando memórias RAM 1x8 do modelo acima (04).

## Extras

- 06.) Projetar e descrever em Verilog e Logisim um módulo para implementar uma memória RAM 1x16 (1 endereço para 8 bits) usando quatro memórias RAM 1x4.
- 07.) Projetar e descrever em Verilog e Logisim um módulo para implementar uma memória RAM 4x16 (1 endereço para 8 bits) usando memórias RAM 1x8.









```
module dff ( output q, output qnot,
                                                         module srff (output q, output qnot,
            input d, input clk);
                                                                      input s, input r, input clk);
reg q, qnot;
                                                         reg q, qnot;
always @( posedge clk )
                                                         always @( posedge clk )
begin
                                                         begin
  q \le d;
                qnot <= ~q;
                                                           if (s & ~r)
end
                                                            begin
                                                            q <= 1;
                                                                         qnot \le 0;
endmodule // dff
                                                            end
module tff ( output q, output qnot,
                                                           else
            input t, input clk,
                                                             if (~s & r)
            input preset, input clear );
                                                             begin
                                                              q <= 0;
                                                                         qnot \ll 1;
reg q, qnot;
                                                             end
                                                             else
always @( posedge clk )
                                                              if (s&r)
begin
                                                               begin
if (~clear)
                                                                         qnot <= 0; // arbitrary
                                                               q <= 0;
begin
                                                               end
 q <= 0;
                qnot <= -q;
                                                         end
 end
else
                                                         endmodule // srff
 if (~preset)
 begin
                                                         module jkff (output q, output qnot,
  q <= 1;
                qnot <= -q;
                                                                      input j, input k, input clk);
 end
                                                         reg q, qnot;
 else
 begin
                                                         always @( posedge clk )
   if (t)
                                                         begin
   begin
                                                           if ( j & ~k )
    q <= ~q;
                qnot <= \sim q;
                                                            begin
   end
                                                             q <= 1;
                                                                          qnot \le 0;
 end
                                                            end
end
                                                            else
                                                             if (~j & k)
endmodule // tff
                                                             begin
                                                              q <= 0;
                                                                          qnot <= 1;
                                                             end
                                                             else
                                                              if (j&k)
                                                               begin
                                                               q \le q; q \le q 
                                                               end
                                                         end
                                                         endmodule // jkff
```