ARM: tegra: Decode optional chip-private feature string in cmd line
[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_3x_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 extern struct tegra_id tegra_id;
41
42 unsigned long long tegra_chip_uid(void);
43 unsigned int tegra_spare_fuse(int bit);
44 int tegra_sku_id(void);
45 int tegra_cpu_process_id(void);
46 int tegra_core_process_id(void);
47 int tegra_soc_speedo_id(void);
48 void tegra_init_fuse(void);
49 void tegra_init_speedo_data(void);
50 u32 tegra_fuse_readl(unsigned long offset);
51 void tegra_fuse_writel(u32 value, unsigned long offset);
52 enum tegra_revision tegra_get_revision(void);