probe_rs/error.rs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84
use crate::architecture::arm::ArmError;
use crate::architecture::riscv::communication_interface::RiscvError;
use crate::architecture::xtensa::communication_interface::XtensaError;
use crate::config::RegistryError;
use crate::core::memory_mapped_registers::RegisterAddressOutOfBounds;
use crate::memory::{InvalidDataLengthError, MemoryNotAlignedError};
use crate::probe::DebugProbeError;
/// The overarching error type which contains all possible errors as variants.
#[derive(thiserror::Error, Debug, docsplay::Display)]
pub enum Error {
/// An error with the usage of the probe occurred
Probe(#[from] DebugProbeError),
/// An ARM specific error occurred.
Arm(#[source] ArmError),
/// A RISC-V specific error occurred.
Riscv(#[source] RiscvError),
/// An Xtensa specific error occurred.
Xtensa(#[source] XtensaError),
/// Core {0} is not enabled.
CoreDisabled(usize),
/// Core {0} does not exist.
CoreNotFound(usize),
/// Unable to load specification for chip
ChipNotFound(#[from] RegistryError),
/// An operation was not performed because the required permissions were not given: {0}.
///
/// This can for example happen when the core is locked and needs to be erased to be unlocked.
/// Then the correct permission needs to be given to automatically unlock the core to prevent accidental erases.
#[ignore_extra_doc_attributes]
MissingPermissions(String),
/// An error that is not architecture specific occurred: {0}
GenericCoreError(String),
/// Errors accessing core register: {0}
Register(String),
/// Error calculating the address of a register
#[error(transparent)]
RegisterAddressOutOfBounds(#[from] RegisterAddressOutOfBounds),
/// The {0} capability has not yet been implemented for this architecture.
///
/// Because of the large varieties of supported architectures, it is not always possible for
/// a contributor to implement functionality for all of them. This allows us to
/// implement new functionality on selected architectures first, and then add support for
/// the other architectures later.
NotImplemented(&'static str),
/// Some uncategorized error occurred.
#[display("{0}")]
Other(String),
/// A timeout occurred.
// TODO: Errors below should be core specific
Timeout,
/// Memory access to address {0.address:#X?} was not aligned to {0.alignment} bytes.
#[error(transparent)]
MemoryNotAligned(#[from] MemoryNotAlignedError),
/// The data buffer had an invalid length.
#[error(transparent)]
InvalidDataLength(#[from] InvalidDataLengthError),
/// Failed to write CPU register {register}.
WriteRegister {
/// The name of the register that was tried to be written.
register: String,
/// The source error of this error.
source: Box<dyn std::error::Error + 'static + Send + Sync>,
},
/// Failed to read CPU register {register}.
ReadRegister {
/// The name of the register that was tried to be read.
register: String,
/// The source error of this error.
source: Box<dyn std::error::Error + 'static + Send + Sync>,
},
}
impl From<ArmError> for Error {
fn from(value: ArmError) -> Self {
match value {
ArmError::Timeout => Error::Timeout,
ArmError::MemoryNotAligned(e) => Error::MemoryNotAligned(e),
ArmError::InvalidDataLength(e) => Error::InvalidDataLength(e),
other => Error::Arm(other),
}
}
}