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
#![doc = "Peripheral access API for FE310 microcontrollers (generated using svd2rust v0.16.1)\n\nYou can find an overview of the API [here].\n\n[here]: https://docs.rs/svd2rust/0.16.1/svd2rust/#peripheral-api"]
#![deny(missing_docs)]
#![deny(warnings)]
#![allow(non_camel_case_types)]
#![no_std]
extern crate bare_metal;
extern crate riscv;
#[cfg(feature = "rt")]
extern crate riscv_rt;
extern crate vcell;
#[doc(hidden)]
pub mod interrupt;
pub use self::interrupt::Interrupt;
#[allow(unused_imports)]
use generic::*;
#[doc = r"Common register and bit access and modify traits"]
pub mod generic;
#[allow(unused)]
mod common;
pub use common::{
aonclk, backup, clint, gpio0, otp, plic, pmu, prci, pwm0, qspi0, rtc, uart0, wdog, AONCLK,
BACKUP, CLINT, GPIO0, OTP, PLIC, PMU, PRCI, PWM0, PWM1, PWM2, QSPI0, QSPI1, QSPI2, RTC, UART0,
UART1, WDOG,
};
#[cfg(feature = "g002")]
pub use common::{i2c0, I2C0};
#[allow(non_snake_case)]
pub struct Peripherals {
#[doc = "CLINT"]
pub CLINT: CLINT,
#[doc = "PLIC"]
pub PLIC: PLIC,
#[doc = "WDOG"]
pub WDOG: WDOG,
#[doc = "RTC"]
pub RTC: RTC,
#[doc = "AONCLK"]
pub AONCLK: AONCLK,
#[doc = "BACKUP"]
pub BACKUP: BACKUP,
#[doc = "PMU"]
pub PMU: PMU,
#[doc = "PRCI"]
pub PRCI: PRCI,
#[doc = "OTP"]
pub OTP: OTP,
#[doc = "GPIO0"]
pub GPIO0: GPIO0,
#[doc = "UART0"]
pub UART0: UART0,
#[doc = "QSPI0"]
pub QSPI0: QSPI0,
#[doc = "PWM0"]
pub PWM0: PWM0,
#[doc = "UART1"]
pub UART1: UART1,
#[doc = "QSPI1"]
pub QSPI1: QSPI1,
#[doc = "PWM1"]
pub PWM1: PWM1,
#[doc = "QSPI2"]
pub QSPI2: QSPI2,
#[doc = "PWM2"]
pub PWM2: PWM2,
#[cfg(feature = "g002")]
#[doc = "I2C0"]
pub I2C0: I2C0,
}
impl Peripherals {
#[inline]
fn from_common(peripherals: common::Peripherals) -> Self {
Self {
CLINT: peripherals.CLINT,
PLIC: peripherals.PLIC,
WDOG: peripherals.WDOG,
RTC: peripherals.RTC,
AONCLK: peripherals.AONCLK,
BACKUP: peripherals.BACKUP,
PMU: peripherals.PMU,
PRCI: peripherals.PRCI,
OTP: peripherals.OTP,
GPIO0: peripherals.GPIO0,
UART0: peripherals.UART0,
QSPI0: peripherals.QSPI0,
PWM0: peripherals.PWM0,
UART1: peripherals.UART1,
QSPI1: peripherals.QSPI1,
PWM1: peripherals.PWM1,
QSPI2: peripherals.QSPI2,
PWM2: peripherals.PWM2,
#[cfg(feature = "g002")]
I2C0: peripherals.I2C0,
}
}
#[inline]
pub fn take() -> Option<Self> {
common::Peripherals::take().map(Self::from_common)
}
pub unsafe fn steal() -> Self {
Self::from_common(common::Peripherals::steal())
}
}