opentitanlib/transport/
errors.rsuse serde::{Deserialize, Serialize};
use thiserror::Error;
use super::Capability;
use crate::impl_serializable_error;
#[derive(Error, Debug, Serialize, Deserialize)]
pub enum TransportError {
#[error("USB device did not match")]
NoMatch,
#[error("Found no USB device")]
NoDevice,
#[error("Found multiple USB devices, use --usb-serial")]
MultipleDevices,
#[error("USB error: {0}")]
UsbGenericError(String),
#[error("Error opening USB device: {0}")]
UsbOpenError(String),
#[error("Transport does not support {0:?}")]
InvalidInterface(TransportInterfaceType),
#[error("Transport does not support {0:?} instance {1}")]
InvalidInstance(TransportInterfaceType, String),
#[error("Encountered non-unicode device path")]
UnicodePathError,
#[error("Error opening {0}: {1}")]
OpenError(String, String),
#[error("Error reading from {0}: {1}")]
ReadError(String, String),
#[error("FPGA programming failed: {0}")]
FpgaProgramFailed(String),
#[error("Firmware programming failed: {0}")]
FirmwareProgramFailed(String),
#[error("Error clearing FPGA bitstream")]
ClearBitstreamFailed(),
#[error("PLL programming failed: {0}")]
PllProgramFailed(String),
#[error("Invalid pin strapping name \"{0}\"")]
InvalidStrappingName(String),
#[error("Invalid IO expander name \"{0}\"")]
InvalidIoExpanderName(String),
#[error("Invalid pin {1} for IO expander \"{0}\"")]
InvalidIoExpanderPinNo(String, u32),
#[error("Transport does not support the requested operation")]
UnsupportedOperation,
#[error("Requested operation invalid at this time")]
InvalidOperation,
#[error("Error communicating with FTDI: {0}")]
FtdiError(String),
#[error("Error communicating with debugger: {0}")]
CommunicationError(String),
#[error("Proxy unable to resolve `{0}`: {1}")]
ProxyLookupError(String, String),
#[error("Proxy unable to connect to `{0}`: {1}")]
ProxyConnectError(String, String),
#[error("Requested capabilities {0:?}, but capabilities {1:?} are supplied")]
MissingCapabilities(Capability, Capability),
#[error("Inconsistent configuration for {0:?} instance \"{1}\"")]
InconsistentConf(TransportInterfaceType, String),
#[error("Inconsistent configuration of transport interface \"{0}\" vs. \"{1}\"")]
InconsistentInterfaceConf(String, String),
#[error("Strapping \"{0}\" pin \"{1}\" cannot declare \"alias_of\"")]
InvalidConfStrapAlias(String, String),
#[error("Strapping \"{0}\" pin \"{1}\" cannot declare \"invert\"")]
InvalidConfStrapInvert(String, String),
#[error("Expected value \"{1}\" for key \"{0}\", found \"{2}\"")]
RequiresUnequal(String, String, String),
#[error("Expected value \"{1}\" for key \"{0}\", found none")]
RequiresMissing(String, String),
}
impl_serializable_error!(TransportError);
#[derive(Debug, serde::Serialize, serde::Deserialize)]
pub enum TransportInterfaceType {
Gpio,
Uart,
Spi,
I2c,
Jtag,
Emulator,
ProxyOps,
GpioMonitoring,
GpioBitbanging,
IoExpander,
Provides,
}