1
1
mirror of https://github.com/systemd/systemd-stable.git synced 2025-01-11 05:17:44 +03:00

shared: add MAXSIZE() and use it in resolved

The MAXSIZE() macro takes two types and returns the size of the larger
one. It is much simpler to use than MAX(sizeof(A), sizeof(B)) and also
avoids any compiler-extensions, unlike CONST_MAX() and MAX() (which are
needed to avoid evaluating arguments more than once). This was suggested
by Daniele Nicolodi <daniele@grinta.net>.

Also make resolved use this macro instead of CONST_MAX(). This enhances
readability quite a bit.
This commit is contained in:
David Herrmann 2014-08-22 13:55:57 +02:00
parent 0975b63fb3
commit 40a1eebde6
4 changed files with 9 additions and 2 deletions

View File

@ -64,7 +64,7 @@ static int dns_stream_complete(DnsStream *s, int error) {
static int dns_stream_identify(DnsStream *s) { static int dns_stream_identify(DnsStream *s) {
union { union {
struct cmsghdr header; /* For alignment */ struct cmsghdr header; /* For alignment */
uint8_t buffer[CMSG_SPACE(CONST_MAX(sizeof(struct in_pktinfo), sizeof(struct in6_pktinfo))) uint8_t buffer[CMSG_SPACE(MAXSIZE(struct in_pktinfo, struct in6_pktinfo))
+ EXTRA_CMSG_SPACE /* kernel appears to require extra space */]; + EXTRA_CMSG_SPACE /* kernel appears to require extra space */];
} control; } control;
struct msghdr mh = {}; struct msghdr mh = {};

View File

@ -841,7 +841,7 @@ int manager_recv(Manager *m, int fd, DnsProtocol protocol, DnsPacket **ret) {
_cleanup_(dns_packet_unrefp) DnsPacket *p = NULL; _cleanup_(dns_packet_unrefp) DnsPacket *p = NULL;
union { union {
struct cmsghdr header; /* For alignment */ struct cmsghdr header; /* For alignment */
uint8_t buffer[CMSG_SPACE(CONST_MAX(sizeof(struct in_pktinfo), sizeof(struct in6_pktinfo))) uint8_t buffer[CMSG_SPACE(MAXSIZE(struct in_pktinfo, struct in6_pktinfo))
+ CMSG_SPACE(int) /* ttl/hoplimit */ + CMSG_SPACE(int) /* ttl/hoplimit */
+ EXTRA_CMSG_SPACE /* kernel appears to require extra buffer space */]; + EXTRA_CMSG_SPACE /* kernel appears to require extra buffer space */];
} control; } control;

View File

@ -149,6 +149,9 @@ static inline unsigned long ALIGN_POWER2(unsigned long u) {
((_A) > (_B)) ? (_A) : (_B), \ ((_A) > (_B)) ? (_A) : (_B), \
(void)0)) (void)0))
/* takes two types and returns the size of the larger one */
#define MAXSIZE(A, B) (sizeof(union _packed_ { typeof(A) a; typeof(B) b; }))
#define MAX3(x,y,z) \ #define MAX3(x,y,z) \
__extension__ ({ \ __extension__ ({ \
const typeof(x) _c = MAX(x,y); \ const typeof(x) _c = MAX(x,y); \

View File

@ -90,6 +90,10 @@ static void test_max(void) {
assert_se(val1.a == 100); assert_se(val1.a == 100);
assert_se(MAX(++d, 0) == 1); assert_se(MAX(++d, 0) == 1);
assert_se(d == 1); assert_se(d == 1);
assert_cc(MAXSIZE(char[3], uint16_t) == 3);
assert_cc(MAXSIZE(char[3], uint32_t) == 4);
assert_cc(MAXSIZE(char, long) == sizeof(long));
} }
static void test_first_word(void) { static void test_first_word(void) {