1
0
mirror of https://github.com/systemd/systemd.git synced 2025-01-27 18:04:05 +03:00

Merge pull request #26687 from yuwata/c2x

C2X support
This commit is contained in:
Luca Boccassi 2023-03-06 20:50:17 +00:00 committed by GitHub
commit 52bdfbf7d7
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
23 changed files with 42 additions and 14 deletions

View File

@ -756,6 +756,7 @@ foreach header : ['crypt.h',
'linux/memfd.h', 'linux/memfd.h',
'linux/vm_sockets.h', 'linux/vm_sockets.h',
'sys/auxv.h', 'sys/auxv.h',
'threads.h',
'valgrind/memcheck.h', 'valgrind/memcheck.h',
'valgrind/valgrind.h', 'valgrind/valgrind.h',
'linux/time_types.h', 'linux/time_types.h',

View File

@ -14,6 +14,7 @@
#include "logarithm.h" #include "logarithm.h"
#include "macro.h" #include "macro.h"
#include "missing_prctl.h" #include "missing_prctl.h"
#include "missing_threads.h"
#include "parse-util.h" #include "parse-util.h"
#include "user-util.h" #include "user-util.h"

View File

@ -23,6 +23,7 @@
#include "login-util.h" #include "login-util.h"
#include "macro.h" #include "macro.h"
#include "missing_magic.h" #include "missing_magic.h"
#include "missing_threads.h"
#include "mkdir.h" #include "mkdir.h"
#include "parse-util.h" #include "parse-util.h"
#include "path-util.h" #include "path-util.h"

View File

@ -25,6 +25,7 @@
#include "log.h" #include "log.h"
#include "macro.h" #include "macro.h"
#include "missing_syscall.h" #include "missing_syscall.h"
#include "missing_threads.h"
#include "parse-util.h" #include "parse-util.h"
#include "proc-cmdline.h" #include "proc-cmdline.h"
#include "process-util.h" #include "process-util.h"

View File

@ -297,20 +297,6 @@ static inline int __coverity_check_and_return__(int condition) {
p != (typeof(p)) POINTER_MAX; \ p != (typeof(p)) POINTER_MAX; \
p = *(++_l)) p = *(++_l))
/* Define C11 thread_local attribute even on older gcc compiler
* version */
#ifndef thread_local
/*
* Don't break on glibc < 2.16 that doesn't define __STDC_NO_THREADS__
* see https://gcc.gnu.org/bugzilla/show_bug.cgi?id=53769
*/
#if __STDC_VERSION__ >= 201112L && !(defined(__STDC_NO_THREADS__) || (defined(__GNU_LIBRARY__) && __GLIBC__ == 2 && __GLIBC_MINOR__ < 16))
#define thread_local _Thread_local
#else
#define thread_local __thread
#endif
#endif
#define DEFINE_TRIVIAL_DESTRUCTOR(name, type, func) \ #define DEFINE_TRIVIAL_DESTRUCTOR(name, type, func) \
static inline void name(type *p) { \ static inline void name(type *p) { \
func(p); \ func(p); \

View File

@ -3,6 +3,7 @@
#include <unistd.h> #include <unistd.h>
#include "memory-util.h" #include "memory-util.h"
#include "missing_threads.h"
size_t page_size(void) { size_t page_size(void) {
static thread_local size_t pgsz = 0; static thread_local size_t pgsz = 0;

View File

@ -0,0 +1,15 @@
/* SPDX-License-Identifier: LGPL-2.1-or-later */
#pragma once
/* If threads.h doesn't exist, then define our own thread_local to match C11's thread_local. */
#if HAVE_THREADS_H
# include <threads.h>
#elif !(defined(thread_local))
/* Don't break on glibc < 2.16 that doesn't define __STDC_NO_THREADS__
* see https://gcc.gnu.org/bugzilla/show_bug.cgi?id=53769 */
# if __STDC_VERSION__ >= 201112L && !(defined(__STDC_NO_THREADS__) || (defined(__GNU_LIBRARY__) && __GLIBC__ == 2 && __GLIBC_MINOR__ < 16))
# define thread_local _Thread_local
# else
# define thread_local __thread
# endif
#endif

View File

@ -36,6 +36,7 @@
#include "memory-util.h" #include "memory-util.h"
#include "missing_sched.h" #include "missing_sched.h"
#include "missing_syscall.h" #include "missing_syscall.h"
#include "missing_threads.h"
#include "mountpoint-util.h" #include "mountpoint-util.h"
#include "namespace-util.h" #include "namespace-util.h"
#include "nulstr-util.h" #include "nulstr-util.h"

View File

@ -8,6 +8,7 @@
#include "extract-word.h" #include "extract-word.h"
#include "fd-util.h" #include "fd-util.h"
#include "fileio.h" #include "fileio.h"
#include "missing_threads.h"
#include "parse-util.h" #include "parse-util.h"
#include "psi-util.h" #include "psi-util.h"
#include "string-util.h" #include "string-util.h"

View File

@ -24,6 +24,7 @@
#include "io-util.h" #include "io-util.h"
#include "missing_random.h" #include "missing_random.h"
#include "missing_syscall.h" #include "missing_syscall.h"
#include "missing_threads.h"
#include "parse-util.h" #include "parse-util.h"
#include "random-util.h" #include "random-util.h"
#include "sha256.h" #include "sha256.h"

View File

@ -6,6 +6,7 @@
#include "errno-util.h" #include "errno-util.h"
#include "macro.h" #include "macro.h"
#include "missing_syscall.h" #include "missing_syscall.h"
#include "missing_threads.h"
#include "parse-util.h" #include "parse-util.h"
#include "signal-util.h" #include "signal-util.h"
#include "stdio-util.h" #include "stdio-util.h"

View File

@ -17,6 +17,7 @@
#include "io-util.h" #include "io-util.h"
#include "log.h" #include "log.h"
#include "macro.h" #include "macro.h"
#include "missing_threads.h"
#include "missing_timerfd.h" #include "missing_timerfd.h"
#include "parse-util.h" #include "parse-util.h"
#include "path-util.h" #include "path-util.h"

View File

@ -16,6 +16,7 @@
#include "fd-util.h" #include "fd-util.h"
#include "fileio.h" #include "fileio.h"
#include "macro.h" #include "macro.h"
#include "missing_threads.h"
#include "process-util.h" #include "process-util.h"
#include "stat-util.h" #include "stat-util.h"
#include "string-table.h" #include "string-table.h"

View File

@ -37,6 +37,7 @@
#include "macro.h" #include "macro.h"
#include "memory-util.h" #include "memory-util.h"
#include "missing_syscall.h" #include "missing_syscall.h"
#include "missing_threads.h"
#include "parse-util.h" #include "parse-util.h"
#include "path-util.h" #include "path-util.h"
#include "process-util.h" #include "process-util.h"

View File

@ -24,6 +24,7 @@
#include "memory-util.h" #include "memory-util.h"
#include "missing_magic.h" #include "missing_magic.h"
#include "missing_syscall.h" #include "missing_syscall.h"
#include "missing_threads.h"
#include "path-util.h" #include "path-util.h"
#include "prioq.h" #include "prioq.h"
#include "process-util.h" #include "process-util.h"

View File

@ -14,6 +14,7 @@
#include "io-util.h" #include "io-util.h"
#include "macro.h" #include "macro.h"
#include "missing_syscall.h" #include "missing_syscall.h"
#include "missing_threads.h"
#include "random-util.h" #include "random-util.h"
#include "stat-util.h" #include "stat-util.h"
#include "user-util.h" #include "user-util.h"

View File

@ -22,6 +22,7 @@
#include "list.h" #include "list.h"
#include "memory-util.h" #include "memory-util.h"
#include "missing_syscall.h" #include "missing_syscall.h"
#include "missing_threads.h"
#include "process-util.h" #include "process-util.h"
#include "resolve-private.h" #include "resolve-private.h"
#include "socket-util.h" #include "socket-util.h"

View File

@ -18,6 +18,7 @@
#include "io-util.h" #include "io-util.h"
#include "logind-dbus.h" #include "logind-dbus.h"
#include "logind-inhibit.h" #include "logind-inhibit.h"
#include "missing_threads.h"
#include "mkdir-label.h" #include "mkdir-label.h"
#include "parse-util.h" #include "parse-util.h"
#include "path-util.h" #include "path-util.h"

View File

@ -4,6 +4,7 @@
#include "alloc-util.h" #include "alloc-util.h"
#include "logarithm.h" #include "logarithm.h"
#include "missing_threads.h"
#include "networkd-address.h" #include "networkd-address.h"
#include "networkd-link.h" #include "networkd-link.h"
#include "networkd-manager.h" #include "networkd-manager.h"

View File

@ -9,6 +9,7 @@
#include "fd-util.h" #include "fd-util.h"
#include "log.h" #include "log.h"
#include "macro.h" #include "macro.h"
#include "missing_threads.h"
#include "nss-systemd.h" #include "nss-systemd.h"
#include "nss-util.h" #include "nss-util.h"
#include "pthread-util.h" #include "pthread-util.h"

View File

@ -8,6 +8,7 @@
#include "fd-util.h" #include "fd-util.h"
#include "fileio.h" #include "fileio.h"
#include "fs-util.h" #include "fs-util.h"
#include "missing_threads.h"
#include "mkdir.h" #include "mkdir.h"
#include "parse-util.h" #include "parse-util.h"
#include "path-util.h" #include "path-util.h"

View File

@ -3,6 +3,7 @@
#include "chase-symlinks.h" #include "chase-symlinks.h"
#include "fd-util.h" #include "fd-util.h"
#include "fileio.h" #include "fileio.h"
#include "missing_threads.h"
#include "string-util.h" #include "string-util.h"
#include "uid-alloc-range.h" #include "uid-alloc-range.h"
#include "user-util.h" #include "user-util.h"

View File

@ -59,6 +59,10 @@ if cc.has_argument('-std=iso9899:2017')
opts += [['c', '-std=iso9899:2017']] opts += [['c', '-std=iso9899:2017']]
endif endif
if cc.has_argument('-std=c2x')
opts += [['c', '-std=c2x']]
endif
if cxx_cmd != '' if cxx_cmd != ''
opts += [['c++'], opts += [['c++'],
['c++', '-std=c++98'], ['c++', '-std=c++98'],
@ -72,6 +76,9 @@ if cxx_cmd != ''
if cxx.has_argument('-std=c++20') if cxx.has_argument('-std=c++20')
opts += [['c++', '-std=c++20']] opts += [['c++', '-std=c++20']]
endif endif
if cxx.has_argument('-std=c++23')
opts += [['c++', '-std=c++23']]
endif
endif endif
foreach header : _systemd_headers + _not_installed_headers + [libudev_h_path] foreach header : _systemd_headers + _not_installed_headers + [libudev_h_path]