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
120
121
122
123
#[doc = r"Register block"]
#[repr(C)]
pub struct RegisterBlock {
    #[doc = "0x00 - Timer/Counter Interrupt Flag Register"]
    pub tifr2: TIFR2,
    _reserved1: [u8; 11usize],
    #[doc = "0x0c - General Timer Counter Control register"]
    pub gtccr: GTCCR,
    _reserved2: [u8; 44usize],
    #[doc = "0x39 - Timer/Counter Interrupt Mask register"]
    pub timsk2: TIMSK2,
    _reserved3: [u8; 63usize],
    #[doc = "0x79 - Timer/Counter2 Control Register A"]
    pub tccr2a: TCCR2A,
    #[doc = "0x7a - Timer/Counter2 Control Register B"]
    pub tccr2b: TCCR2B,
    #[doc = "0x7b - Timer/Counter2"]
    pub tcnt2: TCNT2,
    #[doc = "0x7c - Timer/Counter2 Output Compare Register A"]
    pub ocr2a: OCR2A,
    #[doc = "0x7d - Timer/Counter2 Output Compare Register B"]
    pub ocr2b: OCR2B,
    _reserved8: [u8; 1usize],
    #[doc = "0x7f - Asynchronous Status Register"]
    pub assr: ASSR,
}
#[doc = "Asynchronous Status Register\n\nThis register you can [`read`](crate::generic::Reg::read), [`reset`](crate::generic::Reg::reset), [`write`](crate::generic::Reg::write), [`write_with_zero`](crate::generic::Reg::write_with_zero), [`modify`](crate::generic::Reg::modify). See [API](https://docs.rs/svd2rust/#read--modify--write-api).\n\nFor information about available fields see [assr](assr) module"]
pub type ASSR = crate::Reg<u8, _ASSR>;
#[allow(missing_docs)]
#[doc(hidden)]
pub struct _ASSR;
#[doc = "`read()` method returns [assr::R](assr::R) reader structure"]
impl crate::Readable for ASSR {}
#[doc = "`write(|w| ..)` method takes [assr::W](assr::W) writer structure"]
impl crate::Writable for ASSR {}
#[doc = "Asynchronous Status Register"]
pub mod assr;
#[doc = "General Timer Counter Control register\n\nThis register you can [`read`](crate::generic::Reg::read), [`reset`](crate::generic::Reg::reset), [`write`](crate::generic::Reg::write), [`write_with_zero`](crate::generic::Reg::write_with_zero), [`modify`](crate::generic::Reg::modify). See [API](https://docs.rs/svd2rust/#read--modify--write-api).\n\nFor information about available fields see [gtccr](gtccr) module"]
pub type GTCCR = crate::Reg<u8, _GTCCR>;
#[allow(missing_docs)]
#[doc(hidden)]
pub struct _GTCCR;
#[doc = "`read()` method returns [gtccr::R](gtccr::R) reader structure"]
impl crate::Readable for GTCCR {}
#[doc = "`write(|w| ..)` method takes [gtccr::W](gtccr::W) writer structure"]
impl crate::Writable for GTCCR {}
#[doc = "General Timer Counter Control register"]
pub mod gtccr;
#[doc = "Timer/Counter2 Output Compare Register A\n\nThis register you can [`read`](crate::generic::Reg::read), [`reset`](crate::generic::Reg::reset), [`write`](crate::generic::Reg::write), [`write_with_zero`](crate::generic::Reg::write_with_zero), [`modify`](crate::generic::Reg::modify). See [API](https://docs.rs/svd2rust/#read--modify--write-api).\n\nFor information about available fields see [ocr2a](ocr2a) module"]
pub type OCR2A = crate::Reg<u8, _OCR2A>;
#[allow(missing_docs)]
#[doc(hidden)]
pub struct _OCR2A;
#[doc = "`read()` method returns [ocr2a::R](ocr2a::R) reader structure"]
impl crate::Readable for OCR2A {}
#[doc = "`write(|w| ..)` method takes [ocr2a::W](ocr2a::W) writer structure"]
impl crate::Writable for OCR2A {}
#[doc = "Timer/Counter2 Output Compare Register A"]
pub mod ocr2a;
#[doc = "Timer/Counter2 Output Compare Register B\n\nThis register you can [`read`](crate::generic::Reg::read), [`reset`](crate::generic::Reg::reset), [`write`](crate::generic::Reg::write), [`write_with_zero`](crate::generic::Reg::write_with_zero), [`modify`](crate::generic::Reg::modify). See [API](https://docs.rs/svd2rust/#read--modify--write-api).\n\nFor information about available fields see [ocr2b](ocr2b) module"]
pub type OCR2B = crate::Reg<u8, _OCR2B>;
#[allow(missing_docs)]
#[doc(hidden)]
pub struct _OCR2B;
#[doc = "`read()` method returns [ocr2b::R](ocr2b::R) reader structure"]
impl crate::Readable for OCR2B {}
#[doc = "`write(|w| ..)` method takes [ocr2b::W](ocr2b::W) writer structure"]
impl crate::Writable for OCR2B {}
#[doc = "Timer/Counter2 Output Compare Register B"]
pub mod ocr2b;
#[doc = "Timer/Counter2 Control Register A\n\nThis register you can [`read`](crate::generic::Reg::read), [`reset`](crate::generic::Reg::reset), [`write`](crate::generic::Reg::write), [`write_with_zero`](crate::generic::Reg::write_with_zero), [`modify`](crate::generic::Reg::modify). See [API](https://docs.rs/svd2rust/#read--modify--write-api).\n\nFor information about available fields see [tccr2a](tccr2a) module"]
pub type TCCR2A = crate::Reg<u8, _TCCR2A>;
#[allow(missing_docs)]
#[doc(hidden)]
pub struct _TCCR2A;
#[doc = "`read()` method returns [tccr2a::R](tccr2a::R) reader structure"]
impl crate::Readable for TCCR2A {}
#[doc = "`write(|w| ..)` method takes [tccr2a::W](tccr2a::W) writer structure"]
impl crate::Writable for TCCR2A {}
#[doc = "Timer/Counter2 Control Register A"]
pub mod tccr2a;
#[doc = "Timer/Counter2 Control Register B\n\nThis register you can [`read`](crate::generic::Reg::read), [`reset`](crate::generic::Reg::reset), [`write`](crate::generic::Reg::write), [`write_with_zero`](crate::generic::Reg::write_with_zero), [`modify`](crate::generic::Reg::modify). See [API](https://docs.rs/svd2rust/#read--modify--write-api).\n\nFor information about available fields see [tccr2b](tccr2b) module"]
pub type TCCR2B = crate::Reg<u8, _TCCR2B>;
#[allow(missing_docs)]
#[doc(hidden)]
pub struct _TCCR2B;
#[doc = "`read()` method returns [tccr2b::R](tccr2b::R) reader structure"]
impl crate::Readable for TCCR2B {}
#[doc = "`write(|w| ..)` method takes [tccr2b::W](tccr2b::W) writer structure"]
impl crate::Writable for TCCR2B {}
#[doc = "Timer/Counter2 Control Register B"]
pub mod tccr2b;
#[doc = "Timer/Counter2\n\nThis register you can [`read`](crate::generic::Reg::read), [`reset`](crate::generic::Reg::reset), [`write`](crate::generic::Reg::write), [`write_with_zero`](crate::generic::Reg::write_with_zero), [`modify`](crate::generic::Reg::modify). See [API](https://docs.rs/svd2rust/#read--modify--write-api).\n\nFor information about available fields see [tcnt2](tcnt2) module"]
pub type TCNT2 = crate::Reg<u8, _TCNT2>;
#[allow(missing_docs)]
#[doc(hidden)]
pub struct _TCNT2;
#[doc = "`read()` method returns [tcnt2::R](tcnt2::R) reader structure"]
impl crate::Readable for TCNT2 {}
#[doc = "`write(|w| ..)` method takes [tcnt2::W](tcnt2::W) writer structure"]
impl crate::Writable for TCNT2 {}
#[doc = "Timer/Counter2"]
pub mod tcnt2;
#[doc = "Timer/Counter Interrupt Flag Register\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 [tifr2](tifr2) module"]
pub type TIFR2 = crate::Reg<u8, _TIFR2>;
#[allow(missing_docs)]
#[doc(hidden)]
pub struct _TIFR2;
#[doc = "`read()` method returns [tifr2::R](tifr2::R) reader structure"]
impl crate::Readable for TIFR2 {}
#[doc = "Timer/Counter Interrupt Flag Register"]
pub mod tifr2;
#[doc = "Timer/Counter Interrupt Mask register\n\nThis register you can [`read`](crate::generic::Reg::read), [`reset`](crate::generic::Reg::reset), [`write`](crate::generic::Reg::write), [`write_with_zero`](crate::generic::Reg::write_with_zero), [`modify`](crate::generic::Reg::modify). See [API](https://docs.rs/svd2rust/#read--modify--write-api).\n\nFor information about available fields see [timsk2](timsk2) module"]
pub type TIMSK2 = crate::Reg<u8, _TIMSK2>;
#[allow(missing_docs)]
#[doc(hidden)]
pub struct _TIMSK2;
#[doc = "`read()` method returns [timsk2::R](timsk2::R) reader structure"]
impl crate::Readable for TIMSK2 {}
#[doc = "`write(|w| ..)` method takes [timsk2::W](timsk2::W) writer structure"]
impl crate::Writable for TIMSK2 {}
#[doc = "Timer/Counter Interrupt Mask register"]
pub mod timsk2;