w5100-rs/src/register.rs
2021-02-18 19:16:16 -08:00

198 lines
5.6 KiB
Rust

pub const COMMON: u8 = 0;
pub mod common {
use bit_field::BitArray;
pub const MODE: u16 = 0x0;
pub const GATEWAY: u16 = 0x01;
pub const SUBNET_MASK: u16 = 0x05;
pub const MAC: u16 = 0x09;
pub const IP: u16 = 0x0F;
pub const PHY_CONFIG: u16 = 0x2E;
pub const VERSION: u16 = 0x39;
#[derive(Debug, Copy, Clone, Eq, PartialEq, Ord, PartialOrd)]
#[repr(u8)]
pub enum PhyOperationMode {
/// 10BT half-duplex. Auto-negotiation disabled.
HalfDuplex10bt = 0b000_000,
/// 10BT full-duplex. Auto-negotiation disabled.
FullDuplex10bt = 0b001_000,
/// 100BT half-duplex. Auto-negotiation disabled.
HalfDuplex100bt = 0b010_000,
/// 100BT full-duplex. Auto-negotiation disabled.
FullDuplex100bt = 0b011_000,
/// 100BT half-duplex. Auto-negotiation enabled.
HalfDuplex100btAuto = 0b100_000,
/// Power down mode.
PowerDown = 0b110_000,
/// All capable. Auto-negotiation enabled.
Auto = 0b111_000,
}
impl From<PhyOperationMode> for u8 {
fn from(val: PhyOperationMode) -> u8 {
val as u8
}
}
impl Default for PhyOperationMode {
fn default() -> PhyOperationMode {
PhyOperationMode::Auto
}
}
#[derive(Debug, Copy, Clone, Eq, PartialEq, Ord, PartialOrd)]
#[repr(u8)]
pub enum PhySpeedStatus {
/// 10Mbps based.
Mbps10 = 0,
/// 100Mbps based.
Mbps100 = 1,
}
#[derive(Debug, Copy, Clone, Eq, PartialEq, Ord, PartialOrd)]
#[repr(u8)]
pub enum PhyDuplexStatus {
/// Half duplex.
HalfDuplex = 0,
/// Full duplex.
FullDuplex = 1,
}
#[derive(Debug, Copy, Clone, Eq, PartialEq)]
pub struct PhyConfig([u8; 1]);
impl PhyConfig {
// Link status bit position.
const LNK_POS: usize = 7;
// Speed status bit position.
const SPD_POS: usize = 6;
// Duplex status bit position.
const DPX_POS: usize = 5;
// Operation mode bit position.
// const OPMDC_POS = 2;
// Configure PHY opeartion mode bit position.
// const OPMD_POS = 1;
// Reset bit position.
// const RST_POS = 0;
/// PHY link status.
///
/// `true` if the link is up, `false` if the link is down.
pub fn link_up(&self) -> bool {
self.0.get_bit(Self::LNK_POS)
}
/// PHY speed status.
pub fn speed(&self) -> PhySpeedStatus {
if !self.0.get_bit(Self::SPD_POS) {
PhySpeedStatus::Mbps10
} else {
PhySpeedStatus::Mbps100
}
}
/// PHY duplex status.
pub fn duplex(&self) -> PhyDuplexStatus {
if !self.0.get_bit(Self::DPX_POS) {
PhyDuplexStatus::HalfDuplex
} else {
PhyDuplexStatus::FullDuplex
}
}
/// PHY operation mode.
pub fn operation_mode(&self) -> PhyOperationMode {
match self.0[0] & 0b111_000u8 {
0b000_000 => PhyOperationMode::HalfDuplex10bt,
0b001_000 => PhyOperationMode::FullDuplex10bt,
0b010_000 => PhyOperationMode::HalfDuplex100bt,
0b011_000 => PhyOperationMode::FullDuplex100bt,
0b100_000 => PhyOperationMode::HalfDuplex100btAuto,
0b110_000 => PhyOperationMode::PowerDown,
0b111_000 => PhyOperationMode::Auto,
_ => unreachable!(),
}
}
}
impl core::convert::From<u8> for PhyConfig {
fn from(val: u8) -> Self {
PhyConfig([val])
}
}
}
pub const SOCKET0: u8 = 0b000_00001;
pub const SOCKET0_BUFFER_TX: u8 = 0b000_00010;
pub const SOCKET0_BUFFER_RX: u8 = 0b000_00011;
pub const SOCKET1: u8 = 0b000_00101;
pub const SOCKET1_BUFFER_TX: u8 = 0b000_00110;
pub const SOCKET1_BUFFER_RX: u8 = 0b000_00111;
pub const SOCKET2: u8 = 0b000_01001;
pub const SOCKET2_BUFFER_TX: u8 = 0b000_01010;
pub const SOCKET2_BUFFER_RX: u8 = 0b000_01011;
pub const SOCKET3: u8 = 0b000_01101;
pub const SOCKET3_BUFFER_TX: u8 = 0b000_01110;
pub const SOCKET3_BUFFER_RX: u8 = 0b000_01111;
pub const SOCKET4: u8 = 0b000_10001;
pub const SOCKET4_BUFFER_TX: u8 = 0b000_10010;
pub const SOCKET4_BUFFER_RX: u8 = 0b000_10011;
pub const SOCKET5: u8 = 0b000_10101;
pub const SOCKET5_BUFFER_TX: u8 = 0b000_10110;
pub const SOCKET5_BUFFER_RX: u8 = 0b000_10111;
pub const SOCKET6: u8 = 0b000_11001;
pub const SOCKET6_BUFFER_TX: u8 = 0b000_11010;
pub const SOCKET6_BUFFER_RX: u8 = 0b000_11011;
pub const SOCKET7: u8 = 0b000_11101;
pub const SOCKET7_BUFFER_TX: u8 = 0b000_11110;
pub const SOCKET7_BUFFER_RX: u8 = 0b000_11111;
pub mod socketn {
pub const MODE: u16 = 0x00;
#[repr(u8)]
pub enum Protocol {
Udp = 0b10u8,
Closed = 0u8,
}
pub const COMMAND: u16 = 0x01;
#[repr(u8)]
pub enum Command {
Open = 0x01,
Send = 0x20,
Receive = 0x40,
Close = 0x10,
}
pub const INTERRUPT: u16 = 0x02;
#[repr(u8)]
pub enum Interrupt {
All = 0b11111111u8,
SendOk = 0b010000u8,
Timeout = 0b01000u8,
Receive = 0b00100u8,
}
pub const SOURCE_PORT: u16 = 0x04;
pub const DESTINATION_IP: u16 = 0x0C;
pub const DESTINATION_PORT: u16 = 0x10;
pub const TX_DATA_READ_POINTER: u16 = 0x22;
pub const TX_DATA_WRITE_POINTER: u16 = 0x24;
pub const RECEIVED_SIZE: u16 = 0x26;
pub const RX_DATA_READ_POINTER: u16 = 0x28;
pub const INTERRUPT_MASK: u16 = 0x2C;
}