diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/basic/time-util.c | 8 | ||||
-rw-r--r-- | src/basic/unit-name.c | 17 | ||||
-rwxr-xr-x | src/journal-remote/log-generator.py | 16 | ||||
-rw-r--r-- | src/network/meson.build | 6 | ||||
-rw-r--r-- | src/network/networkd-address.c | 28 | ||||
-rw-r--r-- | src/network/networkd-address.h | 4 | ||||
-rw-r--r-- | src/network/test-networkd-address.c | 28 | ||||
-rw-r--r-- | src/shared/gpt.c | 98 | ||||
-rw-r--r-- | src/shared/gpt.h | 92 | ||||
-rw-r--r-- | src/shared/pretty-print.c | 4 | ||||
-rw-r--r-- | src/systemd/sd-bus-vtable.h | 9 | ||||
-rw-r--r-- | src/udev/udev-event.c | 40 |
12 files changed, 200 insertions, 150 deletions
diff --git a/src/basic/time-util.c b/src/basic/time-util.c index 0a4fcdcd13..c3b175a192 100644 --- a/src/basic/time-util.c +++ b/src/basic/time-util.c @@ -553,14 +553,12 @@ char *format_timespan(char *buf, size_t l, usec_t t, usec_t accuracy) { /* Let's see if we should shows this in dot notation */ if (t < USEC_PER_MINUTE && b > 0) { - usec_t cc; - signed char j; + signed char j = 0; - j = 0; - for (cc = table[i].usec; cc > 1; cc /= 10) + for (usec_t cc = table[i].usec; cc > 1; cc /= 10) j++; - for (cc = accuracy; cc > 1; cc /= 10) { + for (usec_t cc = accuracy; cc > 1; cc /= 10) { b /= 10; j--; } diff --git a/src/basic/unit-name.c b/src/basic/unit-name.c index 284a773483..1deead7458 100644 --- a/src/basic/unit-name.c +++ b/src/basic/unit-name.c @@ -378,12 +378,13 @@ int unit_name_unescape(const char *f, char **ret) { } int unit_name_path_escape(const char *f, char **ret) { - char *p, *s; + _cleanup_free_ char *p = NULL; + char *s; assert(f); assert(ret); - p = strdupa(f); + p = strdup(f); if (!p) return -ENOMEM; @@ -395,13 +396,9 @@ int unit_name_path_escape(const char *f, char **ret) { if (!path_is_normalized(p)) return -EINVAL; - /* Truncate trailing slashes */ + /* Truncate trailing slashes and skip leading slashes */ delete_trailing_chars(p, "/"); - - /* Truncate leading slashes */ - p = skip_leading_chars(p, "/"); - - s = unit_name_escape(p); + s = unit_name_escape(skip_leading_chars(p, "/")); } if (!s) return -ENOMEM; @@ -531,7 +528,7 @@ int unit_name_from_path(const char *path, const char *suffix, char **ret) { if (strlen(s) >= UNIT_NAME_MAX) /* Return a slightly more descriptive error for this specific condition */ return -ENAMETOOLONG; - /* Refuse this if this got too long or for some other reason didn't result in a valid name */ + /* Refuse if this for some other reason didn't result in a valid name */ if (!unit_name_is_valid(s, UNIT_NAME_PLAIN)) return -EINVAL; @@ -565,7 +562,7 @@ int unit_name_from_path_instance(const char *prefix, const char *path, const cha if (strlen(s) >= UNIT_NAME_MAX) /* Return a slightly more descriptive error for this specific condition */ return -ENAMETOOLONG; - /* Refuse this if this got too long or for some other reason didn't result in a valid name */ + /* Refuse if this for some other reason didn't result in a valid name */ if (!unit_name_is_valid(s, UNIT_NAME_INSTANCE)) return -EINVAL; diff --git a/src/journal-remote/log-generator.py b/src/journal-remote/log-generator.py index 6e42d8a8b4..2843afb4c9 100755 --- a/src/journal-remote/log-generator.py +++ b/src/journal-remote/log-generator.py @@ -32,10 +32,6 @@ _SOURCE_REALTIME_TIMESTAMP={source_realtime_ts} DATA={data} """ -m = 0x198603b12d7 -realtime_ts = 1404101101501873 -monotonic_ts = 1753961140951 -source_realtime_ts = 1404101101483516 priority = 3 facility = 6 @@ -55,18 +51,14 @@ for i in range(OPTIONS.n): data = '{:0{}}'.format(counter, OPTIONS.data_size) counter += 1 - entry = template.format(m=m, - realtime_ts=realtime_ts, - monotonic_ts=monotonic_ts, - source_realtime_ts=source_realtime_ts, + entry = template.format(m=0x198603b12d7 + i, + realtime_ts=1404101101501873 + i, + monotonic_ts=1753961140951 + i, + source_realtime_ts=1404101101483516 + i, priority=priority, facility=facility, message=message, data=data) - m += 1 - realtime_ts += 1 - monotonic_ts += 1 - source_realtime_ts += 1 bytes += len(entry) diff --git a/src/network/meson.build b/src/network/meson.build index 4e137d7b9e..2ea12c8d03 100644 --- a/src/network/meson.build +++ b/src/network/meson.build @@ -268,6 +268,12 @@ fuzzers += [ ] tests += [ + [['src/network/test-networkd-address.c'], + [libnetworkd_core, + libsystemd_network], + [], + network_includes], + [['src/network/test-networkd-conf.c'], [libnetworkd_core, libsystemd_network], diff --git a/src/network/networkd-address.c b/src/network/networkd-address.c index 2d3f8ece2d..f4257b3b91 100644 --- a/src/network/networkd-address.c +++ b/src/network/networkd-address.c @@ -621,19 +621,17 @@ int manager_has_address(Manager *manager, int family, const union in_addr_union return false; } -char *format_lifetime(char *buf, size_t l, uint32_t lifetime) { - char *p = buf; - +const char* format_lifetime(char *buf, size_t l, uint32_t lifetime) { assert(buf); - assert(l > 0); + assert(l > 4); - if (lifetime == CACHE_INFO_INFINITY_LIFE_TIME) { - strscpy(buf, l, "forever"); - return buf; - } + if (lifetime == CACHE_INFO_INFINITY_LIFE_TIME) + return "forever"; - l -= strpcpy(&p, l, "for "); - return format_timespan(p, l, lifetime * USEC_PER_SEC, USEC_PER_SEC); + sprintf(buf, "for "); + /* format_timespan() never fails */ + assert_se(format_timespan(buf + 4, l - 4, lifetime * USEC_PER_SEC, USEC_PER_SEC)); + return buf; } static void log_address_debug(const Address *address, const char *str, const Link *link) { @@ -1273,17 +1271,17 @@ int request_process_address(Request *req) { if (r <= 0) return r; - r = address_get(link, req->address, &a); - if (r < 0) - return r; - - r = address_configure(a, link, req->netlink_handler); + r = address_configure(req->address, link, req->netlink_handler); if (r < 0) return r; /* To prevent a double decrement on failure in after_configure(). */ req->message_counter = NULL; + r = address_get(link, req->address, &a); + if (r < 0) + return r; + if (req->after_configure) { r = req->after_configure(req, a); if (r < 0) diff --git a/src/network/networkd-address.h b/src/network/networkd-address.h index 1569b588a0..811940c126 100644 --- a/src/network/networkd-address.h +++ b/src/network/networkd-address.h @@ -50,7 +50,7 @@ typedef struct Address { address_ready_callback_t callback; } Address; -char *format_lifetime(char *buf, size_t l, uint32_t lifetime) _warn_unused_result_; +const char* format_lifetime(char *buf, size_t l, uint32_t lifetime) _warn_unused_result_; /* Note: the lifetime of the compound literal is the immediately surrounding block, * see C11 §6.5.2.5, and * https://stackoverflow.com/questions/34880638/compound-literal-lifetime-and-if-blocks */ @@ -58,7 +58,7 @@ char *format_lifetime(char *buf, size_t l, uint32_t lifetime) _warn_unused_resul format_lifetime((char[FORMAT_TIMESPAN_MAX+STRLEN("for ")]){}, FORMAT_TIMESPAN_MAX+STRLEN("for "), lifetime) int address_new(Address **ret); -Address *address_free(Address *address); +Address* address_free(Address *address); int address_get(Link *link, const Address *in, Address **ret); int address_configure_handler_internal(sd_netlink *rtnl, sd_netlink_message *m, Link *link, const char *error_msg); int address_remove(const Address *address, Link *link); diff --git a/src/network/test-networkd-address.c b/src/network/test-networkd-address.c new file mode 100644 index 0000000000..7c1d65a433 --- /dev/null +++ b/src/network/test-networkd-address.c @@ -0,0 +1,28 @@ +/* SPDX-License-Identifier: LGPL-2.1-or-later */ + +#include "networkd-address.h" +#include "tests.h" + +static void test_FORMAT_LIFETIME_one(uint32_t lifetime, const char *expected) { + const char *t = FORMAT_LIFETIME(lifetime); + + log_debug("%"PRIu32 " → \"%s\" (expected \"%s\")", lifetime, t, expected); + assert_se(streq(t, expected)); +} + +static void test_FORMAT_LIFETIME(void) { + log_info("/* %s */", __func__); + + test_FORMAT_LIFETIME_one(0, "for 0"); + test_FORMAT_LIFETIME_one(1, "for 1s"); + test_FORMAT_LIFETIME_one(3 * (USEC_PER_WEEK/USEC_PER_SEC), "for 3w"); + test_FORMAT_LIFETIME_one(CACHE_INFO_INFINITY_LIFE_TIME, "forever"); +} + +int main(int argc, char *argv[]) { + test_setup_logging(LOG_INFO); + + test_FORMAT_LIFETIME(); + + return 0; +} diff --git a/src/shared/gpt.c b/src/shared/gpt.c index 882d11ca6c..edd56c1493 100644 --- a/src/shared/gpt.c +++ b/src/shared/gpt.c @@ -5,59 +5,63 @@ #include "utf8.h" const GptPartitionType gpt_partition_type_table[] = { - { GPT_ROOT_X86, "root-x86" }, - { GPT_ROOT_X86_VERITY, "root-x86-verity" }, - { GPT_ROOT_X86_64, "root-x86-64" }, - { GPT_ROOT_X86_64_VERITY, "root-x86-64-verity" }, - { GPT_ROOT_ARM, "root-arm" }, - { GPT_ROOT_ARM_VERITY, "root-arm-verity" }, - { GPT_ROOT_ARM_64, "root-arm64" }, - { GPT_ROOT_ARM_64_VERITY, "root-arm64-verity" }, - { GPT_ROOT_IA64, "root-ia64" }, - { GPT_ROOT_IA64_VERITY, "root-ia64-verity" }, - { GPT_ROOT_RISCV32, "root-riscv32" }, - { GPT_ROOT_RISCV32_VERITY, "root-riscv32-verity" }, - { GPT_ROOT_RISCV64, "root-riscv64" }, - { GPT_ROOT_RISCV64_VERITY, "root-riscv64-verity" }, + { GPT_ROOT_X86, "root-x86" }, + { GPT_ROOT_X86_VERITY, "root-x86-verity" }, + { GPT_ROOT_X86_64, "root-x86-64" }, + { GPT_ROOT_X86_64_VERITY, "root-x86-64-verity" }, + { GPT_ROOT_ARM, "root-arm" }, + { GPT_ROOT_ARM_VERITY, "root-arm-verity" }, + { GPT_ROOT_ARM_64, "root-arm64" }, + { GPT_ROOT_ARM_64_VERITY, "root-arm64-verity" }, + { GPT_ROOT_IA64, "root-ia64" }, + { GPT_ROOT_IA64_VERITY, "root-ia64-verity" }, + { GPT_ROOT_LOONGARCH64, "root-loongarch64" }, + { GPT_ROOT_LOONGARCH64_VERITY, "root-loongarch64-verity" }, + { GPT_ROOT_RISCV32, "root-riscv32" }, + { GPT_ROOT_RISCV32_VERITY, "root-riscv32-verity" }, + { GPT_ROOT_RISCV64, "root-riscv64" }, + { GPT_ROOT_RISCV64_VERITY, "root-riscv64-verity" }, #ifdef GPT_ROOT_NATIVE - { GPT_ROOT_NATIVE, "root" }, - { GPT_ROOT_NATIVE_VERITY, "root-verity" }, + { GPT_ROOT_NATIVE, "root" }, + { GPT_ROOT_NATIVE_VERITY, "root-verity" }, #endif #ifdef GPT_ROOT_SECONDARY - { GPT_ROOT_SECONDARY, "root-secondary" }, - { GPT_ROOT_SECONDARY_VERITY, "root-secondary-verity" }, + { GPT_ROOT_SECONDARY, "root-secondary" }, + { GPT_ROOT_SECONDARY_VERITY, "root-secondary-verity" }, #endif - { GPT_USR_X86, "usr-x86" }, - { GPT_USR_X86_VERITY, "usr-x86-verity" }, - { GPT_USR_X86_64, "usr-x86-64" }, - { GPT_USR_X86_64_VERITY, "usr-x86-64-verity" }, - { GPT_USR_ARM, "usr-arm" }, - { GPT_USR_ARM_VERITY, "usr-arm-verity" }, - { GPT_USR_ARM_64, "usr-arm64" }, - { GPT_USR_ARM_64_VERITY, "usr-arm64-verity" }, - { GPT_USR_IA64, "usr-ia64" }, - { GPT_USR_IA64_VERITY, "usr-ia64-verity" }, - { GPT_USR_RISCV32, "usr-riscv32" }, - { GPT_USR_RISCV32_VERITY, "usr-riscv32-verity" }, - { GPT_USR_RISCV64, "usr-riscv64" }, - { GPT_USR_RISCV64_VERITY, "usr-riscv64-verity" }, + { GPT_USR_X86, "usr-x86" }, + { GPT_USR_X86_VERITY, "usr-x86-verity" }, + { GPT_USR_X86_64, "usr-x86-64" }, + { GPT_USR_X86_64_VERITY, "usr-x86-64-verity" }, + { GPT_USR_ARM, "usr-arm" }, + { GPT_USR_ARM_VERITY, "usr-arm-verity" }, + { GPT_USR_ARM_64, "usr-arm64" }, + { GPT_USR_ARM_64_VERITY, "usr-arm64-verity" }, + { GPT_USR_IA64, "usr-ia64" }, + { GPT_USR_IA64_VERITY, "usr-ia64-verity" }, + { GPT_USR_LOONGARCH64, "usr-loongarch64" }, + { GPT_USR_LOONGARCH64_VERITY, "usr-loongarch64-verity" }, + { GPT_USR_RISCV32, "usr-riscv32" }, + { GPT_USR_RISCV32_VERITY, "usr-riscv32-verity" }, + { GPT_USR_RISCV64, "usr-riscv64" }, + { GPT_USR_RISCV64_VERITY, "usr-riscv64-verity" }, #ifdef GPT_USR_NATIVE - { GPT_USR_NATIVE, "usr" }, - { GPT_USR_NATIVE_VERITY, "usr-verity" }, + { GPT_USR_NATIVE, "usr" }, + { GPT_USR_NATIVE_VERITY, "usr-verity" }, #endif #ifdef GPT_USR_SECONDARY - { GPT_USR_SECONDARY, "usr-secondary" }, - { GPT_USR_SECONDARY_VERITY, "usr-secondary-verity" }, + { GPT_USR_SECONDARY, "usr-secondary" }, + { GPT_USR_SECONDARY_VERITY, "usr-secondary-verity" }, #endif - { GPT_ESP, "esp" }, - { GPT_XBOOTLDR, "xbootldr" }, - { GPT_SWAP, "swap" }, - { GPT_HOME, "home" }, - { GPT_SRV, "srv" }, - { GPT_VAR, "var" }, - { GPT_TMP, "tmp" }, - { GPT_USER_HOME, "user-home" }, - { GPT_LINUX_GENERIC, "linux-generic" }, + { GPT_ESP, "esp" }, + { GPT_XBOOTLDR, "xbootldr" }, + { GPT_SWAP, "swap" }, + { GPT_HOME, "home" }, + { GPT_SRV, "srv" }, + { GPT_VAR, "var" }, + { GPT_TMP, "tmp" }, + { GPT_USER_HOME, "user-home" }, + { GPT_LINUX_GENERIC, "linux-generic" }, {} }; @@ -114,6 +118,7 @@ bool gpt_partition_type_is_root(sd_id128_t id) { GPT_ROOT_ARM, GPT_ROOT_ARM_64, GPT_ROOT_IA64, + GPT_ROOT_LOONGARCH64, GPT_ROOT_RISCV32, GPT_ROOT_RISCV64); } @@ -125,6 +130,7 @@ bool gpt_partition_type_is_root_verity(sd_id128_t id) { GPT_ROOT_ARM_VERITY, GPT_ROOT_ARM_64_VERITY, GPT_ROOT_IA64_VERITY, + GPT_ROOT_LOONGARCH64_VERITY, GPT_ROOT_RISCV32_VERITY, GPT_ROOT_RISCV64_VERITY); } @@ -136,6 +142,7 @@ bool gpt_partition_type_is_usr(sd_id128_t id) { GPT_USR_ARM, GPT_USR_ARM_64, GPT_USR_IA64, + GPT_USR_LOONGARCH64, GPT_USR_RISCV32, GPT_USR_RISCV64); } @@ -147,6 +154,7 @@ bool gpt_partition_type_is_usr_verity(sd_id128_t id) { GPT_USR_ARM_VERITY, GPT_USR_ARM_64_VERITY, GPT_USR_IA64_VERITY, + GPT_USR_LOONGARCH64_VERITY, GPT_USR_RISCV32_VERITY, GPT_USR_RISCV64_VERITY); } diff --git a/src/shared/gpt.h b/src/shared/gpt.h index dc530ef1b0..a5fc9534e1 100644 --- a/src/shared/gpt.h +++ b/src/shared/gpt.h @@ -7,49 +7,54 @@ #include "id128-util.h" -/* We only support root disk discovery for x86, x86-64, Itanium and ARM for now, since EFI for anything else - * doesn't really exist, and we only care for root partitions on the same disk as the EFI ESP. */ - -#define GPT_ROOT_X86 SD_ID128_MAKE(44,47,95,40,f2,97,41,b2,9a,f7,d1,31,d5,f0,45,8a) -#define GPT_ROOT_X86_64 SD_ID128_MAKE(4f,68,bc,e3,e8,cd,4d,b1,96,e7,fb,ca,f9,84,b7,09) -#define GPT_ROOT_ARM SD_ID128_MAKE(69,da,d7,10,2c,e4,4e,3c,b1,6c,21,a1,d4,9a,be,d3) -#define GPT_ROOT_ARM_64 SD_ID128_MAKE(b9,21,b0,45,1d,f0,41,c3,af,44,4c,6f,28,0d,3f,ae) -#define GPT_ROOT_IA64 SD_ID128_MAKE(99,3d,8d,3d,f8,0e,42,25,85,5a,9d,af,8e,d7,ea,97) -#define GPT_ROOT_RISCV32 SD_ID128_MAKE(60,d5,a7,fe,8e,7d,43,5c,b7,14,3d,d8,16,21,44,e1) -#define GPT_ROOT_RISCV64 SD_ID128_MAKE(72,ec,70,a6,cf,74,40,e6,bd,49,4b,da,08,e8,f2,24) -#define GPT_USR_X86 SD_ID128_MAKE(75,25,0d,76,8c,c6,45,8e,bd,66,bd,47,cc,81,a8,12) -#define GPT_USR_X86_64 SD_ID128_MAKE(84,84,68,0c,95,21,48,c6,9c,11,b0,72,06,56,f6,9e) -#define GPT_USR_ARM SD_ID128_MAKE(7d,03,59,a3,02,b3,4f,0a,86,5c,65,44,03,e7,06,25) -#define GPT_USR_ARM_64 SD_ID128_MAKE(b0,e0,10,50,ee,5f,43,90,94,9a,91,01,b1,71,04,e9) -#define GPT_USR_IA64 SD_ID128_MAKE(43,01,d2,a6,4e,3b,4b,2a,bb,94,9e,0b,2c,42,25,ea) -#define GPT_USR_RISCV32 SD_ID128_MAKE(b9,33,fb,22,5c,3f,4f,91,af,90,e2,bb,0f,a5,07,02) -#define GPT_USR_RISCV64 SD_ID128_MAKE(be,ae,c3,4b,84,42,43,9b,a4,0b,98,43,81,ed,09,7d) -#define GPT_ESP SD_ID128_MAKE(c1,2a,73,28,f8,1f,11,d2,ba,4b,00,a0,c9,3e,c9,3b) -#define GPT_XBOOTLDR SD_ID128_MAKE(bc,13,c2,ff,59,e6,42,62,a3,52,b2,75,fd,6f,71,72) -#define GPT_SWAP SD_ID128_MAKE(06,57,fd,6d,a4,ab,43,c4,84,e5,09,33,c8,4b,4f,4f) -#define GPT_HOME SD_ID128_MAKE(93,3a,c7,e1,2e,b4,4f,13,b8,44,0e,14,e2,ae,f9,15) -#define GPT_SRV SD_ID128_MAKE(3b,8f,84,25,20,e0,4f,3b,90,7f,1a,25,a7,6f,98,e8) -#define GPT_VAR SD_ID128_MAKE(4d,21,b0,16,b5,34,45,c2,a9,fb,5c,16,e0,91,fd,2d) -#define GPT_TMP SD_ID128_MAKE(7e,c6,f5,57,3b,c5,4a,ca,b2,93,16,ef,5d,f6,39,d1) -#define GPT_USER_HOME SD_ID128_MAKE(77,3f,91,ef,66,d4,49,b5,bd,83,d6,83,bf,40,ad,16) -#define GPT_LINUX_GENERIC SD_ID128_MAKE(0f,c6,3d,af,84,83,47,72,8e,79,3d,69,d8,47,7d,e4) +/* We only support root disk discovery for x86, x86-64, Itanium, ARM and LoongArch for now, + * since EFI for anything else doesn't really exist, and we only care for root partitions + * on the same disk as the EFI ESP. */ + +#define GPT_ROOT_X86 SD_ID128_MAKE(44,47,95,40,f2,97,41,b2,9a,f7,d1,31,d5,f0,45,8a) +#define GPT_ROOT_X86_64 SD_ID128_MAKE(4f,68,bc,e3,e8,cd,4d,b1,96,e7,fb,ca,f9,84,b7,09) +#define GPT_ROOT_ARM SD_ID128_MAKE(69,da,d7,10,2c,e4,4e,3c,b1,6c,21,a1,d4,9a,be,d3) +#define GPT_ROOT_ARM_64 SD_ID128_MAKE(b9,21,b0,45,1d,f0,41,c3,af,44,4c,6f,28,0d,3f,ae) +#define GPT_ROOT_IA64 SD_ID128_MAKE(99,3d,8d,3d,f8,0e,42,25,85,5a,9d,af,8e,d7,ea,97) +#define GPT_ROOT_LOONGARCH64 SD_ID128_MAKE(77,05,58,00,79,2c,4f,94,b3,9a,99,c9,1b,76,2b,b6) +#define GPT_ROOT_RISCV32 SD_ID128_MAKE(60,d5,a7,fe,8e,7d,43,5c,b7,14,3d,d8,16,21,44,e1) +#define GPT_ROOT_RISCV64 SD_ID128_MAKE(72,ec,70,a6,cf,74,40,e6,bd,49,4b,da,08,e8,f2,24) +#define GPT_USR_X86 SD_ID128_MAKE(75,25,0d,76,8c,c6,45,8e,bd,66,bd,47,cc,81,a8,12) +#define GPT_USR_X86_64 SD_ID128_MAKE(84,84,68,0c,95,21,48,c6,9c,11,b0,72,06,56,f6,9e) +#define GPT_USR_ARM SD_ID128_MAKE(7d,03,59,a3,02,b3,4f,0a,86,5c,65,44,03,e7,06,25) +#define GPT_USR_ARM_64 SD_ID128_MAKE(b0,e0,10,50,ee,5f,43,90,94,9a,91,01,b1,71,04,e9) +#define GPT_USR_IA64 SD_ID128_MAKE(43,01,d2,a6,4e,3b,4b,2a,bb,94,9e,0b,2c,42,25,ea) +#define GPT_USR_LOONGARCH64 SD_ID128_MAKE(e6,11,c7,02,57,5c,4c,be,9a,46,43,4f,a0,bf,7e,3f) +#define GPT_USR_RISCV32 SD_ID128_MAKE(b9,33,fb,22,5c,3f,4f,91,af,90,e2,bb,0f,a5,07,02) +#define GPT_USR_RISCV64 SD_ID128_MAKE(be,ae,c3,4b,84,42,43,9b,a4,0b,98,43,81,ed,09,7d) +#define GPT_ESP SD_ID128_MAKE(c1,2a,73,28,f8,1f,11,d2,ba,4b,00,a0,c9,3e,c9,3b) +#define GPT_XBOOTLDR SD_ID128_MAKE(bc,13,c2,ff,59,e6,42,62,a3,52,b2,75,fd,6f,71,72) +#define GPT_SWAP SD_ID128_MAKE(06,57,fd,6d,a4,ab,43,c4,84,e5,09,33,c8,4b,4f,4f) +#define GPT_HOME SD_ID128_MAKE(93,3a,c7,e1,2e,b4,4f,13,b8,44,0e,14,e2,ae,f9,15) +#define GPT_SRV SD_ID128_MAKE(3b,8f,84,25,20,e0,4f,3b,90,7f,1a,25,a7,6f,98,e8) +#define GPT_VAR SD_ID128_MAKE(4d,21,b0,16,b5,34,45,c2,a9,fb,5c,16,e0,91,fd,2d) +#define GPT_TMP SD_ID128_MAKE(7e,c6,f5,57,3b,c5,4a,ca,b2,93,16,ef,5d,f6,39,d1) +#define GPT_USER_HOME SD_ID128_MAKE(77,3f,91,ef,66,d4,49,b5,bd,83,d6,83,bf,40,ad,16) +#define GPT_LINUX_GENERIC SD_ID128_MAKE(0f,c6,3d,af,84,83,47,72,8e,79,3d,69,d8,47,7d,e4) /* Verity partitions for the root partitions above (we only define them for the root and /usr partitions, * because only they are commonly read-only and hence suitable for verity). */ -#define GPT_ROOT_X86_VERITY SD_ID128_MAKE(d1,3c,5d,3b,b5,d1,42,2a,b2,9f,94,54,fd,c8,9d,76) -#define GPT_ROOT_X86_64_VERITY SD_ID128_MAKE(2c,73,57,ed,eb,d2,46,d9,ae,c1,23,d4,37,ec,2b,f5) -#define GPT_ROOT_ARM_VERITY SD_ID128_MAKE(73,86,cd,f2,20,3c,47,a9,a4,98,f2,ec,ce,45,a2,d6) -#define GPT_ROOT_ARM_64_VERITY SD_ID128_MAKE(df,33,00,ce,d6,9f,4c,92,97,8c,9b,fb,0f,38,d8,20) -#define GPT_ROOT_IA64_VERITY SD_ID128_MAKE(86,ed,10,d5,b6,07,45,bb,89,57,d3,50,f2,3d,05,71) -#define GPT_ROOT_RISCV32_VERITY SD_ID128_MAKE(ae,02,53,be,11,67,40,07,ac,68,43,92,6c,14,c5,de) -#define GPT_ROOT_RISCV64_VERITY SD_ID128_MAKE(b6,ed,55,82,44,0b,42,09,b8,da,5f,f7,c4,19,ea,3d) -#define GPT_USR_X86_VERITY SD_ID128_MAKE(8f,46,1b,0d,14,ee,4e,81,9a,a9,04,9b,6f,b9,7a,bd) -#define GPT_USR_X86_64_VERITY SD_ID128_MAKE(77,ff,5f,63,e7,b6,46,33,ac,f4,15,65,b8,64,c0,e6) -#define GPT_USR_ARM_VERITY SD_ID128_MAKE(c2,15,d7,51,7b,cd,46,49,be,90,66,27,49,0a,4c,05) -#define GPT_USR_ARM_64_VERITY SD_ID128_MAKE(6e,11,a4,e7,fb,ca,4d,ed,b9,e9,e1,a5,12,bb,66,4e) -#define GPT_USR_IA64_VERITY SD_ID128_MAKE(6a,49,1e,03,3b,e7,45,45,8e,38,83,32,0e,0e,a8,80) -#define GPT_USR_RISCV32_VERITY SD_ID128_MAKE(cb,1e,e4,e3,8c,d0,41,36,a0,a4,aa,61,a3,2e,87,30) -#define GPT_USR_RISCV64_VERITY SD_ID128_MAKE(8f,10,56,be,9b,05,47,c4,81,d6,be,53,12,8e,5b,54) +#define GPT_ROOT_X86_VERITY SD_ID128_MAKE(d1,3c,5d,3b,b5,d1,42,2a,b2,9f,94,54,fd,c8,9d,76) +#define GPT_ROOT_X86_64_VERITY SD_ID128_MAKE(2c,73,57,ed,eb,d2,46,d9,ae,c1,23,d4,37,ec,2b,f5) +#define GPT_ROOT_ARM_VERITY SD_ID128_MAKE(73,86,cd,f2,20,3c,47,a9,a4,98,f2,ec,ce,45,a2,d6) +#define GPT_ROOT_ARM_64_VERITY SD_ID128_MAKE(df,33,00,ce,d6,9f,4c,92,97,8c,9b,fb,0f,38,d8,20) +#define GPT_ROOT_IA64_VERITY SD_ID128_MAKE(86,ed,10,d5,b6,07,45,bb,89,57,d3,50,f2,3d,05,71) +#define GPT_ROOT_LOONGARCH64_VERITY SD_ID128_MAKE(f3,39,3b,22,e9,af,46,13,a9,48,9d,3b,fb,d0,c5,35) +#define GPT_ROOT_RISCV32_VERITY SD_ID128_MAKE(ae,02,53,be,11,67,40,07,ac,68,43,92,6c,14,c5,de) +#define GPT_ROOT_RISCV64_VERITY SD_ID128_MAKE(b6,ed,55,82,44,0b,42,09,b8,da,5f,f7,c4,19,ea,3d) +#define GPT_USR_X86_VERITY SD_ID128_MAKE(8f,46,1b,0d,14,ee,4e,81,9a,a9,04,9b,6f,b9,7a,bd) +#define GPT_USR_X86_64_VERITY SD_ID128_MAKE(77,ff,5f,63,e7,b6,46,33,ac,f4,15,65,b8,64,c0,e6) +#define GPT_USR_ARM_VERITY SD_ID128_MAKE(c2,15,d7,51,7b,cd,46,49,be,90,66,27,49,0a,4c,05) +#define GPT_USR_ARM_64_VERITY SD_ID128_MAKE(6e,11,a4,e7,fb,ca,4d,ed,b9,e9,e1,a5,12,bb,66,4e) +#define GPT_USR_IA64_VERITY SD_ID128_MAKE(6a,49,1e,03,3b,e7,45,45,8e,38,83,32,0e,0e,a8,80) +#define GPT_USR_LOONGARCH64_VERITY SD_ID128_MAKE(f4,6b,2c,26,59,ae,48,f0,91,06,c5,0e,d4,7f,67,3d) +#define GPT_USR_RISCV32_VERITY SD_ID128_MAKE(cb,1e,e4,e3,8c,d0,41,36,a0,a4,aa,61,a3,2e,87,30) +#define GPT_USR_RISCV64_VERITY SD_ID128_MAKE(8f,10,56,be,9b,05,47,c4,81,d6,be,53,12,8e,5b,54) #if defined(__x86_64__) # define GPT_ROOT_NATIVE GPT_ROOT_X86_64 @@ -90,6 +95,13 @@ # define GPT_USR_NATIVE_VERITY GPT_USR_ARM_VERITY #endif +#if defined(__loongarch64) +# define GPT_ROOT_NATIVE GPT_ROOT_LOONGARCH64 +# define GPT_ROOT_NATIVE_VERITY GPT_ROOT_LOONGARCH64_VERITY +# define GPT_USR_NATIVE GPT_USR_LOONGARCH64 +# define GPT_USR_NATIVE_VERITY GPT_USR_LOONGARCH64_VERITY +#endif + #if defined(__riscv) #if (__riscv_xlen == 32) # define GPT_ROOT_NATIVE GPT_ROOT_RISCV32 diff --git a/src/shared/pretty-print.c b/src/shared/pretty-print.c index 137ba77b3a..7983c0a33a 100644 --- a/src/shared/pretty-print.c +++ b/src/shared/pretty-print.c @@ -19,6 +19,7 @@ #include "util.h" bool urlify_enabled(void) { +#if ENABLE_URLIFY static int cached_urlify_enabled = -1; if (cached_urlify_enabled < 0) { @@ -32,6 +33,9 @@ bool urlify_enabled(void) { } return cached_urlify_enabled; +#else + return 0; +#endif } int terminal_urlify(const char *url, const char *text, char **ret) { diff --git a/src/systemd/sd-bus-vtable.h b/src/systemd/sd-bus-vtable.h index 75f8848360..35c942b16c 100644 --- a/src/systemd/sd-bus-vtable.h +++ b/src/systemd/sd-bus-vtable.h @@ -76,6 +76,9 @@ struct sd_bus_vtable { const unsigned *vtable_format_reference; } start; struct { + size_t reserved; + } end; + struct { const char *member; const char *signature; const char *result; @@ -185,7 +188,11 @@ struct sd_bus_vtable { { \ .type = _SD_BUS_VTABLE_END, \ .flags = 0, \ - .x = { { 0 } }, \ + .x = { \ + .end = { \ + .reserved = 0, \ + }, \ + }, \ } #define _SD_ECHO(X) X diff --git a/src/udev/udev-event.c b/src/udev/udev-event.c index c31d4851a0..d269345259 100644 --- a/src/udev/udev-event.c +++ b/src/udev/udev-event.c @@ -247,13 +247,13 @@ static ssize_t udev_event_subst_format( r = sd_device_get_devpath(dev, &val); if (r < 0) return r; - l = strpcpy(&s, l, val); + strpcpy(&s, l, val); break; case FORMAT_SUBST_KERNEL: r = sd_device_get_sysname(dev, &val); if (r < 0) return r; - l = strpcpy(&s, l, val); + strpcpy(&s, l, val); break; case FORMAT_SUBST_KERNEL_NUMBER: r = sd_device_get_sysnum(dev, &val); @@ -261,7 +261,7 @@ static ssize_t udev_event_subst_format( goto null_terminate; if (r < 0) return r; - l = strpcpy(&s, l, val); + strpcpy(&s, l, val); break; case FORMAT_SUBST_ID: if (!event->dev_parent) @@ -269,7 +269,7 @@ static ssize_t udev_event_subst_format( r = sd_device_get_sysname(event->dev_parent, &val); if (r < 0) return r; - l = strpcpy(&s, l, val); + strpcpy(&s, l, val); break; case FORMAT_SUBST_DRIVER: if (!event->dev_parent) @@ -279,7 +279,7 @@ static ssize_t udev_event_subst_format( goto null_terminate; if (r < 0) return r; - l = strpcpy(&s, l, val); + strpcpy(&s, l, val); break; case FORMAT_SUBST_MAJOR: case FORMAT_SUBST_MINOR: { @@ -288,7 +288,7 @@ static ssize_t udev_event_subst_format( r = sd_device_get_devnum(dev, &devnum); if (r < 0 && r != -ENOENT) return r; - l = strpcpyf(&s, l, "%u", r < 0 ? 0 : type == FORMAT_SUBST_MAJOR ? major(devnum) : minor(devnum)); + strpcpyf(&s, l, "%u", r < 0 ? 0 : type == FORMAT_SUBST_MAJOR ? major(devnum) : minor(devnum)); break; } case FORMAT_SUBST_RESULT: { @@ -307,7 +307,7 @@ static ssize_t udev_event_subst_format( } if (index == 0) - l = strpcpy(&s, l, event->program_result); + strpcpy(&s, l, event->program_result); else { const char *start, *p; unsigned i; @@ -329,11 +329,11 @@ static ssize_t udev_event_subst_format( start = p; /* %c{2+} copies the whole string from the second part on */ if (has_plus) - l = strpcpy(&s, l, start); + strpcpy(&s, l, start); else { while (*p && !strchr(WHITESPACE, *p)) p++; - l = strnpcpy(&s, l, start, p - start); + strnpcpy(&s, l, start, p - start); } } break; @@ -367,7 +367,7 @@ static ssize_t udev_event_subst_format( count = udev_replace_chars(vbuf, UDEV_ALLOWED_CHARS_INPUT); if (count > 0) log_device_debug(dev, "%i character(s) replaced", count); - l = strpcpy(&s, l, vbuf); + strpcpy(&s, l, vbuf); break; } case FORMAT_SUBST_PARENT: @@ -381,7 +381,7 @@ static ssize_t udev_event_subst_format( goto null_terminate; if (r < 0) return r; - l = strpcpy(&s, l, val + STRLEN("/dev/")); + strpcpy(&s, l, val + STRLEN("/dev/")); break; case FORMAT_SUBST_DEVNODE: r = sd_device_get_devname(dev, &val); @@ -389,34 +389,34 @@ static ssize_t udev_event_subst_format( goto null_terminate; if (r < 0) return r; - l = strpcpy(&s, l, val); + strpcpy(&s, l, val); break; case FORMAT_SUBST_NAME: if (event->name) - l = strpcpy(&s, l, event->name); + strpcpy(&s, l, event->name); else if (sd_device_get_devname(dev, &val) >= 0) - l = strpcpy(&s, l, val + STRLEN("/dev/")); + strpcpy(&s, l, val + STRLEN("/dev/")); else { r = sd_device_get_sysname(dev, &val); if (r < 0) return r; - l = strpcpy(&s, l, val); + strpcpy(&s, l, val); } break; case FORMAT_SUBST_LINKS: FOREACH_DEVICE_DEVLINK(dev, val) if (s == dest) - l = strpcpy(&s, l, val + STRLEN("/dev/")); + strpcpy(&s, l, val + STRLEN("/dev/")); else - l = strpcpyl(&s, l, " ", val + STRLEN("/dev/"), NULL); + strpcpyl(&s, l, " ", val + STRLEN("/dev/"), NULL); if (s == dest) goto null_terminate; break; case FORMAT_SUBST_ROOT: - l = strpcpy(&s, l, "/dev"); + strpcpy(&s, l, "/dev"); break; case FORMAT_SUBST_SYS: - l = strpcpy(&s, l, "/sys"); + strpcpy(&s, l, "/sys"); break; case FORMAT_SUBST_ENV: if (isempty(attr)) @@ -426,7 +426,7 @@ static ssize_t udev_event_subst_format( goto null_terminate; if (r < 0) return r; - l = strpcpy(&s, l, val); + strpcpy(&s, l, val); break; default: assert_not_reached("Unknown format substitution type"); |