diff options
| author | Christian Grothoff <christian@grothoff.org> | 2021-08-05 11:07:20 +0200 | 
|---|---|---|
| committer | Christian Grothoff <christian@grothoff.org> | 2021-08-05 11:07:20 +0200 | 
| commit | 453d984569c17c22fecd56d9f2deb14cc59cdf93 (patch) | |
| tree | d081a93ae5c4f8dd22e06c7552a5032ddb45be38 /src/util/crypto_helper_esign.c | |
| parent | 1ca5213894e9852bbc5a069b11e1e17d1038f1a5 (diff) | |
-try to fix Florian's FIXME/endless loop, alas without test as Florian did not provide enough details for that
Diffstat (limited to 'src/util/crypto_helper_esign.c')
| -rw-r--r-- | src/util/crypto_helper_esign.c | 10 | 
1 files changed, 7 insertions, 3 deletions
| diff --git a/src/util/crypto_helper_esign.c b/src/util/crypto_helper_esign.c index 2c51187d..f98faae2 100644 --- a/src/util/crypto_helper_esign.c +++ b/src/util/crypto_helper_esign.c @@ -146,11 +146,11 @@ try_connect (struct TALER_CRYPTO_ExchangeSignHelper *esh)    /* Fix permissions on client UNIX domain socket,       just in case umask() is not set to enable group write */    { -    char path[sizeof (esh->sa.sun_path) + 1]; +    char path[sizeof (esh->my_sa.sun_path) + 1];      strncpy (path,               esh->my_sa.sun_path, -             sizeof (esh->my_sa.sun_path)); +             sizeof (path) - 1);      path[sizeof (esh->my_sa.sun_path)] = '\0';      if (0 != chmod (path, @@ -393,6 +393,7 @@ TALER_CRYPTO_helper_esign_poll (struct TALER_CRYPTO_ExchangeSignHelper *esh)    ssize_t ret;    const struct GNUNET_MessageHeader *hdr      = (const struct GNUNET_MessageHeader *) buf; +  int flag = MSG_DONTWAIT;    try_connect (esh);    if (-1 == esh->sock) @@ -402,11 +403,12 @@ TALER_CRYPTO_helper_esign_poll (struct TALER_CRYPTO_ExchangeSignHelper *esh)      ret = recv (esh->sock,                  buf,                  sizeof (buf), -                MSG_DONTWAIT); +                flag);      if (ret < 0)      {        if (EAGAIN == errno)        { +        GNUNET_assert (0 != flag);          if (esh->synced)            break;          if (! await_read_ready (esh)) @@ -419,6 +421,7 @@ TALER_CRYPTO_helper_esign_poll (struct TALER_CRYPTO_ExchangeSignHelper *esh)            if (-1 == esh->sock)              return; /* give up */          } +        flag = 0; /* syscall must be non-blocking this time */          continue; /* try again */        }        GNUNET_log_strerror (GNUNET_ERROR_TYPE_WARNING, @@ -427,6 +430,7 @@ TALER_CRYPTO_helper_esign_poll (struct TALER_CRYPTO_ExchangeSignHelper *esh)        return;      } +    flag = MSG_DONTWAIT;      if ( (ret < sizeof (struct GNUNET_MessageHeader)) ||           (ret != ntohs (hdr->size)) )      { | 
