From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753843AbcBBCco (ORCPT ); Mon, 1 Feb 2016 21:32:44 -0500 Received: from mail-pa0-f66.google.com ([209.85.220.66]:36853 "EHLO mail-pa0-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752057AbcBBCci (ORCPT ); Mon, 1 Feb 2016 21:32:38 -0500 From: Bean Huo To: richard@nod.at, dedekind1@gmail.com, adrian.hunter@intel.com, computersforpeace@gmail.com, boris.brezillon@free-electrons.com Cc: beanhuo@micron.com, linux-mtd@lists.infradead.org, linux-kernel@vger.kernel.org, zszubbocsev@micron.com, peterpandong@micron.com Subject: [PATCH v2 03/17] drivers:mtd:add dual plane page program support in partition layer Date: Tue, 2 Feb 2016 02:30:38 +0000 Message-Id: <1454380252-16170-4-git-send-email-jackyard88@gmail.com> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1454380252-16170-1-git-send-email-jackyard88@gmail.com> References: <1454380252-16170-1-git-send-email-jackyard88@gmail.com> Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Bean Huo This file patch is to add multi-plane page program function in MTD partition layer and call back MTD master dual plane page program function. Signed-off-by: BeanHuo --- drivers/mtd/mtdpart.c | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/drivers/mtd/mtdpart.c b/drivers/mtd/mtdpart.c index cafdb88..85f68d0 100644 --- a/drivers/mtd/mtdpart.c +++ b/drivers/mtd/mtdpart.c @@ -203,6 +203,23 @@ static int part_write_oob(struct mtd_info *mtd, loff_t to, return part->master->_write_oob(part->master, to + part->offset, ops); } +static int part_write_dual_plane_oob(struct mtd_info *mtd, loff_t to_plane0, + struct mtd_oob_ops *ops_plane0, loff_t to_plane1, + struct mtd_oob_ops *ops_plane1) +{ + struct mtd_part *part = PART(mtd); + + if ((to_plane0 >= mtd->size) || ((to_plane1 >= mtd->size))) + return -EINVAL; + if ((ops_plane0->datbuf && to_plane0 + ops_plane0->len > mtd->size) || + (ops_plane1->datbuf && to_plane1 + ops_plane0->len > mtd->size)) + return -EINVAL; + + return part->master->_dual_plane_write_oob(part->master, + to_plane0 + part->offset, ops_plane0, + to_plane1 + part->offset, ops_plane1); +} + static int part_write_user_prot_reg(struct mtd_info *mtd, loff_t from, size_t len, size_t *retlen, u_char *buf) { @@ -409,6 +426,8 @@ static struct mtd_part *allocate_partition(struct mtd_info *master, slave->mtd._read_oob = part_read_oob; if (master->_write_oob) slave->mtd._write_oob = part_write_oob; + if (master->_dual_plane_write_oob) + slave->mtd._dual_plane_write_oob = part_write_dual_plane_oob; if (master->_read_user_prot_reg) slave->mtd._read_user_prot_reg = part_read_user_prot_reg; if (master->_read_fact_prot_reg) -- 1.9.1