teknoraver / rpms / systemd

Forked from rpms/systemd 2 months ago
Clone

Blame 0014-basic-journal-importer-Fix-unaligned-access-in-get_d.patch

Zbigniew Jędrzejewski-Szmek d743bb
From a7637ee87936b9530b0ed56b5520a3e22bd04f94 Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek d743bb
From: John Paul Adrian Glaubitz <glaubitz@physik.fu-berlin.de>
Zbigniew Jędrzejewski-Szmek d743bb
Date: Wed, 22 Mar 2017 03:36:50 +0100
Zbigniew Jędrzejewski-Szmek d743bb
Subject: [PATCH] basic/journal-importer: Fix unaligned access in
Zbigniew Jędrzejewski-Szmek d743bb
 get_data_size() (#5622)
Zbigniew Jędrzejewski-Szmek d743bb
Zbigniew Jędrzejewski-Szmek d743bb
(cherry picked from commit f652c62d71a412704efe7c73c2066d1baaf83456)
Zbigniew Jędrzejewski-Szmek d743bb
---
Zbigniew Jędrzejewski-Szmek d743bb
 src/basic/journal-importer.c | 3 ++-
Zbigniew Jędrzejewski-Szmek d743bb
 1 file changed, 2 insertions(+), 1 deletion(-)
Zbigniew Jędrzejewski-Szmek d743bb
Zbigniew Jędrzejewski-Szmek d743bb
diff --git a/src/basic/journal-importer.c b/src/basic/journal-importer.c
Zbigniew Jędrzejewski-Szmek d743bb
index d25fd358e8..66119d2de1 100644
Zbigniew Jędrzejewski-Szmek d743bb
--- a/src/basic/journal-importer.c
Zbigniew Jędrzejewski-Szmek d743bb
+++ b/src/basic/journal-importer.c
Zbigniew Jędrzejewski-Szmek d743bb
@@ -24,6 +24,7 @@
Zbigniew Jędrzejewski-Szmek d743bb
 #include "fd-util.h"
Zbigniew Jędrzejewski-Szmek d743bb
 #include "parse-util.h"
Zbigniew Jędrzejewski-Szmek d743bb
 #include "string-util.h"
Zbigniew Jędrzejewski-Szmek d743bb
+#include "unaligned.h"
Zbigniew Jędrzejewski-Szmek d743bb
 
Zbigniew Jędrzejewski-Szmek d743bb
 enum {
Zbigniew Jędrzejewski-Szmek d743bb
         IMPORTER_STATE_LINE = 0,    /* waiting to read, or reading line */
Zbigniew Jędrzejewski-Szmek d743bb
@@ -203,7 +204,7 @@ static int get_data_size(JournalImporter *imp) {
Zbigniew Jędrzejewski-Szmek d743bb
         if (r <= 0)
Zbigniew Jędrzejewski-Szmek d743bb
                 return r;
Zbigniew Jędrzejewski-Szmek d743bb
 
Zbigniew Jędrzejewski-Szmek d743bb
-        imp->data_size = le64toh( *(uint64_t *) data );
Zbigniew Jędrzejewski-Szmek d743bb
+        imp->data_size = unaligned_read_le64(data);
Zbigniew Jędrzejewski-Szmek d743bb
         if (imp->data_size > DATA_SIZE_MAX) {
Zbigniew Jędrzejewski-Szmek d743bb
                 log_error("Stream declares field with size %zu > DATA_SIZE_MAX = %u",
Zbigniew Jędrzejewski-Szmek d743bb
                           imp->data_size, DATA_SIZE_MAX);