Received: by 2002:ac0:950c:0:0:0:0:0 with SMTP id f12csp1858721imc; Tue, 12 Mar 2019 02:03:40 -0700 (PDT) X-Google-Smtp-Source: APXvYqz/T89cyMvteBnkkpdJpupXrSObYiM1RmD7huGj7j++aP/F6a1/dZTgFX2XwUVyt/SRcB9O X-Received: by 2002:a17:902:9a98:: with SMTP id w24mr37873047plp.247.1552381419944; Tue, 12 Mar 2019 02:03:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1552381419; cv=none; d=google.com; s=arc-20160816; b=AF0+wOL5s+LU2Yh0ZPJJSUV761n5ephe5vT64eDkkp2SsvXNqRTNP8YWUy92KP8uag TvC+hKHTytKFU6dY3RKCrJUe+X2pH8DqEA2vP9Cb80b+aUq4Sr7NnZ3sjX3wlL8CCjVX lhdOk4kQSt3lPQkbRvunDbOfPquGlGZRNLGhJy0oiyzBjcHWf+rwskbxNlIpA3Wni1nZ WbAq6clZnumOAA3nnr3QD0rNLFW58tIYxZuMl9rtRGfRxyOLfC6NvgCmFx4GGl2UnG2K WKRMpSSznWOWQUGYsJIbqR/t3coFb/xATalC2gtSWtX1CWqgyl6ghPfJKd5UY6YVUBEJ FaCA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :organization:references:in-reply-to:message-id:subject:cc:to:from :date; bh=WNkDhObk2S4WSJG9jsOowFmWMntflj1KAiz69/sUjfU=; b=PnKajMVYpnDdibFQ/GBHswIKilXJRFxBxJNZIF0fZaiASLaCyAnFSojZlT7jufM50y dyHHpWziwpwrLvKhy/ovAB1wzMI7CRgY5cd06qE33ck6myRaOgGSGiNWw46JKDy6s1ZE wGV8hfAGldxqCtu2z8qmR3VcBbivDwc4WPSKLSzh2MwzbjbIDJ/htL+FaMabLmUZ+6rh mlIb6STeZGKwuw18dVQFqu0yWPpZT006qmJep2qI/8EhcRfbcd5bdCs9zfcOqaMsBJtS 0nqPAerK57LseMmxKQbNoDnPoWB8IWCfwyBbFv7tiAQFfjFSBiDRwiR7MTFnCKcD5oOo S8WQ== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id e3si7099870pfi.223.2019.03.12.02.03.24; Tue, 12 Mar 2019 02:03:39 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727492AbfCLJDE (ORCPT + 99 others); Tue, 12 Mar 2019 05:03:04 -0400 Received: from bhuna.collabora.co.uk ([46.235.227.227]:58334 "EHLO bhuna.collabora.co.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726567AbfCLJDD (ORCPT ); Tue, 12 Mar 2019 05:03:03 -0400 Received: from localhost (unknown [IPv6:2a01:e0a:2c:6930:5cf4:84a1:2763:fe0d]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) (Authenticated sender: bbrezillon) by bhuna.collabora.co.uk (Postfix) with ESMTPSA id 8EE67280794; Tue, 12 Mar 2019 09:03:01 +0000 (GMT) Date: Tue, 12 Mar 2019 10:02:57 +0100 From: Boris Brezillon To: Masahiro Yamada Cc: linux-mtd@lists.infradead.org, Miquel Raynal , Boris Brezillon , Brian Norris , linux-kernel@vger.kernel.org, Marek Vasut , Richard Weinberger , David Woodhouse Subject: Re: [PATCH v3 4/9] mtd: rawnand: denali: switch over to ->exec_op() from legacy hooks Message-ID: <20190312100257.4fa142d1@collabora.com> In-Reply-To: <1552380290-19951-5-git-send-email-yamada.masahiro@socionext.com> References: <1552380290-19951-1-git-send-email-yamada.masahiro@socionext.com> <1552380290-19951-5-git-send-email-yamada.masahiro@socionext.com> Organization: Collabora X-Mailer: Claws Mail 3.17.3 (GTK+ 2.24.32; x86_64-redhat-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, 12 Mar 2019 17:44:45 +0900 Masahiro Yamada wrote: > + > +static int denali_exec_instr(struct nand_chip *chip, > + const struct nand_op_instr *instr) > +{ > + struct denali_nand_info *denali = to_denali(chip); > + bool width16 = chip->options & NAND_BUSWIDTH_16; > + > + switch (instr->type) { > + case NAND_OP_CMD_INSTR: > + denali_exec_out8(denali, DENALI_MAP11_CMD, > + &instr->ctx.cmd.opcode, 1); > + return 0; > + case NAND_OP_ADDR_INSTR: > + denali_exec_out8(denali, DENALI_MAP11_ADDR, > + instr->ctx.addr.addrs, > + instr->ctx.addr.naddrs); > + return 0; > + case NAND_OP_DATA_IN_INSTR: > + (!instr->ctx.data.force_8bit && width16 ? > + denali_exec_in16 : > + denali_exec_in8)(denali, DENALI_MAP11_DATA, > + instr->ctx.data.buf.in, > + instr->ctx.data.len); I agree with Miquel, this statement tends to obfuscate the code, and it's not like an extra if will make a huge difference in term of LOC. > + return 0; > + case NAND_OP_DATA_OUT_INSTR: > + (!instr->ctx.data.force_8bit && width16 ? > + denali_exec_out16 : > + denali_exec_out8)(denali, DENALI_MAP11_DATA, > + instr->ctx.data.buf.out, > + instr->ctx.data.len); Ditto. > + return 0; > + case NAND_OP_WAITRDY_INSTR: > + return denali_exec_waitrdy(denali); > + default: > + WARN_ONCE(1, "unsupported NAND instruction type: %d\n", > + instr->type); > + > + return -EINVAL; > + } > +}