[PATCH 29/67] policycoreutils: restorecon: Always check return code

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA1


This patch looks good to me. acked.
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1.4.11 (GNU/Linux)
Comment: Using GnuPG with Mozilla - http://enigmail.mozdev.org/

iEYEARECAAYFAk5yVEIACgkQrlYvE4MpobPnDgCeLJ+2tDou34px2EYbS46HyP5K
l40AoKyRBpUa64iE9VSJ+kdfx5PAsK7p
=zSIU
-----END PGP SIGNATURE-----
>From 98dbff2fd2fe41d96b40ee0adc82a4c815ff0733 Mon Sep 17 00:00:00 2001
From: Dan Walsh <dwalsh@xxxxxxxxxx>
Date: Tue, 9 Aug 2011 09:58:53 -0400
Subject: [PATCH 29/67] policycoreutils: restorecon: Always check return code
 on asprintf

Do not assume it is always a success and error gracefully when it isn't.

Signed-off-by: Eric Paris <eparis@xxxxxxxxxx>
Acked-by: Dan Walsh <dwalsh@xxxxxxxxxx>
---
 policycoreutils/restorecond/user.c  |    6 +++++-
 policycoreutils/restorecond/watch.c |    4 +++-
 2 files changed, 8 insertions(+), 2 deletions(-)

diff --git a/policycoreutils/restorecond/user.c b/policycoreutils/restorecond/user.c
index c315b99..ade3fb8 100644
--- a/policycoreutils/restorecond/user.c
+++ b/policycoreutils/restorecond/user.c
@@ -190,7 +190,11 @@ int start() {
 static int local_server() {
 	// ! dbus, run as local service
 	char *ptr=NULL;
-	asprintf(&ptr, "%s/.restorecond", homedir);
+	if (asprintf(&ptr, "%s/.restorecond", homedir) < 0) {
+		if (debug_mode)
+			perror("asprintf");
+		return -1;
+	}
 	int fd = open(ptr, O_CREAT | O_WRONLY | O_NOFOLLOW, S_IRUSR | S_IWUSR);
 	if (debug_mode)
 		g_warning ("Lock file: %s", ptr);
diff --git a/policycoreutils/restorecond/watch.c b/policycoreutils/restorecond/watch.c
index d9e321e..6a833c3 100644
--- a/policycoreutils/restorecond/watch.c
+++ b/policycoreutils/restorecond/watch.c
@@ -226,7 +226,9 @@ static void process_config(int fd, FILE * cfg)
 		if (buffer[0] == '~') {
 			if (run_as_user) {
 				char *ptr=NULL;
-				asprintf(&ptr, "%s%s", homedir, &buffer[1]);
+				if (asprintf(&ptr, "%s%s", homedir, &buffer[1]) < 0)
+					exitApp("Error allocating memory.");
+
 				watch_list_add(fd, ptr);
 				free(ptr);
 			} else {
-- 
1.7.6.2


[Index of Archives]     [Selinux Refpolicy]     [Linux SGX]     [Fedora Users]     [Fedora Desktop]     [Yosemite Photos]     [Yosemite Camping]     [Yosemite Campsites]     [KDE Users]     [Gnome Users]

  Powered by Linux