Commit aa38e9fc authored by Li Zefan's avatar Li Zefan Committed by Steven Rostedt

tracing/filters: Add filter_type to struct ftrace_event_field

The type of a field is stored as a string in @type, and here
we add @filter_type which is an enum value.

This prepares for later patches, so we can specifically assign
different @filter_type for the same @type.

For example normally a "char *" field is treated as a ptr,
but we may want it to be treated as a string when doing filting.
Signed-off-by: default avatarLi Zefan <lizf@cn.fujitsu.com>
LKML-Reference: <4A7B925E.9030605@cn.fujitsu.com>
Signed-off-by: default avatarSteven Rostedt <rostedt@goodmis.org>
parent 6591b493
...@@ -755,6 +755,7 @@ struct ftrace_event_field { ...@@ -755,6 +755,7 @@ struct ftrace_event_field {
struct list_head link; struct list_head link;
char *name; char *name;
char *type; char *type;
int filter_type;
int offset; int offset;
int size; int size;
int is_signed; int is_signed;
...@@ -800,6 +801,7 @@ extern int apply_subsystem_event_filter(struct event_subsystem *system, ...@@ -800,6 +801,7 @@ extern int apply_subsystem_event_filter(struct event_subsystem *system,
char *filter_string); char *filter_string);
extern void print_subsystem_event_filter(struct event_subsystem *system, extern void print_subsystem_event_filter(struct event_subsystem *system,
struct trace_seq *s); struct trace_seq *s);
extern int filter_assign_type(const char *type);
static inline int static inline int
filter_check_discard(struct ftrace_event_call *call, void *rec, filter_check_discard(struct ftrace_event_call *call, void *rec,
......
...@@ -44,9 +44,11 @@ int trace_define_field(struct ftrace_event_call *call, const char *type, ...@@ -44,9 +44,11 @@ int trace_define_field(struct ftrace_event_call *call, const char *type,
if (!field->type) if (!field->type)
goto err; goto err;
field->filter_type = filter_assign_type(type);
field->offset = offset; field->offset = offset;
field->size = size; field->size = size;
field->is_signed = is_signed; field->is_signed = is_signed;
list_add(&field->link, &call->fields); list_add(&field->link, &call->fields);
return 0; return 0;
......
...@@ -476,11 +476,12 @@ static int filter_add_pred_fn(struct filter_parse_state *ps, ...@@ -476,11 +476,12 @@ static int filter_add_pred_fn(struct filter_parse_state *ps,
} }
enum { enum {
FILTER_STATIC_STRING = 1, FILTER_OTHER = 0,
FILTER_DYN_STRING FILTER_STATIC_STRING,
FILTER_DYN_STRING,
}; };
static int is_string_field(const char *type) int filter_assign_type(const char *type)
{ {
if (strstr(type, "__data_loc") && strstr(type, "char")) if (strstr(type, "__data_loc") && strstr(type, "char"))
return FILTER_DYN_STRING; return FILTER_DYN_STRING;
...@@ -488,12 +489,18 @@ static int is_string_field(const char *type) ...@@ -488,12 +489,18 @@ static int is_string_field(const char *type)
if (strchr(type, '[') && strstr(type, "char")) if (strchr(type, '[') && strstr(type, "char"))
return FILTER_STATIC_STRING; return FILTER_STATIC_STRING;
return 0; return FILTER_OTHER;
}
static bool is_string_field(struct ftrace_event_field *field)
{
return field->filter_type == FILTER_DYN_STRING ||
field->filter_type == FILTER_STATIC_STRING;
} }
static int is_legal_op(struct ftrace_event_field *field, int op) static int is_legal_op(struct ftrace_event_field *field, int op)
{ {
if (is_string_field(field->type) && (op != OP_EQ && op != OP_NE)) if (is_string_field(field) && (op != OP_EQ && op != OP_NE))
return 0; return 0;
return 1; return 1;
...@@ -550,7 +557,6 @@ static int filter_add_pred(struct filter_parse_state *ps, ...@@ -550,7 +557,6 @@ static int filter_add_pred(struct filter_parse_state *ps,
struct ftrace_event_field *field; struct ftrace_event_field *field;
filter_pred_fn_t fn; filter_pred_fn_t fn;
unsigned long long val; unsigned long long val;
int string_type;
int ret; int ret;
pred->fn = filter_pred_none; pred->fn = filter_pred_none;
...@@ -578,9 +584,8 @@ static int filter_add_pred(struct filter_parse_state *ps, ...@@ -578,9 +584,8 @@ static int filter_add_pred(struct filter_parse_state *ps,
return -EINVAL; return -EINVAL;
} }
string_type = is_string_field(field->type); if (is_string_field(field)) {
if (string_type) { if (field->filter_type == FILTER_STATIC_STRING)
if (string_type == FILTER_STATIC_STRING)
fn = filter_pred_string; fn = filter_pred_string;
else else
fn = filter_pred_strloc; fn = filter_pred_strloc;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment