summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPetre Rodan <petre.rodan@subdimension.ro>2024-01-08 12:32:20 +0200
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2024-04-13 12:50:16 +0200
commit4a886ce3c846032ed8d9bf18f525f12dcb5de614 (patch)
treeb76bf73b71c5d8ddeddd228f3b60fc1160efa47b
parent50e05164d41db0231f2d3273f89a24e2bb62149b (diff)
downloadlinux-stable-4a886ce3c846032ed8d9bf18f525f12dcb5de614.tar.gz
linux-stable-4a886ce3c846032ed8d9bf18f525f12dcb5de614.tar.bz2
linux-stable-4a886ce3c846032ed8d9bf18f525f12dcb5de614.zip
tools: iio: replace seekdir() in iio_generic_buffer
[ Upstream commit 4e6500bfa053dc133021f9c144261b77b0ba7dc8 ] Replace seekdir() with rewinddir() in order to fix a localized glibc bug. One of the glibc patches that stable Gentoo is using causes an improper directory stream positioning bug on 32bit arm. That in turn ends up as a floating point exception in iio_generic_buffer. The attached patch provides a fix by using an equivalent function which should not cause trouble for other distros and is easier to reason about in general as it obviously always goes back to to the start. https://sourceware.org/bugzilla/show_bug.cgi?id=31212 Signed-off-by: Petre Rodan <petre.rodan@subdimension.ro> Link: https://lore.kernel.org/r/20240108103224.3986-1-petre.rodan@subdimension.ro Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com> Signed-off-by: Sasha Levin <sashal@kernel.org>
-rw-r--r--tools/iio/iio_utils.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/tools/iio/iio_utils.c b/tools/iio/iio_utils.c
index d174487b2f22..1ef51c7e7b04 100644
--- a/tools/iio/iio_utils.c
+++ b/tools/iio/iio_utils.c
@@ -376,7 +376,7 @@ int build_channel_array(const char *device_dir,
goto error_close_dir;
}
- seekdir(dp, 0);
+ rewinddir(dp);
while (ent = readdir(dp), ent) {
if (strcmp(ent->d_name + strlen(ent->d_name) - strlen("_en"),
"_en") == 0) {