#[allow(unused_imports)]
use crate::{
byte_converter::*, device::*, error::TinkerforgeError, ip_connection::async_io::AsyncIpConnection, low_level_traits::LowLevelRead,
};
#[allow(unused_imports)]
use futures_core::Stream;
#[allow(unused_imports)]
use tokio_stream::StreamExt;
pub enum DcV2BrickletFunction {
SetEnabled,
GetEnabled,
SetVelocity,
GetVelocity,
GetCurrentVelocity,
SetMotion,
GetMotion,
FullBrake,
SetDriveMode,
GetDriveMode,
SetPwmFrequency,
GetPwmFrequency,
GetPowerStatistics,
SetErrorLedConfig,
GetErrorLedConfig,
SetEmergencyShutdownCallbackConfiguration,
GetEmergencyShutdownCallbackConfiguration,
SetVelocityReachedCallbackConfiguration,
GetVelocityReachedCallbackConfiguration,
SetCurrentVelocityCallbackConfiguration,
GetCurrentVelocityCallbackConfiguration,
GetSpitfpErrorCount,
SetBootloaderMode,
GetBootloaderMode,
SetWriteFirmwarePointer,
WriteFirmware,
SetStatusLedConfig,
GetStatusLedConfig,
GetChipTemperature,
Reset,
WriteUid,
ReadUid,
GetIdentity,
CallbackEmergencyShutdown,
CallbackVelocityReached,
CallbackCurrentVelocity,
}
impl From<DcV2BrickletFunction> for u8 {
fn from(fun: DcV2BrickletFunction) -> Self {
match fun {
DcV2BrickletFunction::SetEnabled => 1,
DcV2BrickletFunction::GetEnabled => 2,
DcV2BrickletFunction::SetVelocity => 3,
DcV2BrickletFunction::GetVelocity => 4,
DcV2BrickletFunction::GetCurrentVelocity => 5,
DcV2BrickletFunction::SetMotion => 6,
DcV2BrickletFunction::GetMotion => 7,
DcV2BrickletFunction::FullBrake => 8,
DcV2BrickletFunction::SetDriveMode => 9,
DcV2BrickletFunction::GetDriveMode => 10,
DcV2BrickletFunction::SetPwmFrequency => 11,
DcV2BrickletFunction::GetPwmFrequency => 12,
DcV2BrickletFunction::GetPowerStatistics => 13,
DcV2BrickletFunction::SetErrorLedConfig => 14,
DcV2BrickletFunction::GetErrorLedConfig => 15,
DcV2BrickletFunction::SetEmergencyShutdownCallbackConfiguration => 16,
DcV2BrickletFunction::GetEmergencyShutdownCallbackConfiguration => 17,
DcV2BrickletFunction::SetVelocityReachedCallbackConfiguration => 18,
DcV2BrickletFunction::GetVelocityReachedCallbackConfiguration => 19,
DcV2BrickletFunction::SetCurrentVelocityCallbackConfiguration => 20,
DcV2BrickletFunction::GetCurrentVelocityCallbackConfiguration => 21,
DcV2BrickletFunction::GetSpitfpErrorCount => 234,
DcV2BrickletFunction::SetBootloaderMode => 235,
DcV2BrickletFunction::GetBootloaderMode => 236,
DcV2BrickletFunction::SetWriteFirmwarePointer => 237,
DcV2BrickletFunction::WriteFirmware => 238,
DcV2BrickletFunction::SetStatusLedConfig => 239,
DcV2BrickletFunction::GetStatusLedConfig => 240,
DcV2BrickletFunction::GetChipTemperature => 242,
DcV2BrickletFunction::Reset => 243,
DcV2BrickletFunction::WriteUid => 248,
DcV2BrickletFunction::ReadUid => 249,
DcV2BrickletFunction::GetIdentity => 255,
DcV2BrickletFunction::CallbackEmergencyShutdown => 22,
DcV2BrickletFunction::CallbackVelocityReached => 23,
DcV2BrickletFunction::CallbackCurrentVelocity => 24,
}
}
}
pub const DC_V2_BRICKLET_DRIVE_MODE_DRIVE_BRAKE: u8 = 0;
pub const DC_V2_BRICKLET_DRIVE_MODE_DRIVE_COAST: u8 = 1;
pub const DC_V2_BRICKLET_ERROR_LED_CONFIG_OFF: u8 = 0;
pub const DC_V2_BRICKLET_ERROR_LED_CONFIG_ON: u8 = 1;
pub const DC_V2_BRICKLET_ERROR_LED_CONFIG_SHOW_HEARTBEAT: u8 = 2;
pub const DC_V2_BRICKLET_ERROR_LED_CONFIG_SHOW_ERROR: u8 = 3;
pub const DC_V2_BRICKLET_BOOTLOADER_MODE_BOOTLOADER: u8 = 0;
pub const DC_V2_BRICKLET_BOOTLOADER_MODE_FIRMWARE: u8 = 1;
pub const DC_V2_BRICKLET_BOOTLOADER_MODE_BOOTLOADER_WAIT_FOR_REBOOT: u8 = 2;
pub const DC_V2_BRICKLET_BOOTLOADER_MODE_FIRMWARE_WAIT_FOR_REBOOT: u8 = 3;
pub const DC_V2_BRICKLET_BOOTLOADER_MODE_FIRMWARE_WAIT_FOR_ERASE_AND_REBOOT: u8 = 4;
pub const DC_V2_BRICKLET_BOOTLOADER_STATUS_OK: u8 = 0;
pub const DC_V2_BRICKLET_BOOTLOADER_STATUS_INVALID_MODE: u8 = 1;
pub const DC_V2_BRICKLET_BOOTLOADER_STATUS_NO_CHANGE: u8 = 2;
pub const DC_V2_BRICKLET_BOOTLOADER_STATUS_ENTRY_FUNCTION_NOT_PRESENT: u8 = 3;
pub const DC_V2_BRICKLET_BOOTLOADER_STATUS_DEVICE_IDENTIFIER_INCORRECT: u8 = 4;
pub const DC_V2_BRICKLET_BOOTLOADER_STATUS_CRC_MISMATCH: u8 = 5;
pub const DC_V2_BRICKLET_STATUS_LED_CONFIG_OFF: u8 = 0;
pub const DC_V2_BRICKLET_STATUS_LED_CONFIG_ON: u8 = 1;
pub const DC_V2_BRICKLET_STATUS_LED_CONFIG_SHOW_HEARTBEAT: u8 = 2;
pub const DC_V2_BRICKLET_STATUS_LED_CONFIG_SHOW_STATUS: u8 = 3;
#[derive(Clone, Copy, Debug, Default, PartialEq, Eq, Hash)]
pub struct Motion {
pub acceleration: u16,
pub deceleration: u16,
}
impl FromByteSlice for Motion {
fn bytes_expected() -> usize {
4
}
fn from_le_byte_slice(bytes: &[u8]) -> Motion {
Motion { acceleration: <u16>::from_le_byte_slice(&bytes[0..2]), deceleration: <u16>::from_le_byte_slice(&bytes[2..4]) }
}
}
#[derive(Clone, Copy, Debug, Default, PartialEq, Eq, Hash)]
pub struct PowerStatistics {
pub voltage: u16,
pub current: u16,
}
impl FromByteSlice for PowerStatistics {
fn bytes_expected() -> usize {
4
}
fn from_le_byte_slice(bytes: &[u8]) -> PowerStatistics {
PowerStatistics { voltage: <u16>::from_le_byte_slice(&bytes[0..2]), current: <u16>::from_le_byte_slice(&bytes[2..4]) }
}
}
#[derive(Clone, Copy, Debug, Default, PartialEq, Eq, Hash)]
pub struct CurrentVelocityCallbackConfiguration {
pub period: u32,
pub value_has_to_change: bool,
}
impl FromByteSlice for CurrentVelocityCallbackConfiguration {
fn bytes_expected() -> usize {
5
}
fn from_le_byte_slice(bytes: &[u8]) -> CurrentVelocityCallbackConfiguration {
CurrentVelocityCallbackConfiguration {
period: <u32>::from_le_byte_slice(&bytes[0..4]),
value_has_to_change: <bool>::from_le_byte_slice(&bytes[4..5]),
}
}
}
#[derive(Clone, Copy, Debug, Default, PartialEq, Eq, Hash)]
pub struct SpitfpErrorCount {
pub error_count_ack_checksum: u32,
pub error_count_message_checksum: u32,
pub error_count_frame: u32,
pub error_count_overflow: u32,
}
impl FromByteSlice for SpitfpErrorCount {
fn bytes_expected() -> usize {
16
}
fn from_le_byte_slice(bytes: &[u8]) -> SpitfpErrorCount {
SpitfpErrorCount {
error_count_ack_checksum: <u32>::from_le_byte_slice(&bytes[0..4]),
error_count_message_checksum: <u32>::from_le_byte_slice(&bytes[4..8]),
error_count_frame: <u32>::from_le_byte_slice(&bytes[8..12]),
error_count_overflow: <u32>::from_le_byte_slice(&bytes[12..16]),
}
}
}
#[derive(Clone, Debug, Default, PartialEq, Eq, Hash)]
pub struct Identity {
pub uid: String,
pub connected_uid: String,
pub position: char,
pub hardware_version: [u8; 3],
pub firmware_version: [u8; 3],
pub device_identifier: u16,
}
impl FromByteSlice for Identity {
fn bytes_expected() -> usize {
25
}
fn from_le_byte_slice(bytes: &[u8]) -> Identity {
Identity {
uid: <String>::from_le_byte_slice(&bytes[0..8]),
connected_uid: <String>::from_le_byte_slice(&bytes[8..16]),
position: <char>::from_le_byte_slice(&bytes[16..17]),
hardware_version: <[u8; 3]>::from_le_byte_slice(&bytes[17..20]),
firmware_version: <[u8; 3]>::from_le_byte_slice(&bytes[20..23]),
device_identifier: <u16>::from_le_byte_slice(&bytes[23..25]),
}
}
}
#[derive(Clone)]
pub struct DcV2Bricklet {
device: Device,
}
impl DcV2Bricklet {
pub const DEVICE_IDENTIFIER: u16 = 2165;
pub const DEVICE_DISPLAY_NAME: &'static str = "DC Bricklet 2.0";
pub fn new(uid: &str, connection: AsyncIpConnection) -> DcV2Bricklet {
let mut result = DcV2Bricklet { device: Device::new([2, 0, 10], uid, connection, Self::DEVICE_DISPLAY_NAME) };
result.device.response_expected[u8::from(DcV2BrickletFunction::SetEnabled) as usize] = ResponseExpectedFlag::False;
result.device.response_expected[u8::from(DcV2BrickletFunction::GetEnabled) as usize] = ResponseExpectedFlag::AlwaysTrue;
result.device.response_expected[u8::from(DcV2BrickletFunction::SetVelocity) as usize] = ResponseExpectedFlag::False;
result.device.response_expected[u8::from(DcV2BrickletFunction::GetVelocity) as usize] = ResponseExpectedFlag::AlwaysTrue;
result.device.response_expected[u8::from(DcV2BrickletFunction::GetCurrentVelocity) as usize] = ResponseExpectedFlag::AlwaysTrue;
result.device.response_expected[u8::from(DcV2BrickletFunction::SetMotion) as usize] = ResponseExpectedFlag::False;
result.device.response_expected[u8::from(DcV2BrickletFunction::GetMotion) as usize] = ResponseExpectedFlag::AlwaysTrue;
result.device.response_expected[u8::from(DcV2BrickletFunction::FullBrake) as usize] = ResponseExpectedFlag::False;
result.device.response_expected[u8::from(DcV2BrickletFunction::SetDriveMode) as usize] = ResponseExpectedFlag::False;
result.device.response_expected[u8::from(DcV2BrickletFunction::GetDriveMode) as usize] = ResponseExpectedFlag::AlwaysTrue;
result.device.response_expected[u8::from(DcV2BrickletFunction::SetPwmFrequency) as usize] = ResponseExpectedFlag::False;
result.device.response_expected[u8::from(DcV2BrickletFunction::GetPwmFrequency) as usize] = ResponseExpectedFlag::AlwaysTrue;
result.device.response_expected[u8::from(DcV2BrickletFunction::GetPowerStatistics) as usize] = ResponseExpectedFlag::AlwaysTrue;
result.device.response_expected[u8::from(DcV2BrickletFunction::SetErrorLedConfig) as usize] = ResponseExpectedFlag::False;
result.device.response_expected[u8::from(DcV2BrickletFunction::GetErrorLedConfig) as usize] = ResponseExpectedFlag::AlwaysTrue;
result.device.response_expected[u8::from(DcV2BrickletFunction::SetEmergencyShutdownCallbackConfiguration) as usize] =
ResponseExpectedFlag::True;
result.device.response_expected[u8::from(DcV2BrickletFunction::GetEmergencyShutdownCallbackConfiguration) as usize] =
ResponseExpectedFlag::AlwaysTrue;
result.device.response_expected[u8::from(DcV2BrickletFunction::SetVelocityReachedCallbackConfiguration) as usize] =
ResponseExpectedFlag::True;
result.device.response_expected[u8::from(DcV2BrickletFunction::GetVelocityReachedCallbackConfiguration) as usize] =
ResponseExpectedFlag::AlwaysTrue;
result.device.response_expected[u8::from(DcV2BrickletFunction::SetCurrentVelocityCallbackConfiguration) as usize] =
ResponseExpectedFlag::True;
result.device.response_expected[u8::from(DcV2BrickletFunction::GetCurrentVelocityCallbackConfiguration) as usize] =
ResponseExpectedFlag::AlwaysTrue;
result.device.response_expected[u8::from(DcV2BrickletFunction::GetSpitfpErrorCount) as usize] = ResponseExpectedFlag::AlwaysTrue;
result.device.response_expected[u8::from(DcV2BrickletFunction::SetBootloaderMode) as usize] = ResponseExpectedFlag::AlwaysTrue;
result.device.response_expected[u8::from(DcV2BrickletFunction::GetBootloaderMode) as usize] = ResponseExpectedFlag::AlwaysTrue;
result.device.response_expected[u8::from(DcV2BrickletFunction::SetWriteFirmwarePointer) as usize] = ResponseExpectedFlag::False;
result.device.response_expected[u8::from(DcV2BrickletFunction::WriteFirmware) as usize] = ResponseExpectedFlag::AlwaysTrue;
result.device.response_expected[u8::from(DcV2BrickletFunction::SetStatusLedConfig) as usize] = ResponseExpectedFlag::False;
result.device.response_expected[u8::from(DcV2BrickletFunction::GetStatusLedConfig) as usize] = ResponseExpectedFlag::AlwaysTrue;
result.device.response_expected[u8::from(DcV2BrickletFunction::GetChipTemperature) as usize] = ResponseExpectedFlag::AlwaysTrue;
result.device.response_expected[u8::from(DcV2BrickletFunction::Reset) as usize] = ResponseExpectedFlag::False;
result.device.response_expected[u8::from(DcV2BrickletFunction::WriteUid) as usize] = ResponseExpectedFlag::False;
result.device.response_expected[u8::from(DcV2BrickletFunction::ReadUid) as usize] = ResponseExpectedFlag::AlwaysTrue;
result.device.response_expected[u8::from(DcV2BrickletFunction::GetIdentity) as usize] = ResponseExpectedFlag::AlwaysTrue;
result
}
pub fn get_response_expected(&mut self, fun: DcV2BrickletFunction) -> Result<bool, GetResponseExpectedError> {
self.device.get_response_expected(u8::from(fun))
}
pub fn set_response_expected(&mut self, fun: DcV2BrickletFunction, response_expected: bool) -> Result<(), SetResponseExpectedError> {
self.device.set_response_expected(u8::from(fun), response_expected)
}
pub fn set_response_expected_all(&mut self, response_expected: bool) {
self.device.set_response_expected_all(response_expected)
}
pub fn get_api_version(&self) -> [u8; 3] {
self.device.api_version
}
pub async fn get_emergency_shutdown_callback_receiver(&mut self) -> impl Stream<Item = ()> {
self.device.get_callback_receiver(u8::from(DcV2BrickletFunction::CallbackEmergencyShutdown)).await.map(|_p| ())
}
pub async fn get_velocity_reached_callback_receiver(&mut self) -> impl Stream<Item = i16> {
self.device
.get_callback_receiver(u8::from(DcV2BrickletFunction::CallbackVelocityReached))
.await
.map(|p| i16::from_le_byte_slice(p.body()))
}
pub async fn get_current_velocity_callback_receiver(&mut self) -> impl Stream<Item = i16> {
self.device
.get_callback_receiver(u8::from(DcV2BrickletFunction::CallbackCurrentVelocity))
.await
.map(|p| i16::from_le_byte_slice(p.body()))
}
pub async fn set_enabled(&mut self, enabled: bool) -> Result<(), TinkerforgeError> {
let mut payload = [0; 1];
enabled.write_to_slice(&mut payload[0..1]);
#[allow(unused_variables)]
let result = self.device.set(u8::from(DcV2BrickletFunction::SetEnabled), &payload).await?;
Ok(())
}
pub async fn get_enabled(&mut self) -> Result<bool, TinkerforgeError> {
let payload = [0; 0];
#[allow(unused_variables)]
let result = self.device.get(u8::from(DcV2BrickletFunction::GetEnabled), &payload).await?;
Ok(bool::from_le_byte_slice(result.body()))
}
pub async fn set_velocity(&mut self, velocity: i16) -> Result<(), TinkerforgeError> {
let mut payload = [0; 2];
velocity.write_to_slice(&mut payload[0..2]);
#[allow(unused_variables)]
let result = self.device.set(u8::from(DcV2BrickletFunction::SetVelocity), &payload).await?;
Ok(())
}
pub async fn get_velocity(&mut self) -> Result<i16, TinkerforgeError> {
let payload = [0; 0];
#[allow(unused_variables)]
let result = self.device.get(u8::from(DcV2BrickletFunction::GetVelocity), &payload).await?;
Ok(i16::from_le_byte_slice(result.body()))
}
pub async fn get_current_velocity(&mut self) -> Result<i16, TinkerforgeError> {
let payload = [0; 0];
#[allow(unused_variables)]
let result = self.device.get(u8::from(DcV2BrickletFunction::GetCurrentVelocity), &payload).await?;
Ok(i16::from_le_byte_slice(result.body()))
}
pub async fn set_motion(&mut self, acceleration: u16, deceleration: u16) -> Result<(), TinkerforgeError> {
let mut payload = [0; 4];
acceleration.write_to_slice(&mut payload[0..2]);
deceleration.write_to_slice(&mut payload[2..4]);
#[allow(unused_variables)]
let result = self.device.set(u8::from(DcV2BrickletFunction::SetMotion), &payload).await?;
Ok(())
}
pub async fn get_motion(&mut self) -> Result<Motion, TinkerforgeError> {
let payload = [0; 0];
#[allow(unused_variables)]
let result = self.device.get(u8::from(DcV2BrickletFunction::GetMotion), &payload).await?;
Ok(Motion::from_le_byte_slice(result.body()))
}
pub async fn full_brake(&mut self) -> Result<(), TinkerforgeError> {
let payload = [0; 0];
#[allow(unused_variables)]
let result = self.device.set(u8::from(DcV2BrickletFunction::FullBrake), &payload).await?;
Ok(())
}
pub async fn set_drive_mode(&mut self, mode: u8) -> Result<(), TinkerforgeError> {
let mut payload = [0; 1];
mode.write_to_slice(&mut payload[0..1]);
#[allow(unused_variables)]
let result = self.device.set(u8::from(DcV2BrickletFunction::SetDriveMode), &payload).await?;
Ok(())
}
pub async fn get_drive_mode(&mut self) -> Result<u8, TinkerforgeError> {
let payload = [0; 0];
#[allow(unused_variables)]
let result = self.device.get(u8::from(DcV2BrickletFunction::GetDriveMode), &payload).await?;
Ok(u8::from_le_byte_slice(result.body()))
}
pub async fn set_pwm_frequency(&mut self, frequency: u16) -> Result<(), TinkerforgeError> {
let mut payload = [0; 2];
frequency.write_to_slice(&mut payload[0..2]);
#[allow(unused_variables)]
let result = self.device.set(u8::from(DcV2BrickletFunction::SetPwmFrequency), &payload).await?;
Ok(())
}
pub async fn get_pwm_frequency(&mut self) -> Result<u16, TinkerforgeError> {
let payload = [0; 0];
#[allow(unused_variables)]
let result = self.device.get(u8::from(DcV2BrickletFunction::GetPwmFrequency), &payload).await?;
Ok(u16::from_le_byte_slice(result.body()))
}
pub async fn get_power_statistics(&mut self) -> Result<PowerStatistics, TinkerforgeError> {
let payload = [0; 0];
#[allow(unused_variables)]
let result = self.device.get(u8::from(DcV2BrickletFunction::GetPowerStatistics), &payload).await?;
Ok(PowerStatistics::from_le_byte_slice(result.body()))
}
pub async fn set_error_led_config(&mut self, config: u8) -> Result<(), TinkerforgeError> {
let mut payload = [0; 1];
config.write_to_slice(&mut payload[0..1]);
#[allow(unused_variables)]
let result = self.device.set(u8::from(DcV2BrickletFunction::SetErrorLedConfig), &payload).await?;
Ok(())
}
pub async fn get_error_led_config(&mut self) -> Result<u8, TinkerforgeError> {
let payload = [0; 0];
#[allow(unused_variables)]
let result = self.device.get(u8::from(DcV2BrickletFunction::GetErrorLedConfig), &payload).await?;
Ok(u8::from_le_byte_slice(result.body()))
}
pub async fn set_emergency_shutdown_callback_configuration(&mut self, enabled: bool) -> Result<(), TinkerforgeError> {
let mut payload = [0; 1];
enabled.write_to_slice(&mut payload[0..1]);
#[allow(unused_variables)]
let result = self.device.set(u8::from(DcV2BrickletFunction::SetEmergencyShutdownCallbackConfiguration), &payload).await?;
Ok(())
}
pub async fn get_emergency_shutdown_callback_configuration(&mut self) -> Result<bool, TinkerforgeError> {
let payload = [0; 0];
#[allow(unused_variables)]
let result = self.device.get(u8::from(DcV2BrickletFunction::GetEmergencyShutdownCallbackConfiguration), &payload).await?;
Ok(bool::from_le_byte_slice(result.body()))
}
pub async fn set_velocity_reached_callback_configuration(&mut self, enabled: bool) -> Result<(), TinkerforgeError> {
let mut payload = [0; 1];
enabled.write_to_slice(&mut payload[0..1]);
#[allow(unused_variables)]
let result = self.device.set(u8::from(DcV2BrickletFunction::SetVelocityReachedCallbackConfiguration), &payload).await?;
Ok(())
}
pub async fn get_velocity_reached_callback_configuration(&mut self) -> Result<bool, TinkerforgeError> {
let payload = [0; 0];
#[allow(unused_variables)]
let result = self.device.get(u8::from(DcV2BrickletFunction::GetVelocityReachedCallbackConfiguration), &payload).await?;
Ok(bool::from_le_byte_slice(result.body()))
}
pub async fn set_current_velocity_callback_configuration(
&mut self,
period: u32,
value_has_to_change: bool,
) -> Result<(), TinkerforgeError> {
let mut payload = [0; 5];
period.write_to_slice(&mut payload[0..4]);
value_has_to_change.write_to_slice(&mut payload[4..5]);
#[allow(unused_variables)]
let result = self.device.set(u8::from(DcV2BrickletFunction::SetCurrentVelocityCallbackConfiguration), &payload).await?;
Ok(())
}
pub async fn get_current_velocity_callback_configuration(&mut self) -> Result<CurrentVelocityCallbackConfiguration, TinkerforgeError> {
let payload = [0; 0];
#[allow(unused_variables)]
let result = self.device.get(u8::from(DcV2BrickletFunction::GetCurrentVelocityCallbackConfiguration), &payload).await?;
Ok(CurrentVelocityCallbackConfiguration::from_le_byte_slice(result.body()))
}
pub async fn get_spitfp_error_count(&mut self) -> Result<SpitfpErrorCount, TinkerforgeError> {
let payload = [0; 0];
#[allow(unused_variables)]
let result = self.device.get(u8::from(DcV2BrickletFunction::GetSpitfpErrorCount), &payload).await?;
Ok(SpitfpErrorCount::from_le_byte_slice(result.body()))
}
pub async fn set_bootloader_mode(&mut self, mode: u8) -> Result<u8, TinkerforgeError> {
let mut payload = [0; 1];
mode.write_to_slice(&mut payload[0..1]);
#[allow(unused_variables)]
let result = self.device.get(u8::from(DcV2BrickletFunction::SetBootloaderMode), &payload).await?;
Ok(u8::from_le_byte_slice(result.body()))
}
pub async fn get_bootloader_mode(&mut self) -> Result<u8, TinkerforgeError> {
let payload = [0; 0];
#[allow(unused_variables)]
let result = self.device.get(u8::from(DcV2BrickletFunction::GetBootloaderMode), &payload).await?;
Ok(u8::from_le_byte_slice(result.body()))
}
pub async fn set_write_firmware_pointer(&mut self, pointer: u32) -> Result<(), TinkerforgeError> {
let mut payload = [0; 4];
pointer.write_to_slice(&mut payload[0..4]);
#[allow(unused_variables)]
let result = self.device.set(u8::from(DcV2BrickletFunction::SetWriteFirmwarePointer), &payload).await?;
Ok(())
}
pub async fn write_firmware(&mut self, data: &[u8; 64]) -> Result<u8, TinkerforgeError> {
let mut payload = [0; 64];
data.write_to_slice(&mut payload[0..64]);
#[allow(unused_variables)]
let result = self.device.get(u8::from(DcV2BrickletFunction::WriteFirmware), &payload).await?;
Ok(u8::from_le_byte_slice(result.body()))
}
pub async fn set_status_led_config(&mut self, config: u8) -> Result<(), TinkerforgeError> {
let mut payload = [0; 1];
config.write_to_slice(&mut payload[0..1]);
#[allow(unused_variables)]
let result = self.device.set(u8::from(DcV2BrickletFunction::SetStatusLedConfig), &payload).await?;
Ok(())
}
pub async fn get_status_led_config(&mut self) -> Result<u8, TinkerforgeError> {
let payload = [0; 0];
#[allow(unused_variables)]
let result = self.device.get(u8::from(DcV2BrickletFunction::GetStatusLedConfig), &payload).await?;
Ok(u8::from_le_byte_slice(result.body()))
}
pub async fn get_chip_temperature(&mut self) -> Result<i16, TinkerforgeError> {
let payload = [0; 0];
#[allow(unused_variables)]
let result = self.device.get(u8::from(DcV2BrickletFunction::GetChipTemperature), &payload).await?;
Ok(i16::from_le_byte_slice(result.body()))
}
pub async fn reset(&mut self) -> Result<(), TinkerforgeError> {
let payload = [0; 0];
#[allow(unused_variables)]
let result = self.device.set(u8::from(DcV2BrickletFunction::Reset), &payload).await?;
Ok(())
}
pub async fn write_uid(&mut self, uid: u32) -> Result<(), TinkerforgeError> {
let mut payload = [0; 4];
uid.write_to_slice(&mut payload[0..4]);
#[allow(unused_variables)]
let result = self.device.set(u8::from(DcV2BrickletFunction::WriteUid), &payload).await?;
Ok(())
}
pub async fn read_uid(&mut self) -> Result<u32, TinkerforgeError> {
let payload = [0; 0];
#[allow(unused_variables)]
let result = self.device.get(u8::from(DcV2BrickletFunction::ReadUid), &payload).await?;
Ok(u32::from_le_byte_slice(result.body()))
}
pub async fn get_identity(&mut self) -> Result<Identity, TinkerforgeError> {
let payload = [0; 0];
#[allow(unused_variables)]
let result = self.device.get(u8::from(DcV2BrickletFunction::GetIdentity), &payload).await?;
Ok(Identity::from_le_byte_slice(result.body()))
}
}