Skip to content

Commit

Permalink
Add GetIdevCsr to libcaliptra.
Browse files Browse the repository at this point in the history
  • Loading branch information
clundin25 committed Nov 13, 2024
1 parent a52cdb1 commit 20dc5a3
Show file tree
Hide file tree
Showing 5 changed files with 53 additions and 0 deletions.
24 changes: 24 additions & 0 deletions libcaliptra/examples/generic/test.c
Original file line number Diff line number Diff line change
Expand Up @@ -664,6 +664,30 @@ int rom_test_devid_csr(const test_info* info)
printf("IDEV CSR matches\n");
}

caliptra_req_idev_csr_complete();
caliptra_ready_for_firmware();

// Test Get Idev CSR now that a CSR is provisioned.
// GET IDEV CSR
struct caliptra_get_idev_csr_req csr_req = {0};
struct caliptra_get_idev_csr_resp csr_resp = {0};

status = caliptra_get_idev_csr(&csr_req, &csr_resp, false);

if (status) {
printf("Get IDev CSR failed: 0x%x\n", status);
dump_caliptra_error_codes();
failure = 1;
} else {
if (memcmp(csr_resp.data, idev_csr_bytes, csr_resp.data_size) != 0) {
printf("IDEV CSR does not match\n");
failure = 1;
} else {
printf("Get IDev CSR: OK\n");
}
}


free((void*)caliptra_idevid_csr_buf.data);
return failure;
}
Expand Down
3 changes: 3 additions & 0 deletions libcaliptra/inc/caliptra_api.h
Original file line number Diff line number Diff line change
Expand Up @@ -180,6 +180,9 @@ int caliptra_certify_key_extended(struct caliptra_certify_key_extended_req *req,
// FIPS version
int caliptra_fips_version(struct caliptra_fips_version_resp *resp, bool async);

// Get IDev CSR
int caliptra_get_idev_csr(struct caliptra_get_idev_csr_req *req, struct caliptra_get_idev_csr_resp *resp, bool async);

// Self test start
int caliptra_self_test_start(bool async);

Expand Down
10 changes: 10 additions & 0 deletions libcaliptra/inc/caliptra_types.h
Original file line number Diff line number Diff line change
Expand Up @@ -218,6 +218,16 @@ struct caliptra_capabilities_resp {
uint8_t capabilities[16];
};

struct caliptra_get_idev_csr_req {
struct caliptra_req_header hdr;
};

struct caliptra_get_idev_csr_resp {
struct caliptra_resp_header hdr;
uint32_t data_size;
uint8_t data[512];
};

// DPE commands

#define DPE_MAGIC 0x44504543 // "DPEC"
Expand Down
15 changes: 15 additions & 0 deletions libcaliptra/src/caliptra_api.c
Original file line number Diff line number Diff line change
Expand Up @@ -1170,6 +1170,21 @@ int caliptra_fips_version(struct caliptra_fips_version_resp *resp, bool async)
return pack_and_execute_command(&p, async);
}

// Get IDev CSR
int caliptra_get_idev_csr(struct caliptra_get_idev_csr_req *req, struct caliptra_get_idev_csr_resp *resp, bool async)
{
if (!resp)
{
return INVALID_PARAMS;
}

caliptra_checksum checksum = 0;

CREATE_PARCEL(p, OP_GET_IDEV_CSR, &checksum, resp);

return pack_and_execute_command(&p, async);
}

// Self test start
int caliptra_self_test_start(bool async)
{
Expand Down
1 change: 1 addition & 0 deletions libcaliptra/src/caliptra_mbox.h
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,7 @@ enum mailbox_command {
OP_SELF_TEST_GET_RESULTS = 0x46504C67, // "FPGR"
OP_SHUTDOWN = 0x46505344, // "FPSD"
OP_CAPABILITIES = 0x43415053, // "CAPS"
OP_GET_IDEV_CSR = 0x49444352, // "IDCR"
};

struct parcel {
Expand Down

0 comments on commit 20dc5a3

Please sign in to comment.