usb_util: convert to ThisError and sort

BUG=b:197143586
TEST=cargo check

Change-Id: I747bd7889182addbe1781a6726f10f140c192d5e
Reviewed-on: https://chromium-review.googlesource.com/c/chromiumos/platform/crosvm/+/3105428
Tested-by: kokoro <noreply+kokoro@google.com>
Commit-Queue: Daniel Verkamp <dverkamp@chromium.org>
Reviewed-by: Dennis Kempin <denniskempin@google.com>
This commit is contained in:
Daniel Verkamp 2021-08-18 14:24:53 -07:00 committed by Commit Bot
parent 1fd68656a2
commit 3878e5c6ba
3 changed files with 15 additions and 26 deletions

1
Cargo.lock generated
View file

@ -1215,6 +1215,7 @@ dependencies = [
"data_model", "data_model",
"libc", "libc",
"remain", "remain",
"thiserror",
"usb_sys", "usb_sys",
] ]

View file

@ -9,5 +9,6 @@ assertions = { path = "../assertions" }
data_model = { path = "../data_model" } data_model = { path = "../data_model" }
libc = "*" libc = "*"
remain = "*" remain = "*"
thiserror = "*"
base = { path = "../base" } base = { path = "../base" }
usb_sys = { path = "../usb_sys" } usb_sys = { path = "../usb_sys" }

View file

@ -4,48 +4,35 @@
use base::IoctlNr; use base::IoctlNr;
use remain::sorted; use remain::sorted;
use std::fmt::{self, Display};
use std::io; use std::io;
use std::num; use std::num;
use thiserror::Error;
#[sorted] #[sorted]
#[derive(Debug)] #[derive(Error, Debug)]
pub enum Error { pub enum Error {
#[error("parsing descriptors failed")]
DescriptorParse, DescriptorParse,
#[error("reading descriptors from device failed: {0}")]
DescriptorRead(io::Error), DescriptorRead(io::Error),
#[error("File::try_clone() failed: {0}")]
FdCloneFailed(io::Error), FdCloneFailed(io::Error),
#[error("invalid actual_length in URB: {0}")]
InvalidActualLength(num::TryFromIntError), InvalidActualLength(num::TryFromIntError),
#[error("invalid transfer buffer length: {0}")]
InvalidBufferLength(num::TryFromIntError), InvalidBufferLength(num::TryFromIntError),
#[error("USB ioctl 0x{0:x} failed: {1}")]
IoctlFailed(IoctlNr, base::Error), IoctlFailed(IoctlNr, base::Error),
#[error("Device has been removed")]
NoDevice, NoDevice,
#[error("Requested descriptor not found")]
NoSuchDescriptor, NoSuchDescriptor,
#[error("Rc::get_mut failed")]
RcGetMutFailed, RcGetMutFailed,
#[error("Rc::try_unwrap failed")]
RcUnwrapFailed, RcUnwrapFailed,
#[error("attempted to cancel already-completed transfer")]
TransferAlreadyCompleted, TransferAlreadyCompleted,
} }
impl Display for Error {
#[remain::check]
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
use self::Error::*;
#[sorted]
match self {
DescriptorParse => write!(f, "parsing descriptors failed"),
DescriptorRead(e) => write!(f, "reading descriptors from device failed: {}", e),
FdCloneFailed(e) => write!(f, "File::try_clone() failed: {}", e),
InvalidActualLength(e) => write!(f, "invalid actual_length in URB: {}", e),
InvalidBufferLength(e) => write!(f, "invalid transfer buffer length: {}", e),
IoctlFailed(nr, e) => write!(f, "USB ioctl 0x{:x} failed: {}", nr, e),
NoDevice => write!(f, "Device has been removed"),
NoSuchDescriptor => write!(f, "Requested descriptor not found"),
RcGetMutFailed => write!(f, "Rc::get_mut failed"),
RcUnwrapFailed => write!(f, "Rc::try_unwrap failed"),
TransferAlreadyCompleted => write!(f, "attempted to cancel already-completed transfer"),
}
}
}
pub type Result<T> = std::result::Result<T, Error>; pub type Result<T> = std::result::Result<T, Error>;
impl std::error::Error for Error {}