Skip to content

Commit

Permalink
rcc: access to Enable and Reset for owner only
Browse files Browse the repository at this point in the history
  • Loading branch information
AndreySmirnov81 committed Mar 14, 2022
1 parent 78dcf34 commit 678d25d
Show file tree
Hide file tree
Showing 13 changed files with 37 additions and 43 deletions.
6 changes: 3 additions & 3 deletions src/adc.rs
Original file line number Diff line number Diff line change
Expand Up @@ -271,15 +271,15 @@ macro_rules! adc_hal {
}

fn reset(&mut self) {
<$ADC>::reset();
self.rb.reset();
}

fn enable_clock(&mut self) {
<$ADC>::enable();
self.rb.enable();
}

fn disable_clock(&mut self) {
<$ADC>::disable();
self.rb.disable();
}

fn calibrate(&mut self) {
Expand Down
4 changes: 2 additions & 2 deletions src/afio.rs
Original file line number Diff line number Diff line change
Expand Up @@ -13,8 +13,8 @@ pub trait AfioExt {

impl AfioExt for AFIO {
fn constrain(self) -> Parts {
AFIO::enable();
AFIO::reset();
self.enable();
self.reset();

Parts {
evcr: EVCR { _0: () },
Expand Down
5 changes: 2 additions & 3 deletions src/can.rs
Original file line number Diff line number Diff line change
Expand Up @@ -95,16 +95,15 @@ where
/// prevent accidental shared usage.
#[cfg(not(feature = "connectivity"))]
pub fn new(can: Instance, _usb: pac::USB) -> Can<Instance> {
Instance::enable();
can.enable();

Can { _peripheral: can }
}

/// Creates a CAN interaface.
#[cfg(feature = "connectivity")]
pub fn new(can: Instance) -> Can<Instance> {
let rcc = unsafe { &(*RCC::ptr()) };
Instance::enable(rcc);
can.enable();

Can { _peripheral: can }
}
Expand Down
2 changes: 1 addition & 1 deletion src/crc.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ pub trait CrcExt {

impl CrcExt for CRC {
fn new(self) -> Crc {
CRC::enable();
self.enable();

Crc { crc: self }
}
Expand Down
2 changes: 1 addition & 1 deletion src/dma.rs
Original file line number Diff line number Diff line change
Expand Up @@ -447,7 +447,7 @@ macro_rules! dma {
type Channels = Channels;

fn split(self) -> Channels {
$DMAX::enable();
self.enable();

// reset the DMA control registers (stops all on-going transfers)
$(
Expand Down
4 changes: 2 additions & 2 deletions src/gpio.rs
Original file line number Diff line number Diff line change
Expand Up @@ -366,8 +366,8 @@ macro_rules! gpio {
type Parts = Parts;

fn split(self) -> Parts {
$GPIOX::enable();
$GPIOX::reset();
self.enable();
self.reset();

Parts {
crl: Cr::<$port_id, false>(()),
Expand Down
4 changes: 2 additions & 2 deletions src/i2c.rs
Original file line number Diff line number Diff line change
Expand Up @@ -166,8 +166,8 @@ where
/// Configures the I2C peripheral to work in master mode
fn configure<M: Into<Mode>>(i2c: I2C, pins: PINS, mode: M, clocks: Clocks) -> Self {
let mode = mode.into();
I2C::enable();
I2C::reset();
i2c.enable();
i2c.reset();

let pclk1 = I2C::clock(&clocks);

Expand Down
17 changes: 5 additions & 12 deletions src/rcc.rs
Original file line number Diff line number Diff line change
Expand Up @@ -73,13 +73,6 @@ impl APB1 {
}
}

impl APB1 {
/// Set power interface clock (PWREN) bit in RCC_APB1ENR
pub fn set_pwren() {
PWR::enable();
}
}

/// Advanced Peripheral Bus 2 (APB2) registers
pub struct APB2 {
_0: (),
Expand Down Expand Up @@ -308,8 +301,8 @@ impl BKP {
/// Enables write access to the registers in the backup domain
pub fn constrain(self, bkp: crate::pac::BKP, pwr: &mut PWR) -> BackupDomain {
// Enable the backup interface by setting PWREN and BKPEN
crate::pac::BKP::enable();
crate::pac::PWR::enable();
bkp.enable();
pwr.enable();

// Enable access to the backup registers
pwr.cr.modify(|_r, w| w.dbp().set_bit());
Expand Down Expand Up @@ -468,12 +461,12 @@ pub trait RccBus: crate::Sealed {

/// Enable/disable peripheral
pub trait Enable: RccBus {
fn enable();
fn disable();
fn enable(&self);
fn disable(&self);
}
/// Reset peripheral
pub trait Reset: RccBus {
fn reset();
fn reset(&self);
}

#[derive(Clone, Copy, Debug, PartialEq)]
Expand Down
10 changes: 5 additions & 5 deletions src/rcc/enable.rs
Original file line number Diff line number Diff line change
Expand Up @@ -11,14 +11,14 @@ macro_rules! bus {
}
impl Enable for crate::pac::$PER {
#[inline(always)]
fn enable() {
fn enable(&self) {
let rcc = unsafe { &(*RCC::ptr()) };
unsafe {
bb::set(Self::Bus::enr(rcc), $bit);
}
}
#[inline(always)]
fn disable() {
fn disable(&self) {
let rcc = unsafe { &(*RCC::ptr()) };
unsafe {
bb::clear(Self::Bus::enr(rcc), $bit);
Expand All @@ -27,7 +27,7 @@ macro_rules! bus {
}
impl Reset for crate::pac::$PER {
#[inline(always)]
fn reset() {
fn reset(&self) {
let rcc = unsafe { &(*RCC::ptr()) };
unsafe {
bb::set(Self::Bus::rstr(rcc), $bit);
Expand All @@ -49,14 +49,14 @@ macro_rules! ahb_bus {
}
impl Enable for crate::pac::$PER {
#[inline(always)]
fn enable() {
fn enable(&self) {
let rcc = unsafe { &(*RCC::ptr()) };
unsafe {
bb::set(Self::Bus::enr(rcc), $bit);
}
}
#[inline(always)]
fn disable() {
fn disable(&self) {
let rcc = unsafe { &(*RCC::ptr()) };
unsafe {
bb::clear(Self::Bus::enr(rcc), $bit);
Expand Down
4 changes: 2 additions & 2 deletions src/serial.rs
Original file line number Diff line number Diff line change
Expand Up @@ -292,8 +292,8 @@ impl<USART: Instance, PINS> Serial<USART, PINS> {
PINS: Pins<USART>,
{
// Enable and reset USART
USART::enable();
USART::reset();
usart.enable();
usart.reset();

PINS::remap(mapr);

Expand Down
8 changes: 4 additions & 4 deletions src/spi.rs
Original file line number Diff line number Diff line change
Expand Up @@ -468,8 +468,8 @@ where
{
fn configure(spi: SPI, pins: PINS, mode: Mode, freq: Hertz, clocks: Clocks) -> Self {
// enable or reset SPI
SPI::enable();
SPI::reset();
spi.enable();
spi.reset();

// disable SS output
spi.cr2.write(|w| w.ssoe().clear_bit());
Expand Down Expand Up @@ -539,8 +539,8 @@ where
{
fn configure(spi: SPI, pins: PINS, mode: Mode) -> Self {
// enable or reset SPI
SPI::enable();
SPI::reset();
spi.enable();
spi.reset();

// disable SS output
spi.cr2.write(|w| w.ssoe().clear_bit());
Expand Down
8 changes: 4 additions & 4 deletions src/timer.rs
Original file line number Diff line number Diff line change
Expand Up @@ -637,8 +637,8 @@ impl<TIM: Instance> Timer<TIM> {
/// Initialize timer
pub fn new(tim: TIM, clocks: &Clocks) -> Self {
// Enable and reset the timer peripheral
TIM::enable();
TIM::reset();
tim.enable();
tim.reset();

Self {
clk: TIM::timer_clock(clocks),
Expand Down Expand Up @@ -710,8 +710,8 @@ impl<TIM: Instance, const FREQ: u32> FTimer<TIM, FREQ> {
/// Initialize timer
pub fn new(tim: TIM, clocks: &Clocks) -> Self {
// Enable and reset the timer peripheral
TIM::enable();
TIM::reset();
tim.enable();
tim.reset();

let mut t = Self { tim };
t.configure(clocks);
Expand Down
6 changes: 4 additions & 2 deletions src/usb.rs
Original file line number Diff line number Diff line change
Expand Up @@ -28,10 +28,12 @@ unsafe impl UsbPeripheral for Peripheral {
const EP_MEMORY_ACCESS_2X16: bool = false;

fn enable() {
// TODO: use self.usb, after adding the &self parameter
let usb = unsafe { crate::pac::Peripherals::steal().USB };
// Enable USB peripheral
USB::enable();
usb.enable();
// Reset USB peripheral
USB::reset();
usb.reset();
}

fn startup_delay() {
Expand Down

0 comments on commit 678d25d

Please sign in to comment.