mirror of
https://gitlab.nic.cz/labs/bird.git
synced 2024-12-22 09:41:54 +00:00
Merge commit '1d309c4ce6e95b68c64a8f007f6dd2f1830a5707' into haugesund
This commit is contained in:
commit
b7e2edd441
26
aclocal.m4
vendored
26
aclocal.m4
vendored
@ -1,6 +1,32 @@
|
||||
dnl ** Additional Autoconf tests for BIRD configure script
|
||||
dnl ** (c) 1999 Martin Mares <mj@ucw.cz>
|
||||
|
||||
AC_DEFUN([BIRD_CHECK_POINTER_ALIGNMENT],
|
||||
[
|
||||
AC_CACHE_CHECK(
|
||||
[how pointers are aligned],
|
||||
[bird_cv_pointer_alignment],
|
||||
AC_COMPILE_IFELSE([
|
||||
AC_LANG_PROGRAM(
|
||||
[
|
||||
_Static_assert(_Alignof(void *) == 8, "bad");
|
||||
], []
|
||||
)
|
||||
],
|
||||
[bird_cv_pointer_alignment=8],
|
||||
AC_COMPILE_IFELSE([
|
||||
AC_LANG_PROGRAM(
|
||||
[
|
||||
_Static_assert(_Alignof(void *) == 4, "bad");
|
||||
], []
|
||||
)
|
||||
],
|
||||
[bird_cv_pointer_alignment=4],
|
||||
[bird_cv_pointer_alignment=unknown]
|
||||
))
|
||||
)
|
||||
])
|
||||
|
||||
AC_DEFUN([BIRD_CHECK_THREAD_LOCAL],
|
||||
[
|
||||
AC_CACHE_CHECK(
|
||||
|
@ -360,6 +360,13 @@ AC_C_BIGENDIAN(
|
||||
[AC_MSG_ERROR([Cannot determine CPU endianity.])]
|
||||
)
|
||||
|
||||
BIRD_CHECK_POINTER_ALIGNMENT
|
||||
if test "$bird_cv_pointer_alignment" = "unknown" ; then
|
||||
AC_MSG_ERROR([Couldn't determine pointer alignment])
|
||||
else
|
||||
AC_DEFINE_UNQUOTED([CPU_POINTER_ALIGNMENT], [$bird_cv_pointer_alignment], [Pointer alignment for macro usage])
|
||||
fi
|
||||
|
||||
BIRD_CHECK_ANDROID_GLOB
|
||||
if test "$bird_cv_lib_glob" = no ; then
|
||||
AC_MSG_ERROR([glob.h not found.])
|
||||
|
@ -2,6 +2,6 @@ src := a-path.c a-set.c bitmap.c bitops.c blake2s.c blake2b.c checksum.c event.c
|
||||
obj := $(src-o-files)
|
||||
$(all-daemon)
|
||||
|
||||
tests_src := a-set_test.c a-path_test.c bitmap_test.c heap_test.c buffer_test.c event_test.c flowspec_test.c bitops_test.c patmatch_test.c fletcher16_test.c slist_test.c checksum_test.c lists_test.c mac_test.c ip_test.c hash_test.c printf_test.c slab_test.c
|
||||
tests_src := a-set_test.c a-path_test.c bitmap_test.c heap_test.c buffer_test.c event_test.c flowspec_test.c bitops_test.c patmatch_test.c fletcher16_test.c slist_test.c checksum_test.c lists_test.c mac_test.c ip_test.c hash_test.c printf_test.c slab_test.c type_test.c
|
||||
tests_targets := $(tests_targets) $(tests-target-files)
|
||||
tests_objs := $(tests_objs) $(src-o-files)
|
||||
|
@ -9,18 +9,30 @@
|
||||
#ifndef _BIRD_BIRDLIB_H_
|
||||
#define _BIRD_BIRDLIB_H_
|
||||
|
||||
#include "sysdep/config.h"
|
||||
#include "lib/alloca.h"
|
||||
|
||||
/* Ugly structure offset handling macros */
|
||||
|
||||
struct align_probe { char x; long int y; };
|
||||
|
||||
#define OFFSETOF(s, i) ((size_t) &((s *)0)->i)
|
||||
#define SKIP_BACK(s, i, p) ((s *)((char *)p - OFFSETOF(s, i)))
|
||||
#define BIRD_ALIGN(s, a) (((s)+a-1)&~(a-1))
|
||||
#define CPU_STRUCT_ALIGN (sizeof(struct align_probe))
|
||||
#define CPU_STRUCT_ALIGN (MAX_(_Alignof(void*), _Alignof(u64)))
|
||||
#define BIRD_CPU_ALIGN(s) BIRD_ALIGN((s), CPU_STRUCT_ALIGN)
|
||||
|
||||
/* Structure item alignment macros */
|
||||
|
||||
#define PADDING_NAME(id) _padding_##id
|
||||
#define PADDING_(id, sz) u8 PADDING_NAME(id)[sz]
|
||||
|
||||
#if CPU_POINTER_ALIGNMENT == 4
|
||||
#define PADDING(id, n32, n64) PADDING_(id, n32)
|
||||
#elif CPU_POINTER_ALIGNMENT == 8
|
||||
#define PADDING(id, n32, n64) PADDING_(id, n64)
|
||||
#else
|
||||
#error "Strange CPU pointer alignment: " CPU_POINTER_ALIGNMENT
|
||||
#endif
|
||||
|
||||
/* Utility macros */
|
||||
|
||||
#define MIN_(a,b) (((a)<(b))?(a):(b))
|
||||
|
13
lib/route.h
13
lib/route.h
@ -146,6 +146,8 @@ typedef struct eattr {
|
||||
byte fresh:1; /* An uncached attribute (e.g. modified in export filter) */
|
||||
byte undef:1; /* Explicitly undefined */
|
||||
|
||||
PADDING(unused, 0, 4);
|
||||
|
||||
union bval u;
|
||||
} eattr;
|
||||
|
||||
@ -227,9 +229,14 @@ struct ea_one_attr_list {
|
||||
EA_LITERAL_GENERIC(_id, _type, _flags, .u.i = _val); \
|
||||
})
|
||||
|
||||
#define EA_LITERAL_ADATA(_id, _type, _flags, _buf, _len) ({ \
|
||||
#define EA_LITERAL_STORE_ADATA(_id, _type, _flags, _buf, _len) ({ \
|
||||
ASSERT_DIE(!(_type & EAF_EMBEDDED)); \
|
||||
EA_LITERAL_GENERIC(_id, _type, _flags, .u.ad = tmp_store_adata(_buf, _len)); \
|
||||
EA_LITERAL_GENERIC(_id, _type, _flags, .u.ad = tmp_store_adata((_buf), (_len))); \
|
||||
})
|
||||
|
||||
#define EA_LITERAL_DIRECT_ADATA(_id, _type, _flags, _adata) ({ \
|
||||
ASSERT_DIE(!(_type & EAF_EMBEDDED)); \
|
||||
EA_LITERAL_GENERIC(_id, _type, _flags, .u.ad = _adata); \
|
||||
})
|
||||
|
||||
#define EA_LITERAL_GENERIC(_id, _type, _flags, ...) \
|
||||
@ -263,7 +270,7 @@ ea_set_attr_u32(ea_list **to, uint id, uint flags, uint type, u32 data)
|
||||
|
||||
static inline void
|
||||
ea_set_attr_data(ea_list **to, uint id, uint flags, uint type, void *data, uint len)
|
||||
{ ea_set_attr(to, EA_LITERAL_ADATA(id, type, flags, data, len)); }
|
||||
{ ea_set_attr(to, EA_LITERAL_STORE_ADATA(id, type, flags, data, len)); }
|
||||
|
||||
|
||||
#define NEXTHOP_MAX_SIZE (sizeof(struct nexthop) + sizeof(u32)*MPLS_MAX_LABEL_STACK)
|
||||
|
12
lib/type.h
12
lib/type.h
@ -13,9 +13,15 @@
|
||||
#include "lib/attrs.h"
|
||||
|
||||
union bval {
|
||||
#define BVAL_ITEMS \
|
||||
u32 data; /* Integer type inherited from eattrs */ \
|
||||
u32 i; /* Integer type inherited from filters */ \
|
||||
#define BVAL_ITEMS \
|
||||
struct { \
|
||||
u32 data; /* Integer type inherited from eattrs */ \
|
||||
PADDING(data, 0, 4); /* Must be padded on 64-bits */ \
|
||||
}; \
|
||||
struct { \
|
||||
u32 i; /* Integer type inherited from filters */ \
|
||||
PADDING(i, 0, 4); /* Must be padded on 64-bits */ \
|
||||
}; \
|
||||
const struct adata *ptr; /* Generic attribute data inherited from eattrs */ \
|
||||
const struct adata *ad; /* Generic attribute data inherited from filters */ \
|
||||
|
||||
|
78
lib/type_test.c
Normal file
78
lib/type_test.c
Normal file
@ -0,0 +1,78 @@
|
||||
/*
|
||||
* BIRD Library -- Data Type Alignment Tests
|
||||
*
|
||||
* (c) 2022 Maria Matejka <mq@jmq.cz>
|
||||
*
|
||||
* Can be freely distributed and used under the terms of the GNU GPL.
|
||||
*/
|
||||
|
||||
#include "test/birdtest.h"
|
||||
#include "lib/type.h"
|
||||
#include "lib/route.h"
|
||||
|
||||
#define CHECK_ONE(val) \
|
||||
for (uint i=0; i<sizeof(val); i++) \
|
||||
bt_assert(((const u8 *) &val)[i] == (u8) ~0);
|
||||
|
||||
#define SET_PADDING(val, name) \
|
||||
for (uint i=0; i<sizeof(val.PADDING_NAME(name)); i++) \
|
||||
val.PADDING_NAME(name)[i] = ~0;
|
||||
|
||||
|
||||
static int
|
||||
t_bval(void)
|
||||
{
|
||||
union bval v;
|
||||
|
||||
memset(&v, 0, sizeof(v));
|
||||
v.data = ~0;
|
||||
SET_PADDING(v, data);
|
||||
CHECK_ONE(v);
|
||||
|
||||
memset(&v, 0, sizeof(v));
|
||||
v.i = ~0;
|
||||
SET_PADDING(v, i);
|
||||
CHECK_ONE(v);
|
||||
|
||||
memset(&v, 0, sizeof(v));
|
||||
v.ptr = (void *) ~0;
|
||||
CHECK_ONE(v);
|
||||
|
||||
memset(&v, 0, sizeof(v));
|
||||
v.ad = (void *) ~0;
|
||||
CHECK_ONE(v);
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
static int
|
||||
t_eattr(void)
|
||||
{
|
||||
struct eattr e;
|
||||
memset(&e, 0, sizeof(e));
|
||||
|
||||
e.id = ~0;
|
||||
e.flags = ~0;
|
||||
e.type = ~0;
|
||||
e.originated = ~0;
|
||||
e.fresh = ~0;
|
||||
e.undef = ~0;
|
||||
memset(&e.u, ~0, sizeof(e.u)); /* Assumes t_bval passed */
|
||||
|
||||
SET_PADDING(e, unused);
|
||||
|
||||
CHECK_ONE(e);
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
{
|
||||
bt_init(argc, argv);
|
||||
|
||||
bt_test_suite(t_bval, "Structure alignment test: bval");
|
||||
bt_test_suite(t_eattr, "Structure alignment test: eattr");
|
||||
|
||||
return bt_exit_value();
|
||||
}
|
@ -6,7 +6,7 @@ $(call proto-build,dev_build)
|
||||
|
||||
$(proto-build-c): $(lastword $(MAKEFILE_LIST))
|
||||
$(E)echo GEN $@
|
||||
$(Q)echo "$(patsubst %,void %(void); ,$(PROTO_BUILD)) void protos_build_gen(void) { $(patsubst %, %(); ,$(PROTO_BUILD))}" > $@
|
||||
$(Q)echo "#include \"lib/birdlib.h\"\n$(patsubst %,void %(void);\n,$(PROTO_BUILD)) void protos_build_gen(void) { $(patsubst %, %();\n,$(PROTO_BUILD))}" > $@
|
||||
|
||||
tests_src :=
|
||||
tests_targets := $(tests_targets) $(tests-target-files)
|
||||
|
@ -9,7 +9,6 @@
|
||||
#ifndef _BIRD_BIRD_H_
|
||||
#define _BIRD_BIRD_H_
|
||||
|
||||
#include "sysdep/config.h"
|
||||
#include "lib/birdlib.h"
|
||||
#include "lib/ip.h"
|
||||
#include "lib/net.h"
|
||||
|
@ -640,6 +640,18 @@ babel_announce_rte(struct babel_proto *p, struct babel_entry *e)
|
||||
|
||||
if (r)
|
||||
{
|
||||
struct {
|
||||
ea_list l;
|
||||
eattr a[3];
|
||||
} eattrs = {
|
||||
.l.count = 3,
|
||||
.a = {
|
||||
EA_LITERAL_EMBEDDED(EA_BABEL_METRIC, T_INT, 0, r->metric),
|
||||
EA_LITERAL_STORE_ADATA(EA_BABEL_ROUTER_ID, T_OPAQUE, 0, &r->router_id, sizeof(r->router_id)),
|
||||
EA_LITERAL_EMBEDDED(EA_BABEL_SEQNO, T_INT, 0, r->seqno),
|
||||
}
|
||||
};
|
||||
|
||||
rta a0 = {
|
||||
.source = RTS_BABEL,
|
||||
.scope = SCOPE_UNIVERSE,
|
||||
@ -648,29 +660,7 @@ babel_announce_rte(struct babel_proto *p, struct babel_entry *e)
|
||||
.from = r->neigh->addr,
|
||||
.nh.gw = r->next_hop,
|
||||
.nh.iface = r->neigh->ifa->iface,
|
||||
.eattrs = alloca(sizeof(ea_list) + 3*sizeof(eattr)),
|
||||
};
|
||||
|
||||
*a0.eattrs = (ea_list) { .count = 3 };
|
||||
a0.eattrs->attrs[0] = (eattr) {
|
||||
.id = EA_BABEL_METRIC,
|
||||
.type = T_INT,
|
||||
.u.data = r->metric,
|
||||
};
|
||||
|
||||
struct adata *ad = alloca(sizeof(struct adata) + sizeof(u64));
|
||||
ad->length = sizeof(u64);
|
||||
memcpy(ad->data, &(r->router_id), sizeof(u64));
|
||||
a0.eattrs->attrs[1] = (eattr) {
|
||||
.id = EA_BABEL_ROUTER_ID,
|
||||
.type = T_OPAQUE,
|
||||
.u.ptr = ad,
|
||||
};
|
||||
|
||||
a0.eattrs->attrs[2] = (eattr) {
|
||||
.id = EA_BABEL_SEQNO,
|
||||
.type = T_INT,
|
||||
.u.data = r->seqno,
|
||||
.eattrs = &eattrs.l,
|
||||
};
|
||||
|
||||
/*
|
||||
|
@ -94,13 +94,12 @@ void bgp_set_attr_u32(ea_list **to, uint code, uint flags, u32 val)
|
||||
void bgp_set_attr_ptr(ea_list **to, uint code, uint flags, const struct adata *ad)
|
||||
{
|
||||
ASSERT(bgp_attr_known(code));
|
||||
ASSERT_DIE(!(bgp_attr_table[code].type & EAF_EMBEDDED));
|
||||
|
||||
ea_set_attr(to, EA_LITERAL_GENERIC(
|
||||
ea_set_attr(to, EA_LITERAL_DIRECT_ADATA(
|
||||
EA_CODE(PROTOCOL_BGP, code),
|
||||
bgp_attr_table[code].type,
|
||||
flags & ~BAF_EXT_LEN,
|
||||
.u.ad = ad
|
||||
ad
|
||||
));
|
||||
}
|
||||
|
||||
@ -109,7 +108,7 @@ bgp_set_attr_data(ea_list **to, uint code, uint flags, void *data, uint len)
|
||||
{
|
||||
ASSERT(bgp_attr_known(code));
|
||||
|
||||
ea_set_attr(to, EA_LITERAL_ADATA(
|
||||
ea_set_attr(to, EA_LITERAL_STORE_ADATA(
|
||||
EA_CODE(PROTOCOL_BGP, code),
|
||||
bgp_attr_table[code].type,
|
||||
flags & ~BAF_EXT_LEN,
|
||||
|
@ -2062,39 +2062,33 @@ again1:
|
||||
|
||||
if (reload || ort_changed(nf, &a0))
|
||||
{
|
||||
a0.eattrs = alloca(sizeof(ea_list) + 4 * sizeof(eattr));
|
||||
memset(a0.eattrs, 0, sizeof(ea_list));
|
||||
|
||||
nf->old_metric1 = nf->n.metric1;
|
||||
nf->old_metric2 = nf->n.metric2;
|
||||
nf->old_tag = nf->n.tag;
|
||||
nf->old_rid = nf->n.rid;
|
||||
|
||||
a0.eattrs->attrs[a0.eattrs->count++] = (eattr) {
|
||||
.id = EA_OSPF_METRIC1,
|
||||
.type = T_INT,
|
||||
.u.data = nf->n.metric1,
|
||||
};
|
||||
struct {
|
||||
ea_list l;
|
||||
eattr a[4];
|
||||
} eattrs;
|
||||
|
||||
eattrs.l = (ea_list) {};
|
||||
|
||||
eattrs.a[eattrs.l.count++] =
|
||||
EA_LITERAL_EMBEDDED(EA_OSPF_METRIC1, T_INT, 0, nf->n.metric1);
|
||||
|
||||
if (nf->n.type == RTS_OSPF_EXT2)
|
||||
a0.eattrs->attrs[a0.eattrs->count++] = (eattr) {
|
||||
.id = EA_OSPF_METRIC2,
|
||||
.type = T_INT,
|
||||
.u.data = nf->n.metric2,
|
||||
};
|
||||
eattrs.a[eattrs.l.count++] =
|
||||
EA_LITERAL_EMBEDDED(EA_OSPF_METRIC2, T_INT, 0, nf->n.metric2);
|
||||
|
||||
if ((nf->n.type == RTS_OSPF_EXT1) || (nf->n.type == RTS_OSPF_EXT2))
|
||||
a0.eattrs->attrs[a0.eattrs->count++] = (eattr) {
|
||||
.id = EA_OSPF_TAG,
|
||||
.type = T_INT,
|
||||
.u.data = nf->n.tag,
|
||||
};
|
||||
eattrs.a[eattrs.l.count++] =
|
||||
EA_LITERAL_EMBEDDED(EA_OSPF_TAG, T_INT, 0, nf->n.tag);
|
||||
|
||||
a0.eattrs->attrs[a0.eattrs->count++] = (eattr) {
|
||||
.id = EA_OSPF_ROUTER_ID,
|
||||
.type = T_QUAD,
|
||||
.u.data = nf->n.rid,
|
||||
};
|
||||
eattrs.a[eattrs.l.count++] =
|
||||
EA_LITERAL_EMBEDDED(EA_OSPF_ROUTER_ID, T_QUAD, 0, nf->n.rid);
|
||||
|
||||
a0.eattrs = &eattrs.l;
|
||||
|
||||
rta_free(nf->old_rta);
|
||||
nf->old_rta = rta_lookup(&a0);
|
||||
|
@ -195,26 +195,14 @@ rip_announce_rte(struct rip_proto *p, struct rip_entry *en)
|
||||
|
||||
struct {
|
||||
ea_list l;
|
||||
eattr e[3];
|
||||
eattr a[3];
|
||||
struct rip_iface_adata riad;
|
||||
} ea_block = {
|
||||
.l = { .count = 3, },
|
||||
.e = {
|
||||
{
|
||||
.id = EA_RIP_METRIC,
|
||||
.type = T_INT,
|
||||
.u.data = rt_metric,
|
||||
},
|
||||
{
|
||||
.id = EA_RIP_TAG,
|
||||
.type = T_INT,
|
||||
.u.data = rt_tag,
|
||||
},
|
||||
{
|
||||
.id = EA_RIP_FROM,
|
||||
.type = T_IFACE,
|
||||
.u.ptr = &ea_block.riad.ad,
|
||||
}
|
||||
.l.count = 3,
|
||||
.a = {
|
||||
EA_LITERAL_EMBEDDED(EA_RIP_METRIC, T_INT, 0, rt_metric),
|
||||
EA_LITERAL_EMBEDDED(EA_RIP_TAG, T_INT, 0, rt_tag),
|
||||
EA_LITERAL_DIRECT_ADATA(EA_RIP_FROM, T_IFACE, 0, &ea_block.riad.ad),
|
||||
},
|
||||
.riad = {
|
||||
.ad = { .length = sizeof(struct rip_iface_adata) - sizeof(struct adata) },
|
||||
|
Loading…
Reference in New Issue
Block a user