We should check the return value of fcntl().

Addresses-Coverity-ID: 131108 ("Unchecked return value from library")
Addresses-Coverity-ID: 131109 ("Unchecked return value from library")
Signed-off-by: Heinrich Schuchardt <[email protected]>
---
 arch/sandbox/cpu/eth-raw-os.c | 14 ++++++++++++--
 1 file changed, 12 insertions(+), 2 deletions(-)

diff --git a/arch/sandbox/cpu/eth-raw-os.c b/arch/sandbox/cpu/eth-raw-os.c
index e59b96be5f..4ef2af0c36 100644
--- a/arch/sandbox/cpu/eth-raw-os.c
+++ b/arch/sandbox/cpu/eth-raw-os.c
@@ -105,7 +105,12 @@ static int _raw_packet_start(struct eth_sandbox_raw_priv 
*priv,
 
        /* Make the socket non-blocking */
        flags = fcntl(priv->sd, F_GETFL, 0);
-       fcntl(priv->sd, F_SETFL, flags | O_NONBLOCK);
+       ret = fcntl(priv->sd, F_SETFL, flags | O_NONBLOCK);
+       if (ret == -1) {
+               printf("Failed to make socket non-blocking: %d %s\n", errno,
+                      strerror(errno));
+               return -errno;
+       }
 
        /* Enable promiscuous mode to receive responses meant for us */
        mr.mr_ifindex = device->sll_ifindex;
@@ -172,7 +177,12 @@ static int _local_inet_start(struct eth_sandbox_raw_priv 
*priv)
 
        /* Make the socket non-blocking */
        flags = fcntl(priv->sd, F_GETFL, 0);
-       fcntl(priv->sd, F_SETFL, flags | O_NONBLOCK);
+       ret = fcntl(priv->sd, F_SETFL, flags | O_NONBLOCK);
+       if (ret == -1) {
+               printf("Failed to make socket non-blocking: %d %s\n", errno,
+                      strerror(errno));
+               return -errno;
+       }
 
        /* Include the UDP/IP headers on send and receive */
        ret = setsockopt(priv->sd, IPPROTO_IP, IP_HDRINCL, &one,
-- 
2.43.0

Reply via email to