From patchwork Mon Apr 25 13:59:03 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Ying-Chun Liu X-Patchwork-Id: 565708 Delivered-To: patch@linaro.org Received: by 2002:a05:7000:6886:0:0:0:0 with SMTP id m6csp2724167map; Mon, 25 Apr 2022 06:59:46 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzpcLIlVR6v+AXiy2d6c2dqtFTQsUGeVoDkZ129Cl+y+MuClwo/NQkdYYjedq8U5KPZ2HxO X-Received: by 2002:a17:906:5d04:b0:6db:7262:570e with SMTP id g4-20020a1709065d0400b006db7262570emr16615860ejt.8.1650895186011; Mon, 25 Apr 2022 06:59:46 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1650895186; cv=none; d=google.com; s=arc-20160816; b=QVMvuWjrV+vs/dYlhFCNFAZ2BsPSSFwj/UpImkT1gSrMdOZ6L+kO9WOh/gqTaMGgtD cYMVQ1lxMIcyRyQHw14YjqfqRgr3pOj1SQNY91JuZI3CoO07S5wfM5KcC6pYtkdT7lIL blA27cd+8YhKj/8shZmbdqkzqj1kgpBmmD5FjrXPhzavI3+52j2rKgDyPN08xANnyYph oo77fio8f0In6Ts5K69afe6skwcEdkeS0Y0Or9HxzTD/EAAsmFfvMXZNeVA5YPQdXrCA hSiK8WuLHVFyPlXV8T0oJ+YQpvCmrvLccbA6BtuOwnpi5sIgOg2E0jrDvPFD+xqF7ihh G+mA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=sender:errors-to:list-subscribe:list-help:list-post:list-archive :list-unsubscribe:list-id:precedence:content-transfer-encoding :mime-version:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=cv2j9FK2ZRE2zXKhiEG34+Eixsk1+M2hs8yRWDHGnLI=; b=lix3FocwPpXRPEVRgeDSE4SkBaA4zYgxhnAMCAaEgL/5SEh5l3WkrBuLGk1Agvgkix zvmo6yFTgV6hYg/aq1hHvGlXh2NCil2wVBEY7wz0NA2tJa3UxR1+8PhxvAdkLGBhxjFa WoSud9c3JLnM/FyG1iwwNjzra7hiec3tgm7cRJ0unkyLSNAqR5kFYUhmTIC5AINisOZD uf3fIimUN82KkuVc1CdeNuXOtdQFKyKXQaJPq8pZNuKXEsIA6avBvrjVc1epu0L2n9X+ TVVxoG8JHnmbzkvmye8O6pWCMpnJg87E9zEo/xfit+FesDkyPgtnPP/35KfTOcUKI6H0 XUxQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b="M/nk1X+x"; spf=pass (google.com: domain of u-boot-bounces@lists.denx.de designates 2a01:238:438b:c500:173d:9f52:ddab:ee01 as permitted sender) smtp.mailfrom=u-boot-bounces@lists.denx.de; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from phobos.denx.de (phobos.denx.de. [2a01:238:438b:c500:173d:9f52:ddab:ee01]) by mx.google.com with ESMTPS id v21-20020a1709062f1500b006df76385ee9si13178851eji.905.2022.04.25.06.59.45 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 25 Apr 2022 06:59:46 -0700 (PDT) Received-SPF: pass (google.com: domain of u-boot-bounces@lists.denx.de designates 2a01:238:438b:c500:173d:9f52:ddab:ee01 as permitted sender) client-ip=2a01:238:438b:c500:173d:9f52:ddab:ee01; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b="M/nk1X+x"; spf=pass (google.com: domain of u-boot-bounces@lists.denx.de designates 2a01:238:438b:c500:173d:9f52:ddab:ee01 as permitted sender) smtp.mailfrom=u-boot-bounces@lists.denx.de; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: from h2850616.stratoserver.net (localhost [IPv6:::1]) by phobos.denx.de (Postfix) with ESMTP id 793DE83EA0; Mon, 25 Apr 2022 15:59:39 +0200 (CEST) Authentication-Results: phobos.denx.de; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: phobos.denx.de; spf=pass smtp.mailfrom=u-boot-bounces@lists.denx.de Authentication-Results: phobos.denx.de; dkim=pass (2048-bit key; unprotected) header.d=gmail.com header.i=@gmail.com header.b="M/nk1X+x"; dkim-atps=neutral Received: by phobos.denx.de (Postfix, from userid 109) id 8270783C62; Mon, 25 Apr 2022 15:59:23 +0200 (CEST) X-Spam-Checker-Version: SpamAssassin 3.4.2 (2018-09-13) on phobos.denx.de X-Spam-Level: X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,FREEMAIL_FROM,SPF_HELO_NONE, SPF_PASS autolearn=ham autolearn_force=no version=3.4.2 Received: from mail-pl1-x632.google.com (mail-pl1-x632.google.com [IPv6:2607:f8b0:4864:20::632]) (using TLSv1.3 with cipher TLS_AES_128_GCM_SHA256 (128/128 bits)) (No client certificate requested) by phobos.denx.de (Postfix) with ESMTPS id 1BBE183953 for ; Mon, 25 Apr 2022 15:59:17 +0200 (CEST) Authentication-Results: phobos.denx.de; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: phobos.denx.de; spf=pass smtp.mailfrom=grandpaul@gmail.com Received: by mail-pl1-x632.google.com with SMTP id s17so27252920plg.9 for ; Mon, 25 Apr 2022 06:59:17 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=cv2j9FK2ZRE2zXKhiEG34+Eixsk1+M2hs8yRWDHGnLI=; b=M/nk1X+xvCNEf8m7GEREcT8mTZUtZaLmgV3MpDJrWpPlSjwC73uhJsERC71XAeNPph zJytUoA85W0jZY/tNqD7O0sNKNqJM7btWzYXoAeA0QY94/bRHJaoH51QcsplfrJnCreV f+Uuek4JK1WxRM1z6G+Kz7SsA4zL6n/L9zLm77w+oQroldHR3M4vFfCEOXZ+K8+D4Ilp fEWVrF0CLUW2g/KnyjiyfDKNPW+ArwWDsuxxrDQ1JzrQxHt/alq2pgQ932/V0vvffhy5 l05KkLPNITkpDjnctoVsV1mWB7wnYMpSEZVzXk8n49W9yuVFsKdRHrZ7UmV4P8fciIMC OXyw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=cv2j9FK2ZRE2zXKhiEG34+Eixsk1+M2hs8yRWDHGnLI=; b=qonweFytkyvWBBWty8grXW7Wm8kvwMrMT2H6gyIlkhNYsUNXMIend4btI4noytRFIA Ru3B5InHIR9f94fZPy7M2M6RsACBBa6qMSDGc+bUV1q99EHx7lU/RY8gi/u1iVT0+g6Y HW7vsqDCAgcWrnay+230TNqcw1rC6TFgS/+H3T1sqpMy9mcmsN+Nacd2hm2kPrL8TJr5 u5RwNiDsc9ak4NeRIMjXZxlQ7emO9wb9RdzUPGjQAa2DQ5pRgZMdLqY99dmkuvP1a96C vsVAl55JsffwipzPTsj/x0ZCwPWkQGH4OLeYz/5ZrTDW0o/r7orBJV6jjMvHLKCvP71v KIOw== X-Gm-Message-State: AOAM531RqEVT+XgtKk3chk22qhkuW9p8Fkv6lW+qkiZJhPTYG4nif/u6 49uMRavfct5Q+2i12l/s7Yhr3OE3i30= X-Received: by 2002:a17:903:2ca:b0:156:f1cc:7cb6 with SMTP id s10-20020a17090302ca00b00156f1cc7cb6mr18530505plk.174.1650895155191; Mon, 25 Apr 2022 06:59:15 -0700 (PDT) Received: from localhost ([111.184.129.17]) by smtp.gmail.com with ESMTPSA id b2-20020a056a000a8200b004f1111c66afsm12856627pfl.148.2022.04.25.06.59.14 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 25 Apr 2022 06:59:14 -0700 (PDT) From: Ying-Chun Liu To: u-boot@lists.denx.de Cc: "Ying-Chun Liu (PaulLiu)" , Peng Fan , Jaehoon Chung Subject: [PATCH 2/2] cmd: mmc: allow to write protect single boot partition Date: Mon, 25 Apr 2022 21:59:03 +0800 Message-Id: <20220425135903.271098-3-grandpaul@gmail.com> X-Mailer: git-send-email 2.35.1 In-Reply-To: <20220425135903.271098-1-grandpaul@gmail.com> References: <20220425135903.271098-1-grandpaul@gmail.com> MIME-Version: 1.0 X-BeenThere: u-boot@lists.denx.de X-Mailman-Version: 2.1.39 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.5 at phobos.denx.de X-Virus-Status: Clean From: "Ying-Chun Liu (PaulLiu)" add arguments for mmc wp to assign which boot partition to protect. Signed-off-by: Ying-Chun Liu (PaulLiu) Cc: Peng Fan Cc: Jaehoon Chung --- cmd/mmc.c | 18 +++++++++++++++--- 1 file changed, 15 insertions(+), 3 deletions(-) diff --git a/cmd/mmc.c b/cmd/mmc.c index 7464f8d00c..7f3e5da6cd 100644 --- a/cmd/mmc.c +++ b/cmd/mmc.c @@ -1046,6 +1046,7 @@ static int do_mmc_boot_wp(struct cmd_tbl *cmdtp, int flag, { int err; struct mmc *mmc; + int part; mmc = init_mmc_device(curr_device, false); if (!mmc) @@ -1054,7 +1055,14 @@ static int do_mmc_boot_wp(struct cmd_tbl *cmdtp, int flag, printf("It is not an eMMC device\n"); return CMD_RET_FAILURE; } - err = mmc_boot_wp(mmc); + + if (argc == 2) { + part = dectoul(argv[1], NULL); + err = mmc_boot_wp_single_partition(mmc, part); + } else { + err = mmc_boot_wp(mmc); + } + if (err) return CMD_RET_FAILURE; printf("boot areas protected\n"); @@ -1064,7 +1072,7 @@ static int do_mmc_boot_wp(struct cmd_tbl *cmdtp, int flag, static struct cmd_tbl cmd_mmc[] = { U_BOOT_CMD_MKENT(info, 1, 0, do_mmcinfo, "", ""), U_BOOT_CMD_MKENT(read, 4, 1, do_mmc_read, "", ""), - U_BOOT_CMD_MKENT(wp, 1, 0, do_mmc_boot_wp, "", ""), + U_BOOT_CMD_MKENT(wp, 2, 0, do_mmc_boot_wp, "", ""), #if CONFIG_IS_ENABLED(MMC_WRITE) U_BOOT_CMD_MKENT(write, 4, 0, do_mmc_write, "", ""), U_BOOT_CMD_MKENT(erase, 3, 0, do_mmc_erase, "", ""), @@ -1138,7 +1146,11 @@ U_BOOT_CMD( " [MMC_LEGACY, MMC_HS, SD_HS, MMC_HS_52, MMC_DDR_52, UHS_SDR12, UHS_SDR25,\n" " UHS_SDR50, UHS_DDR50, UHS_SDR104, MMC_HS_200, MMC_HS_400, MMC_HS_400_ES]\n" "mmc list - lists available devices\n" - "mmc wp - power on write protect boot partitions\n" + "mmc wp [PART] - power on write protect boot partitions\n" + " arguments:\n" + " PART - [0|1]\n" + " : 0 - first boot partition, 1 - second boot partition\n" + " if not assigned, write protect all boot partitions\n" #if CONFIG_IS_ENABLED(MMC_HW_PARTITIONING) "mmc hwpartition - does hardware partitioning\n" " arguments (sizes in 512-byte blocks):\n"