summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorThomas Haller <thaller@redhat.com>2014-11-27 15:56:42 (GMT)
committerThomas Haller <thaller@redhat.com>2014-11-27 15:57:08 (GMT)
commitbf4b042ed1fdd304a541e412970d6757475d5ecc (patch)
tree4c960eebcbac52cd561106a2488c7443c443fa08
parenta60b3e46e74f91bde3264c5f5382b87d05fcb917 (diff)
parent1c61ac3f4e35f17e7894c277fb68172b41a7f72d (diff)
downloadlibnl-bf4b042ed1fdd304a541e412970d6757475d5ecc.zip
libnl-bf4b042ed1fdd304a541e412970d6757475d5ecc.tar.gz
libnl-bf4b042ed1fdd304a541e412970d6757475d5ecc.tar.bz2
idiag: merge branch 'idiag-compare-all'
oo_compare() is also relevant for nl_object_diff() and nl_object_filter(). Compare all fields so that comparing idiag_meminfo_obj works properly. http://lists.infradead.org/pipermail/libnl/2014-November/001783.html Signed-off-by: Thomas Haller <thaller@redhat.com>
-rw-r--r--lib/idiag/idiag_meminfo_obj.c15
-rw-r--r--lib/idiag/idiag_msg_obj.c72
-rw-r--r--lib/idiag/idiag_vegasinfo_obj.c15
3 files changed, 76 insertions, 26 deletions
diff --git a/lib/idiag/idiag_meminfo_obj.c b/lib/idiag/idiag_meminfo_obj.c
index 7a044f4..f07800f 100644
--- a/lib/idiag/idiag_meminfo_obj.c
+++ b/lib/idiag/idiag_meminfo_obj.c
@@ -81,9 +81,24 @@ void idiagnl_meminfo_set_tmem(struct idiagnl_meminfo *minfo, uint32_t tmem)
/** @} */
/** @cond SKIP */
+static int idiagnl_meminfo_compare(struct nl_object *_a, struct nl_object *_b,
+ uint32_t attrs, int flags)
+{
+ struct idiagnl_meminfo *a = (struct idiagnl_meminfo *) _a;
+ struct idiagnl_meminfo *b = (struct idiagnl_meminfo *) _b;
+
+ /* meminfo is a very simple object. It has no attribe flags (ce_mask),
+ * hence compare just returns 0 or 1, not a bit mask of attributes. */
+ return a->idiag_rmem != b->idiag_rmem ||
+ a->idiag_wmem != b->idiag_wmem ||
+ a->idiag_fmem != b->idiag_fmem ||
+ a->idiag_tmem != b->idiag_tmem;
+}
+
struct nl_object_ops idiagnl_meminfo_obj_ops = {
.oo_name = "idiag/idiag_meminfo",
.oo_size = sizeof(struct idiagnl_meminfo),
+ .oo_compare = idiagnl_meminfo_compare,
};
/** @endcond */
/** @} */
diff --git a/lib/idiag/idiag_msg_obj.c b/lib/idiag/idiag_msg_obj.c
index 8199536..3be6dfc 100644
--- a/lib/idiag/idiag_msg_obj.c
+++ b/lib/idiag/idiag_msg_obj.c
@@ -458,7 +458,7 @@ static void idiag_msg_dump_details(struct nl_object *a, struct nl_dump_params *p
nl_dump(p, "tos: 0x%x\n", msg->idiag_tos);
nl_dump(p, "traffic class: %d\n", msg->idiag_tclass);
- nl_dump(p, "congestion algorithm: %s\n", msg->idiag_cong);
+ nl_dump(p, "congestion algorithm: %s\n", msg->idiag_cong ? : "");
}
static void idiag_msg_dump_stats(struct nl_object *obj, struct nl_dump_params *p)
@@ -575,27 +575,29 @@ static void idiag_msg_dump_stats(struct nl_object *obj, struct nl_dump_params *p
nl_dump(p, "]\n");
}
- nl_dump(p, "skmeminfo: [\n");
- nl_dump(p, "\trmem alloc: %d\n",
- msg->idiag_skmeminfo[SK_MEMINFO_RMEM_ALLOC]);
- nl_dump(p, "\trcv buf: %s\n",
- nl_size2str(msg->idiag_skmeminfo[SK_MEMINFO_RCVBUF],
- buf, sizeof(buf)));
- nl_dump(p, "\twmem alloc: %d\n",
- msg->idiag_skmeminfo[SK_MEMINFO_WMEM_ALLOC]);
- nl_dump(p, "\tsnd buf: %s\n",
- nl_size2str(msg->idiag_skmeminfo[SK_MEMINFO_SNDBUF],
- buf, sizeof(buf)));
- nl_dump(p, "\tfwd alloc: %d\n",
- msg->idiag_skmeminfo[SK_MEMINFO_FWD_ALLOC]);
- nl_dump(p, "\twmem queued: %s\n",
- nl_size2str(msg->idiag_skmeminfo[SK_MEMINFO_WMEM_QUEUED],
- buf, sizeof(buf)));
- nl_dump(p, "\topt mem: %d\n",
- msg->idiag_skmeminfo[SK_MEMINFO_OPTMEM]);
- nl_dump(p, "\tbacklog: %d\n",
- msg->idiag_skmeminfo[SK_MEMINFO_BACKLOG]);
- nl_dump(p, "]\n\n");
+ if (msg->ce_mask & IDIAGNL_ATTR_MEMINFO) {
+ nl_dump(p, "skmeminfo: [\n");
+ nl_dump(p, "\trmem alloc: %d\n",
+ msg->idiag_skmeminfo[SK_MEMINFO_RMEM_ALLOC]);
+ nl_dump(p, "\trcv buf: %s\n",
+ nl_size2str(msg->idiag_skmeminfo[SK_MEMINFO_RCVBUF],
+ buf, sizeof(buf)));
+ nl_dump(p, "\twmem alloc: %d\n",
+ msg->idiag_skmeminfo[SK_MEMINFO_WMEM_ALLOC]);
+ nl_dump(p, "\tsnd buf: %s\n",
+ nl_size2str(msg->idiag_skmeminfo[SK_MEMINFO_SNDBUF],
+ buf, sizeof(buf)));
+ nl_dump(p, "\tfwd alloc: %d\n",
+ msg->idiag_skmeminfo[SK_MEMINFO_FWD_ALLOC]);
+ nl_dump(p, "\twmem queued: %s\n",
+ nl_size2str(msg->idiag_skmeminfo[SK_MEMINFO_WMEM_QUEUED],
+ buf, sizeof(buf)));
+ nl_dump(p, "\topt mem: %d\n",
+ msg->idiag_skmeminfo[SK_MEMINFO_OPTMEM]);
+ nl_dump(p, "\tbacklog: %d\n",
+ msg->idiag_skmeminfo[SK_MEMINFO_BACKLOG]);
+ nl_dump(p, "]\n\n");
+ }
}
static void idiagnl_msg_free(struct nl_object *a)
@@ -859,10 +861,28 @@ static int idiagnl_compare(struct nl_object *_a, struct nl_object *_b,
int diff = 0;
#define _DIFF(ATTR, EXPR) ATTR_DIFF(attrs, IDIAGNL_ATTR_##ATTR, a, b, EXPR)
- diff |= _DIFF(FAMILY, a->idiag_family != b->idiag_family);
- diff |= _DIFF(STATE, a->idiag_state != b->idiag_state);
- diff |= _DIFF(SPORT, a->idiag_sport != b->idiag_sport);
- diff |= _DIFF(DPORT, a->idiag_dport != b->idiag_dport);
+ diff |= _DIFF(FAMILY, a->idiag_family != b->idiag_family);
+ diff |= _DIFF(STATE, a->idiag_state != b->idiag_state);
+ diff |= _DIFF(TIMER, a->idiag_timer != b->idiag_timer);
+ diff |= _DIFF(RETRANS, a->idiag_retrans != b->idiag_retrans);
+ diff |= _DIFF(SPORT, a->idiag_sport != b->idiag_sport);
+ diff |= _DIFF(DPORT, a->idiag_dport != b->idiag_dport);
+ diff |= _DIFF(SRC, nl_addr_cmp (a->idiag_src, b->idiag_src));
+ diff |= _DIFF(DST, nl_addr_cmp (a->idiag_dst, b->idiag_dst));
+ diff |= _DIFF(IFINDEX, a->idiag_ifindex != b->idiag_ifindex);
+ diff |= _DIFF(EXPIRES, a->idiag_expires != b->idiag_expires);
+ diff |= _DIFF(RQUEUE, a->idiag_rqueue != b->idiag_rqueue);
+ diff |= _DIFF(WQUEUE, a->idiag_wqueue != b->idiag_wqueue);
+ diff |= _DIFF(UID, a->idiag_uid != b->idiag_uid);
+ diff |= _DIFF(INODE, a->idiag_inode != b->idiag_inode);
+ diff |= _DIFF(TOS, a->idiag_tos != b->idiag_tos);
+ diff |= _DIFF(TCLASS, a->idiag_tclass != b->idiag_tclass);
+ diff |= _DIFF(SHUTDOWN, a->idiag_shutdown != b->idiag_shutdown);
+ diff |= _DIFF(CONG, strcmp(a->idiag_cong, b->idiag_cong));
+ diff |= _DIFF(MEMINFO, nl_object_diff((struct nl_object *) a->idiag_meminfo, (struct nl_object *) b->idiag_meminfo));
+ diff |= _DIFF(VEGASINFO, nl_object_diff((struct nl_object *) a->idiag_vegasinfo, (struct nl_object *) b->idiag_vegasinfo));
+ diff |= _DIFF(TCPINFO, memcmp(&a->idiag_tcpinfo, &b->idiag_tcpinfo, sizeof(a->idiag_tcpinfo)));
+ diff |= _DIFF(SKMEMINFO, memcmp(a->idiag_skmeminfo, b->idiag_skmeminfo, sizeof(a->idiag_skmeminfo)));
#undef _DIFF
return diff;
}
diff --git a/lib/idiag/idiag_vegasinfo_obj.c b/lib/idiag/idiag_vegasinfo_obj.c
index ffeb357..eddd8af 100644
--- a/lib/idiag/idiag_vegasinfo_obj.c
+++ b/lib/idiag/idiag_vegasinfo_obj.c
@@ -84,9 +84,24 @@ void idiagnl_vegasinfo_set_minrtt(struct idiagnl_vegasinfo *vinfo, uint32_t
/** @} */
/** @cond SKIP */
+static int idiagnl_vegasinfo_compare(struct nl_object *_a, struct nl_object *_b,
+ uint32_t attrs, int flags)
+{
+ struct idiagnl_vegasinfo *a = (struct idiagnl_vegasinfo *) _a;
+ struct idiagnl_vegasinfo *b = (struct idiagnl_vegasinfo *) _b;
+
+ /* vegasinfo is a very simple object. It has no attribe flags (ce_mask),
+ * hence compare just returns 0 or 1, not a bit mask of attributes. */
+ return a->tcpv_enabled != b->tcpv_enabled ||
+ a->tcpv_rttcnt != b->tcpv_rttcnt ||
+ a->tcpv_rtt != b->tcpv_rtt ||
+ a->tcpv_minrtt != b->tcpv_minrtt;
+}
+
struct nl_object_ops idiagnl_vegasinfo_obj_ops = {
.oo_name = "idiag/idiag_vegasinfo",
.oo_size = sizeof(struct idiagnl_vegasinfo),
+ .oo_compare = idiagnl_vegasinfo_compare,
};
/** @endcond */
/** @} */