teknoraver / rpms / systemd

Forked from rpms/systemd 3 months ago
Clone

Blame 0159-journald-malloc-less-when-streaming-messages.patch

Zbigniew Jędrzejewski-Szmek 126222
From feaaf9358a0bd619ef77dca732aa08e21f5c1a56 Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek 126222
From: =?UTF-8?q?Zbigniew=20J=C4=99drzejewski-Szmek?= <zbyszek@in.waw.pl>
Zbigniew Jędrzejewski-Szmek 126222
Date: Tue, 10 Dec 2013 06:17:01 -0500
Zbigniew Jędrzejewski-Szmek 126222
Subject: [PATCH] journald: malloc less when streaming messages
Zbigniew Jędrzejewski-Szmek 126222
Zbigniew Jędrzejewski-Szmek 126222
---
Zbigniew Jędrzejewski-Szmek 126222
 src/journal/journald-stream.c | 23 ++++++++++++-----------
Zbigniew Jędrzejewski-Szmek 126222
 src/journal/journald-syslog.c |  4 ++--
Zbigniew Jędrzejewski-Szmek 126222
 src/journal/journald-syslog.h |  2 +-
Zbigniew Jędrzejewski-Szmek 126222
 3 files changed, 15 insertions(+), 14 deletions(-)
