fix: handle EINTR correctly in get_cpu_mask_from_sysfs master
authorMathieu Desnoyers <mathieu.desnoyers@efficios.com>
Thu, 2 May 2024 14:43:16 +0000 (10:43 -0400)
committerMathieu Desnoyers <mathieu.desnoyers@efficios.com>
Thu, 2 May 2024 14:43:16 +0000 (10:43 -0400)
commitb7fb4410db9d5403c1c7e19595b1eeff0a4322cc
treecca7e06573e94e7bd33b1479fbbaf485518718e4
parent2d9f5025ed0ee15cbb708921c3581b983b60da32
fix: handle EINTR correctly in get_cpu_mask_from_sysfs

If the read() in get_cpu_mask_from_sysfs() fails with EINTR, the code is
supposed to retry, but the while loop condition has (bytes_read > 0),
which is false when read() fails with EINTR. The result is that the code
exits the loop, having only read part of the string.

Use (bytes_read != 0) in the while loop condition instead, since the
(bytes_read < 0) case is already handled in the loop.

Original fix in liburcu from Benjamin Marzinski <bmarzins@redhat.com>:

  commit 9922f33e2986 ("fix: handle EINTR correctly in get_cpu_mask_from_sysfs")

Signed-off-by: Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
Change-Id: I134662fe83613ff914433d3b30a63a0134ffa124
src/smp.c
This page took 0.023817 seconds and 4 git commands to generate.