Commit 01bb2dc4 authored by Ingo Molnar's avatar Ingo Molnar

Merge branch 'perf/urgent' of...

Merge branch 'perf/urgent' of git://git.kernel.org/pub/scm/linux/kernel/git/acme/linux-2.6 into perf/urgent
parents 806839b2 ffb5e0fb
...@@ -380,13 +380,18 @@ static int test__open_syscall_event_on_all_cpus(void) ...@@ -380,13 +380,18 @@ static int test__open_syscall_event_on_all_cpus(void)
for (cpu = 0; cpu < cpus->nr; ++cpu) { for (cpu = 0; cpu < cpus->nr; ++cpu) {
unsigned int ncalls = nr_open_calls + cpu; unsigned int ncalls = nr_open_calls + cpu;
CPU_SET(cpu, cpu_set); CPU_SET_S(cpus->map[cpu], cpu_set_size, cpu_set);
sched_setaffinity(0, cpu_set_size, cpu_set); if (sched_setaffinity(0, cpu_set_size, cpu_set) < 0) {
pr_debug("sched_setaffinity() failed on CPU %d: %s ",
cpus->map[cpu],
strerror(errno));
goto out_close_fd;
}
for (i = 0; i < ncalls; ++i) { for (i = 0; i < ncalls; ++i) {
fd = open("/etc/passwd", O_RDONLY); fd = open("/etc/passwd", O_RDONLY);
close(fd); close(fd);
} }
CPU_CLR(cpu, cpu_set); CPU_CLR_S(cpus->map[cpu], cpu_set_size, cpu_set);
} }
/* /*
...@@ -410,7 +415,7 @@ static int test__open_syscall_event_on_all_cpus(void) ...@@ -410,7 +415,7 @@ static int test__open_syscall_event_on_all_cpus(void)
expected = nr_open_calls + cpu; expected = nr_open_calls + cpu;
if (evsel->counts->cpu[cpu].val != expected) { if (evsel->counts->cpu[cpu].val != expected) {
pr_debug("perf_evsel__read_on_cpu: expected to intercept %d calls on cpu %d, got %Ld\n", pr_debug("perf_evsel__read_on_cpu: expected to intercept %d calls on cpu %d, got %Ld\n",
expected, cpu, evsel->counts->cpu[cpu].val); expected, cpus->map[cpu], evsel->counts->cpu[cpu].val);
goto out_close_fd; goto out_close_fd;
} }
} }
......
...@@ -1161,6 +1161,13 @@ static int dso__load_sym(struct dso *self, struct map *map, const char *name, ...@@ -1161,6 +1161,13 @@ static int dso__load_sym(struct dso *self, struct map *map, const char *name,
section_name = elf_sec__name(&shdr, secstrs); section_name = elf_sec__name(&shdr, secstrs);
/* On ARM, symbols for thumb functions have 1 added to
* the symbol address as a flag - remove it */
if ((ehdr.e_machine == EM_ARM) &&
(map->type == MAP__FUNCTION) &&
(sym.st_value & 1))
--sym.st_value;
if (self->kernel != DSO_TYPE_USER || kmodule) { if (self->kernel != DSO_TYPE_USER || kmodule) {
char dso_name[PATH_MAX]; char dso_name[PATH_MAX];
......
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