Commit 9fc89f79 authored by Jean-Baptiste Maneyrol's avatar Jean-Baptiste Maneyrol Committed by Jonathan Cameron

iio: imu: inv_mpu6050: update LPF bandwidth settings

As every chip has some little variant in LPF bandwidth values,
use common values that are working for all chips.
Simplify the LPF setting function.
Signed-off-by: default avatarJean-Baptiste Maneyrol <jmaneyrol@invensense.com>
Signed-off-by: default avatarJonathan Cameron <Jonathan.Cameron@huawei.com>
parent 8abce87d
...@@ -707,30 +707,32 @@ static int inv_mpu6050_write_raw(struct iio_dev *indio_dev, ...@@ -707,30 +707,32 @@ static int inv_mpu6050_write_raw(struct iio_dev *indio_dev,
/** /**
* inv_mpu6050_set_lpf() - set low pass filer based on fifo rate. * inv_mpu6050_set_lpf() - set low pass filer based on fifo rate.
* *
* Based on the Nyquist principle, the sampling rate must * Based on the Nyquist principle, the bandwidth of the low
* exceed twice of the bandwidth of the signal, or there * pass filter must not exceed the signal sampling rate divided
* would be alising. This function basically search for the * by 2, or there would be aliasing.
* correct low pass parameters based on the fifo rate, e.g, * This function basically search for the correct low pass
* sampling frequency. * parameters based on the fifo rate, e.g, sampling frequency.
* *
* lpf is set automatically when setting sampling rate to avoid any aliases. * lpf is set automatically when setting sampling rate to avoid any aliases.
*/ */
static int inv_mpu6050_set_lpf(struct inv_mpu6050_state *st, int rate) static int inv_mpu6050_set_lpf(struct inv_mpu6050_state *st, int rate)
{ {
static const int hz[] = {188, 98, 42, 20, 10, 5}; static const int hz[] = {400, 200, 90, 40, 20, 10};
static const int d[] = { static const int d[] = {
INV_MPU6050_FILTER_188HZ, INV_MPU6050_FILTER_98HZ, INV_MPU6050_FILTER_200HZ, INV_MPU6050_FILTER_100HZ,
INV_MPU6050_FILTER_42HZ, INV_MPU6050_FILTER_20HZ, INV_MPU6050_FILTER_45HZ, INV_MPU6050_FILTER_20HZ,
INV_MPU6050_FILTER_10HZ, INV_MPU6050_FILTER_5HZ INV_MPU6050_FILTER_10HZ, INV_MPU6050_FILTER_5HZ
}; };
int i, h, result; int i, result;
u8 data; u8 data;
h = (rate >> 1); data = INV_MPU6050_FILTER_5HZ;
i = 0; for (i = 0; i < ARRAY_SIZE(hz); ++i) {
while ((h < hz[i]) && (i < ARRAY_SIZE(d) - 1)) if (rate >= hz[i]) {
i++; data = d[i];
data = d[i]; break;
}
}
result = inv_mpu6050_set_lpf_regs(st, data); result = inv_mpu6050_set_lpf_regs(st, data);
if (result) if (result)
return result; return result;
......
...@@ -370,14 +370,14 @@ enum inv_mpu6050_scan { ...@@ -370,14 +370,14 @@ enum inv_mpu6050_scan {
}; };
enum inv_mpu6050_filter_e { enum inv_mpu6050_filter_e {
INV_MPU6050_FILTER_256HZ_NOLPF2 = 0, INV_MPU6050_FILTER_NOLPF2 = 0,
INV_MPU6050_FILTER_188HZ, INV_MPU6050_FILTER_200HZ,
INV_MPU6050_FILTER_98HZ, INV_MPU6050_FILTER_100HZ,
INV_MPU6050_FILTER_42HZ, INV_MPU6050_FILTER_45HZ,
INV_MPU6050_FILTER_20HZ, INV_MPU6050_FILTER_20HZ,
INV_MPU6050_FILTER_10HZ, INV_MPU6050_FILTER_10HZ,
INV_MPU6050_FILTER_5HZ, INV_MPU6050_FILTER_5HZ,
INV_MPU6050_FILTER_2100HZ_NOLPF, INV_MPU6050_FILTER_NOLPF,
NUM_MPU6050_FILTER NUM_MPU6050_FILTER
}; };
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment