From 92df783e5943172f28f3a4c2f7cacc6258199cb1 Mon Sep 17 00:00:00 2001 From: Laura Abbott Date: Tue, 8 Oct 2024 09:23:36 -0400 Subject: [PATCH 1/2] Change error name to avoid hiffy conflict The name `SprotError` is already used in hubris. This is technically fine but is causing some conflicts with our other tooling. Change the name to avoid conflicts. --- Cargo.lock | 2 +- attest-data/Cargo.toml | 2 +- attest-data/src/messages.rs | 87 ++++++++++++++++++++++--------------- 3 files changed, 53 insertions(+), 38 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index b7faaca..8f2d965 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -114,7 +114,7 @@ checksum = "0952808a6c2afd1aa8947271f3a60f1a6763c7b912d210184c5149b5cf147247" [[package]] name = "attest-data" -version = "0.3.0" +version = "0.4.0" dependencies = [ "getrandom", "hubpack", diff --git a/attest-data/Cargo.toml b/attest-data/Cargo.toml index be26ab4..9dfc1aa 100644 --- a/attest-data/Cargo.toml +++ b/attest-data/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "attest-data" -version = "0.3.0" +version = "0.4.0" edition = "2021" [dependencies] diff --git a/attest-data/src/messages.rs b/attest-data/src/messages.rs index 96e833c..97ef576 100644 --- a/attest-data/src/messages.rs +++ b/attest-data/src/messages.rs @@ -13,7 +13,6 @@ pub const ATTEST_MAGIC: u32 = 0xA77E5700; /// Right now `Attest` and `TqSign` are the only commands that take data /// argumenets. They happen to be the same length right now but this also /// catches anything silly - const fn const_max(a: usize, b: usize) -> usize { [a, b][(a < b) as usize] } @@ -82,13 +81,13 @@ pub enum HostToRotError { /// Unexpected command returned UnexpectedCommand, /// Error return from the sprot command - SprotError(SprotError), + SprotError(RecvSprotError), } #[derive(Debug, Clone, Copy, PartialEq, Eq, Deserialize, Serialize)] #[repr(u32)] // Errors returned from the hubris side. This is _so many_ -pub enum SprotError { +pub enum RecvSprotError { // protocol /// CRC check failed. ProtocolInvalidCrc, @@ -164,8 +163,8 @@ pub enum RotToHost { RotTqSign, } -impl From for RotToHost { - fn from(e: SprotError) -> Self { +impl From for RotToHost { + fn from(e: RecvSprotError) -> Self { RotToHost::HostToRotError(HostToRotError::SprotError(e)) } } @@ -343,139 +342,155 @@ mod tests { (HostToRotError::IncorrectDataLen, [4, 0, 0, 0]), (HostToRotError::UnexpectedCommand, [5, 0, 0, 0]), ( - HostToRotError::SprotError(SprotError::ProtocolInvalidCrc), + HostToRotError::SprotError(RecvSprotError::ProtocolInvalidCrc), [6, 0, 0, 0], ), ( - HostToRotError::SprotError(SprotError::ProtocolFlowError), + HostToRotError::SprotError(RecvSprotError::ProtocolFlowError), [6, 1, 0, 0], ), ( HostToRotError::SprotError( - SprotError::ProtocolUnsupportedProtocol, + RecvSprotError::ProtocolUnsupportedProtocol, ), [6, 2, 0, 0], ), ( - HostToRotError::SprotError(SprotError::ProtocolBadMessageType), + HostToRotError::SprotError( + RecvSprotError::ProtocolBadMessageType, + ), [6, 3, 0, 0], ), ( HostToRotError::SprotError( - SprotError::ProtocolBadMessageLength, + RecvSprotError::ProtocolBadMessageLength, ), [6, 4, 0, 0], ), ( - HostToRotError::SprotError(SprotError::ProtocolCannotAssertCSn), + HostToRotError::SprotError( + RecvSprotError::ProtocolCannotAssertCSn, + ), [6, 5, 0, 0], ), ( - HostToRotError::SprotError(SprotError::ProtocolTimeout), + HostToRotError::SprotError(RecvSprotError::ProtocolTimeout), [6, 6, 0, 0], ), ( - HostToRotError::SprotError(SprotError::ProtocolDeserialization), + HostToRotError::SprotError( + RecvSprotError::ProtocolDeserialization, + ), [6, 7, 0, 0], ), ( HostToRotError::SprotError( - SprotError::ProtocolRotIrqRemainsAsserted, + RecvSprotError::ProtocolRotIrqRemainsAsserted, ), [6, 8, 0, 0], ), ( HostToRotError::SprotError( - SprotError::ProtocolUnexpectedResponse, + RecvSprotError::ProtocolUnexpectedResponse, ), [6, 9, 0, 0], ), ( - HostToRotError::SprotError(SprotError::ProtocolBadUpdateStatus), + HostToRotError::SprotError( + RecvSprotError::ProtocolBadUpdateStatus, + ), [6, 10, 0, 0], ), ( - HostToRotError::SprotError(SprotError::ProtocolTaskRestarted), + HostToRotError::SprotError( + RecvSprotError::ProtocolTaskRestarted, + ), [6, 11, 0, 0], ), ( - HostToRotError::SprotError(SprotError::ProtocolDesynchronized), + HostToRotError::SprotError( + RecvSprotError::ProtocolDesynchronized, + ), [6, 12, 0, 0], ), ( - HostToRotError::SprotError(SprotError::SpiBadTransferSize), + HostToRotError::SprotError(RecvSprotError::SpiBadTransferSize), [6, 13, 0, 0], ), ( - HostToRotError::SprotError(SprotError::SpiTaskRestarted), + HostToRotError::SprotError(RecvSprotError::SpiTaskRestarted), [6, 14, 0, 0], ), ( - HostToRotError::SprotError(SprotError::UpdateError), + HostToRotError::SprotError(RecvSprotError::UpdateError), [6, 15, 0, 0], ), ( - HostToRotError::SprotError(SprotError::SprocketsError), + HostToRotError::SprotError(RecvSprotError::SprocketsError), [6, 16, 0, 0], ), ( - HostToRotError::SprotError(SprotError::WatchdogError), + HostToRotError::SprotError(RecvSprotError::WatchdogError), [6, 17, 0, 0], ), ( - HostToRotError::SprotError(SprotError::AttestCertTooBig), + HostToRotError::SprotError(RecvSprotError::AttestCertTooBig), [6, 18, 0, 0], ), ( - HostToRotError::SprotError(SprotError::AttestInvalidCertIndex), + HostToRotError::SprotError( + RecvSprotError::AttestInvalidCertIndex, + ), [6, 19, 0, 0], ), ( - HostToRotError::SprotError(SprotError::AttestNoCerts), + HostToRotError::SprotError(RecvSprotError::AttestNoCerts), [6, 20, 0, 0], ), ( - HostToRotError::SprotError(SprotError::AttestOutOfRange), + HostToRotError::SprotError(RecvSprotError::AttestOutOfRange), [6, 21, 0, 0], ), ( - HostToRotError::SprotError(SprotError::AttestLogFull), + HostToRotError::SprotError(RecvSprotError::AttestLogFull), [6, 22, 0, 0], ), ( - HostToRotError::SprotError(SprotError::AttestLogTooBig), + HostToRotError::SprotError(RecvSprotError::AttestLogTooBig), [6, 23, 0, 0], ), ( - HostToRotError::SprotError(SprotError::AttestTaskRestarted), + HostToRotError::SprotError(RecvSprotError::AttestTaskRestarted), [6, 24, 0, 0], ), ( - HostToRotError::SprotError(SprotError::AttestBadLease), + HostToRotError::SprotError(RecvSprotError::AttestBadLease), [6, 25, 0, 0], ), ( HostToRotError::SprotError( - SprotError::AttestUnsupportedAlgorithm, + RecvSprotError::AttestUnsupportedAlgorithm, ), [6, 26, 0, 0], ), ( - HostToRotError::SprotError(SprotError::AttestSerializeLog), + HostToRotError::SprotError(RecvSprotError::AttestSerializeLog), [6, 27, 0, 0], ), ( HostToRotError::SprotError( - SprotError::AttestSerializeSignature, + RecvSprotError::AttestSerializeSignature, ), [6, 28, 0, 0], ), ( - HostToRotError::SprotError(SprotError::AttestSignatureTooBig), + HostToRotError::SprotError( + RecvSprotError::AttestSignatureTooBig, + ), [6, 29, 0, 0], ), ( - HostToRotError::SprotError(SprotError::CommsBufTooSmall), + HostToRotError::SprotError(RecvSprotError::CommsBufTooSmall), [6, 30, 0, 0], ), ]; From 634fe9e6e35ad66c2c66b5b1056e0f1384479545 Mon Sep 17 00:00:00 2001 From: Laura Abbott Date: Tue, 8 Oct 2024 09:38:42 -0400 Subject: [PATCH 2/2] clippy fix --- dice-cert-tmpl/src/cert.rs | 2 +- dice-cert-tmpl/src/csr.rs | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/dice-cert-tmpl/src/cert.rs b/dice-cert-tmpl/src/cert.rs index 9925ed0..a394da1 100644 --- a/dice-cert-tmpl/src/cert.rs +++ b/dice-cert-tmpl/src/cert.rs @@ -13,7 +13,7 @@ type Result = result::Result; pub struct Cert<'a>(pub &'a mut [u8]); -impl<'a> fmt::Display for Cert<'a> { +impl fmt::Display for Cert<'_> { fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { crate::arrayfmt(self.as_bytes(), f) } diff --git a/dice-cert-tmpl/src/csr.rs b/dice-cert-tmpl/src/csr.rs index 6f5bdb1..2829208 100644 --- a/dice-cert-tmpl/src/csr.rs +++ b/dice-cert-tmpl/src/csr.rs @@ -13,7 +13,7 @@ type Result = result::Result; // Type to expose parsing operations on CSR in underlying slice pub struct Csr<'a>(&'a mut [u8]); -impl<'a> fmt::Display for Csr<'a> { +impl fmt::Display for Csr<'_> { fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { crate::arrayfmt(self.as_bytes(), f) }