#[doc = r"Register block"]
#[repr(C)]
pub struct RegisterBlock {
_reserved0: [u8; 16usize],
#[doc = "0x10 - Code memory page size"]
pub codepagesize: CODEPAGESIZE,
#[doc = "0x14 - Code memory size"]
pub codesize: CODESIZE,
_reserved2: [u8; 72usize],
#[doc = "0x60 - Description collection: Device identifier"]
pub deviceid: [DEVICEID; 2],
_reserved3: [u8; 24usize],
#[doc = "0x80 - Description collection: Encryption root, word n"]
pub er: [ER; 4],
#[doc = "0x90 - Description collection: Identity Root, word n"]
pub ir: [IR; 4],
#[doc = "0xa0 - Device address type"]
pub deviceaddrtype: DEVICEADDRTYPE,
#[doc = "0xa4 - Description collection: Device address n"]
pub deviceaddr: [DEVICEADDR; 2],
_reserved7: [u8; 84usize],
#[doc = "0x100 - Device info"]
pub info: INFO,
_reserved8: [u8; 572usize],
#[doc = "0x350 - Description collection: Production test signature n"]
pub prodtest: [PRODTEST; 3],
_reserved9: [u8; 168usize],
#[doc = "0x404 - Registers storing factory TEMP module linearization coefficients"]
pub temp: TEMP,
_reserved10: [u8; 8usize],
#[doc = "0x450 - Unspecified"]
pub nfc: NFC,
}
#[doc = r"Register block"]
#[repr(C)]
pub struct INFO {
#[doc = "0x00 - Part code"]
pub part: self::info::PART,
#[doc = "0x04 - Build code (hardware version and production configuration)"]
pub variant: self::info::VARIANT,
#[doc = "0x08 - Package option"]
pub package: self::info::PACKAGE,
#[doc = "0x0c - RAM variant"]
pub ram: self::info::RAM,
#[doc = "0x10 - Flash variant"]
pub flash: self::info::FLASH,
}
#[doc = r"Register block"]
#[doc = "Device info"]
pub mod info;
#[doc = r"Register block"]
#[repr(C)]
pub struct TEMP {
#[doc = "0x00 - Slope definition A0"]
pub a0: self::temp::A0,
#[doc = "0x04 - Slope definition A1"]
pub a1: self::temp::A1,
#[doc = "0x08 - Slope definition A2"]
pub a2: self::temp::A2,
#[doc = "0x0c - Slope definition A3"]
pub a3: self::temp::A3,
#[doc = "0x10 - Slope definition A4"]
pub a4: self::temp::A4,
#[doc = "0x14 - Slope definition A5"]
pub a5: self::temp::A5,
#[doc = "0x18 - Y-intercept B0"]
pub b0: self::temp::B0,
#[doc = "0x1c - Y-intercept B1"]
pub b1: self::temp::B1,
#[doc = "0x20 - Y-intercept B2"]
pub b2: self::temp::B2,
#[doc = "0x24 - Y-intercept B3"]
pub b3: self::temp::B3,
#[doc = "0x28 - Y-intercept B4"]
pub b4: self::temp::B4,
#[doc = "0x2c - Y-intercept B5"]
pub b5: self::temp::B5,
#[doc = "0x30 - Segment end T0"]
pub t0: self::temp::T0,
#[doc = "0x34 - Segment end T1"]
pub t1: self::temp::T1,
#[doc = "0x38 - Segment end T2"]
pub t2: self::temp::T2,
#[doc = "0x3c - Segment end T3"]
pub t3: self::temp::T3,
#[doc = "0x40 - Segment end T4"]
pub t4: self::temp::T4,
}
#[doc = r"Register block"]
#[doc = "Registers storing factory TEMP module linearization coefficients"]
pub mod temp;
#[doc = r"Register block"]
#[repr(C)]
pub struct NFC {
#[doc = "0x00 - Default header for NFC tag. Software can read these values to populate NFCID1_3RD_LAST, NFCID1_2ND_LAST, and NFCID1_LAST."]
pub tagheader0: self::nfc::TAGHEADER0,
#[doc = "0x04 - Default header for NFC tag. Software can read these values to populate NFCID1_3RD_LAST, NFCID1_2ND_LAST, and NFCID1_LAST."]
pub tagheader1: self::nfc::TAGHEADER1,
#[doc = "0x08 - Default header for NFC tag. Software can read these values to populate NFCID1_3RD_LAST, NFCID1_2ND_LAST, and NFCID1_LAST."]
pub tagheader2: self::nfc::TAGHEADER2,
#[doc = "0x0c - Default header for NFC tag. Software can read these values to populate NFCID1_3RD_LAST, NFCID1_2ND_LAST, and NFCID1_LAST."]
pub tagheader3: self::nfc::TAGHEADER3,
}
#[doc = r"Register block"]
#[doc = "Unspecified"]
pub mod nfc;
#[doc = "Code memory page size\n\nThis register you can [`read`](crate::generic::Reg::read). See [API](https://docs.rs/svd2rust/#read--modify--write-api).\n\nFor information about available fields see [codepagesize](codepagesize) module"]
pub type CODEPAGESIZE = crate::Reg<u32, _CODEPAGESIZE>;
#[allow(missing_docs)]
#[doc(hidden)]
pub struct _CODEPAGESIZE;
#[doc = "`read()` method returns [codepagesize::R](codepagesize::R) reader structure"]
impl crate::Readable for CODEPAGESIZE {}
#[doc = "Code memory page size"]
pub mod codepagesize;
#[doc = "Code memory size\n\nThis register you can [`read`](crate::generic::Reg::read). See [API](https://docs.rs/svd2rust/#read--modify--write-api).\n\nFor information about available fields see [codesize](codesize) module"]
pub type CODESIZE = crate::Reg<u32, _CODESIZE>;
#[allow(missing_docs)]
#[doc(hidden)]
pub struct _CODESIZE;
#[doc = "`read()` method returns [codesize::R](codesize::R) reader structure"]
impl crate::Readable for CODESIZE {}
#[doc = "Code memory size"]
pub mod codesize;
#[doc = "Description collection: Device identifier\n\nThis register you can [`read`](crate::generic::Reg::read). See [API](https://docs.rs/svd2rust/#read--modify--write-api).\n\nFor information about available fields see [deviceid](deviceid) module"]
pub type DEVICEID = crate::Reg<u32, _DEVICEID>;
#[allow(missing_docs)]
#[doc(hidden)]
pub struct _DEVICEID;
#[doc = "`read()` method returns [deviceid::R](deviceid::R) reader structure"]
impl crate::Readable for DEVICEID {}
#[doc = "Description collection: Device identifier"]
pub mod deviceid;
#[doc = "Description collection: Encryption root, word n\n\nThis register you can [`read`](crate::generic::Reg::read). See [API](https://docs.rs/svd2rust/#read--modify--write-api).\n\nFor information about available fields see [er](er) module"]
pub type ER = crate::Reg<u32, _ER>;
#[allow(missing_docs)]
#[doc(hidden)]
pub struct _ER;
#[doc = "`read()` method returns [er::R](er::R) reader structure"]
impl crate::Readable for ER {}
#[doc = "Description collection: Encryption root, word n"]
pub mod er;
#[doc = "Description collection: Identity Root, word n\n\nThis register you can [`read`](crate::generic::Reg::read). See [API](https://docs.rs/svd2rust/#read--modify--write-api).\n\nFor information about available fields see [ir](ir) module"]
pub type IR = crate::Reg<u32, _IR>;
#[allow(missing_docs)]
#[doc(hidden)]
pub struct _IR;
#[doc = "`read()` method returns [ir::R](ir::R) reader structure"]
impl crate::Readable for IR {}
#[doc = "Description collection: Identity Root, word n"]
pub mod ir;
#[doc = "Device address type\n\nThis register you can [`read`](crate::generic::Reg::read). See [API](https://docs.rs/svd2rust/#read--modify--write-api).\n\nFor information about available fields see [deviceaddrtype](deviceaddrtype) module"]
pub type DEVICEADDRTYPE = crate::Reg<u32, _DEVICEADDRTYPE>;
#[allow(missing_docs)]
#[doc(hidden)]
pub struct _DEVICEADDRTYPE;
#[doc = "`read()` method returns [deviceaddrtype::R](deviceaddrtype::R) reader structure"]
impl crate::Readable for DEVICEADDRTYPE {}
#[doc = "Device address type"]
pub mod deviceaddrtype;
#[doc = "Description collection: Device address n\n\nThis register you can [`read`](crate::generic::Reg::read). See [API](https://docs.rs/svd2rust/#read--modify--write-api).\n\nFor information about available fields see [deviceaddr](deviceaddr) module"]
pub type DEVICEADDR = crate::Reg<u32, _DEVICEADDR>;
#[allow(missing_docs)]
#[doc(hidden)]
pub struct _DEVICEADDR;
#[doc = "`read()` method returns [deviceaddr::R](deviceaddr::R) reader structure"]
impl crate::Readable for DEVICEADDR {}
#[doc = "Description collection: Device address n"]
pub mod deviceaddr;
#[doc = "Description collection: Production test signature n\n\nThis register you can [`read`](crate::generic::Reg::read). See [API](https://docs.rs/svd2rust/#read--modify--write-api).\n\nFor information about available fields see [prodtest](prodtest) module"]
pub type PRODTEST = crate::Reg<u32, _PRODTEST>;
#[allow(missing_docs)]
#[doc(hidden)]
pub struct _PRODTEST;
#[doc = "`read()` method returns [prodtest::R](prodtest::R) reader structure"]
impl crate::Readable for PRODTEST {}
#[doc = "Description collection: Production test signature n"]
pub mod prodtest;