From patchwork Thu Apr 14 14:49:51 2011 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Lee Jones X-Patchwork-Id: 1025 Return-Path: Delivered-To: unknown Received: from imap.gmail.com (74.125.159.109) by localhost6.localdomain6 with IMAP4-SSL; 08 Jun 2011 14:48:24 -0000 Delivered-To: patches@linaro.org Received: by 10.68.59.138 with SMTP id z10cs53763pbq; Thu, 14 Apr 2011 07:50:57 -0700 (PDT) Received: by 10.227.202.11 with SMTP id fc11mr920825wbb.131.1302792656755; Thu, 14 Apr 2011 07:50:56 -0700 (PDT) Received: from mail-ww0-f50.google.com (mail-ww0-f50.google.com [74.125.82.50]) by mx.google.com with ESMTPS id a4si3152458wbi.22.2011.04.14.07.50.55 (version=TLSv1/SSLv3 cipher=OTHER); Thu, 14 Apr 2011 07:50:56 -0700 (PDT) Received-SPF: neutral (google.com: 74.125.82.50 is neither permitted nor denied by best guess record for domain of lee.jones@linaro.org) client-ip=74.125.82.50; Authentication-Results: mx.google.com; spf=neutral (google.com: 74.125.82.50 is neither permitted nor denied by best guess record for domain of lee.jones@linaro.org) smtp.mail=lee.jones@linaro.org Received: by mail-ww0-f50.google.com with SMTP id 33so1988466wwc.31 for ; Thu, 14 Apr 2011 07:50:55 -0700 (PDT) Received: by 10.216.59.205 with SMTP id s55mr6423156wec.72.1302792655534; Thu, 14 Apr 2011 07:50:55 -0700 (PDT) Received: from localhost.localdomain (cpc2-aztw21-0-0-cust264.aztw.cable.virginmedia.com [77.100.97.9]) by mx.google.com with ESMTPS id m2sm850881wer.37.2011.04.14.07.50.53 (version=SSLv3 cipher=OTHER); Thu, 14 Apr 2011 07:50:54 -0700 (PDT) From: Lee Jones To: linux-arm-kernel@lists.infradead.org Cc: linus.walleij@linaro.org, patches@linaro.org, arnd@arndb.de, jamie@jamieiles.com, Lee Jones Subject: [PATCH 2/3] mach-ux500: export System-on-Chip information via sysfs Date: Thu, 14 Apr 2011 15:49:51 +0100 Message-Id: <1302792592-17484-3-git-send-email-lee.jones@linaro.org> X-Mailer: git-send-email 1.7.4.1 In-Reply-To: <1302792592-17484-1-git-send-email-lee.jones@linaro.org> References: <1302792592-17484-1-git-send-email-lee.jones@linaro.org> Signed-off-by: Lee Jones --- arch/arm/mach-ux500/Kconfig | 1 + arch/arm/mach-ux500/id.c | 96 +++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 97 insertions(+), 0 deletions(-) diff --git a/arch/arm/mach-ux500/Kconfig b/arch/arm/mach-ux500/Kconfig index c6b2375..ffee422 100644 --- a/arch/arm/mach-ux500/Kconfig +++ b/arch/arm/mach-ux500/Kconfig @@ -25,6 +25,7 @@ config MACH_U8500 bool "U8500 Development platform" depends on UX500_SOC_DB8500 select TPS6105X + select SYS_SOC help Include support for the mop500 development platform. diff --git a/arch/arm/mach-ux500/id.c b/arch/arm/mach-ux500/id.c index d35122e..74492ee 100644 --- a/arch/arm/mach-ux500/id.c +++ b/arch/arm/mach-ux500/id.c @@ -2,12 +2,17 @@ * Copyright (C) ST-Ericsson SA 2010 * * Author: Rabin Vincent for ST-Ericsson + * Author: Lee Jones for ST-Ericsson * License terms: GNU General Public License (GPL) version 2 */ #include #include #include +#include +#include +#include +#include #include #include @@ -105,3 +110,94 @@ void __init ux500_map_io(void) ux500_print_soc_info(asicid); } + +#ifdef CONFIG_SYS_SOC +#define U8500_BB_UID_BASE (U8500_BACKUPRAM1_BASE + 0xFC0) +#define U8500_BB_UID_LENGTH 5 + +static ssize_t ux500_get_family(struct device *dev, + struct device_attribute *attr, + char *buf) +{ + return sprintf(buf, "Ux500\n"); +} + +static ssize_t ux500_get_machine(struct device *dev, + struct device_attribute *attr, + char *buf) +{ + return sprintf(buf, "DB%4x\n", dbx500_partnumber()); +} + +static ssize_t ux500_get_soc_id(struct device *dev, + struct device_attribute *attr, + char *buf) +{ + void __iomem *uid_base; + int i; + ssize_t sz = 0; + + if (dbx500_partnumber() == 0x8500) { + uid_base = __io_address(U8500_BB_UID_BASE); + for (i = 0; i < U8500_BB_UID_LENGTH; i++) + sz += sprintf(buf + sz, "%08x", readl(uid_base + i * sizeof(u32))); + sz += sprintf(buf + sz, "\n"); + } else { + /* Don't know where it is located for U5500 */ + sz = sprintf(buf, "N/A\n"); + } + + return sz; +} + +static ssize_t ux500_get_revision(struct device *dev, + struct device_attribute *attr, + char *buf) +{ + unsigned int rev = dbx500_revision(); + + if (rev == 0x01) + return sprintf(buf, "%s\n", "ED"); + else if (rev >= 0xA0) + return sprintf(buf, "%d.%d\n" , (rev >> 4) - 0xA + 1, rev & 0xf); + + return sprintf(buf, "%s", "Unknown\n"); +} + +static ssize_t ux500_get_process(struct device *dev, + struct device_attribute *attr, + char *buf) +{ + if (dbx500_id.process == 0x00) + return sprintf(buf, "Standard\n"); + + return sprintf(buf, "%02xnm\n", dbx500_id.process); +} + +struct device_attribute soc_one_attrs[] = { + __ATTR(machine, S_IRUGO, ux500_get_machine, NULL), + __ATTR(family, S_IRUGO, ux500_get_family, NULL), + __ATTR(soc_id, S_IRUGO, ux500_get_soc_id, NULL), + __ATTR(revision, S_IRUGO, ux500_get_revision, NULL), + __ATTR(process, S_IRUGO, ux500_get_process, NULL), + __ATTR_NULL, +}; + +struct device_attribute *each_soc_attrs[] = { + soc_one_attrs, + NULL, +}; + +static int __init ux500_soc_sysfs_init(void) +{ + return soc_device_register(each_soc_attrs, ARRAY_SIZE(each_soc_attrs)); +} +module_init(ux500_soc_sysfs_init); + +static void __exit ux500_soc_sysfs_exit(void) +{ + return soc_device_unregister(each_soc_attrs, ARRAY_SIZE(each_soc_attrs)); +} +module_exit(ux500_soc_sysfs_exit); + +#endif