Skip to content

Commit

Permalink
Merge pull request #318 from chipsalliance/dev-msft-20231130
Browse files Browse the repository at this point in the history
Dev msft 20231130
  • Loading branch information
calebofearth authored Dec 1, 2023
2 parents 81a774b + 15acd7b commit 5bdfabd
Show file tree
Hide file tree
Showing 31 changed files with 802 additions and 142 deletions.
4 changes: 2 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -41,8 +41,8 @@ Simulation:
- `2022.3`

Synthesis:
- Synopsys DC
- `Version 2020.09-SP1`
- Synopsys Fusion Compiler
- `Version 2022.12-SP3`

GCC:
- RISCV Toolchain for generating memory initialization files
Expand Down
1 change: 0 additions & 1 deletion src/csrng/config/csrng.vf
Original file line number Diff line number Diff line change
Expand Up @@ -102,4 +102,3 @@ ${CALIPTRA_ROOT}/src/csrng/rtl/csrng_block_encrypt.sv
${CALIPTRA_ROOT}/src/csrng/rtl/csrng_state_db.sv
${CALIPTRA_ROOT}/src/csrng/rtl/csrng_cmd_stage.sv
${CALIPTRA_ROOT}/src/csrng/rtl/csrng.sv
${CALIPTRA_ROOT}/src/csrng/tb/csrng_tb.sv
17 changes: 17 additions & 0 deletions src/hmac/formal/model/simulation_model/simulation/hmac_main.cpp
Original file line number Diff line number Diff line change
@@ -1,3 +1,20 @@
// SPDX-License-Identifier: Apache-2.0
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
// Description:
//

#include "systemc.h"
#include "Interfaces.h"
#include "../../hmac_core.h"
Expand Down
17 changes: 17 additions & 0 deletions src/hmac/formal/model/simulation_model/simulation/hmac_tests.h
Original file line number Diff line number Diff line change
@@ -1,3 +1,20 @@
// SPDX-License-Identifier: Apache-2.0
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
// Description:
//

#ifndef HMAC_CORE_TESTS_H
#define HMAC_CORE_TESTS_H

Expand Down
17 changes: 16 additions & 1 deletion src/hmac/formal/readme.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,18 @@
_*SPDX-License-Identifier: Apache-2.0<BR>
<BR>
<BR>
Licensed under the Apache License, Version 2.0 (the "License");<BR>
you may not use this file except in compliance with the License.<BR>
You may obtain a copy of the License at<BR>
<BR>
http://www.apache.org/licenses/LICENSE-2.0 <BR>
<BR>
Unless required by applicable law or agreed to in writing, software<BR>
distributed under the License is distributed on an "AS IS" BASIS,<BR>
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.<BR>
See the License for the specific language governing permissions and<BR>
limitations under the License.*_<BR>

# HMAC

Date: 28-07-2023 Author: LUBIS EDA
Expand Down Expand Up @@ -67,4 +82,4 @@ cut u_sha512_core_h2.digest

The sha512_masked core had been verified separately. By cutting the signal model complexity is drastically reduced.

