diff options
Diffstat (limited to 'tools/perf/tests/code-reading.c')
| -rw-r--r-- | tools/perf/tests/code-reading.c | 26 | 
1 files changed, 16 insertions, 10 deletions
| diff --git a/tools/perf/tests/code-reading.c b/tools/perf/tests/code-reading.c index f671ec37a7c4..22f8a00446e1 100644 --- a/tools/perf/tests/code-reading.c +++ b/tools/perf/tests/code-reading.c @@ -248,6 +248,7 @@ static int process_sample_event(struct machine *machine,  	struct perf_sample sample;  	struct thread *thread;  	u8 cpumode; +	int ret;  	if (perf_evlist__parse_sample(evlist, event, &sample)) {  		pr_debug("perf_evlist__parse_sample failed\n"); @@ -262,7 +263,9 @@ static int process_sample_event(struct machine *machine,  	cpumode = event->header.misc & PERF_RECORD_MISC_CPUMODE_MASK; -	return read_object_code(sample.ip, READLEN, cpumode, thread, state); +	ret = read_object_code(sample.ip, READLEN, cpumode, thread, state); +	thread__put(thread); +	return ret;  }  static int process_event(struct machine *machine, struct perf_evlist *evlist, @@ -448,7 +451,7 @@ static int do_test_code_reading(bool try_kcore)  	}  	ret = perf_event__synthesize_thread_map(NULL, threads, -						perf_event__process, machine, false); +						perf_event__process, machine, false, 500);  	if (ret < 0) {  		pr_debug("perf_event__synthesize_thread_map failed\n");  		goto out_err; @@ -457,13 +460,13 @@ static int do_test_code_reading(bool try_kcore)  	thread = machine__findnew_thread(machine, pid, pid);  	if (!thread) {  		pr_debug("machine__findnew_thread failed\n"); -		goto out_err; +		goto out_put;  	}  	cpus = cpu_map__new(NULL);  	if (!cpus) {  		pr_debug("cpu_map__new failed\n"); -		goto out_err; +		goto out_put;  	}  	while (1) { @@ -472,7 +475,7 @@ static int do_test_code_reading(bool try_kcore)  		evlist = perf_evlist__new();  		if (!evlist) {  			pr_debug("perf_evlist__new failed\n"); -			goto out_err; +			goto out_put;  		}  		perf_evlist__set_maps(evlist, cpus, threads); @@ -482,10 +485,10 @@ static int do_test_code_reading(bool try_kcore)  		else  			str = "cycles";  		pr_debug("Parsing event '%s'\n", str); -		ret = parse_events(evlist, str); +		ret = parse_events(evlist, str, NULL);  		if (ret < 0) {  			pr_debug("parse_events failed\n"); -			goto out_err; +			goto out_put;  		}  		perf_evlist__config(evlist, &opts); @@ -506,7 +509,7 @@ static int do_test_code_reading(bool try_kcore)  				continue;  			}  			pr_debug("perf_evlist__open failed\n"); -			goto out_err; +			goto out_put;  		}  		break;  	} @@ -514,7 +517,7 @@ static int do_test_code_reading(bool try_kcore)  	ret = perf_evlist__mmap(evlist, UINT_MAX, false);  	if (ret < 0) {  		pr_debug("perf_evlist__mmap failed\n"); -		goto out_err; +		goto out_put;  	}  	perf_evlist__enable(evlist); @@ -525,7 +528,7 @@ static int do_test_code_reading(bool try_kcore)  	ret = process_events(machine, evlist, &state);  	if (ret < 0) -		goto out_err; +		goto out_put;  	if (!have_vmlinux && !have_kcore && !try_kcore)  		err = TEST_CODE_READING_NO_KERNEL_OBJ; @@ -535,7 +538,10 @@ static int do_test_code_reading(bool try_kcore)  		err = TEST_CODE_READING_NO_ACCESS;  	else  		err = TEST_CODE_READING_OK; +out_put: +	thread__put(thread);  out_err: +  	if (evlist) {  		perf_evlist__delete(evlist);  	} else { | 
