[BUG] Healthchecks: get a proper error code if connection cannot be completed immediately

In case of a non-blocking socket, used for connecting to a remote
server (not localhost), the error reported by the health check
was most of a time one of EINPROGRESS/EAGAIN/EALREADY.

This patch adds a getsockopt(..., SO_ERROR, ...) call so now
the proper error message is reported.
diff --git a/src/checks.c b/src/checks.c
index 388efdf..b6f73bd 100644
--- a/src/checks.c
+++ b/src/checks.c
@@ -651,7 +651,13 @@
 
 	//fprintf(stderr, "event_srv_chk_w, state=%ld\n", unlikely(fdtab[fd].state));
 	if (unlikely(fdtab[fd].state == FD_STERROR || (fdtab[fd].ev & FD_POLL_ERR))) {
-		set_server_check_status(s, HCHK_STATUS_L4CON, strerror(errno));
+		int skerr, err = errno;
+		socklen_t lskerr = sizeof(skerr);
+
+		if (!getsockopt(fd, SOL_SOCKET, SO_ERROR, &skerr, &lskerr) && skerr)
+			err = skerr;
+
+		set_server_check_status(s, HCHK_STATUS_L4CON, strerror(err));
 		goto out_error;
 	}