1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119
#[doc = r" Register block"] #[repr(C)] pub struct RegisterBlock { #[doc = "0x00 - Control A"] pub ctrla: CTRLA, #[doc = "0x01 - Control B"] pub ctrlb: CTRLB, #[doc = "0x02 - Event Control"] pub evctrl: EVCTRL, #[doc = "0x04 - Interrupt Enable Clear"] pub intenclr: INTENCLR, #[doc = "0x05 - Interrupt Enable Set"] pub intenset: INTENSET, #[doc = "0x06 - Interrupt Flag Status and Clear"] pub intflag: INTFLAG, #[doc = "0x07 - Status A"] pub statusa: STATUSA, #[doc = "0x08 - Status B"] pub statusb: STATUSB, #[doc = "0x09 - Debug Control"] pub dbgctrl: DBGCTRL, #[doc = "0x0a - Window Control"] pub winctrl: WINCTRL, _reserved10: [u8; 1usize], #[doc = "0x0c - Scaler n"] pub scaler: [SCALER; 2], _reserved11: [u8; 2usize], #[doc = "0x10 - Comparator Control n"] pub compctrl: [COMPCTRL; 2], _reserved12: [u8; 8usize], #[doc = "0x20 - Synchronization Busy"] pub syncbusy: SYNCBUSY, #[doc = "0x24 - Calibration"] pub calib: CALIB, } #[doc = "Control A"] pub struct CTRLA { register: ::vcell::VolatileCell<u8>, } #[doc = "Control A"] pub mod ctrla; #[doc = "Control B"] pub struct CTRLB { register: ::vcell::VolatileCell<u8>, } #[doc = "Control B"] pub mod ctrlb; #[doc = "Event Control"] pub struct EVCTRL { register: ::vcell::VolatileCell<u16>, } #[doc = "Event Control"] pub mod evctrl; #[doc = "Interrupt Enable Clear"] pub struct INTENCLR { register: ::vcell::VolatileCell<u8>, } #[doc = "Interrupt Enable Clear"] pub mod intenclr; #[doc = "Interrupt Enable Set"] pub struct INTENSET { register: ::vcell::VolatileCell<u8>, } #[doc = "Interrupt Enable Set"] pub mod intenset; #[doc = "Interrupt Flag Status and Clear"] pub struct INTFLAG { register: ::vcell::VolatileCell<u8>, } #[doc = "Interrupt Flag Status and Clear"] pub mod intflag; #[doc = "Status A"] pub struct STATUSA { register: ::vcell::VolatileCell<u8>, } #[doc = "Status A"] pub mod statusa; #[doc = "Status B"] pub struct STATUSB { register: ::vcell::VolatileCell<u8>, } #[doc = "Status B"] pub mod statusb; #[doc = "Debug Control"] pub struct DBGCTRL { register: ::vcell::VolatileCell<u8>, } #[doc = "Debug Control"] pub mod dbgctrl; #[doc = "Window Control"] pub struct WINCTRL { register: ::vcell::VolatileCell<u8>, } #[doc = "Window Control"] pub mod winctrl; #[doc = "Scaler n"] pub struct SCALER { register: ::vcell::VolatileCell<u8>, } #[doc = "Scaler n"] pub mod scaler; #[doc = "Comparator Control n"] pub struct COMPCTRL { register: ::vcell::VolatileCell<u32>, } #[doc = "Comparator Control n"] pub mod compctrl; #[doc = "Synchronization Busy"] pub struct SYNCBUSY { register: ::vcell::VolatileCell<u32>, } #[doc = "Synchronization Busy"] pub mod syncbusy; #[doc = "Calibration"] pub struct CALIB { register: ::vcell::VolatileCell<u16>, } #[doc = "Calibration"] pub mod calib;