arm: tegra: Clean up SOC conditionals
[linux-2.6.git] / arch / arm / mach-tegra / fuse.h
1 /*
2  * arch/arm/mach-tegra/fuse.c
3  *
4  * Copyright (C) 2010 Google, Inc.
5  * Copyright (C) 2010-2011 NVIDIA Corp.
6  *
7  * Author:
8  *      Colin Cross <ccross@android.com>
9  *
10  * This software is licensed under the terms of the GNU General Public
11  * License version 2, as published by the Free Software Foundation, and
12  * may be copied, distributed, and modified under those terms.
13  *
14  * This program is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17  * GNU General Public License for more details.
18  *
19  */
20
21 enum tegra_revision {
22         TEGRA_REVISION_UNKNOWN = 0,
23 #if !defined(CONFIG_ARCH_TEGRA_2x_SOC)
24         TEGRA_REVISION_A01,
25 #endif
26         TEGRA_REVISION_A02,
27 #if defined(CONFIG_ARCH_TEGRA_2x_SOC)
28         TEGRA_REVISION_A03,
29         TEGRA_REVISION_A03p,
30 #endif
31         TEGRA_REVISION_MAX,
32 };
33
34 struct tegra_id {
35         unsigned int chipid, major, minor, netlist, patch;
36         enum tegra_revision revision;
37         char *priv;
38 };
39
40 #define INVALID_PROCESS_ID      99 // don't expect to have 100 process id's
41
42 extern struct tegra_id tegra_id;
43
44 unsigned long long tegra_chip_uid(void);
45 unsigned int tegra_spare_fuse(int bit);
46 int tegra_sku_id(void);
47 void tegra_init_fuse(void);
48 u32 tegra_fuse_readl(unsigned long offset);
49 void tegra_fuse_writel(u32 value, unsigned long offset);
50 enum tegra_revision tegra_get_revision(void);
51 const char *tegra_get_revision_name(void);
52
53 #ifndef CONFIG_TEGRA_FPGA_PLATFORM
54
55 int tegra_cpu_process_id(void);
56 int tegra_core_process_id(void);
57 int tegra_soc_speedo_id(void);
58 void tegra_init_speedo_data(void);
59
60 #else // CONFIG_TEGRA_FPGA_PLATFORM
61
62 static inline int tegra_cpu_process_id(void) { return 0; }
63 static inline int tegra_core_process_id(void) { return 0; }
64 static inline int tegra_soc_speedo_id(void) { return 0; }
65 static inline void tegra_init_speedo_data(void) { }
66
67 #endif// CONFIG_TEGRA_FPGA_PLATFORM