crypto: avoid passing NULL to access() syscall
authorDaniel P. Berrange <berrange@redhat.com>
Wed, 18 Nov 2015 15:42:26 +0000 (15:42 +0000)
committerDaniel P. Berrange <berrange@redhat.com>
Wed, 18 Nov 2015 15:42:26 +0000 (15:42 +0000)
The qcrypto_tls_creds_x509_sanity_check() checks whether
certs exist by calling access(). It is valid for this
method to be invoked with certfile==NULL though, since
for client credentials the cert is optional. This caused
it to call access(NULL), which happens to be harmless on
current Linux, but should none the less be avoided.

Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
crypto/tlscredsx509.c

index c5d1a0d..d080deb 100644 (file)
@@ -485,7 +485,8 @@ qcrypto_tls_creds_x509_sanity_check(QCryptoTLSCredsX509 *creds,
     int ret = -1;
 
     memset(cacerts, 0, sizeof(cacerts));
-    if (access(certFile, R_OK) == 0) {
+    if (certFile &&
+        access(certFile, R_OK) == 0) {
         cert = qcrypto_tls_creds_load_cert(creds,
                                            certFile, isServer,
                                            errp);