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
#[doc = r" Register block"]
#[repr(C)]
pub struct RegisterBlock {
    #[doc = "0x00 - Timer Interrupt Flag Register"]
    pub tifr: TIFR,
    _reserved0: [u8; 56usize],
    #[doc = "0x39 - Timer Interrupt Mask Register"]
    pub timsk: TIMSK,
    _reserved1: [u8; 75usize],
    #[doc = "0x85 - Timer/Counter Register"]
    pub tcnt: TCNT,
    #[doc = "0x86 - Timer/Counter High Byte"]
    pub tch: TCH,
    #[doc = "0x87 - Timer/Counter Control Register A"]
    pub tccr_a: TCCR_A,
    #[doc = "0x88 - Timer/Counter Control Register B"]
    pub tccr_b: TCCR_B,
    #[doc = "0x89 - Timer/Counter Control Register C"]
    pub tccr_c: TCCR_C,
    #[doc = "0x8a - Timer/Counter Control Register D"]
    pub tccr_d: TCCR_D,
    #[doc = "0x8b - Timer/Counter Control Register E"]
    pub tccr_e: TCCR_E,
    _reserved2: [u8; 10usize],
    #[doc = "0x96 - Output Compare Register A"]
    pub ocr_a: OCR_A,
    #[doc = "0x97 - Output Compare Register B"]
    pub ocr_b: OCR_B,
    #[doc = "0x98 - Output Compare Register B"]
    pub ocr_c: OCR_C,
    #[doc = "0x99 - Output Compare Register B"]
    pub ocr_d: OCR_D,
    _reserved3: [u8; 1usize],
    #[doc = "0x9b - Dead Time Value"]
    pub dt: DT,
}
#[doc = "Timer Interrupt Flag Register"]
pub struct TIFR {
    register: ::vcell::VolatileCell<u8>,
}
#[doc = "Timer Interrupt Flag Register"]
pub mod tifr;
#[doc = "Timer Interrupt Mask Register"]
pub struct TIMSK {
    register: ::vcell::VolatileCell<u8>,
}
#[doc = "Timer Interrupt Mask Register"]
pub mod timsk;
#[doc = "Timer/Counter Register"]
pub struct TCNT {
    register: ::vcell::VolatileCell<u8>,
}
#[doc = "Timer/Counter Register"]
pub mod tcnt;
#[doc = "Timer/Counter High Byte"]
pub struct TCH {
    register: ::vcell::VolatileCell<u8>,
}
#[doc = "Timer/Counter High Byte"]
pub mod tch;
#[doc = "Timer/Counter Control Register A"]
pub struct TCCR_A {
    register: ::vcell::VolatileCell<u8>,
}
#[doc = "Timer/Counter Control Register A"]
pub mod tccr_a;
#[doc = "Timer/Counter Control Register B"]
pub struct TCCR_B {
    register: ::vcell::VolatileCell<u8>,
}
#[doc = "Timer/Counter Control Register B"]
pub mod tccr_b;
#[doc = "Timer/Counter Control Register C"]
pub struct TCCR_C {
    register: ::vcell::VolatileCell<u8>,
}
#[doc = "Timer/Counter Control Register C"]
pub mod tccr_c;
#[doc = "Timer/Counter Control Register D"]
pub struct TCCR_D {
    register: ::vcell::VolatileCell<u8>,
}
#[doc = "Timer/Counter Control Register D"]
pub mod tccr_d;
#[doc = "Timer/Counter Control Register E"]
pub struct TCCR_E {
    register: ::vcell::VolatileCell<u8>,
}
#[doc = "Timer/Counter Control Register E"]
pub mod tccr_e;
#[doc = "Output Compare Register A"]
pub struct OCR_A {
    register: ::vcell::VolatileCell<u8>,
}
#[doc = "Output Compare Register A"]
pub mod ocr_a;
#[doc = "Output Compare Register B"]
pub struct OCR_B {
    register: ::vcell::VolatileCell<u8>,
}
#[doc = "Output Compare Register B"]
pub mod ocr_b;
#[doc = "Output Compare Register B"]
pub struct OCR_C {
    register: ::vcell::VolatileCell<u8>,
}
#[doc = "Output Compare Register B"]
pub mod ocr_c;
#[doc = "Output Compare Register B"]
pub struct OCR_D {
    register: ::vcell::VolatileCell<u8>,
}
#[doc = "Output Compare Register B"]
pub mod ocr_d;
#[doc = "Dead Time Value"]
pub struct DT {
    register: ::vcell::VolatileCell<u8>,
}
#[doc = "Dead Time Value"]
pub mod dt;