mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 ee84a3032b
			
		
	
	
		ee84a3032b
		
	
	
	
	
		
			
			Using accessors will make it easier to add reference count checking in later patches. Committer notes: thread->nsinfo wasn't wrapped as it is used together with nsinfo__zput(), where does a trick to set the field with a refcount being dropped to NULL, and that doesn't work well with using thread__nsinfo(thread), that loses the &thread->nsinfo pointer. When refcount checking is added to 'struct thread', later in this series, nsinfo__zput(RC_CHK_ACCESS(thread)->nsinfo) will be used to check the thread pointer. Signed-off-by: Ian Rogers <irogers@google.com> Cc: Adrian Hunter <adrian.hunter@intel.com> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: Ali Saidi <alisaidi@amazon.com> Cc: Andi Kleen <ak@linux.intel.com> Cc: Athira Rajeev <atrajeev@linux.vnet.ibm.com> Cc: Brian Robbins <brianrob@linux.microsoft.com> Cc: Changbin Du <changbin.du@huawei.com> Cc: Dmitrii Dolgov <9erthalion6@gmail.com> Cc: Fangrui Song <maskray@google.com> Cc: German Gomez <german.gomez@arm.com> Cc: Ingo Molnar <mingo@redhat.com> Cc: Ivan Babrou <ivan@cloudflare.com> Cc: James Clark <james.clark@arm.com> Cc: Jing Zhang <renyu.zj@linux.alibaba.com> Cc: Jiri Olsa <jolsa@kernel.org> Cc: John Garry <john.g.garry@oracle.com> Cc: K Prateek Nayak <kprateek.nayak@amd.com> Cc: Kan Liang <kan.liang@linux.intel.com> Cc: Leo Yan <leo.yan@linaro.org> Cc: Liam Howlett <liam.howlett@oracle.com> Cc: Mark Rutland <mark.rutland@arm.com> Cc: Miguel Ojeda <ojeda@kernel.org> Cc: Mike Leach <mike.leach@linaro.org> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Naveen N. Rao <naveen.n.rao@linux.vnet.ibm.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Ravi Bangoria <ravi.bangoria@amd.com> Cc: Sean Christopherson <seanjc@google.com> Cc: Steinar H. Gunderson <sesse@google.com> Cc: Suzuki Poulouse <suzuki.poulose@arm.com> Cc: Wenyu Liu <liuwenyu7@huawei.com> Cc: Will Deacon <will@kernel.org> Cc: Yang Jihong <yangjihong1@huawei.com> Cc: Ye Xingchen <ye.xingchen@zte.com.cn> Cc: Yuan Can <yuancan@huawei.com> Cc: coresight@lists.linaro.org Cc: linux-arm-kernel@lists.infradead.org Link: https://lore.kernel.org/r/20230608232823.4027869-4-irogers@google.com Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
		
			
				
	
	
		
			64 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			64 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| // SPDX-License-Identifier: GPL-2.0
 | |
| #include <string.h>
 | |
| #include "perf_regs.h"
 | |
| #include "thread.h"
 | |
| #include "map.h"
 | |
| #include "maps.h"
 | |
| #include "event.h"
 | |
| #include "debug.h"
 | |
| #include "tests/tests.h"
 | |
| 
 | |
| #define STACK_SIZE 8192
 | |
| 
 | |
| static int sample_ustack(struct perf_sample *sample,
 | |
| 			 struct thread *thread, u64 *regs)
 | |
| {
 | |
| 	struct stack_dump *stack = &sample->user_stack;
 | |
| 	struct map *map;
 | |
| 	unsigned long sp;
 | |
| 	u64 stack_size, *buf;
 | |
| 
 | |
| 	buf = malloc(STACK_SIZE);
 | |
| 	if (!buf) {
 | |
| 		pr_debug("failed to allocate sample uregs data\n");
 | |
| 		return -1;
 | |
| 	}
 | |
| 
 | |
| 	sp = (unsigned long) regs[PERF_REG_POWERPC_R1];
 | |
| 
 | |
| 	map = maps__find(thread__maps(thread), (u64)sp);
 | |
| 	if (!map) {
 | |
| 		pr_debug("failed to get stack map\n");
 | |
| 		free(buf);
 | |
| 		return -1;
 | |
| 	}
 | |
| 
 | |
| 	stack_size = map__end(map) - sp;
 | |
| 	stack_size = stack_size > STACK_SIZE ? STACK_SIZE : stack_size;
 | |
| 
 | |
| 	memcpy(buf, (void *) sp, stack_size);
 | |
| 	stack->data = (char *) buf;
 | |
| 	stack->size = stack_size;
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| int test__arch_unwind_sample(struct perf_sample *sample,
 | |
| 			     struct thread *thread)
 | |
| {
 | |
| 	struct regs_dump *regs = &sample->user_regs;
 | |
| 	u64 *buf;
 | |
| 
 | |
| 	buf = calloc(1, sizeof(u64) * PERF_REGS_MAX);
 | |
| 	if (!buf) {
 | |
| 		pr_debug("failed to allocate sample uregs data\n");
 | |
| 		return -1;
 | |
| 	}
 | |
| 
 | |
| 	perf_regs_load(buf);
 | |
| 	regs->abi  = PERF_SAMPLE_REGS_ABI;
 | |
| 	regs->regs = buf;
 | |
| 	regs->mask = PERF_REGS_MASK;
 | |
| 
 | |
| 	return sample_ustack(sample, thread, buf);
 | |
| }
 |