misc: tegra-profiler: backtracing for Thumb code
[linux-2.6.git] / drivers / misc / tegra-profiler / tegra.h
1 /*
2  * drivers/misc/tegra-profiler/tegra.h
3  *
4  * Copyright (c) 2013, NVIDIA CORPORATION.  All rights reserved.
5  *
6  * This program is free software; you can redistribute it and/or modify it
7  * under the terms and conditions of the GNU General Public License,
8  * version 2, as published by the Free Software Foundation.
9  *
10  * This program is distributed in the hope it will be useful, but WITHOUT
11  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
12  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
13  * more details.
14  *
15  */
16
17 #ifndef __QUADD_TEGRA_H
18 #define __QUADD_TEGRA_H
19
20 #include <linux/smp.h>
21 #include <asm/ptrace.h>
22
23 #ifdef CONFIG_TEGRA_CLUSTER_CONTROL
24 #include <linux/io.h>
25 #include <../../mach-tegra/pm.h>
26 #endif
27
28 static inline int quadd_get_processor_id(struct pt_regs *regs)
29 {
30         int cpu_id = smp_processor_id();
31
32 #ifdef CONFIG_TEGRA_CLUSTER_CONTROL
33         if (is_lp_cluster())
34                 cpu_id |= QUADD_CPUMODE_TEGRA_POWER_CLUSTER_LP;
35 #endif
36
37         if (thumb_mode(regs))
38                 cpu_id |= QUADD_CPUMODE_THUMB;
39
40         return cpu_id;
41 }
42
43 static inline int quadd_is_cpu_with_lp_cluster(void)
44 {
45 #ifdef CONFIG_TEGRA_CLUSTER_CONTROL
46         return 1;
47 #else
48         return 0;
49 #endif
50 }
51
52 #endif  /* __QUADD_TEGRA_H */