pub struct BitSync { /* private fields */ }
Expand description

Bit synchronization.

This must be cleared to 0x00 (the reset value) when using packet types other than LoRa.

Argument of set_bit_sync.

Implementations§

source§

impl BitSync

source

pub const RESET: BitSync = _

Bit synchronization register reset value.

source

pub const fn from_raw(raw: u8) -> Self

Create a new BitSync structure from a raw value.

Reserved bits will be masked.

source

pub const fn as_bits(&self) -> u8

Get the raw value of the BitSync register.

source

pub const fn set_simple_bit_sync_en(self, en: bool) -> BitSync

LoRa simple bit synchronization enable.

Example

Enable simple bit synchronization.

use stm32wlxx_hal::subghz::BitSync;

const BIT_SYNC: BitSync = BitSync::RESET.set_simple_bit_sync_en(true);
source

pub const fn simple_bit_sync_en(&self) -> bool

Returns true if simple bit synchronization is enabled.

Example
use stm32wlxx_hal::subghz::BitSync;

let bs: BitSync = BitSync::RESET;
assert_eq!(bs.simple_bit_sync_en(), false);
let bs: BitSync = bs.set_simple_bit_sync_en(true);
assert_eq!(bs.simple_bit_sync_en(), true);
let bs: BitSync = bs.set_simple_bit_sync_en(false);
assert_eq!(bs.simple_bit_sync_en(), false);
source

pub const fn set_rx_data_inv(self, inv: bool) -> BitSync

LoRa RX data inversion.

Example

Invert receive data.

use stm32wlxx_hal::subghz::BitSync;

const BIT_SYNC: BitSync = BitSync::RESET.set_rx_data_inv(true);
source

pub const fn rx_data_inv(&self) -> bool

Returns true if LoRa RX data is inverted.

Example
use stm32wlxx_hal::subghz::BitSync;

let bs: BitSync = BitSync::RESET;
assert_eq!(bs.rx_data_inv(), false);
let bs: BitSync = bs.set_rx_data_inv(true);
assert_eq!(bs.rx_data_inv(), true);
let bs: BitSync = bs.set_rx_data_inv(false);
assert_eq!(bs.rx_data_inv(), false);
source

pub const fn set_norm_bit_sync_en(self, en: bool) -> BitSync

LoRa normal bit synchronization enable.

Example

Enable normal bit synchronization.

use stm32wlxx_hal::subghz::BitSync;

const BIT_SYNC: BitSync = BitSync::RESET.set_norm_bit_sync_en(true);
source

pub const fn norm_bit_sync_en(&self) -> bool

Returns true if normal bit synchronization is enabled.

Example
use stm32wlxx_hal::subghz::BitSync;

let bs: BitSync = BitSync::RESET;
assert_eq!(bs.norm_bit_sync_en(), false);
let bs: BitSync = bs.set_norm_bit_sync_en(true);
assert_eq!(bs.norm_bit_sync_en(), true);
let bs: BitSync = bs.set_norm_bit_sync_en(false);
assert_eq!(bs.norm_bit_sync_en(), false);

Trait Implementations§

source§

impl Clone for BitSync

source§

fn clone(&self) -> BitSync

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for BitSync

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for BitSync

source§

fn default() -> Self

Returns the “default value” for a type. Read more
source§

impl From<BitSync> for u8

source§

fn from(bs: BitSync) -> Self

Converts to this type from the input type.
source§

impl PartialEq for BitSync

source§

fn eq(&self, other: &BitSync) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl Copy for BitSync

source§

impl Eq for BitSync

source§

impl StructuralEq for BitSync

source§

impl StructuralPartialEq for BitSync

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.