d284b82b3e
This doesn't have much effect on the final build, because we link libbasic.a into libsystemd-shared.so, so in the end, all the object built from basic/ end up in libsystemd-shared. And when the static library is linked into binaries, any objects that are included in it but are not used are trimmed. Hence, the size of output artifacts doesn't change: $ du -sb /var/tmp/inst* 54181861 /var/tmp/inst1 (old) 54207441 /var/tmp/inst1s (old split-usr) 54182477 /var/tmp/inst2 (new) 54208041 /var/tmp/inst2s (new split-usr) (The negligible change in size is because libsystemd-shared.so is bigger by a few hundred bytes. I guess it's because symbols are named differently or something like that.) The effect is on the build process, in particular partial builds. This change effectively moves the requirements on some build steps toward the leaves of the dependency tree. Two effects: - when building items that do not depend on libsystemd-shared, we build less stuff for libbasic.a (which wouldn't be used anyway, so it's a net win). - when building items that do depend on libshared, we reduce libbasic.a as a synchronization point, possibly allowing better parallelism. Method: 1. copy list of .h files from src/basic/meson.build to /tmp/basic 2. $ for i in $(grep '.h$' /tmp/basic); do echo $i; git --no-pager grep "include \"$i\"" src/basic/ 'src/lib*' 'src/nss-*' 'src/journal/sd-journal.c' |grep -v "${i%.h}.c";echo ;done | less
75 lines
1.8 KiB
C
75 lines
1.8 KiB
C
/* SPDX-License-Identifier: LGPL-2.1+ */
|
|
#pragma once
|
|
|
|
#include <stdbool.h>
|
|
#include <stdint.h>
|
|
#include <sys/types.h>
|
|
|
|
#include "macro.h"
|
|
|
|
/* See source file for an API description. */
|
|
|
|
typedef struct Barrier Barrier;
|
|
|
|
enum {
|
|
BARRIER_SINGLE = 1LL,
|
|
BARRIER_ABORTION = INT64_MAX,
|
|
|
|
/* bias values to store state; keep @WE < @THEY < @I */
|
|
BARRIER_BIAS = INT64_MIN,
|
|
BARRIER_WE_ABORTED = BARRIER_BIAS + 1LL,
|
|
BARRIER_THEY_ABORTED = BARRIER_BIAS + 2LL,
|
|
BARRIER_I_ABORTED = BARRIER_BIAS + 3LL,
|
|
};
|
|
|
|
enum {
|
|
BARRIER_PARENT,
|
|
BARRIER_CHILD,
|
|
};
|
|
|
|
struct Barrier {
|
|
int me;
|
|
int them;
|
|
int pipe[2];
|
|
int64_t barriers;
|
|
};
|
|
|
|
#define BARRIER_NULL {-1, -1, {-1, -1}, 0}
|
|
|
|
int barrier_create(Barrier *obj);
|
|
void barrier_destroy(Barrier *b);
|
|
|
|
DEFINE_TRIVIAL_CLEANUP_FUNC(Barrier*, barrier_destroy);
|
|
|
|
void barrier_set_role(Barrier *b, unsigned role);
|
|
|
|
bool barrier_place(Barrier *b);
|
|
bool barrier_abort(Barrier *b);
|
|
|
|
bool barrier_wait_next(Barrier *b);
|
|
bool barrier_wait_abortion(Barrier *b);
|
|
bool barrier_sync_next(Barrier *b);
|
|
bool barrier_sync(Barrier *b);
|
|
|
|
static inline bool barrier_i_aborted(Barrier *b) {
|
|
return IN_SET(b->barriers, BARRIER_I_ABORTED, BARRIER_WE_ABORTED);
|
|
}
|
|
|
|
static inline bool barrier_they_aborted(Barrier *b) {
|
|
return IN_SET(b->barriers, BARRIER_THEY_ABORTED, BARRIER_WE_ABORTED);
|
|
}
|
|
|
|
static inline bool barrier_we_aborted(Barrier *b) {
|
|
return b->barriers == BARRIER_WE_ABORTED;
|
|
}
|
|
|
|
static inline bool barrier_is_aborted(Barrier *b) {
|
|
return IN_SET(b->barriers,
|
|
BARRIER_I_ABORTED, BARRIER_THEY_ABORTED, BARRIER_WE_ABORTED);
|
|
}
|
|
|
|
static inline bool barrier_place_and_sync(Barrier *b) {
|
|
(void) barrier_place(b);
|
|
return barrier_sync(b);
|
|
}
|