mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-02-02 01:45:17 +00:00
udev: fix crash in libudev logging
Call virLogVMessage instead of virLogMessage, since libudev called us with a va_list object, not a list of arguments. Honor message priority and strip the trailing newline. https://bugzilla.redhat.com/show_bug.cgi?id=969152
This commit is contained in:
parent
1133404c73
commit
f753dd62f9
@ -1480,12 +1480,14 @@ virLogMessage;
|
|||||||
virLogParseDefaultPriority;
|
virLogParseDefaultPriority;
|
||||||
virLogParseFilters;
|
virLogParseFilters;
|
||||||
virLogParseOutputs;
|
virLogParseOutputs;
|
||||||
|
virLogPriorityFromSyslog;
|
||||||
virLogProbablyLogMessage;
|
virLogProbablyLogMessage;
|
||||||
virLogReset;
|
virLogReset;
|
||||||
virLogSetBufferSize;
|
virLogSetBufferSize;
|
||||||
virLogSetDefaultPriority;
|
virLogSetDefaultPriority;
|
||||||
virLogSetFromEnv;
|
virLogSetFromEnv;
|
||||||
virLogUnlock;
|
virLogUnlock;
|
||||||
|
virLogVMessage;
|
||||||
|
|
||||||
|
|
||||||
# util/virmacaddr.h
|
# util/virmacaddr.h
|
||||||
|
@ -348,15 +348,37 @@ static int udevGenerateDeviceName(struct udev_device *device,
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static void udevLogFunction(struct udev *udev ATTRIBUTE_UNUSED,
|
typedef void (*udevLogFunctionPtr)(struct udev *udev,
|
||||||
int priority ATTRIBUTE_UNUSED,
|
int priority,
|
||||||
const char *file,
|
const char *file,
|
||||||
int line,
|
int line,
|
||||||
const char *fn,
|
const char *fn,
|
||||||
const char *fmt,
|
const char *format,
|
||||||
va_list args)
|
va_list args);
|
||||||
|
|
||||||
|
static void
|
||||||
|
ATTRIBUTE_FMT_PRINTF(6,0)
|
||||||
|
udevLogFunction(struct udev *udev ATTRIBUTE_UNUSED,
|
||||||
|
int priority,
|
||||||
|
const char *file,
|
||||||
|
int line,
|
||||||
|
const char *fn,
|
||||||
|
const char *fmt,
|
||||||
|
va_list args)
|
||||||
{
|
{
|
||||||
VIR_ERROR_INT(VIR_LOG_FROM_LIBRARY, file, line, fn, fmt, args);
|
virBuffer buf = VIR_BUFFER_INITIALIZER;
|
||||||
|
const char *format = NULL;
|
||||||
|
|
||||||
|
virBufferAdd(&buf, fmt, -1);
|
||||||
|
virBufferTrim(&buf, "\n", -1);
|
||||||
|
|
||||||
|
format = virBufferContentAndReset(&buf);
|
||||||
|
|
||||||
|
virLogVMessage(VIR_LOG_FROM_LIBRARY,
|
||||||
|
virLogPriorityFromSyslog(priority),
|
||||||
|
file, line, fn, NULL, format ? format : fmt, args);
|
||||||
|
|
||||||
|
VIR_FREE(format);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -1672,7 +1694,8 @@ static int nodeStateInitialize(bool privileged ATTRIBUTE_UNUSED,
|
|||||||
* its return value.
|
* its return value.
|
||||||
*/
|
*/
|
||||||
udev = udev_new();
|
udev = udev_new();
|
||||||
udev_set_log_fn(udev, udevLogFunction);
|
/* cast to get rid of missing-format-attribute warning */
|
||||||
|
udev_set_log_fn(udev, (udevLogFunctionPtr) udevLogFunction);
|
||||||
|
|
||||||
priv->udev_monitor = udev_monitor_new_from_netlink(udev, "udev");
|
priv->udev_monitor = udev_monitor_new_from_netlink(udev, "udev");
|
||||||
if (priv->udev_monitor == NULL) {
|
if (priv->udev_monitor == NULL) {
|
||||||
|
@ -1264,6 +1264,31 @@ static int virLogAddOutputToJournald(int priority)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
# endif /* USE_JOURNALD */
|
# endif /* USE_JOURNALD */
|
||||||
|
|
||||||
|
int virLogPriorityFromSyslog(int priority)
|
||||||
|
{
|
||||||
|
switch (priority) {
|
||||||
|
case LOG_EMERG:
|
||||||
|
case LOG_ALERT:
|
||||||
|
case LOG_CRIT:
|
||||||
|
case LOG_ERR:
|
||||||
|
return VIR_LOG_ERROR;
|
||||||
|
case LOG_WARNING:
|
||||||
|
case LOG_NOTICE:
|
||||||
|
return VIR_LOG_WARN;
|
||||||
|
case LOG_INFO:
|
||||||
|
return VIR_LOG_INFO;
|
||||||
|
case LOG_DEBUG:
|
||||||
|
return VIR_LOG_DEBUG;
|
||||||
|
}
|
||||||
|
return VIR_LOG_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
#else /* HAVE_SYSLOG_H */
|
||||||
|
int virLogPriorityFromSyslog(int priority ATTRIBUTE_UNUSED)
|
||||||
|
{
|
||||||
|
return VIR_LOG_ERROR;
|
||||||
|
}
|
||||||
#endif /* HAVE_SYSLOG_H */
|
#endif /* HAVE_SYSLOG_H */
|
||||||
|
|
||||||
#define IS_SPACE(cur) \
|
#define IS_SPACE(cur) \
|
||||||
|
@ -171,6 +171,7 @@ extern int virLogReset(void);
|
|||||||
extern int virLogParseDefaultPriority(const char *priority);
|
extern int virLogParseDefaultPriority(const char *priority);
|
||||||
extern int virLogParseFilters(const char *filters);
|
extern int virLogParseFilters(const char *filters);
|
||||||
extern int virLogParseOutputs(const char *output);
|
extern int virLogParseOutputs(const char *output);
|
||||||
|
extern int virLogPriorityFromSyslog(int priority);
|
||||||
extern void virLogMessage(virLogSource src,
|
extern void virLogMessage(virLogSource src,
|
||||||
virLogPriority priority,
|
virLogPriority priority,
|
||||||
const char *filename,
|
const char *filename,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user