From 8c5a91578ca929f3a94b54628f6431c136dc417d Mon Sep 17 00:00:00 2001 From: JulianCamacho Date: Tue, 3 Oct 2023 01:39:00 -0600 Subject: comentarios --- rtl/cache/sram.sv | 5 +++++ 1 file changed, 5 insertions(+) (limited to 'rtl/cache/sram.sv') diff --git a/rtl/cache/sram.sv b/rtl/cache/sram.sv index 986c09b..8d68b7e 100644 --- a/rtl/cache/sram.sv +++ b/rtl/cache/sram.sv @@ -27,6 +27,10 @@ module cache_sram addr_tag tag_file[DEPTH] /*verilator public*/; line_state state_file[DEPTH] /*verilator public*/; + // Hace 3 cosas: + // 1. Si se necesita escribir un dato: escribe en los tag y data files en la posición del index de escritura + // 2. Si se necesita escribir un estado: escribe en el state file en la posición del index de escritura + // 3. Cada ciclo retorna siempre lo que esté en todos los files en la posición de index de lectura always_ff @(posedge clk) begin if (write_data) begin tag_file[index_wr] <= tag_wr; @@ -41,6 +45,7 @@ module cache_sram state_rd <= state_file[index_rd]; end + // Se inicializan todas las líneas del state file como INVALID //FIXME: rst_n para state_file? initial for (int i = 0; i < DEPTH; ++i) -- cgit v1.2.3 From bc466f0511d8b3029c0822f415ebc9ae152b9d09 Mon Sep 17 00:00:00 2001 From: JulianCamacho Date: Tue, 3 Oct 2023 16:55:27 -0600 Subject: sram, offset and routing comments --- rtl/cache/sram.sv | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) (limited to 'rtl/cache/sram.sv') diff --git a/rtl/cache/sram.sv b/rtl/cache/sram.sv index 8d68b7e..74f9e65 100644 --- a/rtl/cache/sram.sv +++ b/rtl/cache/sram.sv @@ -26,11 +26,12 @@ module cache_sram line data_file[DEPTH] /*verilator public*/; addr_tag tag_file[DEPTH] /*verilator public*/; line_state state_file[DEPTH] /*verilator public*/; - - // Hace 3 cosas: - // 1. Si se necesita escribir un dato: escribe en los tag y data files en la posición del index de escritura - // 2. Si se necesita escribir un estado: escribe en el state file en la posición del index de escritura - // 3. Cada ciclo retorna siempre lo que esté en todos los files en la posición de index de lectura + + /* 3 funciones principales: + * 1. Si se necesita escribir un dato: escribe en los tag y data files en la posición del index de escritura + * 2. Si se necesita escribir un estado: escribe en el state file en la posición del index de escritura + * 3. Cada ciclo retorna siempre lo que esté en todos los files en la posición de index de lectura + */ always_ff @(posedge clk) begin if (write_data) begin tag_file[index_wr] <= tag_wr; -- cgit v1.2.3