[systemd-devel] [PATCH] Bootchart: allow parse LABEL, UUID, PARTUUID for svg info
Timofey Titovets
nefelim4ag at gmail.com
Mon Oct 27 17:30:13 PDT 2014
Good time of day, list.
I try to fix "Fixme" in svg.c:
/* FIXME: this works only in the simple case */
By default function try to get root=/dev/*
I write small function to determine block device name by specified
LABEL, UUID, PARTUUID.
Please check code, its working, but i think it can look more pretty.
May be i missed(reimplemented) some internal functional of systemd?
I also attach patch to email. Thanks.
From 896ef1c040a6395375e3adcd230bf2b766db633c Mon Sep 17 00:00:00 2001
From: Timofey Titovets <nefelim4ag at gmail.com>
Date: Tue, 28 Oct 2014 03:17:40 +0300
Subject: [PATCH] Bootchart: allow parse LABEL, UUID, PARTUUID for svg info
---
src/bootchart/svg.c | 58
+++++++++++++++++++++++++++++++++++++++++++++++++----
1 file changed, 54 insertions(+), 4 deletions(-)
diff --git a/src/bootchart/svg.c b/src/bootchart/svg.c
index faf377e..a074b71 100644
--- a/src/bootchart/svg.c
+++ b/src/bootchart/svg.c
@@ -32,6 +32,7 @@
#include <sys/utsname.h>
#include <sys/stat.h>
#include <fcntl.h>
+#include <dirent.h>
#include "util.h"
#include "macro.h"
@@ -151,6 +152,57 @@ static void svg_header(void) {
svg(" ]]>\n </style>\n</defs>\n\n");
}
+static void get_root_disk(const char *cmdline, char *rootbdev) {
+ char *ptr = strstr(cmdline, "root=");
+ char path[PATH_MAX]="";
+ char dev_path[PATH_MAX]="";
+ DIR *d;
+ struct dirent *dir;
+
+ if (!ptr)
+ goto out;
+
+ ptr = &ptr[5];
+ if (ptr[0] == '/') {
+ ptr = &ptr[5];
+ strncpy(rootbdev, ptr, 3);
+ rootbdev[3] = '\0';
+ return;
+ }
+
+ d = opendir("/dev/disk/");
+ if (!d)
+ goto out;
+
+ if (!strncmp("LABEL", ptr, 5))
+ strncpy(path, "/dev/disk/by-label/", 30);
+ else if (!strncmp("UUID", ptr, 4))
+ strncpy(path, "/dev/disk/by-uuid/", 30);
+ else if (!strncmp("PARTUUID", ptr, 8))
+ strncpy(path, "/dev/disk/by-partuuid/", 30);
+
+ ptr = strstr(ptr, "=");
+ ptr++;
+ ptr = strtok(ptr," ");
+
+ d = opendir(path);
+
+ while ((dir = readdir(d)) != NULL) {
+ if (!strncmp(dir->d_name, ptr, 32)) {
+ break;
+ }
+ }
+
+ strcat(path, ptr);
+ readlink (path, dev_path, sizeof(dev_path));
+ ptr = &dev_path[6];
+ strncpy(rootbdev, ptr, 3);
+ rootbdev[3] = '\0';
+
+out:
+ closedir(d);
+}
+
static void svg_title(const char *build) {
char cmdline[256] = "";
char filename[PATH_MAX];
@@ -175,11 +227,9 @@ static void svg_title(const char *build) {
}
/* extract root fs so we can find disk model name in sysfs */
- /* FIXME: this works only in the simple case */
- c = strstr(cmdline, "root=/dev/");
+ c = strstr(cmdline, "root=");
if (c) {
- strncpy(rootbdev, &c[10], 3);
- rootbdev[3] = '\0';
+ get_root_disk(cmdline, rootbdev);
sprintf(filename, "block/%s/device/model", rootbdev);
fd = openat(sysfd, filename, O_RDONLY);
f = fdopen(fd, "r");
--
2.1.2
-------------- next part --------------
A non-text attachment was scrubbed...
Name: 0001-Bootchart-allow-parse-LABEL-UUID-PARTUUID-for-svg-in.patch
Type: text/x-patch
Size: 2858 bytes
Desc: not available
URL: <http://lists.freedesktop.org/archives/systemd-devel/attachments/20141028/78c1bb6c/attachment-0001.bin>
More information about the systemd-devel
mailing list