use std::fmt;
pub mod commands;
pub mod device;
pub mod error;
pub mod flash_op;
pub mod format;
mod operations;
pub mod regs;
pub mod transport;
pub use crate::error::{Error, Result};
#[derive(Clone, Copy, Debug)]
#[repr(u8)]
pub enum WchLinkVariant {
Ch549 = 1,
ECh32v305 = 2,
SCh32v203 = 3,
B = 4,
}
impl WchLinkVariant {
pub fn try_from_u8(value: u8) -> Result<Self> {
match value {
1 => Ok(Self::Ch549),
2 => Ok(Self::ECh32v305),
3 => Ok(Self::SCh32v203),
4 => Ok(Self::B),
18 => Ok(Self::ECh32v305),
_ => Err(Error::UnknownLinkVariant(value)),
}
}
}
impl fmt::Display for WchLinkVariant {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
match self {
WchLinkVariant::Ch549 => write!(f, "WCH-Link-CH549"),
WchLinkVariant::ECh32v305 => write!(f, "WCH-LinkE-CH32V305"),
WchLinkVariant::SCh32v203 => write!(f, "WCH-LinkS-CH32V203"),
WchLinkVariant::B => write!(f, "WCH-LinkB"),
}
}
}
#[derive(Clone, Copy, Debug, PartialEq, Eq)]
#[repr(u8)]
pub enum RiscvChip {
CH32V103 = 0x01,
CH57X = 0x02,
CH56X = 0x03,
CH32V20X = 0x05,
CH32V30X = 0x06,
CH58X = 0x07,
CH32V003 = 0x09,
}
impl RiscvChip {
fn can_disable_debug(&self) -> bool {
matches!(self, RiscvChip::CH57X | RiscvChip::CH56X | RiscvChip::CH58X)
}
fn reset_command(&self) -> crate::commands::Reset {
match self {
RiscvChip::CH57X | RiscvChip::CH58X => crate::commands::Reset::Normal2,
_ => crate::commands::Reset::Normal,
}
}
fn flash_op(&self) -> &[u8] {
match self {
RiscvChip::CH32V103 => &flash_op::CH32V103,
RiscvChip::CH32V003 => &flash_op::CH32V003,
RiscvChip::CH57X => &flash_op::CH573,
RiscvChip::CH56X => &flash_op::CH569,
RiscvChip::CH32V20X => &flash_op::CH32V307,
RiscvChip::CH32V30X => &flash_op::CH32V307,
RiscvChip::CH58X => &flash_op::CH573,
}
}
fn try_from_u8(value: u8) -> Result<Self> {
match value {
0x01 => Ok(RiscvChip::CH32V103),
0x02 => Ok(RiscvChip::CH57X),
0x03 => Ok(RiscvChip::CH56X),
0x05 => Ok(RiscvChip::CH32V20X),
0x06 => Ok(RiscvChip::CH32V30X),
0x07 => Ok(RiscvChip::CH58X),
0x09 => Ok(RiscvChip::CH32V003),
_ => Err(Error::UnknownChip(value)),
}
}
pub fn page_size(&self) -> u32 {
match self {
RiscvChip::CH32V103 => 128,
RiscvChip::CH32V003 => 64,
_ => 256,
}
}
pub fn code_flash_start(&self) -> u32 {
match self {
RiscvChip::CH56X => 0x0000_0000,
RiscvChip::CH57X => 0x0000_0000,
RiscvChip::CH58X => 0x0000_0000,
_ => 0x0800_0000,
}
}
pub fn write_pack_size(&self) -> u32 {
match self {
RiscvChip::CH32V003 => 1024,
_ => 4096,
}
}
}