Received: by 2002:ac0:a581:0:0:0:0:0 with SMTP id m1-v6csp7281796imm; Thu, 28 Jun 2018 00:43:58 -0700 (PDT) X-Google-Smtp-Source: AAOMgpf3WWs7v3uMH2WA3ZSWSne5xQMrcsCdmMw6bdGA7wvh/b5GMN958HEuBZlng7H9LEl5wEo5 X-Received: by 2002:a62:9c0d:: with SMTP id f13-v6mr9054717pfe.215.1530171838629; Thu, 28 Jun 2018 00:43:58 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1530171838; cv=none; d=google.com; s=arc-20160816; b=owlnWdeXW0BRFq/1S89vLBs4rhki5ACfOH9vOSywukBmniOmzi88xL/d3MbOV03B5A TR9IwXz+Alfo3eL9sVxCcxqZZk7owF56ozBNsZOyV/WuRT2w5rIzV/1mYgDf/gYrMl+5 XwOZZjPSHtrK36IsuCHbJtm8q7z/44kYycN/z5wkp4SbVT0MA/wywCWYGs4PwFPmsCg+ eOj8CoDsUBfgVglJ1CSx0tQoo6nLVDiT6dQX2n9HnxYsDZrJXUiQsEBArh1WMRDyCGyY N7XjHz0zv88f0HmzyhtQzuEl/zr66qbtJobzPZCZhSLh+q3SQE9yO0tJw1NxEBHvM5FD VFAQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:references :in-reply-to:message-id:date:subject:cc:to:from :arc-authentication-results; bh=072RMBsyaPyos9Hv2bqvtYxgnvY1TLxnWa3ILkuWCwE=; b=nWZUtMvubpIdjWwX6KB33JvW32CtK8ziHEw1491aadkkIls4dOfkSVu+GkLzCD/7Ob K+WK0fd9K+J6I5fghGb7a/v7DWkbkdZ3aO+BC2G6uoUVAw+h+pabysof/xflB1xWdR+U w22AkTsmHk9qjoR3csVZuCbLub1OFXqOoOqh1D5JcE/uTzt0WpS658VdF67XZ6gvF5vd EFbW4h27VhborIX4wkBYUnFEXfb/XGujC9teL0FfSss6hZ5a07spOH52Z4K4V1/ExY9E A0jmV6t6DTLLcSaYHEDFfzWsRcddCE1o6xKW/0Hmnp2rCs3MA/A3bPOnj9AoMjah5Mb9 OU0g== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id r9-v6si5114542pgp.591.2018.06.28.00.43.44; Thu, 28 Jun 2018 00:43:58 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S965213AbeF1Hl7 (ORCPT + 99 others); Thu, 28 Jun 2018 03:41:59 -0400 Received: from mail.bootlin.com ([62.4.15.54]:37101 "EHLO mail.bootlin.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S964984AbeF1Hl5 (ORCPT ); Thu, 28 Jun 2018 03:41:57 -0400 Received: by mail.bootlin.com (Postfix, from userid 110) id A35C120DE2; Thu, 28 Jun 2018 09:41:55 +0200 (CEST) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on mail.bootlin.com X-Spam-Level: X-Spam-Status: No, score=-1.0 required=5.0 tests=ALL_TRUSTED,SHORTCIRCUIT, URIBL_BLOCKED shortcircuit=ham autolearn=disabled version=3.4.0 Received: from localhost.localdomain (AAubervilliers-681-1-87-188.w90-88.abo.wanadoo.fr [90.88.29.188]) by mail.bootlin.com (Postfix) with ESMTPSA id 9823120DDB; Thu, 28 Jun 2018 09:41:32 +0200 (CEST) From: Quentin Schulz To: dedekind1@gmail.com, richard@nod.at, dwmw2@infradead.org, computersforpeace@gmail.com, boris.brezillon@bootlin.com, marek.vasut@gmail.com Cc: linux-mtd@lists.infradead.org, linux-kernel@vger.kernel.org, thomas.petazzoni@bootlin.com, Quentin Schulz Subject: [PATCH v3 2/2] ubi: expose the volume CRC check skip flag Date: Thu, 28 Jun 2018 09:40:53 +0200 Message-Id: <0ace6202bddb495ae0e632ae2fd0346f99fcdab4.1530169759.git-series.quentin.schulz@bootlin.com> X-Mailer: git-send-email 2.14.1 In-Reply-To: References: In-Reply-To: References: Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Now that we have the logic for skipping CRC check for static UBI volumes in the core, let's expose it to users. This makes use of a padding byte in the volume description data structure as a flag. This flag only tell for now whether we should skip the CRC check of a volume. This checks the UBI volume for which we are trying to skip the CRC check is static. Suggested-by: Boris Brezillon Signed-off-by: Quentin Schulz Reviewed-by: Boris Brezillon --- drivers/mtd/ubi/cdev.c | 4 ++++ drivers/mtd/ubi/vmt.c | 3 +++ include/uapi/mtd/ubi-user.h | 16 ++++++++++++++-- 3 files changed, 21 insertions(+), 2 deletions(-) diff --git a/drivers/mtd/ubi/cdev.c b/drivers/mtd/ubi/cdev.c index 45c3296..3eea1df 100644 --- a/drivers/mtd/ubi/cdev.c +++ b/drivers/mtd/ubi/cdev.c @@ -622,6 +622,10 @@ static int verify_mkvol_req(const struct ubi_device *ubi, req->vol_type != UBI_STATIC_VOLUME) goto bad; + if (req->flags & UBI_VOL_SKIP_CRC_CHECK_FLG && + req->vol_type != UBI_STATIC_VOLUME) + goto bad; + if (req->alignment > ubi->leb_size) goto bad; diff --git a/drivers/mtd/ubi/vmt.c b/drivers/mtd/ubi/vmt.c index e2606a4..729588b 100644 --- a/drivers/mtd/ubi/vmt.c +++ b/drivers/mtd/ubi/vmt.c @@ -174,6 +174,9 @@ int ubi_create_volume(struct ubi_device *ubi, struct ubi_mkvol_req *req) vol->dev.class = &ubi_class; vol->dev.groups = volume_dev_groups; + if (req->flags & UBI_VOL_SKIP_CRC_CHECK_FLG) + vol->skip_check = 1; + spin_lock(&ubi->volumes_lock); if (vol_id == UBI_VOL_NUM_AUTO) { /* Find unused volume ID */ diff --git a/include/uapi/mtd/ubi-user.h b/include/uapi/mtd/ubi-user.h index 5b04a49..6e5ded5 100644 --- a/include/uapi/mtd/ubi-user.h +++ b/include/uapi/mtd/ubi-user.h @@ -285,6 +285,18 @@ struct ubi_attach_req { __s8 padding[10]; }; +/* + * UBI volume flags. + * + * @UBI_VOL_SKIP_CRC_CHECK_FLG: skip the CRC check done on a static volume at + * open time. Only valid for static volumes and + * should only be used if the volume user has a + * way to verify data integrity + */ +enum { + UBI_VOL_SKIP_CRC_CHECK_FLG = 0x1, +}; + /** * struct ubi_mkvol_req - volume description data structure used in * volume creation requests. @@ -292,7 +304,7 @@ struct ubi_attach_req { * @alignment: volume alignment * @bytes: volume size in bytes * @vol_type: volume type (%UBI_DYNAMIC_VOLUME or %UBI_STATIC_VOLUME) - * @padding1: reserved for future, not used, has to be zeroed + * @flags: volume flags (%UBI_VOL_SKIP_CRC_CHECK_FLG) * @name_len: volume name length * @padding2: reserved for future, not used, has to be zeroed * @name: volume name @@ -321,7 +333,7 @@ struct ubi_mkvol_req { __s32 alignment; __s64 bytes; __s8 vol_type; - __s8 padding1; + __u8 flags; __s16 name_len; __s8 padding2[4]; char name[UBI_MAX_VOLUME_NAME + 1]; -- git-series 0.9.1