diff mbox series

[Ada] GNAT.Expect (Expect_Internal): Try to call 'poll' few times

Message ID 20190917080633.GA37512@adacore.com
State New
Headers show
Series [Ada] GNAT.Expect (Expect_Internal): Try to call 'poll' few times | expand

Commit Message

Pierre-Marie de Rodat Sept. 17, 2019, 8:06 a.m. UTC
'poll' returns -1 in case of any error (including interruption by a
signal), so call need to be repeated few times to avoid false failures.

Tested on x86_64-pc-linux-gnu, committed on trunk

2019-09-17  Vadim Godunko  <godunko@adacore.com>

gcc/ada/

	* libgnat/g-expect.adb (Expect_Internal): Try to call 'poll' few
	times.
diff mbox series

Patch

--- gcc/ada/libgnat/g-expect.adb
+++ gcc/ada/libgnat/g-expect.adb
@@ -679,8 +679,17 @@  package body GNAT.Expect is
          --  Loop until we match or we have a timeout
 
          loop
-            Num_Descriptors :=
-              Poll (Fds'Address, Fds_Count, Timeout, D'Access, Is_Set'Address);
+            --  Poll may be interrupted on Linux by a signal and need to be
+            --  repeated. We don't want to check for errno = EINTER, so just
+            --  attempt to call Poll a few times.
+
+            for J in 1 .. 3 loop
+               Num_Descriptors :=
+                 Poll
+                   (Fds'Address, Fds_Count, Timeout, D'Access, Is_Set'Address);
+
+               exit when Num_Descriptors /= -1;
+            end loop;
 
             case Num_Descriptors is