mirror of
https://github.com/systemd/systemd-stable.git
synced 2025-01-11 05:17:44 +03:00
Merge pull request #15251 from keszybz/coverity-fixes
A few small fixups for stuff found by coverity
This commit is contained in:
commit
fef7397022
@ -171,6 +171,7 @@ basic_sources = files('''
|
|||||||
process-util.h
|
process-util.h
|
||||||
procfs-util.c
|
procfs-util.c
|
||||||
procfs-util.h
|
procfs-util.h
|
||||||
|
pthread-util.h
|
||||||
quota-util.c
|
quota-util.c
|
||||||
quota-util.h
|
quota-util.h
|
||||||
random-util.c
|
random-util.c
|
||||||
|
16
src/basic/pthread-util.h
Normal file
16
src/basic/pthread-util.h
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
/* SPDX-License-Identifier: LGPL-2.1+ */
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <pthread.h>
|
||||||
|
|
||||||
|
#include "macro.h"
|
||||||
|
|
||||||
|
static inline pthread_mutex_t* pthread_mutex_lock_assert(pthread_mutex_t *mutex) {
|
||||||
|
assert_se(pthread_mutex_lock(mutex) == 0);
|
||||||
|
return mutex;
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void pthread_mutex_unlock_assertp(pthread_mutex_t **mutexp) {
|
||||||
|
if (*mutexp)
|
||||||
|
assert_se(pthread_mutex_unlock(*mutexp) == 0);
|
||||||
|
}
|
@ -9,6 +9,7 @@
|
|||||||
#include "group-record-nss.h"
|
#include "group-record-nss.h"
|
||||||
#include "macro.h"
|
#include "macro.h"
|
||||||
#include "nss-util.h"
|
#include "nss-util.h"
|
||||||
|
#include "pthread-util.h"
|
||||||
#include "signal-util.h"
|
#include "signal-util.h"
|
||||||
#include "strv.h"
|
#include "strv.h"
|
||||||
#include "user-util.h"
|
#include "user-util.h"
|
||||||
@ -277,10 +278,11 @@ static enum nss_status nss_systemd_endent(GetentData *p) {
|
|||||||
|
|
||||||
assert(p);
|
assert(p);
|
||||||
|
|
||||||
assert_se(pthread_mutex_lock(&p->mutex) == 0);
|
_cleanup_(pthread_mutex_unlock_assertp) pthread_mutex_t *_l = NULL;
|
||||||
|
_l = pthread_mutex_lock_assert(&p->mutex);
|
||||||
|
|
||||||
p->iterator = userdb_iterator_free(p->iterator);
|
p->iterator = userdb_iterator_free(p->iterator);
|
||||||
p->by_membership = false;
|
p->by_membership = false;
|
||||||
assert_se(pthread_mutex_unlock(&p->mutex) == 0);
|
|
||||||
|
|
||||||
return NSS_STATUS_SUCCESS;
|
return NSS_STATUS_SUCCESS;
|
||||||
}
|
}
|
||||||
@ -294,45 +296,41 @@ enum nss_status _nss_systemd_endgrent(void) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
enum nss_status _nss_systemd_setpwent(int stayopen) {
|
enum nss_status _nss_systemd_setpwent(int stayopen) {
|
||||||
enum nss_status ret;
|
|
||||||
|
|
||||||
PROTECT_ERRNO;
|
PROTECT_ERRNO;
|
||||||
BLOCK_SIGNALS(NSS_SIGNALS_BLOCK);
|
BLOCK_SIGNALS(NSS_SIGNALS_BLOCK);
|
||||||
|
|
||||||
if (userdb_nss_compat_is_enabled() <= 0)
|
if (userdb_nss_compat_is_enabled() <= 0)
|
||||||
return NSS_STATUS_NOTFOUND;
|
return NSS_STATUS_NOTFOUND;
|
||||||
|
|
||||||
assert_se(pthread_mutex_lock(&getpwent_data.mutex) == 0);
|
_cleanup_(pthread_mutex_unlock_assertp) pthread_mutex_t *_l = NULL;
|
||||||
|
int r;
|
||||||
|
|
||||||
|
_l = pthread_mutex_lock_assert(&getpwent_data.mutex);
|
||||||
|
|
||||||
getpwent_data.iterator = userdb_iterator_free(getpwent_data.iterator);
|
getpwent_data.iterator = userdb_iterator_free(getpwent_data.iterator);
|
||||||
getpwent_data.by_membership = false;
|
getpwent_data.by_membership = false;
|
||||||
|
|
||||||
ret = userdb_all(nss_glue_userdb_flags(), &getpwent_data.iterator) < 0 ?
|
r = userdb_all(nss_glue_userdb_flags(), &getpwent_data.iterator);
|
||||||
NSS_STATUS_UNAVAIL : NSS_STATUS_SUCCESS;
|
return r < 0 ? NSS_STATUS_UNAVAIL : NSS_STATUS_SUCCESS;
|
||||||
|
|
||||||
assert_se(pthread_mutex_unlock(&getpwent_data.mutex) == 0);
|
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
enum nss_status _nss_systemd_setgrent(int stayopen) {
|
enum nss_status _nss_systemd_setgrent(int stayopen) {
|
||||||
enum nss_status ret;
|
|
||||||
|
|
||||||
PROTECT_ERRNO;
|
PROTECT_ERRNO;
|
||||||
BLOCK_SIGNALS(NSS_SIGNALS_BLOCK);
|
BLOCK_SIGNALS(NSS_SIGNALS_BLOCK);
|
||||||
|
|
||||||
if (userdb_nss_compat_is_enabled() <= 0)
|
if (userdb_nss_compat_is_enabled() <= 0)
|
||||||
return NSS_STATUS_NOTFOUND;
|
return NSS_STATUS_NOTFOUND;
|
||||||
|
|
||||||
assert_se(pthread_mutex_lock(&getgrent_data.mutex) == 0);
|
_cleanup_(pthread_mutex_unlock_assertp) pthread_mutex_t *_l = NULL;
|
||||||
|
int r;
|
||||||
|
|
||||||
|
_l = pthread_mutex_lock_assert(&getgrent_data.mutex);
|
||||||
|
|
||||||
getgrent_data.iterator = userdb_iterator_free(getgrent_data.iterator);
|
getgrent_data.iterator = userdb_iterator_free(getgrent_data.iterator);
|
||||||
getpwent_data.by_membership = false;
|
getpwent_data.by_membership = false;
|
||||||
|
|
||||||
ret = groupdb_all(nss_glue_userdb_flags(), &getgrent_data.iterator) < 0 ?
|
r = groupdb_all(nss_glue_userdb_flags(), &getgrent_data.iterator);
|
||||||
NSS_STATUS_UNAVAIL : NSS_STATUS_SUCCESS;
|
return r < 0 ? NSS_STATUS_UNAVAIL : NSS_STATUS_SUCCESS;
|
||||||
|
|
||||||
assert_se(pthread_mutex_unlock(&getgrent_data.mutex) == 0);
|
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
enum nss_status _nss_systemd_getpwent_r(
|
enum nss_status _nss_systemd_getpwent_r(
|
||||||
@ -341,7 +339,6 @@ enum nss_status _nss_systemd_getpwent_r(
|
|||||||
int *errnop) {
|
int *errnop) {
|
||||||
|
|
||||||
_cleanup_(user_record_unrefp) UserRecord *ur = NULL;
|
_cleanup_(user_record_unrefp) UserRecord *ur = NULL;
|
||||||
enum nss_status ret;
|
|
||||||
int r;
|
int r;
|
||||||
|
|
||||||
PROTECT_ERRNO;
|
PROTECT_ERRNO;
|
||||||
@ -359,40 +356,33 @@ enum nss_status _nss_systemd_getpwent_r(
|
|||||||
if (!r)
|
if (!r)
|
||||||
return NSS_STATUS_NOTFOUND;
|
return NSS_STATUS_NOTFOUND;
|
||||||
|
|
||||||
assert_se(pthread_mutex_lock(&getpwent_data.mutex) == 0);
|
_cleanup_(pthread_mutex_unlock_assertp) pthread_mutex_t *_l = NULL;
|
||||||
|
|
||||||
|
_l = pthread_mutex_lock_assert(&getpwent_data.mutex);
|
||||||
|
|
||||||
if (!getpwent_data.iterator) {
|
if (!getpwent_data.iterator) {
|
||||||
UNPROTECT_ERRNO;
|
UNPROTECT_ERRNO;
|
||||||
*errnop = EHOSTDOWN;
|
*errnop = EHOSTDOWN;
|
||||||
ret = NSS_STATUS_UNAVAIL;
|
return NSS_STATUS_UNAVAIL;
|
||||||
goto finish;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
r = userdb_iterator_get(getpwent_data.iterator, &ur);
|
r = userdb_iterator_get(getpwent_data.iterator, &ur);
|
||||||
if (r == -ESRCH) {
|
if (r == -ESRCH)
|
||||||
ret = NSS_STATUS_NOTFOUND;
|
return NSS_STATUS_NOTFOUND;
|
||||||
goto finish;
|
|
||||||
}
|
|
||||||
if (r < 0) {
|
if (r < 0) {
|
||||||
UNPROTECT_ERRNO;
|
UNPROTECT_ERRNO;
|
||||||
*errnop = -r;
|
*errnop = -r;
|
||||||
ret = NSS_STATUS_UNAVAIL;
|
return NSS_STATUS_UNAVAIL;
|
||||||
goto finish;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
r = nss_pack_user_record(ur, result, buffer, buflen);
|
r = nss_pack_user_record(ur, result, buffer, buflen);
|
||||||
if (r < 0) {
|
if (r < 0) {
|
||||||
UNPROTECT_ERRNO;
|
UNPROTECT_ERRNO;
|
||||||
*errnop = -r;
|
*errnop = -r;
|
||||||
ret = NSS_STATUS_TRYAGAIN;
|
return NSS_STATUS_TRYAGAIN;
|
||||||
goto finish;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = NSS_STATUS_SUCCESS;
|
return NSS_STATUS_SUCCESS;
|
||||||
|
|
||||||
finish:
|
|
||||||
assert_se(pthread_mutex_unlock(&getpwent_data.mutex) == 0);
|
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
enum nss_status _nss_systemd_getgrent_r(
|
enum nss_status _nss_systemd_getgrent_r(
|
||||||
@ -402,7 +392,6 @@ enum nss_status _nss_systemd_getgrent_r(
|
|||||||
|
|
||||||
_cleanup_(group_record_unrefp) GroupRecord *gr = NULL;
|
_cleanup_(group_record_unrefp) GroupRecord *gr = NULL;
|
||||||
_cleanup_free_ char **members = NULL;
|
_cleanup_free_ char **members = NULL;
|
||||||
enum nss_status ret;
|
|
||||||
int r;
|
int r;
|
||||||
|
|
||||||
PROTECT_ERRNO;
|
PROTECT_ERRNO;
|
||||||
@ -420,19 +409,20 @@ enum nss_status _nss_systemd_getgrent_r(
|
|||||||
if (!r)
|
if (!r)
|
||||||
return NSS_STATUS_UNAVAIL;
|
return NSS_STATUS_UNAVAIL;
|
||||||
|
|
||||||
assert_se(pthread_mutex_lock(&getgrent_data.mutex) == 0);
|
_cleanup_(pthread_mutex_unlock_assertp) pthread_mutex_t *_l = NULL;
|
||||||
|
|
||||||
|
_l = pthread_mutex_lock_assert(&getgrent_data.mutex);
|
||||||
|
|
||||||
if (!getgrent_data.iterator) {
|
if (!getgrent_data.iterator) {
|
||||||
UNPROTECT_ERRNO;
|
UNPROTECT_ERRNO;
|
||||||
*errnop = EHOSTDOWN;
|
*errnop = EHOSTDOWN;
|
||||||
ret = NSS_STATUS_UNAVAIL;
|
return NSS_STATUS_UNAVAIL;
|
||||||
goto finish;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!getgrent_data.by_membership) {
|
if (!getgrent_data.by_membership) {
|
||||||
r = groupdb_iterator_get(getgrent_data.iterator, &gr);
|
r = groupdb_iterator_get(getgrent_data.iterator, &gr);
|
||||||
if (r == -ESRCH) {
|
if (r == -ESRCH) {
|
||||||
/* So we finished iterating native groups now. let's now continue with iterating
|
/* So we finished iterating native groups now. Let's now continue with iterating
|
||||||
* native memberships, and generate additional group entries for any groups
|
* native memberships, and generate additional group entries for any groups
|
||||||
* referenced there that are defined in NSS only. This means for those groups there
|
* referenced there that are defined in NSS only. This means for those groups there
|
||||||
* will be two or more entries generated during iteration, but this is apparently how
|
* will be two or more entries generated during iteration, but this is apparently how
|
||||||
@ -444,23 +434,20 @@ enum nss_status _nss_systemd_getgrent_r(
|
|||||||
if (r < 0) {
|
if (r < 0) {
|
||||||
UNPROTECT_ERRNO;
|
UNPROTECT_ERRNO;
|
||||||
*errnop = -r;
|
*errnop = -r;
|
||||||
ret = NSS_STATUS_UNAVAIL;
|
return NSS_STATUS_UNAVAIL;
|
||||||
goto finish;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
getgrent_data.by_membership = true;
|
getgrent_data.by_membership = true;
|
||||||
} else if (r < 0) {
|
} else if (r < 0) {
|
||||||
UNPROTECT_ERRNO;
|
UNPROTECT_ERRNO;
|
||||||
*errnop = -r;
|
*errnop = -r;
|
||||||
ret = NSS_STATUS_UNAVAIL;
|
return NSS_STATUS_UNAVAIL;
|
||||||
goto finish;
|
|
||||||
} else if (!STR_IN_SET(gr->group_name, root_group.gr_name, nobody_group.gr_name)) {
|
} else if (!STR_IN_SET(gr->group_name, root_group.gr_name, nobody_group.gr_name)) {
|
||||||
r = membershipdb_by_group_strv(gr->group_name, nss_glue_userdb_flags(), &members);
|
r = membershipdb_by_group_strv(gr->group_name, nss_glue_userdb_flags(), &members);
|
||||||
if (r < 0) {
|
if (r < 0) {
|
||||||
UNPROTECT_ERRNO;
|
UNPROTECT_ERRNO;
|
||||||
*errnop = -r;
|
*errnop = -r;
|
||||||
ret = NSS_STATUS_UNAVAIL;
|
return NSS_STATUS_UNAVAIL;
|
||||||
goto finish;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -472,15 +459,12 @@ enum nss_status _nss_systemd_getgrent_r(
|
|||||||
_cleanup_free_ char *user_name = NULL, *group_name = NULL;
|
_cleanup_free_ char *user_name = NULL, *group_name = NULL;
|
||||||
|
|
||||||
r = membershipdb_iterator_get(getgrent_data.iterator, &user_name, &group_name);
|
r = membershipdb_iterator_get(getgrent_data.iterator, &user_name, &group_name);
|
||||||
if (r == -ESRCH) {
|
if (r == -ESRCH)
|
||||||
ret = NSS_STATUS_NOTFOUND;
|
return NSS_STATUS_NOTFOUND;
|
||||||
goto finish;
|
|
||||||
}
|
|
||||||
if (r < 0) {
|
if (r < 0) {
|
||||||
UNPROTECT_ERRNO;
|
UNPROTECT_ERRNO;
|
||||||
*errnop = -r;
|
*errnop = -r;
|
||||||
ret = NSS_STATUS_UNAVAIL;
|
return NSS_STATUS_UNAVAIL;
|
||||||
goto finish;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (STR_IN_SET(user_name, root_passwd.pw_name, nobody_passwd.pw_name))
|
if (STR_IN_SET(user_name, root_passwd.pw_name, nobody_passwd.pw_name))
|
||||||
@ -494,8 +478,7 @@ enum nss_status _nss_systemd_getgrent_r(
|
|||||||
if (lock_fd < 0 && lock_fd != -EBUSY) {
|
if (lock_fd < 0 && lock_fd != -EBUSY) {
|
||||||
UNPROTECT_ERRNO;
|
UNPROTECT_ERRNO;
|
||||||
*errnop = -lock_fd;
|
*errnop = -lock_fd;
|
||||||
ret = NSS_STATUS_UNAVAIL;
|
return NSS_STATUS_UNAVAIL;
|
||||||
goto finish;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -525,15 +508,10 @@ enum nss_status _nss_systemd_getgrent_r(
|
|||||||
if (r < 0) {
|
if (r < 0) {
|
||||||
UNPROTECT_ERRNO;
|
UNPROTECT_ERRNO;
|
||||||
*errnop = -r;
|
*errnop = -r;
|
||||||
ret = NSS_STATUS_TRYAGAIN;
|
return NSS_STATUS_TRYAGAIN;
|
||||||
goto finish;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = NSS_STATUS_SUCCESS;
|
return NSS_STATUS_SUCCESS;
|
||||||
|
|
||||||
finish:
|
|
||||||
assert_se(pthread_mutex_unlock(&getgrent_data.mutex) == 0);
|
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
enum nss_status _nss_systemd_initgroups_dyn(
|
enum nss_status _nss_systemd_initgroups_dyn(
|
||||||
|
@ -674,7 +674,7 @@ static void test_strv_push_prepend(void) {
|
|||||||
|
|
||||||
log_info("/* %s */", __func__);
|
log_info("/* %s */", __func__);
|
||||||
|
|
||||||
a = strv_new("foo", "bar", "three");
|
assert_se(a = strv_new("foo", "bar", "three"));
|
||||||
|
|
||||||
assert_se(strv_push_prepend(&a, strdup("first")) >= 0);
|
assert_se(strv_push_prepend(&a, strdup("first")) >= 0);
|
||||||
assert_se(streq(a[0], "first"));
|
assert_se(streq(a[0], "first"));
|
||||||
|
Loading…
Reference in New Issue
Block a user