MINOR: trace: add the possibility to lock on some arguments

Given that we can pass typed arguments to the trace() function, let's
add provisions for tracking them. They are source-specific so we need
to let the source fill their name and description. Only those with a
non-null name will be proposed.
diff --git a/include/types/trace.h b/include/types/trace.h
index aaf64cc..6d85f9c 100644
--- a/include/types/trace.h
+++ b/include/types/trace.h
@@ -96,6 +96,10 @@
 	TRACE_LOCKON_CONNECTION,  // lock on the connection that started the trace
 	TRACE_LOCKON_SESSION,     // lock on the session that started the trace
 	TRACE_LOCKON_STREAM,      // lock on the stream that started the trace
+	TRACE_LOCKON_ARG1,        // lock on arg1, totally source-dependent
+	TRACE_LOCKON_ARG2,        // lock on arg2, totally source-dependent
+	TRACE_LOCKON_ARG3,        // lock on arg3, totally source-dependent
+	TRACE_LOCKON_ARG4,        // lock on arg4, totally source-dependent
 };
 
 /* Each trace event maps a name to a mask in an uint64_t. Multiple bits are
@@ -110,6 +114,15 @@
 	const char *desc;
 };
 
+/* add a name and description for each arg that we know we can track. Those
+ * with a non-null name will be presented in the menu and will be usable for
+ * trace lock-on.
+ */
+struct trace_lockon_arg {
+	const char *name;
+	const char *desc;
+};
+
 struct trace_source {
 	/* source definition */
 	const struct ist name;
@@ -117,6 +130,7 @@
 	const struct trace_event *known_events;
 	struct list source_link; // element in list of known trace sources
 	uint32_t arg_def;        // argument definitions (sum of TRC_ARG{1..4}_*)
+	const struct trace_lockon_arg *lockon_args; // must be 4 entries if not NULL
 	/* trace configuration, adjusted by "trace <module>" on CLI */
 	enum trace_lockon lockon;
 	uint64_t start_events;   // what will start the trace. default: 0=nothing