]> git.ipfire.org Git - thirdparty/libvirt.git/commitdiff
libvirt_nss: Fix ERROR() macro
authorMichal Privoznik <mprivozn@redhat.com>
Thu, 18 Apr 2024 07:25:07 +0000 (09:25 +0200)
committerMichal Privoznik <mprivozn@redhat.com>
Thu, 18 Apr 2024 12:57:30 +0000 (14:57 +0200)
The purpose of ERROR() macro in our NSS module is to print error
message provided as arguments followed by error string
corresponding to errno. Historically, we've used strerror_r() for
that (please note, we want our NSS module to be free of libvirt
internal functions, or glib even - hence, g_strerror() is off the
table).

Now strerror_r() is documented as:

  Returns ... a pointer to a string that the function stores in
  buf, or a pointer to some (immutable) static string (in which
  case buf is unused).

Therefore, we can't rely the string being stored in the buf and
really need to store the retval and print that instead.

While touching this area, decrease the ebuf size, since its
current size (1KiB) is triggering our stack limit (2KiB) in some
cases.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Peter Krempa <pkrempa@redhat.com>
tools/nss/libvirt_nss.h

index 2bb313f329f0874610b935dbb43c3965a9484d58..5f356618f3ff1be8ac1b985267cccd7839f13717 100644 (file)
 # define NULLSTR(s) ((s) ? (s) : "<null>")
 # define ERROR(...) \
 do { \
-    char ebuf[1024]; \
-    strerror_r(errno, ebuf, sizeof(ebuf)); \
+    char ebuf[512]; \
+    const char *errmsg = strerror_r(errno, ebuf, sizeof(ebuf)); \
     fprintf(stderr, "ERROR %s:%d : ", __FUNCTION__, __LINE__); \
     fprintf(stderr, __VA_ARGS__); \
-    fprintf(stderr, " : %s\n", ebuf); \
+    fprintf(stderr, " : %s\n", errmsg); \
     fprintf(stderr, "\n"); \
 } while (0)