File libgcrypt-fix-rng.patch of Package libgcrypt.openSUSE_Leap_42.1_Update
Index: libgcrypt-1.6.1/random/random.c
===================================================================
--- libgcrypt-1.6.1.orig/random/random.c
+++ libgcrypt-1.6.1/random/random.c
@@ -440,6 +440,9 @@ _gcry_create_nonce (void *buffer, size_t
   size_t n;
   int err;
 
+  /* Make sure we are initialized. */
+  _gcry_random_initialize (1);
+
   /* First check whether we shall use the FIPS nonce generator.  This
      is only done in FIPS mode, in all other modes, we use our own
      nonce generator which is seeded by the RNG actual in use.  */
@@ -455,9 +458,6 @@ _gcry_create_nonce (void *buffer, size_t
      FIPS mode (not that this means it is also used if the FIPS RNG
      has been selected but we are not in fips mode).  */
 
-  /* Make sure we are initialized. */
-  _gcry_random_initialize (1);
-
   /* Acquire the nonce buffer lock. */
   err = ath_mutex_lock (&nonce_buffer_lock);
   if (err)