Commit 431f7667 authored by Andreas Klinger's avatar Andreas Klinger Committed by Jonathan Cameron

iio: srf04: fix wrong limitation in distance measuring

The measured time value in the driver is limited to the maximum distance
which can be read by the sensor. This limitation was wrong and is fixed
by this patch.

It also takes into account that we are supporting a variety of sensors
today and that the recently added sensors have a higher maximum
distance range.

Changes in v2:
- Added a Tested-by
Suggested-by: default avatarZbyněk Kocur <zbynek.kocur@fel.cvut.cz>
Tested-by: default avatarZbyněk Kocur <zbynek.kocur@fel.cvut.cz>
Signed-off-by: default avatarAndreas Klinger <ak@it-klinger.de>
Cc:<Stable@vger.kernel.org>
Signed-off-by: default avatarJonathan Cameron <Jonathan.Cameron@huawei.com>
parent 24e1eb5c
...@@ -110,7 +110,7 @@ static int srf04_read(struct srf04_data *data) ...@@ -110,7 +110,7 @@ static int srf04_read(struct srf04_data *data)
udelay(data->cfg->trigger_pulse_us); udelay(data->cfg->trigger_pulse_us);
gpiod_set_value(data->gpiod_trig, 0); gpiod_set_value(data->gpiod_trig, 0);
/* it cannot take more than 20 ms */ /* it should not take more than 20 ms until echo is rising */
ret = wait_for_completion_killable_timeout(&data->rising, HZ/50); ret = wait_for_completion_killable_timeout(&data->rising, HZ/50);
if (ret < 0) { if (ret < 0) {
mutex_unlock(&data->lock); mutex_unlock(&data->lock);
...@@ -120,7 +120,8 @@ static int srf04_read(struct srf04_data *data) ...@@ -120,7 +120,8 @@ static int srf04_read(struct srf04_data *data)
return -ETIMEDOUT; return -ETIMEDOUT;
} }
ret = wait_for_completion_killable_timeout(&data->falling, HZ/50); /* it cannot take more than 50 ms until echo is falling */
ret = wait_for_completion_killable_timeout(&data->falling, HZ/20);
if (ret < 0) { if (ret < 0) {
mutex_unlock(&data->lock); mutex_unlock(&data->lock);
return ret; return ret;
...@@ -135,19 +136,19 @@ static int srf04_read(struct srf04_data *data) ...@@ -135,19 +136,19 @@ static int srf04_read(struct srf04_data *data)
dt_ns = ktime_to_ns(ktime_dt); dt_ns = ktime_to_ns(ktime_dt);
/* /*
* measuring more than 3 meters is beyond the capabilities of * measuring more than 6,45 meters is beyond the capabilities of
* the sensor * the supported sensors
* ==> filter out invalid results for not measuring echos of * ==> filter out invalid results for not measuring echos of
* another us sensor * another us sensor
* *
* formula: * formula:
* distance 3 m * distance 6,45 * 2 m
* time = ---------- = --------- = 9404389 ns * time = ---------- = ------------ = 40438871 ns
* speed 319 m/s * speed 319 m/s
* *
* using a minimum speed at -20 °C of 319 m/s * using a minimum speed at -20 °C of 319 m/s
*/ */
if (dt_ns > 9404389) if (dt_ns > 40438871)
return -EIO; return -EIO;
time_ns = dt_ns; time_ns = dt_ns;
...@@ -159,20 +160,20 @@ static int srf04_read(struct srf04_data *data) ...@@ -159,20 +160,20 @@ static int srf04_read(struct srf04_data *data)
* with Temp in °C * with Temp in °C
* and speed in m/s * and speed in m/s
* *
* use 343 m/s as ultrasonic speed at 20 °C here in absence of the * use 343,5 m/s as ultrasonic speed at 20 °C here in absence of the
* temperature * temperature
* *
* therefore: * therefore:
* time 343 * time 343,5 time * 106
* distance = ------ * ----- * distance = ------ * ------- = ------------
* 10^6 2 * 10^6 2 617176
* with time in ns * with time in ns
* and distance in mm (one way) * and distance in mm (one way)
* *
* because we limit to 3 meters the multiplication with 343 just * because we limit to 6,45 meters the multiplication with 106 just
* fits into 32 bit * fits into 32 bit
*/ */
distance_mm = time_ns * 343 / 2000000; distance_mm = time_ns * 106 / 617176;
return distance_mm; return distance_mm;
} }
......
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