Received: by 2002:ac0:a594:0:0:0:0:0 with SMTP id m20-v6csp340867imm; Thu, 10 May 2018 22:04:15 -0700 (PDT) X-Google-Smtp-Source: AB8JxZpLj9IVdThz4ctMfdP7ShtJe+fgLhgSGu8mPczAddcuSfF5Dec/69dET90uN9pw+mbiFNsF X-Received: by 2002:a63:715a:: with SMTP id b26-v6mr3263226pgn.440.1526015055771; Thu, 10 May 2018 22:04:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1526015055; cv=none; d=google.com; s=arc-20160816; b=SqqrIBdXlLOPdDELuq2Lh25ngAfnub87VoG/4a59EocdnjGpb5NARSwzacFS0Wn9wm Tz1q9slCUfSScS1+n33aJ2EUP3G5m761EnMwJRPt7clbi6rVwrVWkMx4VwfpJzulMkpc jqq+eLAMQqrJbMdBX9ZCkVIpbWkBK+5mZEXdvbvsJc0vtdSOOp4g9b92rBVimBUb49pU 4lIqfbgwwRJUaWPE/MAfBlUltQ2PA86ZtQEaKBV0yjj3HQxVsF//4Pwv70bRE+zJ6urc N7LdQBgrZwKWVUyWJHrt0JVQ2PtWQtGeLOkwrS8emHBCKvqKo5t5opHyf9jFi4QIslAT xPWw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:arc-authentication-results; bh=TnWLqEOCFLZ3kgw68ZySuKSKz/J7DafU3eNU5HE51io=; b=cFWDcWrN2TsQE8WIs/m7kKYqvxfvuDPMaiqzix68C1sn5m5ol9s6bazYNvXIdcsV+a vjHh04ZYGs0qEDBmM381zrOJjqfCgQEIlo9fmlNs64bsTZaphl755gzd6PeqtpqymgRo yBtT1uhyX9uNXpH8Jk6T6/6YxJ+r3z5JPLN4V+pHxsrS8w4wQ/Rc3iUPkWcKW+WL+5lj b7iPzZQe0KMVVEw08DHxSt6fR1xNw7zA2tUWX73GZ47Fz9y69GlVrlph/yojIuv4xRHK mvQxZaSLs8Ot0pZWqlGSHHcW3f8bPMCEonqgg9Xs7ZQo6NjDXSx15J0qhL4Ungm5YBAM F4PQ== 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 a5-v6si2325970plh.26.2018.05.10.22.04.00; Thu, 10 May 2018 22:04:15 -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 S1751828AbeEKFDp (ORCPT + 99 others); Fri, 11 May 2018 01:03:45 -0400 Received: from smtp4-g21.free.fr ([212.27.42.4]:43242 "EHLO smtp4-g21.free.fr" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750751AbeEKFDo (ORCPT ); Fri, 11 May 2018 01:03:44 -0400 Received: from [192.168.2.7] (unknown [78.218.214.33]) by smtp4-g21.free.fr (Postfix) with ESMTP id 2912F19F576; Fri, 11 May 2018 07:03:41 +0200 (CEST) Subject: Re: [PATCH v2 2/2] mtd: rawnand: fsl_ifc: use bit-wise majority to To: "Wan, Jane (Nokia - US/Sunnyvale)" , Boris Brezillon , Miquel Raynal Cc: "shreeya.patel23498@gmail.com" , "yamada.masahiro@socionext.com" , "richard@nod.at" , "linux-kernel@vger.kernel.org" , "marek.vasut@gmail.com" , "Bos, Ties (Nokia - US/Sunnyvale)" , "prabhakar.kushwaha@nxp.com" , "linux-mtd@lists.infradead.org" , "jagdish.gediya@nxp.com" , "computersforpeace@gmail.com" , "shawnguo@kernel.org" References: From: Chris Moore Message-ID: Date: Fri, 11 May 2018 07:03:31 +0200 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.7.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=windows-1252; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-GB Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, Le 04/05/2018 ? 04:09, Wan, Jane (Nokia - US/Sunnyvale) a ?crit > The following is the reposting of patch with v2 version indication based on comment on "[PATCH 1/2]" (also in the attachment). > > Subject: [PATCH v2 2/2] mtd: rawnand: fsl_ifc: use bit-wise majority to > recover the contents of ONFI parameter > > Per ONFI specification (Rev. 4.0), if all parameter pages have invalid > CRC values, the bit-wise majority may be used to recover the contents of > the parameter pages from the parameter page copies present. > > Signed-off-by: Jane Wan > --- > drivers/mtd/nand/raw/nand_base.c | 36 ++++++++++++++++++++++++++++++------ > 1 file changed, 30 insertions(+), 6 deletions(-) > > diff --git a/drivers/mtd/nand/raw/nand_base.c b/drivers/mtd/nand/raw/nand_base.c > index 72f3a89..464c4fb 100644 > --- a/drivers/mtd/nand/raw/nand_base.c > +++ b/drivers/mtd/nand/raw/nand_base.c [snip] > > + pr_info("Recover ONFI params with bit-wise majority\n"); > + for (j = 0; j < pagesize; j++) { > + v = 0; > + for (k = 0; k < 8; k++) { > + m = 0; > + for (l = 0; l < 3; l++) > + m += GET_BIT(k, buf[l*pagesize + j]); > + if (m > 1) > + v |= BIT(k); > + } > + ((u8 *)p)[j] = v; > + } I am not familiar with the context of this but the three way bit-wise majority can be implemented much more efficiently? using the identity: majority3(a, b, c) = (a & b) | (a & c) | (b & c) This can be factorized slightly to (a & (b | c)) | (b & c) This enables the operation to be performed 8, 16, 32 or even 64 bits at a time depending on the hardware. Cheers, Chris