#[doc = "Analog-to-Digital Converter"]
#[derive(Copy, Clone, Eq, PartialEq)]
pub struct Adc {
ptr: *mut u8,
}
unsafe impl Send for Adc {}
unsafe impl Sync for Adc {}
impl Adc {
#[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 = "Mode Register"]
#[inline(always)]
pub const fn mr(self) -> crate::common::Reg<regs::Mr, crate::common::RW> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x04usize) as _) }
}
#[doc = "Channel Sequence Register 1"]
#[inline(always)]
pub const fn seqr1(self) -> crate::common::Reg<regs::Seqr1, crate::common::RW> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x08usize) as _) }
}
#[doc = "Channel Sequence Register 2"]
#[inline(always)]
pub const fn seqr2(self) -> crate::common::Reg<regs::Seqr2, crate::common::RW> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x0cusize) as _) }
}
#[doc = "Channel Enable Register"]
#[inline(always)]
pub const fn cher(self) -> crate::common::Reg<regs::Cher, crate::common::W> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x10usize) as _) }
}
#[doc = "Channel Disable Register"]
#[inline(always)]
pub const fn chdr(self) -> crate::common::Reg<regs::Chdr, crate::common::W> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x14usize) as _) }
}
#[doc = "Channel Status Register"]
#[inline(always)]
pub const fn chsr(self) -> crate::common::Reg<regs::Chsr, crate::common::R> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x18usize) as _) }
}
#[doc = "Last Converted Data Register"]
#[inline(always)]
pub const fn lcdr(self) -> crate::common::Reg<regs::Lcdr, 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 = "Interrupt Status Register"]
#[inline(always)]
pub const fn isr(self) -> crate::common::Reg<regs::Isr, crate::common::R> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x30usize) as _) }
}
#[doc = "Overrun Status Register"]
#[inline(always)]
pub const fn over(self) -> crate::common::Reg<regs::Over, crate::common::R> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x3cusize) as _) }
}
#[doc = "Extended Mode Register"]
#[inline(always)]
pub const fn emr(self) -> crate::common::Reg<regs::Emr, crate::common::RW> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x40usize) as _) }
}
#[doc = "Compare Window Register"]
#[inline(always)]
pub const fn cwr(self) -> crate::common::Reg<regs::Cwr, crate::common::RW> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x44usize) as _) }
}
#[doc = "Channel Gain Register"]
#[inline(always)]
pub const fn cgr(self) -> crate::common::Reg<regs::Cgr, crate::common::RW> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x48usize) as _) }
}
#[doc = "Channel Offset Register"]
#[inline(always)]
pub const fn cor(self) -> crate::common::Reg<regs::Cor, crate::common::RW> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x4cusize) as _) }
}
#[doc = "Channel Data Register"]
#[inline(always)]
pub const fn cdr(self, n: usize) -> crate::common::Reg<regs::Cdr, crate::common::R> {
assert!(n < 16usize);
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x50usize + n * 4usize) as _) }
}
#[doc = "Analog Control Register"]
#[inline(always)]
pub const fn acr(self) -> crate::common::Reg<regs::Acr, crate::common::RW> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0x94usize) as _) }
}
#[doc = "Write Protect Mode Register"]
#[inline(always)]
pub const fn wpmr(self) -> crate::common::Reg<regs::Wpmr, crate::common::RW> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0xe4usize) as _) }
}
#[doc = "Write Protect Status Register"]
#[inline(always)]
pub const fn wpsr(self) -> crate::common::Reg<regs::Wpsr, crate::common::R> {
unsafe { crate::common::Reg::from_ptr(self.ptr.wrapping_add(0xe8usize) 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 = "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 = "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;