Cleanup clippy warnings
This commit is contained in:
parent
976763c8f8
commit
379442bea6
2 changed files with 98 additions and 109 deletions
76
src/calc.rs
76
src/calc.rs
|
@ -8,15 +8,15 @@ impl Calc {
|
||||||
// cap temperature
|
// cap temperature
|
||||||
let temp = if temp <= 400 { temp } else { 400 };
|
let temp = if temp <= 400 { temp } else { 400 };
|
||||||
|
|
||||||
let var1 = amb_temp as (i32) * calib.par_gh3 as (i32) / 1000i32 * 256i32;
|
let var1 = amb_temp as i32 * calib.par_gh3 as i32 / 1000i32 * 256i32;
|
||||||
let var2 = (calib.par_gh1 as (i32) + 784i32)
|
let var2 = (calib.par_gh1 as i32 + 784i32)
|
||||||
* (((calib.par_gh2 as (i32) + 154009i32) * temp as (i32) * 5i32 / 100i32 + 3276800i32)
|
* (((calib.par_gh2 as i32 + 154009i32) * temp as i32 * 5i32 / 100i32 + 3276800i32)
|
||||||
/ 10i32);
|
/ 10i32);
|
||||||
let var3 = var1 + var2 / 2i32;
|
let var3 = var1 + var2 / 2i32;
|
||||||
let var4 = var3 / (calib.res_heat_range as (i32) + 4i32);
|
let var4 = var3 / (calib.res_heat_range as i32 + 4i32);
|
||||||
let var5 = 131i32 * calib.res_heat_val as (i32) + 65536i32;
|
let var5 = 131i32 * calib.res_heat_val as i32 + 65536i32;
|
||||||
let heatr_res_x100 = (var4 / var5 - 250i32) * 34i32;
|
let heatr_res_x100 = (var4 / var5 - 250i32) * 34i32;
|
||||||
((heatr_res_x100 + 50i32) / 100i32) as (u8)
|
((heatr_res_x100 + 50i32) / 100i32) as u8
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn calc_heater_dur(duration: Duration) -> u8 {
|
pub fn calc_heater_dur(duration: Duration) -> u8 {
|
||||||
|
@ -26,17 +26,17 @@ impl Calc {
|
||||||
const NANOS_PER_MILLI: u64 = 1_000_000;
|
const NANOS_PER_MILLI: u64 = 1_000_000;
|
||||||
let mut dur = (duration.as_secs() as u64 * MILLIS_PER_SEC)
|
let mut dur = (duration.as_secs() as u64 * MILLIS_PER_SEC)
|
||||||
+ (duration.subsec_nanos() as u64 / NANOS_PER_MILLI);
|
+ (duration.subsec_nanos() as u64 / NANOS_PER_MILLI);
|
||||||
let durval = if dur as (i32) >= 0xfc0i32 {
|
let durval = if dur as i32 >= 0xfc0i32 {
|
||||||
0xffu8 // Max duration
|
0xffu8 // Max duration
|
||||||
} else {
|
} else {
|
||||||
loop {
|
loop {
|
||||||
if !(dur as (i32) > 0x3fi32) {
|
if !(dur as i32 > 0x3fi32) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
dur = (dur as (i32) / 4i32) as (u64);
|
dur = (dur as i32 / 4i32) as u64;
|
||||||
factor = (factor as (i32) + 1i32) as (u8);
|
factor = (factor as i32 + 1i32) as u8;
|
||||||
}
|
}
|
||||||
(dur as (i32) + factor as (i32) * 64i32) as (u8)
|
(dur as i32 + factor as i32 * 64i32) as u8
|
||||||
};
|
};
|
||||||
durval
|
durval
|
||||||
}
|
}
|
||||||
|
@ -51,7 +51,7 @@ impl Calc {
|
||||||
temp_adc: u32,
|
temp_adc: u32,
|
||||||
temp_offset: Option<f32>,
|
temp_offset: Option<f32>,
|
||||||
) -> (i16, i32) {
|
) -> (i16, i32) {
|
||||||
let var1: i64 = (temp_adc as (i64) >> 3) - ((calib.par_t1 as (i64)) << 1);
|
let var1: i64 = (temp_adc as i64 >> 3) - ((calib.par_t1 as i64) << 1);
|
||||||
let var2: i64 = (var1 * (calib.par_t2 as i64)) >> 11;
|
let var2: i64 = (var1 * (calib.par_t2 as i64)) >> 11;
|
||||||
let var3: i64 = ((var1 >> 1) * (var1 >> 1)) >> 12;
|
let var3: i64 = ((var1 >> 1) * (var1 >> 1)) >> 12;
|
||||||
let var3: i64 = (var3 * ((calib.par_t3 as i64) << 4)) >> 14;
|
let var3: i64 = (var3 * ((calib.par_t3 as i64) << 4)) >> 14;
|
||||||
|
@ -72,47 +72,47 @@ impl Calc {
|
||||||
|
|
||||||
pub fn calc_pressure(calib: &CalibData, t_fine: i32, pres_adc: u32) -> u32 {
|
pub fn calc_pressure(calib: &CalibData, t_fine: i32, pres_adc: u32) -> u32 {
|
||||||
let mut var1: i32 = (t_fine >> 1) - 64000;
|
let mut var1: i32 = (t_fine >> 1) - 64000;
|
||||||
let mut var2: i32 = ((var1 >> 2) * (var1 >> 2) >> 11) * calib.par_p6 as (i32) >> 2;
|
let mut var2: i32 = ((var1 >> 2) * (var1 >> 2) >> 11) * calib.par_p6 as i32 >> 2;
|
||||||
var2 = var2 + (var1 * calib.par_p5 as (i32) << 1);
|
var2 = var2 + (var1 * (calib.par_p5 as i32) << 1);
|
||||||
var2 = (var2 >> 2i32) + (calib.par_p4 as (i32) << 16i32);
|
var2 = (var2 >> 2i32) + ((calib.par_p4 as i32) << 16i32);
|
||||||
var1 = (((var1 >> 2i32) * (var1 >> 2i32) >> 13i32) * (calib.par_p3 as (i32) << 5i32)
|
var1 = (((var1 >> 2i32) * (var1 >> 2i32) >> 13i32) * ((calib.par_p3 as i32) << 5i32)
|
||||||
>> 3i32)
|
>> 3i32)
|
||||||
+ (calib.par_p2 as (i32) * var1 >> 1i32);
|
+ (calib.par_p2 as i32 * var1 >> 1i32);
|
||||||
var1 = var1 >> 18i32;
|
var1 = var1 >> 18i32;
|
||||||
var1 = (32768i32 + var1) * calib.par_p1 as (i32) >> 15i32;
|
var1 = (32768i32 + var1) * calib.par_p1 as i32 >> 15i32;
|
||||||
let mut pressure_comp: i32 = 1048576u32.wrapping_sub(pres_adc) as (i32);
|
let mut pressure_comp: i32 = 1048576u32.wrapping_sub(pres_adc) as i32;
|
||||||
pressure_comp = ((pressure_comp - (var2 >> 12i32)) as (u32)).wrapping_mul(3125u32) as (i32);
|
pressure_comp = ((pressure_comp - (var2 >> 12i32)) as u32).wrapping_mul(3125u32) as i32;
|
||||||
if pressure_comp >= 0x40000000i32 {
|
if pressure_comp >= 0x40000000i32 {
|
||||||
pressure_comp = ((pressure_comp as (u32)).wrapping_div(var1 as (u32)) << 1i32) as (i32);
|
pressure_comp = ((pressure_comp as u32).wrapping_div(var1 as u32) << 1i32) as i32;
|
||||||
} else {
|
} else {
|
||||||
pressure_comp = ((pressure_comp << 1i32) as (u32)).wrapping_div(var1 as (u32)) as (i32);
|
pressure_comp = ((pressure_comp << 1i32) as u32).wrapping_div(var1 as u32) as i32;
|
||||||
}
|
}
|
||||||
var1 = calib.par_p9 as (i32) * ((pressure_comp >> 3i32) * (pressure_comp >> 3i32) >> 13i32)
|
var1 = calib.par_p9 as i32 * ((pressure_comp >> 3i32) * (pressure_comp >> 3i32) >> 13i32)
|
||||||
>> 12i32;
|
>> 12i32;
|
||||||
var2 = (pressure_comp >> 2i32) * calib.par_p8 as (i32) >> 13i32;
|
var2 = (pressure_comp >> 2i32) * calib.par_p8 as i32 >> 13i32;
|
||||||
let var3: i32 = (pressure_comp >> 8i32)
|
let var3: i32 = (pressure_comp >> 8i32)
|
||||||
* (pressure_comp >> 8i32)
|
* (pressure_comp >> 8i32)
|
||||||
* (pressure_comp >> 8i32)
|
* (pressure_comp >> 8i32)
|
||||||
* calib.par_p10 as (i32)
|
* calib.par_p10 as i32
|
||||||
>> 17i32;
|
>> 17i32;
|
||||||
pressure_comp =
|
pressure_comp =
|
||||||
pressure_comp + (var1 + var2 + var3 + (calib.par_p7 as (i32) << 7i32) >> 4i32);
|
pressure_comp + (var1 + var2 + var3 + ((calib.par_p7 as i32) << 7i32) >> 4i32);
|
||||||
pressure_comp as (u32)
|
pressure_comp as u32
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn calc_humidity(calib: &CalibData, t_fine: i32, hum_adc: u16) -> u32 {
|
pub fn calc_humidity(calib: &CalibData, t_fine: i32, hum_adc: u16) -> u32 {
|
||||||
let temp_scaled: i32 = t_fine * 5i32 + 128i32 >> 8i32;
|
let temp_scaled: i32 = t_fine * 5i32 + 128i32 >> 8i32;
|
||||||
let var1: i32 = hum_adc as (i32)
|
let var1: i32 = hum_adc as i32
|
||||||
- calib.par_h1 as (i32) * 16i32
|
- calib.par_h1 as i32 * 16i32
|
||||||
- (temp_scaled * calib.par_h3 as (i32) / 100i32 >> 1i32);
|
- (temp_scaled * calib.par_h3 as i32 / 100i32 >> 1i32);
|
||||||
let var2: i32 = calib.par_h2 as (i32)
|
let var2: i32 = calib.par_h2 as i32
|
||||||
* (temp_scaled * calib.par_h4 as (i32) / 100i32
|
* (temp_scaled * calib.par_h4 as i32 / 100i32
|
||||||
+ (temp_scaled * (temp_scaled * calib.par_h5 as (i32) / 100i32) >> 6i32) / 100i32
|
+ (temp_scaled * (temp_scaled * calib.par_h5 as i32 / 100i32) >> 6i32) / 100i32
|
||||||
+ (1i32 << 14i32))
|
+ (1i32 << 14i32))
|
||||||
>> 10i32;
|
>> 10i32;
|
||||||
let var3: i32 = var1 * var2;
|
let var3: i32 = var1 * var2;
|
||||||
let var4: i32 = calib.par_h6 as (i32) << 7i32;
|
let var4: i32 = (calib.par_h6 as i32) << 7i32;
|
||||||
let var4: i32 = var4 + temp_scaled * calib.par_h7 as (i32) / 100i32 >> 4i32;
|
let var4: i32 = var4 + temp_scaled * calib.par_h7 as i32 / 100i32 >> 4i32;
|
||||||
let var5: i32 = (var3 >> 14i32) * (var3 >> 14i32) >> 10i32;
|
let var5: i32 = (var3 >> 14i32) * (var3 >> 14i32) >> 10i32;
|
||||||
let var6: i32 = var4 * var5 >> 1i32;
|
let var6: i32 = var4 * var5 >> 1i32;
|
||||||
let mut calc_hum: i32 = (var3 + var6 >> 10i32) * 1000i32 >> 12i32;
|
let mut calc_hum: i32 = (var3 + var6 >> 10i32) * 1000i32 >> 12i32;
|
||||||
|
@ -121,7 +121,7 @@ impl Calc {
|
||||||
} else if calc_hum < 0i32 {
|
} else if calc_hum < 0i32 {
|
||||||
calc_hum = 0i32;
|
calc_hum = 0i32;
|
||||||
}
|
}
|
||||||
calc_hum as (u32)
|
calc_hum as u32
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn calc_gas_resistance(calib: &CalibData, gas_res_adc: u16, gas_range: u8) -> u32 {
|
pub fn calc_gas_resistance(calib: &CalibData, gas_res_adc: u16, gas_range: u8) -> u32 {
|
||||||
|
@ -163,9 +163,9 @@ impl Calc {
|
||||||
];
|
];
|
||||||
let var1: i64 =
|
let var1: i64 =
|
||||||
(1340 + 5 * calib.range_sw_err as i64) * lookup_table1[gas_range as usize] as i64 >> 16;
|
(1340 + 5 * calib.range_sw_err as i64) * lookup_table1[gas_range as usize] as i64 >> 16;
|
||||||
let var2: u64 = (((gas_res_adc as i64) << 15) - 16777216 + var1) as (u64);
|
let var2: u64 = (((gas_res_adc as i64) << 15) - 16777216 + var1) as u64;
|
||||||
let var3: i64 = lookup_table2[gas_range as usize] as i64 * var1 >> 9;
|
let var3: i64 = lookup_table2[gas_range as usize] as i64 * var1 >> 9;
|
||||||
let calc_gas_res: u32 = ((var3 + ((var2 as i64) >> 1i64)) / var2 as (i64)) as (u32);
|
let calc_gas_res: u32 = ((var3 + ((var2 as i64) >> 1i64)) / var2 as i64) as u32;
|
||||||
calc_gas_res
|
calc_gas_res
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
131
src/lib.rs
131
src/lib.rs
|
@ -496,9 +496,9 @@ where
|
||||||
I2CUtil::read_byte(&mut self.i2c, self.dev_id.addr(), BME680_CONF_ODR_FILT_ADDR)?;
|
I2CUtil::read_byte(&mut self.i2c, self.dev_id.addr(), BME680_CONF_ODR_FILT_ADDR)?;
|
||||||
|
|
||||||
debug!("FILTER_SEL: true");
|
debug!("FILTER_SEL: true");
|
||||||
data = (data as (i32) & !0x1ci32
|
data = (data as i32 & !0x1ci32
|
||||||
| tph_sett.filter.unwrap_or(IIRFilterSize::Size0) as (i32) << 2i32 & 0x1ci32)
|
| (tph_sett.filter.unwrap_or(IIRFilterSize::Size0) as i32) << 2i32 & 0x1ci32)
|
||||||
as (u8);
|
as u8;
|
||||||
reg[element_index] = (BME680_CONF_ODR_FILT_ADDR, data);
|
reg[element_index] = (BME680_CONF_ODR_FILT_ADDR, data);
|
||||||
element_index += 1;
|
element_index += 1;
|
||||||
}
|
}
|
||||||
|
@ -512,7 +512,7 @@ where
|
||||||
self.dev_id.addr(),
|
self.dev_id.addr(),
|
||||||
BME680_CONF_HEAT_CTRL_ADDR,
|
BME680_CONF_HEAT_CTRL_ADDR,
|
||||||
)?;
|
)?;
|
||||||
data = (data as (i32) & !0x8i32 | gas_sett_heatr_ctrl as (i32) & 0x8) as (u8);
|
data = (data as i32 & !0x8i32 | gas_sett_heatr_ctrl as i32 & 0x8) as u8;
|
||||||
reg[element_index] = (BME680_CONF_HEAT_CTRL_ADDR, data);
|
reg[element_index] = (BME680_CONF_HEAT_CTRL_ADDR, data);
|
||||||
element_index += 1;
|
element_index += 1;
|
||||||
}
|
}
|
||||||
|
@ -532,15 +532,13 @@ where
|
||||||
0,
|
0,
|
||||||
5,
|
5,
|
||||||
)?;
|
)?;
|
||||||
data = (data as (i32) & !0xe0i32 | tph_sett_os_temp as (i32) << 5i32 & 0xe0i32)
|
data = (data as i32 & !0xe0i32 | (tph_sett_os_temp as i32) << 5i32 & 0xe0i32) as u8;
|
||||||
as (u8);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if desired_settings.contains(DesiredSensorSettings::OSP_SEL) {
|
if desired_settings.contains(DesiredSensorSettings::OSP_SEL) {
|
||||||
debug!("OSP_SEL: true");
|
debug!("OSP_SEL: true");
|
||||||
let tph_sett_os_pres = tph_sett.os_temp.expect("OS TEMP");
|
let tph_sett_os_pres = tph_sett.os_temp.expect("OS TEMP");
|
||||||
data = (data as (i32) & !0x1ci32 | tph_sett_os_pres as (i32) << 2i32 & 0x1ci32)
|
data = (data as i32 & !0x1ci32 | (tph_sett_os_pres as i32) << 2i32 & 0x1ci32) as u8;
|
||||||
as (u8);
|
|
||||||
}
|
}
|
||||||
reg[element_index] = (BME680_CONF_T_P_MODE_ADDR, data);
|
reg[element_index] = (BME680_CONF_T_P_MODE_ADDR, data);
|
||||||
element_index += 1;
|
element_index += 1;
|
||||||
|
@ -553,7 +551,7 @@ where
|
||||||
boundary_check::<I2C>(tph_sett.os_hum.map(|x| x as u8), "TphSett.os_hum", 0, 5)?;
|
boundary_check::<I2C>(tph_sett.os_hum.map(|x| x as u8), "TphSett.os_hum", 0, 5)?;
|
||||||
let mut data =
|
let mut data =
|
||||||
I2CUtil::read_byte(&mut self.i2c, self.dev_id.addr(), BME680_CONF_OS_H_ADDR)?;
|
I2CUtil::read_byte(&mut self.i2c, self.dev_id.addr(), BME680_CONF_OS_H_ADDR)?;
|
||||||
data = (data as (i32) & !0x7i32 | tph_sett_os_hum as (i32) & 0x7i32) as (u8);
|
data = (data as i32 & !0x7i32 | tph_sett_os_hum as i32 & 0x7i32) as u8;
|
||||||
reg[element_index] = (BME680_CONF_OS_H_ADDR, data);
|
reg[element_index] = (BME680_CONF_OS_H_ADDR, data);
|
||||||
element_index += 1;
|
element_index += 1;
|
||||||
}
|
}
|
||||||
|
@ -570,16 +568,16 @@ where
|
||||||
|
|
||||||
if desired_settings.contains(DesiredSensorSettings::RUN_GAS_SEL) {
|
if desired_settings.contains(DesiredSensorSettings::RUN_GAS_SEL) {
|
||||||
debug!("RUN_GAS_SEL: true");
|
debug!("RUN_GAS_SEL: true");
|
||||||
data = (data as (i32) & !0x10i32
|
data = (data as i32 & !0x10i32
|
||||||
| gas_sett.run_gas_measurement as (i32) << 4i32 & 0x10i32)
|
| (gas_sett.run_gas_measurement as i32) << 4i32 & 0x10i32)
|
||||||
as (u8);
|
as u8;
|
||||||
}
|
}
|
||||||
|
|
||||||
if desired_settings.contains(DesiredSensorSettings::NBCONV_SEL) {
|
if desired_settings.contains(DesiredSensorSettings::NBCONV_SEL) {
|
||||||
debug!("NBCONV_SEL: true");
|
debug!("NBCONV_SEL: true");
|
||||||
let gas_sett_nb_conv =
|
let gas_sett_nb_conv =
|
||||||
boundary_check::<I2C>(Some(gas_sett.nb_conv), "GasSett.nb_conv", 0, 10)?;
|
boundary_check::<I2C>(Some(gas_sett.nb_conv), "GasSett.nb_conv", 0, 10)?;
|
||||||
data = (data as (i32) & !0xfi32 | gas_sett_nb_conv as (i32) & 0xfi32) as (u8);
|
data = (data as i32 & !0xfi32 | gas_sett_nb_conv as i32 & 0xfi32) as u8;
|
||||||
}
|
}
|
||||||
|
|
||||||
reg[element_index] = (BME680_CONF_ODR_RUN_GAS_NBC_ADDR, data);
|
reg[element_index] = (BME680_CONF_ODR_RUN_GAS_NBC_ADDR, data);
|
||||||
|
@ -616,35 +614,34 @@ where
|
||||||
|
|
||||||
if desired_settings.contains(DesiredSensorSettings::FILTER_SEL) {
|
if desired_settings.contains(DesiredSensorSettings::FILTER_SEL) {
|
||||||
sensor_settings.tph_sett.filter = Some(IIRFilterSize::from_u8(
|
sensor_settings.tph_sett.filter = Some(IIRFilterSize::from_u8(
|
||||||
((data_array[5usize] as (i32) & 0x1ci32) >> 2i32) as (u8),
|
((data_array[5usize] as i32 & 0x1ci32) >> 2i32) as u8,
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
if desired_settings
|
if desired_settings
|
||||||
.contains(DesiredSensorSettings::OST_SEL | DesiredSensorSettings::OSP_SEL)
|
.contains(DesiredSensorSettings::OST_SEL | DesiredSensorSettings::OSP_SEL)
|
||||||
{
|
{
|
||||||
let os_temp: u8 = ((data_array[4usize] as (i32) & 0xe0i32) >> 5i32) as (u8);
|
let os_temp: u8 = ((data_array[4usize] as i32 & 0xe0i32) >> 5i32) as u8;
|
||||||
let os_pres: u8 = ((data_array[4usize] as (i32) & 0x1ci32) >> 2i32) as (u8);
|
let os_pres: u8 = ((data_array[4usize] as i32 & 0x1ci32) >> 2i32) as u8;
|
||||||
sensor_settings.tph_sett.os_temp = Some(OversamplingSetting::from_u8(os_temp));
|
sensor_settings.tph_sett.os_temp = Some(OversamplingSetting::from_u8(os_temp));
|
||||||
sensor_settings.tph_sett.os_pres = Some(OversamplingSetting::from_u8(os_pres));
|
sensor_settings.tph_sett.os_pres = Some(OversamplingSetting::from_u8(os_pres));
|
||||||
}
|
}
|
||||||
|
|
||||||
if desired_settings.contains(DesiredSensorSettings::OSH_SEL) {
|
if desired_settings.contains(DesiredSensorSettings::OSH_SEL) {
|
||||||
let os_hum: u8 = (data_array[2usize] as (i32) & 0x7i32) as (u8);
|
let os_hum: u8 = (data_array[2usize] as i32 & 0x7i32) as u8;
|
||||||
sensor_settings.tph_sett.os_hum = Some(OversamplingSetting::from_u8(os_hum));
|
sensor_settings.tph_sett.os_hum = Some(OversamplingSetting::from_u8(os_hum));
|
||||||
}
|
}
|
||||||
|
|
||||||
if desired_settings.contains(DesiredSensorSettings::HCNTRL_SEL) {
|
if desired_settings.contains(DesiredSensorSettings::HCNTRL_SEL) {
|
||||||
sensor_settings.gas_sett.heatr_ctrl =
|
sensor_settings.gas_sett.heatr_ctrl = Some((data_array[0usize] as i32 & 0x8i32) as u8);
|
||||||
Some((data_array[0usize] as (i32) & 0x8i32) as (u8));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if desired_settings
|
if desired_settings
|
||||||
.contains(DesiredSensorSettings::RUN_GAS_SEL | DesiredSensorSettings::NBCONV_SEL)
|
.contains(DesiredSensorSettings::RUN_GAS_SEL | DesiredSensorSettings::NBCONV_SEL)
|
||||||
{
|
{
|
||||||
sensor_settings.gas_sett.nb_conv = (data_array[1usize] as (i32) & 0xfi32) as (u8);
|
sensor_settings.gas_sett.nb_conv = (data_array[1usize] as i32 & 0xfi32) as u8;
|
||||||
sensor_settings.gas_sett.run_gas_measurement =
|
sensor_settings.gas_sett.run_gas_measurement =
|
||||||
((data_array[1usize] as (i32) & 0x10i32) >> 4i32) == 0;
|
((data_array[1usize] as i32 & 0x10i32) >> 4i32) == 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
Ok(sensor_settings)
|
Ok(sensor_settings)
|
||||||
|
@ -713,15 +710,15 @@ where
|
||||||
+ (duration.subsec_nanos() as u64 / NANOS_PER_MILLI);
|
+ (duration.subsec_nanos() as u64 / NANOS_PER_MILLI);
|
||||||
|
|
||||||
let mut meas_cycles = os_to_meas_cycles
|
let mut meas_cycles = os_to_meas_cycles
|
||||||
[tph_sett.os_temp.unwrap_or(OversamplingSetting::OSNone) as (usize)]
|
[tph_sett.os_temp.unwrap_or(OversamplingSetting::OSNone) as usize]
|
||||||
as (u64);
|
as u64;
|
||||||
meas_cycles = meas_cycles.wrapping_add(
|
meas_cycles = meas_cycles.wrapping_add(
|
||||||
os_to_meas_cycles[tph_sett.os_pres.unwrap_or(OversamplingSetting::OSNone) as (usize)]
|
os_to_meas_cycles[tph_sett.os_pres.unwrap_or(OversamplingSetting::OSNone) as usize]
|
||||||
as (u64),
|
as u64,
|
||||||
);
|
);
|
||||||
meas_cycles = meas_cycles.wrapping_add(
|
meas_cycles = meas_cycles.wrapping_add(
|
||||||
os_to_meas_cycles[tph_sett.os_hum.unwrap_or(OversamplingSetting::OSNone) as (usize)]
|
os_to_meas_cycles[tph_sett.os_hum.unwrap_or(OversamplingSetting::OSNone) as usize]
|
||||||
as (u64),
|
as u64,
|
||||||
);
|
);
|
||||||
let mut tph_dur = meas_cycles.wrapping_mul(1963u64);
|
let mut tph_dur = meas_cycles.wrapping_mul(1963u64);
|
||||||
tph_dur = tph_dur.wrapping_add(477u64.wrapping_mul(4u64));
|
tph_dur = tph_dur.wrapping_add(477u64.wrapping_mul(4u64));
|
||||||
|
@ -742,18 +739,18 @@ where
|
||||||
.tph_sett
|
.tph_sett
|
||||||
.os_temp
|
.os_temp
|
||||||
.unwrap_or(OversamplingSetting::OSNone)
|
.unwrap_or(OversamplingSetting::OSNone)
|
||||||
as (usize)] as (u32);
|
as usize] as u32;
|
||||||
meas_cycles = meas_cycles.wrapping_add(
|
meas_cycles = meas_cycles.wrapping_add(
|
||||||
os_to_meas_cycles[sensor_settings
|
os_to_meas_cycles[sensor_settings
|
||||||
.tph_sett
|
.tph_sett
|
||||||
.os_pres
|
.os_pres
|
||||||
.unwrap_or(OversamplingSetting::OSNone) as (usize)] as (u32),
|
.unwrap_or(OversamplingSetting::OSNone) as usize] as u32,
|
||||||
);
|
);
|
||||||
meas_cycles = meas_cycles.wrapping_add(
|
meas_cycles = meas_cycles.wrapping_add(
|
||||||
os_to_meas_cycles[sensor_settings
|
os_to_meas_cycles[sensor_settings
|
||||||
.tph_sett
|
.tph_sett
|
||||||
.os_hum
|
.os_hum
|
||||||
.unwrap_or(OversamplingSetting::OSNone) as (usize)] as (u32),
|
.unwrap_or(OversamplingSetting::OSNone) as usize] as u32,
|
||||||
);
|
);
|
||||||
let mut tph_dur = meas_cycles.wrapping_mul(1963u32);
|
let mut tph_dur = meas_cycles.wrapping_mul(1963u32);
|
||||||
tph_dur = tph_dur.wrapping_add(477u32.wrapping_mul(4u32));
|
tph_dur = tph_dur.wrapping_add(477u32.wrapping_mul(4u32));
|
||||||
|
@ -795,40 +792,32 @@ where
|
||||||
[BME680_COEFF_ADDR1_LEN..(BME680_COEFF_ADDR1_LEN + BME680_COEFF_ADDR2_LEN - 1)],
|
[BME680_COEFF_ADDR1_LEN..(BME680_COEFF_ADDR1_LEN + BME680_COEFF_ADDR2_LEN - 1)],
|
||||||
)?;
|
)?;
|
||||||
|
|
||||||
calib.par_t1 = (coeff_array[34usize] as (u16) as (i32) << 8i32
|
calib.par_t1 = ((coeff_array[34usize] as i32) << 8i32 | coeff_array[33usize] as i32) as u16;
|
||||||
| coeff_array[33usize] as (u16) as (i32)) as (u16);
|
calib.par_t2 = ((coeff_array[2usize] as i32) << 8i32 | coeff_array[1usize] as i32) as i16;
|
||||||
calib.par_t2 = (coeff_array[2usize] as (u16) as (i32) << 8i32
|
calib.par_t3 = coeff_array[3usize] as i8;
|
||||||
| coeff_array[1usize] as (u16) as (i32)) as (i16);
|
calib.par_p1 = ((coeff_array[6usize] as i32) << 8i32 | coeff_array[5usize] as i32) as u16;
|
||||||
calib.par_t3 = coeff_array[3usize] as (i8);
|
calib.par_p2 = ((coeff_array[8usize] as i32) << 8i32 | coeff_array[7usize] as i32) as i16;
|
||||||
calib.par_p1 = (coeff_array[6usize] as (u16) as (i32) << 8i32
|
calib.par_p3 = coeff_array[9usize] as i8;
|
||||||
| coeff_array[5usize] as (u16) as (i32)) as (u16);
|
calib.par_p4 = ((coeff_array[12usize] as i32) << 8i32 | coeff_array[11usize] as i32) as i16;
|
||||||
calib.par_p2 = (coeff_array[8usize] as (u16) as (i32) << 8i32
|
calib.par_p5 = ((coeff_array[14usize] as i32) << 8i32 | coeff_array[13usize] as i32) as i16;
|
||||||
| coeff_array[7usize] as (u16) as (i32)) as (i16);
|
calib.par_p6 = coeff_array[16usize] as i8;
|
||||||
calib.par_p3 = coeff_array[9usize] as (i8);
|
calib.par_p7 = coeff_array[15usize] as i8;
|
||||||
calib.par_p4 = (coeff_array[12usize] as (u16) as (i32) << 8i32
|
calib.par_p8 = ((coeff_array[20usize] as i32) << 8i32 | coeff_array[19usize] as i32) as i16;
|
||||||
| coeff_array[11usize] as (u16) as (i32)) as (i16);
|
calib.par_p9 = ((coeff_array[22usize] as i32) << 8i32 | coeff_array[21usize] as i32) as i16;
|
||||||
calib.par_p5 = (coeff_array[14usize] as (u16) as (i32) << 8i32
|
|
||||||
| coeff_array[13usize] as (u16) as (i32)) as (i16);
|
|
||||||
calib.par_p6 = coeff_array[16usize] as (i8);
|
|
||||||
calib.par_p7 = coeff_array[15usize] as (i8);
|
|
||||||
calib.par_p8 = (coeff_array[20usize] as (u16) as (i32) << 8i32
|
|
||||||
| coeff_array[19usize] as (u16) as (i32)) as (i16);
|
|
||||||
calib.par_p9 = (coeff_array[22usize] as (u16) as (i32) << 8i32
|
|
||||||
| coeff_array[21usize] as (u16) as (i32)) as (i16);
|
|
||||||
calib.par_p10 = coeff_array[23usize];
|
calib.par_p10 = coeff_array[23usize];
|
||||||
calib.par_h1 = (coeff_array[27usize] as (u16) as (i32) << 4i32
|
calib.par_h1 =
|
||||||
| coeff_array[26usize] as (i32) & 0xfi32) as (u16);
|
((coeff_array[27usize] as i32) << 4i32 | coeff_array[26usize] as i32 & 0xfi32) as u16;
|
||||||
calib.par_h2 = (coeff_array[25usize] as (u16) as (i32) << 4i32
|
calib.par_h2 =
|
||||||
| coeff_array[26usize] as (i32) >> 4i32) as (u16);
|
((coeff_array[25usize] as i32) << 4i32 | coeff_array[26usize] as i32 >> 4i32) as u16;
|
||||||
calib.par_h3 = coeff_array[28usize] as (i8);
|
calib.par_h3 = coeff_array[28usize] as i8;
|
||||||
calib.par_h4 = coeff_array[29usize] as (i8);
|
calib.par_h4 = coeff_array[29usize] as i8;
|
||||||
calib.par_h5 = coeff_array[30usize] as (i8);
|
calib.par_h5 = coeff_array[30usize] as i8;
|
||||||
calib.par_h6 = coeff_array[31usize];
|
calib.par_h6 = coeff_array[31usize];
|
||||||
calib.par_h7 = coeff_array[32usize] as (i8);
|
calib.par_h7 = coeff_array[32usize] as i8;
|
||||||
calib.par_gh1 = coeff_array[37usize] as (i8);
|
calib.par_gh1 = coeff_array[37usize] as i8;
|
||||||
calib.par_gh2 = (coeff_array[36usize] as (u16) as (i32) << 8i32
|
calib.par_gh2 =
|
||||||
| coeff_array[35usize] as (u16) as (i32)) as (i16);
|
((coeff_array[36usize] as i32) << 8i32 | coeff_array[35usize] as i32) as i16;
|
||||||
calib.par_gh3 = coeff_array[38usize] as (i8);
|
calib.par_gh3 = coeff_array[38usize] as i8;
|
||||||
|
|
||||||
calib.res_heat_range =
|
calib.res_heat_range =
|
||||||
(I2CUtil::read_byte::<I2CX>(i2c, dev_id.addr(), BME680_ADDR_RES_HEAT_RANGE_ADDR)?
|
(I2CUtil::read_byte::<I2CX>(i2c, dev_id.addr(), BME680_ADDR_RES_HEAT_RANGE_ADDR)?
|
||||||
|
@ -917,15 +906,15 @@ where
|
||||||
data.gas_index = buff[0] & BME680_GAS_INDEX_MSK;
|
data.gas_index = buff[0] & BME680_GAS_INDEX_MSK;
|
||||||
data.meas_index = buff[1];
|
data.meas_index = buff[1];
|
||||||
|
|
||||||
let adc_pres = (buff[2] as (u32)).wrapping_mul(4096)
|
let adc_pres = (buff[2] as u32).wrapping_mul(4096)
|
||||||
| (buff[3] as (u32)).wrapping_mul(16)
|
| (buff[3] as u32).wrapping_mul(16)
|
||||||
| (buff[4] as (u32)).wrapping_div(16);
|
| (buff[4] as u32).wrapping_div(16);
|
||||||
let adc_temp = (buff[5] as (u32)).wrapping_mul(4096)
|
let adc_temp = (buff[5] as u32).wrapping_mul(4096)
|
||||||
| (buff[6] as (u32)).wrapping_mul(16)
|
| (buff[6] as u32).wrapping_mul(16)
|
||||||
| (buff[7] as (u32)).wrapping_div(16);
|
| (buff[7] as u32).wrapping_div(16);
|
||||||
let adc_hum = ((buff[8] as (u32)).wrapping_mul(256) | buff[9] as (u32)) as (u16);
|
let adc_hum = ((buff[8] as u32).wrapping_mul(256) | buff[9] as u32) as u16;
|
||||||
let adc_gas_res = ((buff[13] as (u32)).wrapping_mul(4)
|
let adc_gas_res =
|
||||||
| (buff[14] as (u32)).wrapping_div(64)) as (u16);
|
((buff[13] as u32).wrapping_mul(4) | (buff[14] as u32).wrapping_div(64)) as u16;
|
||||||
let gas_range = buff[14] & BME680_GAS_RANGE_MSK;
|
let gas_range = buff[14] & BME680_GAS_RANGE_MSK;
|
||||||
|
|
||||||
data.status = data.status | buff[14] & BME680_GASM_VALID_MSK;
|
data.status = data.status | buff[14] & BME680_GASM_VALID_MSK;
|
||||||
|
|
Loading…
Reference in a new issue