#[doc = "Two-wire Interface 0"]
#[derive(Copy, Clone, Eq, PartialEq)]
pub struct Twi {
ptr: *mut u8,
}
unsafe impl Send for Twi {}
unsafe impl Sync for Twi {}
impl Twi {
#[inline(always)]
pub const unsafe fn from_ptr(ptr: *mut ()) -> Self {
Self { ptr: ptr as _ }
}
#[inline(always)]
pub const fn as_ptr(&self) -> *mut () {
self.ptr as _
}
#[doc = "Control Register"]
#[inline(always)]
pub const fn cr(self) -> crate::common::Reg<regs::Cr, crate::common::W> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x0usize) as _) }
}
#[doc = "Master Mode Register"]
#[inline(always)]
pub const fn mmr(self) -> crate::common::Reg<regs::Mmr, crate::common::RW> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x04usize) as _) }
}
#[doc = "Slave Mode Register"]
#[inline(always)]
pub const fn smr(self) -> crate::common::Reg<regs::Smr, crate::common::RW> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x08usize) as _) }
}
#[doc = "Internal Address Register"]
#[inline(always)]
pub const fn iadr(self) -> crate::common::Reg<regs::Iadr, crate::common::RW> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x0cusize) as _) }
}
#[doc = "Clock Waveform Generator Register"]
#[inline(always)]
pub const fn cwgr(self) -> crate::common::Reg<regs::Cwgr, crate::common::RW> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x10usize) as _) }
}
#[doc = "Status Register"]
#[inline(always)]
pub const fn sr(self) -> crate::common::Reg<regs::Sr, crate::common::R> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x20usize) as _) }
}
#[doc = "Interrupt Enable Register"]
#[inline(always)]
pub const fn ier(self) -> crate::common::Reg<regs::Ier, crate::common::W> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x24usize) as _) }
}
#[doc = "Interrupt Disable Register"]
#[inline(always)]
pub const fn idr(self) -> crate::common::Reg<regs::Idr, crate::common::W> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x28usize) as _) }
}
#[doc = "Interrupt Mask Register"]
#[inline(always)]
pub const fn imr(self) -> crate::common::Reg<regs::Imr, crate::common::R> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x2cusize) as _) }
}
#[doc = "Receive Holding Register"]
#[inline(always)]
pub const fn rhr(self) -> crate::common::Reg<regs::Rhr, crate::common::R> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x30usize) as _) }
}
#[doc = "Transmit Holding Register"]
#[inline(always)]
pub const fn thr(self) -> crate::common::Reg<regs::Thr, crate::common::W> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x34usize) as _) }
}
#[doc = "Receive Pointer Register"]
#[inline(always)]
pub const fn rpr(self) -> crate::common::Reg<regs::Rpr, crate::common::RW> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x0100usize) as _) }
}
#[doc = "Receive Counter Register"]
#[inline(always)]
pub const fn rcr(self) -> crate::common::Reg<regs::Rcr, crate::common::RW> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x0104usize) as _) }
}
#[doc = "Transmit Pointer Register"]
#[inline(always)]
pub const fn tpr(self) -> crate::common::Reg<regs::Tpr, crate::common::RW> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x0108usize) as _) }
}
#[doc = "Transmit Counter Register"]
#[inline(always)]
pub const fn tcr(self) -> crate::common::Reg<regs::Tcr, crate::common::RW> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x010cusize) as _) }
}
#[doc = "Receive Next Pointer Register"]
#[inline(always)]
pub const fn rnpr(self) -> crate::common::Reg<regs::Rnpr, crate::common::RW> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x0110usize) as _) }
}
#[doc = "Receive Next Counter Register"]
#[inline(always)]
pub const fn rncr(self) -> crate::common::Reg<regs::Rncr, crate::common::RW> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x0114usize) as _) }
}
#[doc = "Transmit Next Pointer Register"]
#[inline(always)]
pub const fn tnpr(self) -> crate::common::Reg<regs::Tnpr, crate::common::RW> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x0118usize) as _) }
}
#[doc = "Transmit Next Counter Register"]
#[inline(always)]
pub const fn tncr(self) -> crate::common::Reg<regs::Tncr, crate::common::RW> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x011cusize) as _) }
}
#[doc = "Transfer Control Register"]
#[inline(always)]
pub const fn ptcr(self) -> crate::common::Reg<regs::Ptcr, crate::common::W> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x0120usize) as _) }
}
#[doc = "Transfer Status Register"]
#[inline(always)]
pub const fn ptsr(self) -> crate::common::Reg<regs::Ptsr, crate::common::R> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x0124usize) as _) }
}
}
pub mod regs;
pub mod vals;