Accepting request 451693 from GNOME:Factory
Versionbump and patch, supersede OBS-URL: https://build.opensuse.org/request/show/451693 OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/libgtop?expand=0&rev=54
This commit is contained in:
commit
c9e0b30add
@ -1,3 +0,0 @@
|
|||||||
version https://git-lfs.github.com/spec/v1
|
|
||||||
oid sha256:c89978a76662b18d392edbe0d1b794f5a9a399a5ccf22a02d5b9e28b5ed609e2
|
|
||||||
size 726676
|
|
3
libgtop-2.34.2.tar.xz
Normal file
3
libgtop-2.34.2.tar.xz
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
version https://git-lfs.github.com/spec/v1
|
||||||
|
oid sha256:268ad1478363e8c0955ea842fa134f6eb88965ab5e03166c20d8df9e7a1f8ef8
|
||||||
|
size 725720
|
137
libgtop-bsc1020294-cpu-buffer.patch
Normal file
137
libgtop-bsc1020294-cpu-buffer.patch
Normal file
@ -0,0 +1,137 @@
|
|||||||
|
From b22fddaaa5dc3d667f4b5168c7e95979cf8f7910 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Mike Gorse <mgorse@suse.com>
|
||||||
|
Date: Wed, 18 Jan 2017 16:40:52 -0600
|
||||||
|
Subject: [PATCH] linux: Dynamically allocate the buffer to parse /proc/cpuinfo
|
||||||
|
|
||||||
|
On a server with many cores, /proc/cpuinfo might contain more than 64k of
|
||||||
|
data, so we weren't fully parsing it, meaning that we'd see fewer cores than
|
||||||
|
were present.
|
||||||
|
|
||||||
|
https://bugzilla.gnome.org/show_bug.cgi?id=323354
|
||||||
|
---
|
||||||
|
sysdeps/linux/glibtop_private.c | 63 +++++++++++++++++++++++++++++++++++++++++
|
||||||
|
sysdeps/linux/glibtop_private.h | 4 +++
|
||||||
|
sysdeps/linux/sysinfo.c | 6 ++--
|
||||||
|
3 files changed, 71 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/sysdeps/linux/glibtop_private.c b/sysdeps/linux/glibtop_private.c
|
||||||
|
index 52c3782..8c50723 100644
|
||||||
|
--- a/sysdeps/linux/glibtop_private.c
|
||||||
|
+++ b/sysdeps/linux/glibtop_private.c
|
||||||
|
@@ -133,7 +133,70 @@ file_to_buffer(glibtop *server, char *buffer, size_t bufsiz, const char *filenam
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
+char *file_to_buffer_alloc(const char *format, ...)
|
||||||
|
+{
|
||||||
|
+ char path[4096];
|
||||||
|
+ int fd;
|
||||||
|
+ char *buffer = NULL;
|
||||||
|
+ size_t len = 0;
|
||||||
|
+ size_t bufsiz = 16384;
|
||||||
|
+ ssize_t nread = 0;
|
||||||
|
+ va_list pa;
|
||||||
|
+
|
||||||
|
+ va_start(pa, format);
|
||||||
|
+
|
||||||
|
+ /* C99 also provides vsnprintf */
|
||||||
|
+ g_vsnprintf(path, sizeof path, format, pa);
|
||||||
|
|
||||||
|
+ va_end(pa);
|
||||||
|
+
|
||||||
|
+ buffer = (char *)malloc(bufsiz);
|
||||||
|
+ if (!buffer)
|
||||||
|
+ return NULL;
|
||||||
|
+
|
||||||
|
+ buffer [0] = '\0';
|
||||||
|
+
|
||||||
|
+ if((fd = open (path, O_RDONLY)) < 0)
|
||||||
|
+ return NULL;
|
||||||
|
+
|
||||||
|
+ for (;;) {
|
||||||
|
+ nread = read (fd, buffer + len, bufsiz - len - 1);
|
||||||
|
+
|
||||||
|
+ if (G_UNLIKELY(nread < 0)) {
|
||||||
|
+ if (errno == EINTR)
|
||||||
|
+ continue;
|
||||||
|
+ else
|
||||||
|
+ break;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ len += nread;
|
||||||
|
+
|
||||||
|
+ if (nread == 0)
|
||||||
|
+ break;
|
||||||
|
+
|
||||||
|
+ if (len >= bufsiz - 1) {
|
||||||
|
+ char *new;
|
||||||
|
+ bufsiz *= 2;
|
||||||
|
+ new = realloc (buffer, bufsiz);
|
||||||
|
+ if (!new) {
|
||||||
|
+ free (buffer);
|
||||||
|
+ return NULL;
|
||||||
|
+ }
|
||||||
|
+ buffer = new;
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ close (fd);
|
||||||
|
+
|
||||||
|
+ if (nread < 0) {
|
||||||
|
+ free (buffer);
|
||||||
|
+ return NULL;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ buffer [len] = '\0';
|
||||||
|
+
|
||||||
|
+ return buffer;
|
||||||
|
+}
|
||||||
|
|
||||||
|
|
||||||
|
static unsigned long
|
||||||
|
diff --git a/sysdeps/linux/glibtop_private.h b/sysdeps/linux/glibtop_private.h
|
||||||
|
index 149832a..0ff2ea0 100644
|
||||||
|
--- a/sysdeps/linux/glibtop_private.h
|
||||||
|
+++ b/sysdeps/linux/glibtop_private.h
|
||||||
|
@@ -78,6 +78,10 @@ file_to_buffer(glibtop *server, char *buffer, size_t bufsiz, const char *filenam
|
||||||
|
int
|
||||||
|
try_file_to_buffer(char *buffer, size_t bufsiz, const char *format, ...) G_GNUC_PRINTF(3, 4);
|
||||||
|
|
||||||
|
+/* Returns an allocated buffer to be freed with free(), or NULL on error */
|
||||||
|
+char *
|
||||||
|
+file_to_buffer_alloc(const char *format, ...) G_GNUC_PRINTF(1, 2);
|
||||||
|
+
|
||||||
|
|
||||||
|
/* some inline functions that wrap proc path
|
||||||
|
* as fast as macros :)
|
||||||
|
diff --git a/sysdeps/linux/sysinfo.c b/sysdeps/linux/sysinfo.c
|
||||||
|
index bd80b0d..14bfd8b 100644
|
||||||
|
--- a/sysdeps/linux/sysinfo.c
|
||||||
|
+++ b/sysdeps/linux/sysinfo.c
|
||||||
|
@@ -36,12 +36,13 @@ static glibtop_sysinfo sysinfo = { .flags = 0 };
|
||||||
|
static void
|
||||||
|
init_sysinfo (glibtop *server)
|
||||||
|
{
|
||||||
|
- char buffer [65536];
|
||||||
|
+ char *buffer;
|
||||||
|
gchar ** processors;
|
||||||
|
|
||||||
|
if(G_LIKELY(sysinfo.flags)) return;
|
||||||
|
|
||||||
|
- file_to_buffer(server, buffer, sizeof buffer, FILENAME);
|
||||||
|
+ buffer = file_to_buffer_alloc(FILENAME);
|
||||||
|
+ if (!buffer) return;
|
||||||
|
|
||||||
|
/* cpuinfo records are seperated by a blank line */
|
||||||
|
processors = g_strsplit(buffer, "\n\n", 0);
|
||||||
|
@@ -88,6 +89,7 @@ init_sysinfo (glibtop *server)
|
||||||
|
}
|
||||||
|
|
||||||
|
g_strfreev(processors);
|
||||||
|
+ g_free(buffer);
|
||||||
|
|
||||||
|
sysinfo.flags = _glibtop_sysdeps_sysinfo;
|
||||||
|
}
|
||||||
|
--
|
||||||
|
2.6.6
|
||||||
|
|
@ -1,3 +1,19 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Thu Jan 19 17:29:25 UTC 2017 - mgorse@suse.com
|
||||||
|
|
||||||
|
- Add libgtop-bsc1020294-cpu-buffer.patch: dynamically allocate
|
||||||
|
memory for buffer when reading /proc/cpuinfo (bsc#1020294
|
||||||
|
bgo#323354).
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Mon Jan 16 20:39:12 UTC 2017 - zaitor@opensuse.org
|
||||||
|
|
||||||
|
- Update to version 2.34.2:
|
||||||
|
+ Linux: fill last_processor member.
|
||||||
|
+ Added more gettext options.
|
||||||
|
+ Updated translations.
|
||||||
|
- Add url to upstream developer page, silence rpmlint.
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Thu Dec 1 16:05:29 UTC 2016 - dimstar@opensuse.org
|
Thu Dec 1 16:05:29 UTC 2016 - dimstar@opensuse.org
|
||||||
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
#
|
#
|
||||||
# spec file for package libgtop
|
# spec file for package libgtop
|
||||||
#
|
#
|
||||||
# Copyright (c) 2016 SUSE LINUX GmbH, Nuernberg, Germany.
|
# Copyright (c) 2017 SUSE LINUX GmbH, Nuernberg, Germany.
|
||||||
#
|
#
|
||||||
# All modifications and additions to the file contributed by third parties
|
# All modifications and additions to the file contributed by third parties
|
||||||
# remain the property of their copyright owners, unless otherwise agreed
|
# remain the property of their copyright owners, unless otherwise agreed
|
||||||
@ -17,14 +17,17 @@
|
|||||||
|
|
||||||
|
|
||||||
Name: libgtop
|
Name: libgtop
|
||||||
Version: 2.34.1
|
Version: 2.34.2
|
||||||
Release: 0
|
Release: 0
|
||||||
%define soname 10
|
%define soname 10
|
||||||
Summary: LibGTop Library
|
Summary: LibGTop Library
|
||||||
License: GPL-2.0+
|
License: GPL-2.0+
|
||||||
Group: System/Libraries
|
Group: System/Libraries
|
||||||
|
Url: https://developer.gnome.org/libgtop/stable/
|
||||||
Source: http://download.gnome.org/sources/libgtop/2.34/%{name}-%{version}.tar.xz
|
Source: http://download.gnome.org/sources/libgtop/2.34/%{name}-%{version}.tar.xz
|
||||||
Source99: baselibs.conf
|
Source99: baselibs.conf
|
||||||
|
# PATCH-FIX-UPSTREAM libgtop-bsc1020294-cpu-buffer.patch bsc#1020294 bgo#323354 mgorse@suse.com -- dynamically allocate buffer when reading /proc/cpuinfo.
|
||||||
|
Patch0: libgtop-bsc1020294-cpu-buffer.patch
|
||||||
BuildRequires: fdupes
|
BuildRequires: fdupes
|
||||||
BuildRequires: glib2-devel
|
BuildRequires: glib2-devel
|
||||||
BuildRequires: gobject-introspection-devel
|
BuildRequires: gobject-introspection-devel
|
||||||
@ -111,6 +114,7 @@ from /dev/kmem.
|
|||||||
%lang_package
|
%lang_package
|
||||||
%prep
|
%prep
|
||||||
%setup -q
|
%setup -q
|
||||||
|
%patch0 -p1
|
||||||
%if !0%{?is_opensuse}
|
%if !0%{?is_opensuse}
|
||||||
translation-update-upstream po libgtop
|
translation-update-upstream po libgtop
|
||||||
# rpmlint note: libgtop has a separate translation for both Bengali and Bengali India
|
# rpmlint note: libgtop has a separate translation for both Bengali and Bengali India
|
||||||
|
Loading…
Reference in New Issue
Block a user