@@ -53,6 +53,7 @@ struct NetFilterState {
char *netdev_id;
NetClientState *netdev;
NetFilterChain chain;
+ char info_str[256];
QTAILQ_ENTRY(NetFilterState) global_list;
QTAILQ_ENTRY(NetFilterState) next;
};
@@ -1172,10 +1172,27 @@ void qmp_netdev_del(const char *id, Error **errp)
void print_net_client(Monitor *mon, NetClientState *nc)
{
+ NetFilterState *nf;
+
monitor_printf(mon, "%s: index=%d,type=%s,%s\n", nc->name,
nc->queue_index,
NetClientOptionsKind_lookup[nc->info->type],
nc->info_str);
+ if (!QTAILQ_EMPTY(&nc->filters)) {
+ monitor_printf(mon, "filters:\n");
+ }
+ QTAILQ_FOREACH(nf, &nc->filters, next) {
+ monitor_printf(mon, " - %s: type=%s,netdev=%s,chain=%s",
+ object_get_canonical_path_component(OBJECT(nf)),
+ object_get_typename(OBJECT(nf)),
+ nf->netdev->name,
+ NetFilterChain_lookup[nf->chain]);
+ if (strlen(nf->info_str)) {
+ monitor_printf(mon, ",%s\n", nf->info_str);
+ } else {
+ monitor_printf(mon, "\n");
+ }
+ }
}
RxFilterInfoList *qmp_query_rx_filter(bool has_name, const char *name,