mirror of
https://github.com/tillitis/tillitis-key1.git
synced 2025-01-17 10:27:20 -05:00
Updated README, completed testcase and cleaned up the testbench
Signed-off-by: Joachim Strömbergson <joachim@assured.se>
This commit is contained in:
parent
de7f273f71
commit
1e97e27e66
@ -3,5 +3,19 @@
|
|||||||
Unique Device Secret core
|
Unique Device Secret core
|
||||||
|
|
||||||
## Introduction
|
## Introduction
|
||||||
This core store and protect the Unique Device Secret. The
|
|
||||||
storage is implemented in discrete registers. The contents can be read once between chip reset, and only if the system is in not in application access mode.
|
This core store and protect the Unique Device Secret (UDS) asset. The
|
||||||
|
UDS can be accessed as eight separate 32-bit words. The words can be
|
||||||
|
accessed in any order, but a given word can only be accessed once
|
||||||
|
between reset cycles. The words can only be accessed as long as the
|
||||||
|
fw_app_mode input is low, implying that the CPU is executing the FW.
|
||||||
|
|
||||||
|
Each UDS words has a companion read bit that is set when the word is
|
||||||
|
accessed. This means that the even if the chip select (cs) control
|
||||||
|
input is forced high, the content will become all zero when the read
|
||||||
|
bit has been set after one cycle.
|
||||||
|
|
||||||
|
|
||||||
|
## Implementation
|
||||||
|
|
||||||
|
The UDS words are implemented in discrete registers.
|
||||||
|
@ -19,26 +19,21 @@ module tb_uds();
|
|||||||
// Internal constant and parameter definitions.
|
// Internal constant and parameter definitions.
|
||||||
//----------------------------------------------------------------
|
//----------------------------------------------------------------
|
||||||
parameter DEBUG = 1;
|
parameter DEBUG = 1;
|
||||||
parameter DUMP_WAIT = 0;
|
|
||||||
|
|
||||||
parameter CLK_HALF_PERIOD = 1;
|
parameter CLK_HALF_PERIOD = 1;
|
||||||
parameter CLK_PERIOD = 2 * CLK_HALF_PERIOD;
|
parameter CLK_PERIOD = 2 * CLK_HALF_PERIOD;
|
||||||
|
|
||||||
localparam ADDR_NAME0 = 8'h00;
|
localparam ADDR_UDS_FIRST = 8'h10;
|
||||||
localparam ADDR_NAME1 = 8'h01;
|
localparam ADDR_UDS_LAST = 8'h17;
|
||||||
localparam ADDR_VERSION = 8'h02;
|
|
||||||
|
|
||||||
localparam ADDR_UDS_FIRST = 8'h10;
|
|
||||||
localparam ADDR_UDS_LAST = 8'h17;
|
|
||||||
|
|
||||||
|
|
||||||
//----------------------------------------------------------------
|
//----------------------------------------------------------------
|
||||||
// Register and Wire declarations.
|
// Register and Wire declarations.
|
||||||
//----------------------------------------------------------------
|
//----------------------------------------------------------------
|
||||||
reg [31 : 0] cycle_ctr;
|
reg [31 : 0] cycle_ctr;
|
||||||
reg [31 : 0] error_ctr;
|
reg [31 : 0] error_ctr;
|
||||||
reg [31 : 0] tc_ctr;
|
reg [31 : 0] tc_ctr;
|
||||||
reg tb_monitor;
|
reg tb_monitor;
|
||||||
|
|
||||||
reg tb_clk;
|
reg tb_clk;
|
||||||
reg tb_reset_n;
|
reg tb_reset_n;
|
||||||
@ -47,8 +42,6 @@ module tb_uds();
|
|||||||
reg [7 : 0] tb_address;
|
reg [7 : 0] tb_address;
|
||||||
wire [31 : 0] tb_read_data;
|
wire [31 : 0] tb_read_data;
|
||||||
|
|
||||||
reg [31 : 0] read_data;
|
|
||||||
|
|
||||||
|
|
||||||
//----------------------------------------------------------------
|
//----------------------------------------------------------------
|
||||||
// Device Under Test.
|
// Device Under Test.
|
||||||
@ -102,13 +95,19 @@ module tb_uds();
|
|||||||
task dump_dut_state;
|
task dump_dut_state;
|
||||||
begin : dump_dut_state
|
begin : dump_dut_state
|
||||||
integer i;
|
integer i;
|
||||||
$display("State of DUT");
|
$display("State of DUT at cycle: %08d", cycle_ctr);
|
||||||
$display("------------");
|
$display("------------");
|
||||||
$display("Cycle: %08d", cycle_ctr);
|
$display("Inputs and outputs:");
|
||||||
|
$display("fw_app_mode: 0x%1x", tb_fw_app_mode);
|
||||||
|
$display("cs: 0x%1x, address: 0x%02x, read_data: 0x%08x", tb_cs, tb_address, tb_read_data);
|
||||||
|
$display("");
|
||||||
|
|
||||||
|
$display("Internal state:");
|
||||||
|
$display("tmp_read_ready: 0x%1x, tmp_read_data: 0x%08x", dut.tmp_ready, dut.tmp_read_data);
|
||||||
for (i = 0 ; i < 8 ; i = i + 1) begin
|
for (i = 0 ; i < 8 ; i = i + 1) begin
|
||||||
$display("uds_reg[%1d]: 0x%08x, uds_rd_reg[%1d]: 0x%1x",
|
$display("uds_reg[%1d]: 0x%08x, uds_rd_reg[%1d]: 0x%1x", i, dut.uds_reg[i], i, dut.uds_rd_reg[i]);
|
||||||
i, dut.uds_reg[i], i, dut.uds_rd_reg[i]);
|
|
||||||
end
|
end
|
||||||
|
|
||||||
$display("");
|
$display("");
|
||||||
$display("");
|
$display("");
|
||||||
end
|
end
|
||||||
@ -180,12 +179,17 @@ module tb_uds();
|
|||||||
// read_data.
|
// read_data.
|
||||||
//----------------------------------------------------------------
|
//----------------------------------------------------------------
|
||||||
task read_word(input [11 : 0] address);
|
task read_word(input [11 : 0] address);
|
||||||
begin
|
begin : read_word
|
||||||
tb_address = address;
|
reg [31 : 0] read_data;
|
||||||
tb_cs = 1;
|
|
||||||
#(CLK_PERIOD);
|
tb_address = address;
|
||||||
|
tb_cs = 1'h1;
|
||||||
|
|
||||||
|
#(CLK_HALF_PERIOD);
|
||||||
read_data = tb_read_data;
|
read_data = tb_read_data;
|
||||||
tb_cs = 0;
|
|
||||||
|
#(CLK_HALF_PERIOD);
|
||||||
|
tb_cs = 1'h0;
|
||||||
|
|
||||||
if (DEBUG)
|
if (DEBUG)
|
||||||
begin
|
begin
|
||||||
@ -202,11 +206,20 @@ module tb_uds();
|
|||||||
task test1;
|
task test1;
|
||||||
begin
|
begin
|
||||||
tc_ctr = tc_ctr + 1;
|
tc_ctr = tc_ctr + 1;
|
||||||
tb_monitor = 1'h0;
|
|
||||||
|
|
||||||
$display("");
|
$display("");
|
||||||
$display("--- test1: started.");
|
$display("--- test1: started.");
|
||||||
|
|
||||||
|
$display("--- test1: Filling uds with known values.");
|
||||||
|
dut.uds_reg[0] = 32'hf0f0f0f0;
|
||||||
|
dut.uds_reg[1] = 32'he1e1e1e1;
|
||||||
|
dut.uds_reg[2] = 32'hd2d2d2d2;
|
||||||
|
dut.uds_reg[3] = 32'hc3c3c3c3;
|
||||||
|
dut.uds_reg[4] = 32'hb4b4b4b4;
|
||||||
|
dut.uds_reg[5] = 32'ha5a5a5a5;
|
||||||
|
dut.uds_reg[6] = 32'h96969696;
|
||||||
|
dut.uds_reg[7] = 32'h87878787;
|
||||||
|
|
||||||
$display("--- test1: Dumping DUT state to show UDS contents");
|
$display("--- test1: Dumping DUT state to show UDS contents");
|
||||||
dump_dut_state();
|
dump_dut_state();
|
||||||
|
|
||||||
@ -229,6 +242,7 @@ module tb_uds();
|
|||||||
dump_dut_state();
|
dump_dut_state();
|
||||||
|
|
||||||
$display("--- test1: Reading UDS words again.");
|
$display("--- test1: Reading UDS words again.");
|
||||||
|
$display("--- test1: This should return all zeros.");
|
||||||
read_word(ADDR_UDS_FIRST + 0);
|
read_word(ADDR_UDS_FIRST + 0);
|
||||||
read_word(ADDR_UDS_FIRST + 1);
|
read_word(ADDR_UDS_FIRST + 1);
|
||||||
read_word(ADDR_UDS_FIRST + 2);
|
read_word(ADDR_UDS_FIRST + 2);
|
||||||
@ -239,22 +253,35 @@ module tb_uds();
|
|||||||
read_word(ADDR_UDS_FIRST + 7);
|
read_word(ADDR_UDS_FIRST + 7);
|
||||||
|
|
||||||
$display("--- test1: Resetting DUT.");
|
$display("--- test1: Resetting DUT.");
|
||||||
|
$display("--- test1: This should allow access again.");
|
||||||
reset_dut();
|
reset_dut();
|
||||||
|
|
||||||
|
$display("--- test1: Filling uds with new known values.");
|
||||||
|
dut.uds_reg[0] = 32'h0f0f0f0f;
|
||||||
|
dut.uds_reg[1] = 32'h1e1e1e1e;
|
||||||
|
dut.uds_reg[2] = 32'h2d2d2d2d;
|
||||||
|
dut.uds_reg[3] = 32'h3c3c3c3c;
|
||||||
|
dut.uds_reg[4] = 32'h4b4b4b4b;
|
||||||
|
dut.uds_reg[5] = 32'h5a5a5a5a;
|
||||||
|
dut.uds_reg[6] = 32'h69696969;
|
||||||
|
dut.uds_reg[7] = 32'h78787878;
|
||||||
|
|
||||||
|
|
||||||
$display("--- test1: Dumping state again to see read bits.");
|
$display("--- test1: Dumping state again to see read bits.");
|
||||||
dump_dut_state();
|
dump_dut_state();
|
||||||
|
|
||||||
$display("--- test1: Reading UDS words.");
|
$display("--- test1: Reading UDS words in changed order.");
|
||||||
read_word(ADDR_UDS_FIRST + 0);
|
|
||||||
read_word(ADDR_UDS_FIRST + 1);
|
|
||||||
read_word(ADDR_UDS_FIRST + 2);
|
|
||||||
read_word(ADDR_UDS_FIRST + 3);
|
|
||||||
read_word(ADDR_UDS_FIRST + 4);
|
|
||||||
read_word(ADDR_UDS_FIRST + 5);
|
|
||||||
read_word(ADDR_UDS_FIRST + 6);
|
|
||||||
read_word(ADDR_UDS_FIRST + 7);
|
read_word(ADDR_UDS_FIRST + 7);
|
||||||
|
read_word(ADDR_UDS_FIRST + 6);
|
||||||
|
read_word(ADDR_UDS_FIRST + 4);
|
||||||
|
read_word(ADDR_UDS_FIRST + 3);
|
||||||
|
read_word(ADDR_UDS_FIRST + 1);
|
||||||
|
read_word(ADDR_UDS_FIRST + 0);
|
||||||
|
read_word(ADDR_UDS_FIRST + 5);
|
||||||
|
read_word(ADDR_UDS_FIRST + 2);
|
||||||
|
|
||||||
$display("--- test1: Reading UDS words again.");
|
$display("--- test1: Reading UDS words again.");
|
||||||
|
$display("--- test1: This should return all zeros.");
|
||||||
read_word(ADDR_UDS_FIRST + 0);
|
read_word(ADDR_UDS_FIRST + 0);
|
||||||
read_word(ADDR_UDS_FIRST + 1);
|
read_word(ADDR_UDS_FIRST + 1);
|
||||||
read_word(ADDR_UDS_FIRST + 2);
|
read_word(ADDR_UDS_FIRST + 2);
|
||||||
@ -267,7 +294,7 @@ module tb_uds();
|
|||||||
$display("--- test1: completed.");
|
$display("--- test1: completed.");
|
||||||
$display("");
|
$display("");
|
||||||
end
|
end
|
||||||
endtask // tes1
|
endtask // test1
|
||||||
|
|
||||||
|
|
||||||
//----------------------------------------------------------------
|
//----------------------------------------------------------------
|
||||||
@ -286,8 +313,8 @@ module tb_uds();
|
|||||||
|
|
||||||
display_test_result();
|
display_test_result();
|
||||||
$display("");
|
$display("");
|
||||||
$display(" -= Testbench for uds started =-");
|
$display(" -= Testbench for uds completed =-");
|
||||||
$display(" ===========================");
|
$display(" =============================");
|
||||||
$display("");
|
$display("");
|
||||||
$finish;
|
$finish;
|
||||||
end // uds_test
|
end // uds_test
|
||||||
|
Loading…
Reference in New Issue
Block a user