From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-16.8 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER,INCLUDES_PATCH, MAILING_LIST_MULTI,MSGID_FROM_MTA_HEADER,SPF_HELO_NONE,SPF_PASS, USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 9E0E1C11F64 for ; Tue, 29 Jun 2021 02:06:25 +0000 (UTC) Received: from phobos.denx.de (phobos.denx.de [85.214.62.61]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id 2497A61CCE for ; Tue, 29 Jun 2021 02:06:25 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 2497A61CCE Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=oss.nxp.com Authentication-Results: mail.kernel.org; spf=pass smtp.mailfrom=u-boot-bounces@lists.denx.de Received: from h2850616.stratoserver.net (localhost [IPv6:::1]) by phobos.denx.de (Postfix) with ESMTP id D32CB8317A; Tue, 29 Jun 2021 04:01:39 +0200 (CEST) Authentication-Results: phobos.denx.de; dmarc=none (p=none dis=none) header.from=oss.nxp.com Authentication-Results: phobos.denx.de; spf=pass smtp.mailfrom=u-boot-bounces@lists.denx.de Authentication-Results: phobos.denx.de; dkim=pass (1024-bit key; unprotected) header.d=NXP1.onmicrosoft.com header.i=@NXP1.onmicrosoft.com header.b="d2aRI04K"; dkim-atps=neutral Received: by phobos.denx.de (Postfix, from userid 109) id E93CC8313C; Tue, 29 Jun 2021 04:00:52 +0200 (CEST) Received: from EUR02-VE1-obe.outbound.protection.outlook.com (mail-ve1eur02on0629.outbound.protection.outlook.com [IPv6:2a01:111:f400:fe06::629]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by phobos.denx.de (Postfix) with ESMTPS id EE0FB83129 for ; Tue, 29 Jun 2021 04:00:43 +0200 (CEST) Authentication-Results: phobos.denx.de; dmarc=none (p=none dis=none) header.from=oss.nxp.com Authentication-Results: phobos.denx.de; spf=pass smtp.mailfrom=peng.fan@oss.nxp.com ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=GspyZXVNyg9cNDhSBaDPB1doa5B+DJRFEvpZsfDBSp80aiJ+MOH8Tzf5RfIm91WyjFDBCM3UrdLRT7AYT7V/fJI6vtCCc/bkGLozGGOuHRjdTo1TkbGpHSQ3TQlL6ZncoUEBYC0k20G/Yvj2nK/xRMLa5ltiVVCweEs0IzZ1DWB0ZXUuFc1VP43Y7HCsIgnGvs2/eCpdugHNASl/kRK6MnezDtd/cPo/89r8PKV2NDnJIlsIzZG3W2FZu/2b8DlN49mVW81Y2jRCPK0LhiVthql4aTu6hHj2/6Kn2/qRPSnAHiswfKKYR4ld7OWs0eQSrajOV6j3aZ7Ez7vy2eXKIQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=CnXNqI2Wf+11PWj/KT2GtXZbcvNYvDld5hGLtdnLE3k=; b=PdNyr2i9YLlmNULdIWxPAojFvukLO27iS1duTUiQz6ArCl2GIPzm/YcjT2DGGHtjzMvc7Z/dFoLHBp2N6eatk+KScsQxU1nruTOGU5pfS5RL7oqk3esAXfQ4cnvVb/LgMmvG2+LqgAQxF+P83CAsJy0V/ItzhHXn1mAJHZMhy+tZF0CexHoIlQI3rmJ1K9bbaTqWq5It7HB1MDtnY74wQuZ6oNpxedkgSYmgfhM+USlcqTwMfsCG7namKYXhWBGEV86/IiBNEMmNGQitw285x7W1PBagguJwoPeTKqrsbAduQ/HVW5L/5lpKHgrqz6RaVXD7KjT8Sfv8Mn/BMRxL7g== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=oss.nxp.com; dmarc=pass action=none header.from=oss.nxp.com; dkim=pass header.d=oss.nxp.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=NXP1.onmicrosoft.com; s=selector2-NXP1-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=CnXNqI2Wf+11PWj/KT2GtXZbcvNYvDld5hGLtdnLE3k=; b=d2aRI04KJ9/CW6SubYl8ntKIc2PYgh88sfHcCg376i389TgKQjZtxXFfwUMC7ajXcfNfEVbLCk+fDqEbWgD7mzI6d4z46L3NDqkX8y39RrsANQTnoe/yodeMXkg5jDMRydf/GS/BFY3+4Yr8Jr8x7S2afooWGHKyLHOe15AbOE4= Authentication-Results: denx.de; dkim=none (message not signed) header.d=none;denx.de; dmarc=none action=none header.from=oss.nxp.com; Received: from DB6PR0402MB2760.eurprd04.prod.outlook.com (2603:10a6:4:a1::14) by DB6PR04MB3126.eurprd04.prod.outlook.com (2603:10a6:6:7::15) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4264.23; Tue, 29 Jun 2021 02:00:42 +0000 Received: from DB6PR0402MB2760.eurprd04.prod.outlook.com ([fe80::c445:d742:eb76:86dd]) by DB6PR0402MB2760.eurprd04.prod.outlook.com ([fe80::c445:d742:eb76:86dd%9]) with mapi id 15.20.4264.026; Tue, 29 Jun 2021 02:00:42 +0000 From: "Peng Fan (OSS)" To: sbabic@denx.de, festevam@gmail.com Cc: uboot-imx@nxp.com, u-boot@lists.denx.de, Ye Li Subject: [PATCH V2 36/46] driver: misc: imx8ulp: Add fuse driver for imx8ulp Date: Tue, 29 Jun 2021 10:32:30 +0800 Message-Id: <20210629023240.22394-37-peng.fan@oss.nxp.com> X-Mailer: git-send-email 2.30.0 In-Reply-To: <20210629023240.22394-1-peng.fan@oss.nxp.com> References: <20210629023240.22394-1-peng.fan@oss.nxp.com> Content-Transfer-Encoding: 8bit Content-Type: text/plain X-Originating-IP: [119.31.174.71] X-ClientProxiedBy: SG2PR06CA0088.apcprd06.prod.outlook.com (2603:1096:3:14::14) To DB6PR0402MB2760.eurprd04.prod.outlook.com (2603:10a6:4:a1::14) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from linux-1xn6.ap.freescale.net (119.31.174.71) by SG2PR06CA0088.apcprd06.prod.outlook.com (2603:1096:3:14::14) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4264.19 via Frontend Transport; Tue, 29 Jun 2021 02:00:40 +0000 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 1606b59b-2a6c-4c16-e6c5-08d93aa1b368 X-MS-TrafficTypeDiagnostic: DB6PR04MB3126: X-MS-Exchange-SharedMailbox-RoutingAgent-Processed: True X-MS-Exchange-Transport-Forked: True X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:5516; X-MS-Exchange-SenderADCheck: 1 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: lMA9z57K/zB4ikHYNaYSUx+O78CAnRD9Wu6n0fNQbRC9WAdTbKkyfSOHYacA05LzZUdXitBa93Ax1FrybLpgr9FrOBY+eQxxTPXd3pBahfz1BnVFuzxdrLyFfPcy8k8h8hr3EFIV3Jc3xlSpe8tlGPI1OHV+E5lVCOH9iS/2MsjtZwMjf2ZOgYiX7wQqBA4QezDWgxflKzPPTmiaZGbaPqUpiU6HCt7zjsxPw9AWnp99pE4DSBoZQYixqAhfkLF9cxj2s16acBjpn+wFK1RShfoHbVPeqG45r35FnW1bJy70F1mJCjd8yO+RPVjiUxuk2XUILrqcNk51zZmOmEf+bUxZMapphcQHmUXQRLRL15a+q9qP2+blQ0K/ONuO/38eT/wSPwpFOdxHWD+vByo58XVbYGCYNACSWv/xJOYRx39bWIlmQNb86dhjF+5PG/IOSy3BWvnubBX6ZO1mFJwO3jnVy+KleR4jo84osQZVpvHHyzDoiWAEsWycvjyAbzjx2+Q+eAbVg9ayZ2Rmua5SPfxKBzluR93UEtY9+E4klQ8szKQzf6624sAOob6IinY5ewXn5mhnJJlqyJmRJ1IzmvfpJv0c+mOqD95/r1JQE5hx7m852fLKyZOJOboVb0WI/7AA1iToToTnYbQzHSUU4/rz+7jkeRO4EjX+lhxf8kYc4dYZNGMn1sg9IaFceB59F0FhMbWcxoWS9I0PWCVZl7Hpcxm/+zCR18TB/kzDtbE= X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:DB6PR0402MB2760.eurprd04.prod.outlook.com; PTR:; CAT:NONE; SFS:(4636009)(39860400002)(346002)(366004)(376002)(396003)(136003)(66946007)(316002)(38100700002)(66476007)(52116002)(38350700002)(186003)(4326008)(956004)(6512007)(6486002)(2906002)(26005)(16526019)(66556008)(8936002)(86362001)(478600001)(5660300002)(6506007)(8676002)(6666004)(83380400001)(1076003)(2616005)(32563001); DIR:OUT; SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?us-ascii?Q?qbD2vdB7H1GqcIPnpnXb7/nE2emw+bkynDoGp6J1cG+BUX0+r0i44fvsFXCU?= =?us-ascii?Q?6WWtBm1viXFpOjOBLIMQwnsQb0+97tNvMobZ2sobsXkPwLB79q/lB7fvZcoP?= =?us-ascii?Q?wM+xqA+9sH9/XWywD73n4FfsFPkbMVIojNoX+bYh3Neu4yLWvNgAU4rgduS2?= =?us-ascii?Q?u+bX9DiVnNHcC5jQV5ilT1Z74pzLEXczAGGfv1/lDLUYGfrhpPERCNn+LN/5?= =?us-ascii?Q?ITfUjo+IAJkMYkTzsWmSlBq+iWxVrrIgD9YO8lSJCwu0W7tQEHsGF4vRdwRh?= =?us-ascii?Q?OIV9C4XaBl3iNSLL2n8WA/YYmtaU/6QkT8INM0kseiGRXlAZ1jm22GajYZFB?= =?us-ascii?Q?h0asz2bY2qcloMi6HzW3nDQiNDQykFcRQe/VtVJIm0tG4IujhN1Ql9vc2MLP?= =?us-ascii?Q?BeFb9ISpqHEKRc6wqT1zgsOR51WDWQc21pmPd+H45ZzWSPmmEae9pSEAOsxf?= =?us-ascii?Q?xwFjdHl6rs0/IalEPKvDZPmgpU9jS+bfz6Xbhl5CUBi3xsFFsBssV4MPgwUG?= =?us-ascii?Q?MxeGu43F98ZvQE0jQZB+pTUIOAx8BtBh0iYd5CjiaRFTwuX2xyekCNAJkch9?= =?us-ascii?Q?baPuTYgr+vo88AjvpF6jv4ThaVW2CZgKylG5bbybwH2uDk2u07fLn8aSU8pH?= =?us-ascii?Q?64D9L7Q6zG/yFmoCFAlMMCAt5GNy0Y621dCK7sFh9l41oRA9qTfVV3hUamBr?= =?us-ascii?Q?KCBXKT4+tHmYmjtr1GIdU6dJRlU+yoFu3rpJqZq7iz8lPnAHhkZHpbiZa25k?= =?us-ascii?Q?4vrXDbk1ygjTPgSE4u9Rl5LlpXZZk55mNwSadqwbNjJVCGVIqhNtN7gXeiQi?= =?us-ascii?Q?OR2Ekjp0L1vhpwOX/wUkai7dg0h2vgHBC4PtMzbNGZvyQd5mF2n6zIFoTjcB?= =?us-ascii?Q?Snlem/fhxSuqTS6Vxvfcv+4CF1gKgeK8icdT6U5TMc0nBgDxFsJq0C+pCLxc?= =?us-ascii?Q?aqFxsNu/srhVtG7nMEChZHdvZuEetTEJ3mWaFOtD82Z4g6MCZp2lPHv1ygz1?= =?us-ascii?Q?wvQHRoeux/LHOsXtqD5vdT11buQG8G6LnDOmOCMnpc8omZF/hRmGjXDiq/Zq?= =?us-ascii?Q?ZqXvBPKDaqXDpgiyysrHxCDSpajNPfR/b3I0ABZeOF97QizOxLgBFb+/XNPT?= =?us-ascii?Q?mk5UGhhcWwHs/ohU6EMsOMjLRoAaDaOM4pTCvvkTBY+v0jirlULv4tK09a59?= =?us-ascii?Q?O4VplCU3916uvxBfm3FuBmjxqDIBTK8OBIIlPp882bL4uQUl+3CVFNHzpHcq?= =?us-ascii?Q?XhtAVGzJwfEFky2poIMUIwOOmWtk77BsC1DTkrlYCFWy865JD5PBOj7AuSeR?= =?us-ascii?Q?3yVehIzFl0UYNl6GUi4khbyO?= X-OriginatorOrg: oss.nxp.com X-MS-Exchange-CrossTenant-Network-Message-Id: 1606b59b-2a6c-4c16-e6c5-08d93aa1b368 X-MS-Exchange-CrossTenant-AuthSource: DB6PR0402MB2760.eurprd04.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 29 Jun 2021 02:00:42.5637 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 686ea1d3-bc2b-4c6f-a92c-d99c5c301635 X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: aZNkdgQkURMKA3PDZBAoG9aLy/K1XPd7Gd83TnWin6uw5iEf2GEnVXrCJDMES+FXaBQNiyt7g9TP1dA2ZdxBMQ== X-MS-Exchange-Transport-CrossTenantHeadersStamped: DB6PR04MB3126 X-BeenThere: u-boot@lists.denx.de X-Mailman-Version: 2.1.34 Precedence: list List-Id: U-Boot discussion List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: u-boot-bounces@lists.denx.de Sender: "U-Boot" X-Virus-Scanned: clamav-milter 0.103.2 at phobos.denx.de X-Virus-Status: Clean From: Ye Li This driver uses FSB to read some fuses, but not support program fuse. It only works in SPL (secure mode), u-boot needs traps to ATF to read them. Some fuses can read from S400 API and others are from FSB. Also support program some fuses via S400 API Signed-off-by: Ye Li --- drivers/misc/imx8ulp/Makefile | 1 + drivers/misc/imx8ulp/fuse.c | 198 ++++++++++++++++++++++++++++++++++ 2 files changed, 199 insertions(+) create mode 100644 drivers/misc/imx8ulp/fuse.c diff --git a/drivers/misc/imx8ulp/Makefile b/drivers/misc/imx8ulp/Makefile index 1d792415d2..927cc55216 100644 --- a/drivers/misc/imx8ulp/Makefile +++ b/drivers/misc/imx8ulp/Makefile @@ -1,3 +1,4 @@ # SPDX-License-Identifier: GPL-2.0+ obj-y += s400_api.o imx8ulp_mu.o +obj-$(CONFIG_CMD_FUSE) += fuse.o diff --git a/drivers/misc/imx8ulp/fuse.c b/drivers/misc/imx8ulp/fuse.c new file mode 100644 index 0000000000..d1feb62ab5 --- /dev/null +++ b/drivers/misc/imx8ulp/fuse.c @@ -0,0 +1,198 @@ +// SPDX-License-Identifier: GPL-2.0 +/* + * Copyright 2020 NXP + */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include + +DECLARE_GLOBAL_DATA_PTR; + +#define FUSE_BANKS 64 +#define WORDS_PER_BANKS 8 + +struct fsb_map_entry { + s32 fuse_bank; + u32 fuse_words; + bool redundancy; +}; + +struct s400_map_entry { + s32 fuse_bank; + u32 fuse_words; + u32 fuse_offset; + u32 s400_index; +}; + +struct fsb_map_entry fsb_mapping_table[] = { + { 3, 8 }, + { 4, 8 }, + { 5, 8 }, + { 6, 8 }, + { -1, 48 }, /* Reserve 48 words */ + { 8, 4, true }, + { 24, 4, true }, + { 26, 4, true }, + { 27, 4, true }, + { 28, 8 }, + { 29, 8 }, + { 30, 8 }, + { 31, 8 }, + { 37, 8 }, + { 38, 8 }, + { 39, 8 }, + { 40, 8 }, + { 41, 8 }, + { 42, 8 }, + { 43, 8 }, + { 44, 8 }, + { 45, 8 }, + { 46, 8 }, +}; + +struct s400_map_entry s400_api_mapping_table[] = { + { 1, 8 }, /* LOCK */ + { 2, 8 }, /* ECID */ + { 7, 4, 0, 1 }, /* OTP_UNIQ_ID */ + { 23, 1, 4, 2 }, /* OTFAD */ +}; + +static s32 map_fsb_fuse_index(u32 bank, u32 word, bool *redundancy) +{ + s32 size = ARRAY_SIZE(fsb_mapping_table); + s32 i, word_pos = 0; + + /* map the fuse from ocotp fuse map to FSB*/ + for (i = 0; i < size; i++) { + if (fsb_mapping_table[i].fuse_bank != -1 && + fsb_mapping_table[i].fuse_bank == bank) { + break; + } + + word_pos += fsb_mapping_table[i].fuse_words; + } + + if (i == size) + return -1; /* Failed to find */ + + if (fsb_mapping_table[i].redundancy) { + *redundancy = true; + return (word >> 1) + word_pos; + } + + *redundancy = false; + return word + word_pos; +} + +static s32 map_s400_fuse_index(u32 bank, u32 word) +{ + s32 size = ARRAY_SIZE(s400_api_mapping_table); + s32 i; + + /* map the fuse from ocotp fuse map to FSB*/ + for (i = 0; i < size; i++) { + if (s400_api_mapping_table[i].fuse_bank != -1 && + s400_api_mapping_table[i].fuse_bank == bank) { + if (word >= s400_api_mapping_table[i].fuse_offset && + word < (s400_api_mapping_table[i].fuse_offset + + s400_api_mapping_table[i].fuse_words)) + break; + } + } + + if (i == size) + return -1; /* Failed to find */ + + if (s400_api_mapping_table[i].s400_index != 0) + return s400_api_mapping_table[i].s400_index; + + return s400_api_mapping_table[i].fuse_bank * 8 + word; +} + +int fuse_sense(u32 bank, u32 word, u32 *val) +{ + s32 word_index; + bool redundancy; + + if (bank >= FUSE_BANKS || word >= WORDS_PER_BANKS || !val) + return -EINVAL; + + word_index = map_fsb_fuse_index(bank, word, &redundancy); + if (word_index >= 0) { + *val = readl((ulong)FSB_BASE_ADDR + 0x800 + (word_index << 2)); + if (redundancy) + *val = (*val >> ((word % 2) * 16)) & 0xFFFF; + + return 0; + } + + word_index = map_s400_fuse_index(bank, word); + if (word_index >= 0) { + u32 data[4]; + u32 res, size = 4; + int ret; + + /* Only UID return 4 words */ + if (word_index != 1) + size = 1; + + ret = ahab_read_common_fuse(word_index, data, size, &res); + if (ret) { + printf("ahab read fuse failed %d, 0x%x\n", ret, res); + return ret; + } + + if (word_index == 1) { + *val = data[word]; /* UID */ + } else if (word_index == 2) { + /* + * OTFAD 3 bits as follow: + * bit 0: OTFAD_ENABLE + * bit 1: OTFAD_DISABLE_OVERRIDE + * bit 2: KEY_BLOB_EN + */ + *val = data[0] << 3; + } else { + *val = data[0]; + } + + return 0; + } + + return -ENOENT; +} + +int fuse_read(u32 bank, u32 word, u32 *val) +{ + return fuse_sense(bank, word, val); +} + +int fuse_prog(u32 bank, u32 word, u32 val) +{ + u32 res; + int ret; + + if (bank >= FUSE_BANKS || word >= WORDS_PER_BANKS || !val) + return -EINVAL; + + ret = ahab_write_fuse((bank * 8 + word), val, false, &res); + if (ret) { + printf("ahab write fuse failed %d, 0x%x\n", ret, res); + return ret; + } + + return 0; +} + +int fuse_override(u32 bank, u32 word, u32 val) +{ + printf("Override fuse to i.MX8ULP in u-boot is forbidden\n"); + return -EPERM; +} -- 2.30.0