Feel free to reach out to [email protected] to request the loadscripts.
Feel free to reach out to [email protected] to request the loadscripts.
73 changes: 73 additions & 0 deletions src/integration/tb/caliptra_top_tb.sv
Original file line number Diff line number Diff line change
Expand Up @@ -165,6 +165,8 @@ module caliptra_top_tb (
logic cptra_error_fatal_dly_p;
logic cptra_error_non_fatal_dly_p;

logic rv_dma_resp_error;

logic mbox_apb_dataout_read_ooo;
logic mbox_ooo_read_done;
logic mbox_apb_dataout_read_no_lock;
Expand Down Expand Up @@ -232,7 +234,15 @@ module caliptra_top_tb (
end

else if (ras_test_ctrl.reset_generic_input_wires) begin
`ifdef VERILATOR
generic_input_wires <= {32'h72746C76, ERROR_NONE_SET}; /* 32'h72746c76 is the big-endian ASCII representation of 'vltr' (r t l v) */
`else
generic_input_wires <= {32'h0, ERROR_NONE_SET};
`endif
end

else if (c_state_apb == S_APB_WAIT_ERROR_AXS && rv_dma_resp_error) begin
generic_input_wires <= {32'h0, DMA_ERROR_OBSERVED};
end

else if (c_state_apb == S_APB_RD_HW_ERROR_FATAL && apb_xfer_end) begin
Expand Down Expand Up @@ -1234,6 +1244,69 @@ caliptra_top_tb_services #(

);

`define RV_INST caliptra_top_dut.rvtop
`define RV_IDMA_RESP_INST caliptra_top_dut.responder_inst[`CALIPTRA_SLAVE_SEL_IDMA]
`define RV_DDMA_RESP_INST caliptra_top_dut.responder_inst[`CALIPTRA_SLAVE_SEL_DDMA]
task force_ahb_dma_read(input logic [31:0] address);
while(`RV_INST.dma_hsel) @(posedge core_clk);
force `RV_IDMA_RESP_INST.hreadyout = 1'b0;
force `RV_DDMA_RESP_INST.hreadyout = 1'b0;

force `RV_INST.dma_haddr = address;
force `RV_INST.dma_hsize = 3'b010; // 4-bytes
force `RV_INST.dma_hwrite = 1'b0;
force `RV_INST.dma_hwdata = '0;
force `RV_INST.dma_hreadyin = 1'b1;
force `RV_INST.dma_hsel = 1'b1;
force `RV_INST.dma_htrans = 2'b10;

// Wait for command to be accepted
do @(posedge core_clk); while(!`RV_INST.dma_hreadyout);
force `RV_INST.dma_htrans = 2'b00;
// Wait for response to be provided
do @(posedge core_clk); while(!`RV_INST.dma_hreadyout);
$display("[%t] AHB DMA FORCE READ: Address 0x%x Data 0x%x Resp 0x%x", $time, address, `RV_INST.dma_hrdata, `RV_INST.dma_hresp);
if (`RV_INST.dma_hresp)
rv_dma_resp_error = 1'b1;
release `RV_IDMA_RESP_INST.hreadyout;
release `RV_DDMA_RESP_INST.hreadyout;

release `RV_INST.dma_htrans;
release `RV_INST.dma_haddr;
release `RV_INST.dma_hsize;
release `RV_INST.dma_hwrite;
release `RV_INST.dma_hwdata;
release `RV_INST.dma_hsel;
release `RV_INST.dma_hreadyin;
endtask

task force_ahb_dma_loop_read(input logic [31:0] start_addr, input logic [19:0] count);
automatic logic [31:0] addr;
addr = start_addr;
$display("[%t] AHB DMA FORCE LOOP READ: Start Address 0x%x Count 0x%x", $time, addr, count);
if ($isunknown(start_addr) || $isunknown(addr))
$error("[%t] Unknown signal found: start_addr 0x%x addr 0x%x", $time, start_addr, addr);
repeat(count) begin
force_ahb_dma_read(addr);
addr += 4;
end
endtask

initial begin
fork
forever @(posedge core_clk) begin
if (ras_test_ctrl.dccm_read_burst.start)
force_ahb_dma_loop_read(ras_test_ctrl.dccm_read_burst.addr, ras_test_ctrl.dccm_read_burst.count);
if (ras_test_ctrl.iccm_read_burst.start)
force_ahb_dma_loop_read(ras_test_ctrl.iccm_read_burst.addr, ras_test_ctrl.iccm_read_burst.count);
end
forever @(posedge core_clk) begin
if (c_state_apb != S_APB_WAIT_ERROR_AXS)
rv_dma_resp_error = 1'b0;
end
join
end

caliptra_top_sva sva();

endmodule
8 changes: 8 additions & 0 deletions src/integration/tb/caliptra_top_tb_pkg.sv
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,13 @@ typedef struct packed {
} veer_sram_error_injection_mode_t;

typedef struct packed {
logic [31:0] addr;
logic [19:0] count;
logic start;
} rv_ccm_read_burst_pkt;
typedef struct packed {
rv_ccm_read_burst_pkt dccm_read_burst;
rv_ccm_read_burst_pkt iccm_read_burst;
logic error_injection_seen;
logic reset_generic_input_wires;
logic do_no_lock_access;
Expand All @@ -73,6 +80,7 @@ localparam PROT_OOO_NON_FATAL_OBSERVED = 32'h600dcafe;
localparam ICCM_FATAL_OBSERVED = 32'hdeadaca1;
localparam DCCM_FATAL_OBSERVED = 32'hdeadbeef;
localparam NMI_FATAL_OBSERVED = 32'hdeadc0a7;
localparam DMA_ERROR_OBSERVED = 32'hfadebadd;
localparam ERROR_NONE_SET = 32'hba5eba11; /* default value for a test with no activity observed by TB */

endpackage
37 changes: 37 additions & 0 deletions src/integration/tb/caliptra_top_tb_services.sv
Original file line number Diff line number Diff line change
Expand Up @@ -240,6 +240,8 @@ module caliptra_top_tb_services
// 8'h9a - Inject invalid zero sign_s into ECC
// 8'ha0: 8'ha7 - Inject HMAC_KEY to kv_key register
// 8'hc0: 8'hc7 - Inject SHA_BLOCK to kv_key register
// 8'hde - ICCM SRAM force loop read (requires read params written to other bytes of generic wires)
// 8'hdf - DCCM SRAM force loop read (requires read params written to other bytes of generic wires)
// 8'he0 - Set random ICCM SRAM single bit error injection
// 8'he1 - Set random ICCM SRAM double bit error injection
// 8'he2 - Set random DCCM SRAM single bit error injection
Expand Down Expand Up @@ -339,6 +341,41 @@ module caliptra_top_tb_services
end
end

always @(negedge clk or negedge cptra_rst_b) begin
if (!cptra_rst_b) begin
ras_test_ctrl.iccm_read_burst.start <= 1'b0;
ras_test_ctrl.iccm_read_burst.count <= '0;
ras_test_ctrl.iccm_read_burst.addr <= '0;
ras_test_ctrl.dccm_read_burst.start <= 1'b0;
ras_test_ctrl.dccm_read_burst.count <= '0;
ras_test_ctrl.dccm_read_burst.addr <= '0;
end
else if((WriteData[7:0] == 8'hde) && mailbox_write) begin
ras_test_ctrl.iccm_read_burst.start <= 1'b1;
ras_test_ctrl.iccm_read_burst.count <= WriteData[31:12];
ras_test_ctrl.iccm_read_burst.addr <= caliptra_top_dut.soc_ifc_top1.i_soc_ifc_reg.field_storage.CPTRA_GENERIC_OUTPUT_WIRES[1].generic_wires.value;
ras_test_ctrl.dccm_read_burst.start <= 1'b0;
ras_test_ctrl.dccm_read_burst.count <= '0;
ras_test_ctrl.dccm_read_burst.addr <= '0;
end
else if((WriteData[7:0] == 8'hdf) && mailbox_write) begin
ras_test_ctrl.iccm_read_burst.start <= 1'b0;
ras_test_ctrl.iccm_read_burst.count <= '0;
ras_test_ctrl.iccm_read_burst.addr <= '0;
ras_test_ctrl.dccm_read_burst.start <= 1'b1;
ras_test_ctrl.dccm_read_burst.count <= WriteData[31:12];
ras_test_ctrl.dccm_read_burst.addr <= caliptra_top_dut.soc_ifc_top1.i_soc_ifc_reg.field_storage.CPTRA_GENERIC_OUTPUT_WIRES[1].generic_wires.value;
end
else begin
ras_test_ctrl.iccm_read_burst.start <= 1'b0;
ras_test_ctrl.iccm_read_burst.count <= '0;
ras_test_ctrl.iccm_read_burst.addr <= '0;
ras_test_ctrl.dccm_read_burst.start <= 1'b0;
ras_test_ctrl.dccm_read_burst.count <= '0;
ras_test_ctrl.dccm_read_burst.addr <= '0;
end
end

initial ras_test_ctrl.error_injection_seen = 1'b0;
always @(negedge clk) begin
if (mailbox_write && WriteData[7:0] == 8'hfd) begin
Expand Down
Loading

0 comments on commit 5bdfabd

Please sign in to comment.