Merge branch 'tracing-fixes-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/linux-2.6-tip
* 'tracing-fixes-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/linux-2.6-tip: tracing/filters: Add comment for match callbacks tracing/filters: Fix MATCH_FULL filter matching for PTR_STRING tracing/filters: Fix MATCH_MIDDLE_ONLY filter matching lib: Introduce strnstr() tracing/filters: Fix MATCH_END_ONLY filter matching tracing/filters: Fix MATCH_FRONT_ONLY filter matching ftrace: Fix MATCH_END_ONLY function filter tracing/x86: Derive arch from bits argument in recordmcount.pl ring-buffer: Add rb_list_head() wrapper around new reader page next field ring-buffer: Wrap a list.next reference with rb_list_head()
This commit is contained in:
commit
6ccc347b69
6 changed files with 56 additions and 17 deletions
|
@ -74,6 +74,9 @@ static inline __must_check char *strstrip(char *str)
|
||||||
#ifndef __HAVE_ARCH_STRSTR
|
#ifndef __HAVE_ARCH_STRSTR
|
||||||
extern char * strstr(const char *, const char *);
|
extern char * strstr(const char *, const char *);
|
||||||
#endif
|
#endif
|
||||||
|
#ifndef __HAVE_ARCH_STRNSTR
|
||||||
|
extern char * strnstr(const char *, const char *, size_t);
|
||||||
|
#endif
|
||||||
#ifndef __HAVE_ARCH_STRLEN
|
#ifndef __HAVE_ARCH_STRLEN
|
||||||
extern __kernel_size_t strlen(const char *);
|
extern __kernel_size_t strlen(const char *);
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -1690,7 +1690,7 @@ ftrace_regex_lseek(struct file *file, loff_t offset, int origin)
|
||||||
static int ftrace_match(char *str, char *regex, int len, int type)
|
static int ftrace_match(char *str, char *regex, int len, int type)
|
||||||
{
|
{
|
||||||
int matched = 0;
|
int matched = 0;
|
||||||
char *ptr;
|
int slen;
|
||||||
|
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case MATCH_FULL:
|
case MATCH_FULL:
|
||||||
|
@ -1706,8 +1706,8 @@ static int ftrace_match(char *str, char *regex, int len, int type)
|
||||||
matched = 1;
|
matched = 1;
|
||||||
break;
|
break;
|
||||||
case MATCH_END_ONLY:
|
case MATCH_END_ONLY:
|
||||||
ptr = strstr(str, regex);
|
slen = strlen(str);
|
||||||
if (ptr && (ptr[len] == 0))
|
if (slen >= len && memcmp(str + slen - len, regex, len) == 0)
|
||||||
matched = 1;
|
matched = 1;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -2869,7 +2869,7 @@ rb_get_reader_page(struct ring_buffer_per_cpu *cpu_buffer)
|
||||||
* Splice the empty reader page into the list around the head.
|
* Splice the empty reader page into the list around the head.
|
||||||
*/
|
*/
|
||||||
reader = rb_set_head_page(cpu_buffer);
|
reader = rb_set_head_page(cpu_buffer);
|
||||||
cpu_buffer->reader_page->list.next = reader->list.next;
|
cpu_buffer->reader_page->list.next = rb_list_head(reader->list.next);
|
||||||
cpu_buffer->reader_page->list.prev = reader->list.prev;
|
cpu_buffer->reader_page->list.prev = reader->list.prev;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -2906,7 +2906,7 @@ rb_get_reader_page(struct ring_buffer_per_cpu *cpu_buffer)
|
||||||
*
|
*
|
||||||
* Now make the new head point back to the reader page.
|
* Now make the new head point back to the reader page.
|
||||||
*/
|
*/
|
||||||
reader->list.next->prev = &cpu_buffer->reader_page->list;
|
rb_list_head(reader->list.next)->prev = &cpu_buffer->reader_page->list;
|
||||||
rb_inc_page(cpu_buffer, &cpu_buffer->head_page);
|
rb_inc_page(cpu_buffer, &cpu_buffer->head_page);
|
||||||
|
|
||||||
/* Finally update the reader page to the new head */
|
/* Finally update the reader page to the new head */
|
||||||
|
|
|
@ -211,8 +211,9 @@ static int filter_pred_pchar(struct filter_pred *pred, void *event,
|
||||||
{
|
{
|
||||||
char **addr = (char **)(event + pred->offset);
|
char **addr = (char **)(event + pred->offset);
|
||||||
int cmp, match;
|
int cmp, match;
|
||||||
|
int len = strlen(*addr) + 1; /* including tailing '\0' */
|
||||||
|
|
||||||
cmp = pred->regex.match(*addr, &pred->regex, pred->regex.field_len);
|
cmp = pred->regex.match(*addr, &pred->regex, len);
|
||||||
|
|
||||||
match = cmp ^ pred->not;
|
match = cmp ^ pred->not;
|
||||||
|
|
||||||
|
@ -251,7 +252,18 @@ static int filter_pred_none(struct filter_pred *pred, void *event,
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Basic regex callbacks */
|
/*
|
||||||
|
* regex_match_foo - Basic regex callbacks
|
||||||
|
*
|
||||||
|
* @str: the string to be searched
|
||||||
|
* @r: the regex structure containing the pattern string
|
||||||
|
* @len: the length of the string to be searched (including '\0')
|
||||||
|
*
|
||||||
|
* Note:
|
||||||
|
* - @str might not be NULL-terminated if it's of type DYN_STRING
|
||||||
|
* or STATIC_STRING
|
||||||
|
*/
|
||||||
|
|
||||||
static int regex_match_full(char *str, struct regex *r, int len)
|
static int regex_match_full(char *str, struct regex *r, int len)
|
||||||
{
|
{
|
||||||
if (strncmp(str, r->pattern, len) == 0)
|
if (strncmp(str, r->pattern, len) == 0)
|
||||||
|
@ -261,23 +273,24 @@ static int regex_match_full(char *str, struct regex *r, int len)
|
||||||
|
|
||||||
static int regex_match_front(char *str, struct regex *r, int len)
|
static int regex_match_front(char *str, struct regex *r, int len)
|
||||||
{
|
{
|
||||||
if (strncmp(str, r->pattern, len) == 0)
|
if (strncmp(str, r->pattern, r->len) == 0)
|
||||||
return 1;
|
return 1;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int regex_match_middle(char *str, struct regex *r, int len)
|
static int regex_match_middle(char *str, struct regex *r, int len)
|
||||||
{
|
{
|
||||||
if (strstr(str, r->pattern))
|
if (strnstr(str, r->pattern, len))
|
||||||
return 1;
|
return 1;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int regex_match_end(char *str, struct regex *r, int len)
|
static int regex_match_end(char *str, struct regex *r, int len)
|
||||||
{
|
{
|
||||||
char *ptr = strstr(str, r->pattern);
|
int strlen = len - 1;
|
||||||
|
|
||||||
if (ptr && (ptr[r->len] == 0))
|
if (strlen >= r->len &&
|
||||||
|
memcmp(str + strlen - r->len, r->pattern, r->len) == 0)
|
||||||
return 1;
|
return 1;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -781,10 +794,8 @@ static int filter_add_pred(struct filter_parse_state *ps,
|
||||||
pred->regex.field_len = field->size;
|
pred->regex.field_len = field->size;
|
||||||
} else if (field->filter_type == FILTER_DYN_STRING)
|
} else if (field->filter_type == FILTER_DYN_STRING)
|
||||||
fn = filter_pred_strloc;
|
fn = filter_pred_strloc;
|
||||||
else {
|
else
|
||||||
fn = filter_pred_pchar;
|
fn = filter_pred_pchar;
|
||||||
pred->regex.field_len = strlen(pred->regex.pattern);
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
if (field->is_signed)
|
if (field->is_signed)
|
||||||
ret = strict_strtoll(pred->regex.pattern, 0, &val);
|
ret = strict_strtoll(pred->regex.pattern, 0, &val);
|
||||||
|
|
27
lib/string.c
27
lib/string.c
|
@ -667,7 +667,7 @@ EXPORT_SYMBOL(memscan);
|
||||||
*/
|
*/
|
||||||
char *strstr(const char *s1, const char *s2)
|
char *strstr(const char *s1, const char *s2)
|
||||||
{
|
{
|
||||||
int l1, l2;
|
size_t l1, l2;
|
||||||
|
|
||||||
l2 = strlen(s2);
|
l2 = strlen(s2);
|
||||||
if (!l2)
|
if (!l2)
|
||||||
|
@ -684,6 +684,31 @@ char *strstr(const char *s1, const char *s2)
|
||||||
EXPORT_SYMBOL(strstr);
|
EXPORT_SYMBOL(strstr);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef __HAVE_ARCH_STRNSTR
|
||||||
|
/**
|
||||||
|
* strnstr - Find the first substring in a length-limited string
|
||||||
|
* @s1: The string to be searched
|
||||||
|
* @s2: The string to search for
|
||||||
|
* @len: the maximum number of characters to search
|
||||||
|
*/
|
||||||
|
char *strnstr(const char *s1, const char *s2, size_t len)
|
||||||
|
{
|
||||||
|
size_t l1 = len, l2;
|
||||||
|
|
||||||
|
l2 = strlen(s2);
|
||||||
|
if (!l2)
|
||||||
|
return (char *)s1;
|
||||||
|
while (l1 >= l2) {
|
||||||
|
l1--;
|
||||||
|
if (!memcmp(s1, s2, l2))
|
||||||
|
return (char *)s1;
|
||||||
|
s1++;
|
||||||
|
}
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL(strnstr);
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifndef __HAVE_ARCH_MEMCHR
|
#ifndef __HAVE_ARCH_MEMCHR
|
||||||
/**
|
/**
|
||||||
* memchr - Find a character in an area of memory.
|
* memchr - Find a character in an area of memory.
|
||||||
|
|
|
@ -194,7 +194,7 @@ sub check_objcopy
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($arch eq "x86") {
|
if ($arch =~ /(x86(_64)?)|(i386)/) {
|
||||||
if ($bits == 64) {
|
if ($bits == 64) {
|
||||||
$arch = "x86_64";
|
$arch = "x86_64";
|
||||||
} else {
|
} else {
|
||||||
|
|
Loading…
Reference in a new issue