Move underflow test to make time constant
diff --git a/library/rsa.c b/library/rsa.c
index 154fa58..0a28812 100644
--- a/library/rsa.c
+++ b/library/rsa.c
@@ -702,6 +702,12 @@
     if( md_info == NULL )
         return( POLARSSL_ERR_RSA_BAD_INPUT_DATA );
 
+    hlen = mbedtls_md_get_size( md_info );
+
+    // checking for integer underflow
+    if( 2 * hlen + 2 > ilen )
+        return( MBEDTLS_ERR_RSA_BAD_INPUT_DATA );
+
     /*
      * RSA operation
      */