Zbigniew Jędrzejewski-Szmek 126222
Zbigniew Jędrzejewski-Szmek 126222
diff --git a/src/journal/journald-stream.c b/src/journal/journald-stream.c
Zbigniew Jędrzejewski-Szmek 126222
index 771a2bd..aae381b 100644
Zbigniew Jędrzejewski-Szmek 126222
--- a/src/journal/journald-stream.c
Zbigniew Jędrzejewski-Szmek 126222
+++ b/src/journal/journald-stream.c
Zbigniew Jędrzejewski-Szmek 126222
@@ -75,9 +75,11 @@ struct StdoutStream {
Zbigniew Jędrzejewski-Szmek 126222
 
Zbigniew Jędrzejewski-Szmek 126222
 static int stdout_stream_log(StdoutStream *s, const char *p) {
Zbigniew Jędrzejewski-Szmek 126222
         struct iovec iovec[N_IOVEC_META_FIELDS + 5];
Zbigniew Jędrzejewski-Szmek 126222
-        _cleanup_free_ char *message = NULL, *syslog_priority = NULL, *syslog_facility = NULL, *syslog_identifier = NULL;
Zbigniew Jędrzejewski-Szmek 126222
-        unsigned n = 0;
Zbigniew Jędrzejewski-Szmek 126222
         int priority;
Zbigniew Jędrzejewski-Szmek 126222
+        char syslog_priority[] = "PRIORITY=\0";
Zbigniew Jędrzejewski-Szmek 126222
+        char syslog_facility[sizeof("SYSLOG_FACILITY=") + DECIMAL_STR_MAX(priority)];
Zbigniew Jędrzejewski-Szmek 126222
+        _cleanup_free_ char *message = NULL, *syslog_identifier = NULL;
Zbigniew Jędrzejewski-Szmek 126222
+        unsigned n = 0;
Zbigniew Jędrzejewski-Szmek 126222
         char *label = NULL;
Zbigniew Jędrzejewski-Szmek 126222
         size_t label_len = 0;
Zbigniew Jędrzejewski-Szmek 126222
 
Zbigniew Jędrzejewski-Szmek 126222
@@ -90,7 +92,7 @@ static int stdout_stream_log(StdoutStream *s, const char *p) {
Zbigniew Jędrzejewski-Szmek 126222
         priority = s->priority;
Zbigniew Jędrzejewski-Szmek 126222
 
Zbigniew Jędrzejewski-Szmek 126222
         if (s->level_prefix)
Zbigniew Jędrzejewski-Szmek 126222
-                syslog_parse_priority((char**) &p, &priority, false);
Zbigniew Jędrzejewski-Szmek 126222
+                syslog_parse_priority(&p, &priority, false);
Zbigniew Jędrzejewski-Szmek 126222
 
Zbigniew Jędrzejewski-Szmek 126222
         if (s->forward_to_syslog || s->server->forward_to_syslog)
Zbigniew Jędrzejewski-Szmek 126222
                 server_forward_syslog(s->server, syslog_fixup_facility(priority), s->identifier, p, &s->ucred, NULL);
Zbigniew Jędrzejewski-Szmek 126222
@@ -103,12 +105,13 @@ static int stdout_stream_log(StdoutStream *s, const char *p) {
Zbigniew Jędrzejewski-Szmek 126222
 
Zbigniew Jędrzejewski-Szmek 126222
         IOVEC_SET_STRING(iovec[n++], "_TRANSPORT=stdout");
Zbigniew Jędrzejewski-Szmek 126222
 
Zbigniew Jędrzejewski-Szmek 126222
-        if (asprintf(&syslog_priority, "PRIORITY=%i", priority & LOG_PRIMASK) >= 0)
Zbigniew Jędrzejewski-Szmek 126222
-                IOVEC_SET_STRING(iovec[n++], syslog_priority);
Zbigniew Jędrzejewski-Szmek 126222
+        syslog_priority[strlen("PRIORITY=")] = '0' + LOG_PRI(priority);
Zbigniew Jędrzejewski-Szmek 126222
+        IOVEC_SET_STRING(iovec[n++], syslog_priority);
Zbigniew Jędrzejewski-Szmek 126222
 
Zbigniew Jędrzejewski-Szmek 126222
-        if (priority & LOG_FACMASK)
Zbigniew Jędrzejewski-Szmek 126222
-                if (asprintf(&syslog_facility, "SYSLOG_FACILITY=%i", LOG_FAC(priority)) >= 0)
Zbigniew Jędrzejewski-Szmek 126222
-                        IOVEC_SET_STRING(iovec[n++], syslog_facility);
Zbigniew Jędrzejewski-Szmek 126222
+        if (priority & LOG_FACMASK) {
Zbigniew Jędrzejewski-Szmek 126222
+                snprintf(syslog_facility, sizeof(syslog_facility), "SYSLOG_FACILITY=%i", LOG_FAC(priority));
Zbigniew Jędrzejewski-Szmek 126222
+                IOVEC_SET_STRING(iovec[n++], syslog_facility);
Zbigniew Jędrzejewski-Szmek 126222
+        }
Zbigniew Jędrzejewski-Szmek 126222
 
Zbigniew Jędrzejewski-Szmek 126222
         if (s->identifier) {
Zbigniew Jędrzejewski-Szmek 126222
                 syslog_identifier = strappend("SYSLOG_IDENTIFIER=", s->identifier);
Zbigniew Jędrzejewski-Szmek 126222
@@ -408,7 +411,7 @@ fail:
Zbigniew Jędrzejewski-Szmek 126222
 
Zbigniew Jędrzejewski-Szmek 126222
 int server_open_stdout_socket(Server *s) {
Zbigniew Jędrzejewski-Szmek 126222
         int r;
Zbigniew Jędrzejewski-Szmek 126222
-        struct epoll_event ev;
Zbigniew Jędrzejewski-Szmek 126222
+        struct epoll_event ev = { .events = EPOLLIN };
Zbigniew Jędrzejewski-Szmek 126222
 
Zbigniew Jędrzejewski-Szmek 126222
         assert(s);
Zbigniew Jędrzejewski-Szmek 126222
 
Zbigniew Jędrzejewski-Szmek 126222
@@ -441,8 +444,6 @@ int server_open_stdout_socket(Server *s) {
Zbigniew Jędrzejewski-Szmek 126222
         } else
Zbigniew Jędrzejewski-Szmek 126222
                 fd_nonblock(s->stdout_fd, 1);
Zbigniew Jędrzejewski-Szmek 126222
 
Zbigniew Jędrzejewski-Szmek 126222
-        zero(ev);
Zbigniew Jędrzejewski-Szmek 126222
-        ev.events = EPOLLIN;
Zbigniew Jędrzejewski-Szmek 126222
         ev.data.fd = s->stdout_fd;
Zbigniew Jędrzejewski-Szmek 126222
         if (epoll_ctl(s->epoll_fd, EPOLL_CTL_ADD, s->stdout_fd, &ev) < 0) {
Zbigniew Jędrzejewski-Szmek 126222
                 log_error("Failed to add stdout server fd to epoll object: %m");
Zbigniew Jędrzejewski-Szmek 126222
diff --git a/src/journal/journald-syslog.c b/src/journal/journald-syslog.c
Zbigniew Jędrzejewski-Szmek 126222
index c2770a5..5d9b665 100644
Zbigniew Jędrzejewski-Szmek 126222
--- a/src/journal/journald-syslog.c
Zbigniew Jędrzejewski-Szmek 126222
+++ b/src/journal/journald-syslog.c
Zbigniew Jędrzejewski-Szmek 126222
@@ -236,7 +236,7 @@ size_t syslog_parse_identifier(const char **buf, char **identifier, char **pid)
Zbigniew Jędrzejewski-Szmek 126222
         return e;
Zbigniew Jędrzejewski-Szmek 126222
 }
Zbigniew Jędrzejewski-Szmek 126222
 
Zbigniew Jędrzejewski-Szmek 126222
-void syslog_parse_priority(char **p, int *priority, bool with_facility) {
Zbigniew Jędrzejewski-Szmek 126222
+void syslog_parse_priority(const char **p, int *priority, bool with_facility) {
Zbigniew Jędrzejewski-Szmek 126222
         int a = 0, b = 0, c = 0;
Zbigniew Jędrzejewski-Szmek 126222
         int k;
Zbigniew Jędrzejewski-Szmek 126222
 
Zbigniew Jędrzejewski-Szmek 126222
@@ -365,7 +365,7 @@ void server_process_syslog_message(
Zbigniew Jędrzejewski-Szmek 126222
         assert(buf);
Zbigniew Jędrzejewski-Szmek 126222
 
Zbigniew Jędrzejewski-Szmek 126222
         orig = buf;
Zbigniew Jędrzejewski-Szmek 126222
-        syslog_parse_priority((char**) &buf, &priority, true);
Zbigniew Jędrzejewski-Szmek 126222
+        syslog_parse_priority(&buf, &priority, true);
Zbigniew Jędrzejewski-Szmek 126222
 
Zbigniew Jędrzejewski-Szmek 126222
         if (s->forward_to_syslog)
Zbigniew Jędrzejewski-Szmek 126222
                 forward_syslog_raw(s, priority, orig, ucred, tv);
Zbigniew Jędrzejewski-Szmek 126222
diff --git a/src/journal/journald-syslog.h b/src/journal/journald-syslog.h
Zbigniew Jędrzejewski-Szmek 126222
index 8ccdb77..057ea79 100644
Zbigniew Jędrzejewski-Szmek 126222
--- a/src/journal/journald-syslog.h
Zbigniew Jędrzejewski-Szmek 126222
+++ b/src/journal/journald-syslog.h
Zbigniew Jędrzejewski-Szmek 126222
@@ -25,7 +25,7 @@
Zbigniew Jędrzejewski-Szmek 126222
 
Zbigniew Jędrzejewski-Szmek 126222
 int syslog_fixup_facility(int priority) _const_;
Zbigniew Jędrzejewski-Szmek 126222
 
Zbigniew Jędrzejewski-Szmek 126222
-void syslog_parse_priority(char **p, int *priority, bool with_facility);
Zbigniew Jędrzejewski-Szmek 126222
+void syslog_parse_priority(const char **p, int *priority, bool with_facility);
Zbigniew Jędrzejewski-Szmek 126222
 size_t syslog_parse_identifier(const char **buf, char **identifier, char **pid);
Zbigniew Jędrzejewski-Szmek 126222
 
Zbigniew Jędrzejewski-Szmek 126222
 void server_forward_syslog(Server *s, int priority, const char *identifier, const char *message, struct ucred *ucred, struct timeval *tv);