Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp211768pxb; Wed, 18 Nov 2020 21:58:39 -0800 (PST) X-Google-Smtp-Source: ABdhPJztaCZnhdzC6GsmLPXRSoE0Tyc+gO48sJfffidPbLmYv+JZXS20uy3h5Pjq4x5Xx/Nk+XUL X-Received: by 2002:a17:907:2631:: with SMTP id aq17mr15450522ejc.497.1605765518785; Wed, 18 Nov 2020 21:58:38 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1605765518; cv=none; d=google.com; s=arc-20160816; b=RTkZyBNG9lDnagBSEGDVKqnGuc210O8rH69kKKmMT/3YEiHKvBEMFBlg8f1DrahB2x LvbBF04PlkX+8vmCwVfE2XeGuNjbfU07T5bgIVb40yyF2pifH0Eo1n62fxRVzUvG2kJ9 oJfEpu44eiK+Ot7dtKh+eIzvzwAvDv4N72zOOcS8LL9kRlT533C9Z4mVqzUb9MHazk8e 085xZPkn414pWIuWS1m78PPRKEU98IrX4ysYZMmLJ/MTQpxQ7ni///5YskqTm4UJPnM4 IqycNAkqOP9mtb9omTQofV4qD9V5WM4FMbd3OjlE/sfnv+Ds4/Z/bTQyJw1/1KRDP+Kw Mymw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from:ironport-sdr:ironport-sdr; bh=MRMgcrxqjxDwCkBkMDeZ0pS9cnp06mL4OD+jZDLpiHo=; b=LoKpjDxenFSVFe3WC3e15gdDv7/FP8mubq0qaPx9anMWNeMMZf8DxTHT8p2igEEja1 3rG52Si4N7JG1n0HQGk8uh2xz+wEBIBuIaj1pNv/uZDaWPobocXJfTdTlTP8jK6gpD9Q Off+lJzXbOKjv3KATOyaJUw5Q+Bjp/awOYTMhGuouOdERc46qTIAWSyCwmU06U06zi+U P92tF0PnTqsuqEQllcnbiSkdCodQRx/x2FMUmXTJ8N5dlu1Txjo7/Ys3CuRcbGD7BgJQ 5PUGAjnTCRxAqxx/YIxnI69r01oNBJ9Z9OkUAYYZXLM3/N1lLXxqRsbaukw6+Y1RNuYN JOFA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id j62si17501269edd.159.2020.11.18.21.58.16; Wed, 18 Nov 2020 21:58:38 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726306AbgKSF4L (ORCPT + 99 others); Thu, 19 Nov 2020 00:56:11 -0500 Received: from mga04.intel.com ([192.55.52.120]:3690 "EHLO mga04.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725802AbgKSF4K (ORCPT ); Thu, 19 Nov 2020 00:56:10 -0500 IronPort-SDR: Dn4PVlBKHxUhQ7nAXtQU0mgJzVMWjW4N35fMmf+2GrDV6KsjwcjRegk/RT9Dx9NedZY9tlFiuR aX/v3EpaEIMg== X-IronPort-AV: E=McAfee;i="6000,8403,9809"; a="168665372" X-IronPort-AV: E=Sophos;i="5.77,489,1596524400"; d="scan'208";a="168665372" X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga005.jf.intel.com ([10.7.209.41]) by fmsmga104.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 18 Nov 2020 21:56:09 -0800 IronPort-SDR: 9uBxVasPUCKDhPaAGMzn6MMbAfroMvWRRlAJNKMORKZJLjhUcYfcGMzLzg2rdvJozCE4gS97oK vzcYGyCU3OXw== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.77,489,1596524400"; d="scan'208";a="544867340" Received: from sgsxdev004.isng.intel.com (HELO localhost) ([10.226.88.13]) by orsmga005.jf.intel.com with ESMTP; 18 Nov 2020 21:56:06 -0800 From: "Ramuthevar,Vadivel MuruganX" To: broonie@kernel.org, linux-kernel@vger.kernel.org, linux-spi@vger.kernel.org Cc: linux-mtd@lists.infradead.org, vigneshr@ti.com, p.yadav@ti.com, cheol.yong.kim@intel.com, qi-ming.wu@intel.com, Ramuthevar Vadivel Murugan Subject: [PATCH v8 3/6] spi: cadence-quadspi: Add multi-chipselect support for Intel LGM SoC Date: Thu, 19 Nov 2020 13:55:51 +0800 Message-Id: <20201119055551.26493-4-vadivel.muruganx.ramuthevar@linux.intel.com> X-Mailer: git-send-email 2.11.0 In-Reply-To: <20201119055551.26493-1-vadivel.muruganx.ramuthevar@linux.intel.com> References: <20201119055551.26493-1-vadivel.muruganx.ramuthevar@linux.intel.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Ramuthevar Vadivel Murugan Add multiple chipselect support for Intel LGM SoCs, currently QSPI-NOR and QSPI-NAND supported. Signed-off-by: Ramuthevar Vadivel Murugan --- drivers/spi/spi-cadence-quadspi.c | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/drivers/spi/spi-cadence-quadspi.c b/drivers/spi/spi-cadence-quadspi.c index d12b765e87be..337778f75d5d 100644 --- a/drivers/spi/spi-cadence-quadspi.c +++ b/drivers/spi/spi-cadence-quadspi.c @@ -38,6 +38,7 @@ /* Capabilities */ #define CQSPI_SUPPORTS_OCTAL BIT(0) +#define CQSPI_SUPPORTS_MULTI_CHIPSELECT BIT(1) struct cqspi_st; @@ -75,6 +76,7 @@ struct cqspi_st { bool is_decoded_cs; u32 fifo_depth; u32 fifo_width; + u32 num_chipselect; bool rclk_en; u32 trigger_address; u32 wr_delay; @@ -1049,6 +1051,7 @@ static int cqspi_of_get_flash_pdata(struct platform_device *pdev, static int cqspi_of_get_pdata(struct cqspi_st *cqspi) { + const struct cqspi_driver_platdata *ddata; struct device *dev = &cqspi->pdev->dev; struct device_node *np = dev->of_node; @@ -1070,6 +1073,14 @@ static int cqspi_of_get_pdata(struct cqspi_st *cqspi) return -ENXIO; } + ddata = of_device_get_match_data(dev); + if (ddata->hwcaps_mask & CQSPI_SUPPORTS_MULTI_CHIPSELECT) { + if (of_property_read_u32(np, "num-cs", &cqspi->num_chipselect)) { + dev_err(dev, "couldn't determine number of cs\n"); + return -ENXIO; + } + } + cqspi->rclk_en = of_property_read_bool(np, "cdns,rclk-en"); return 0; @@ -1302,6 +1313,9 @@ static int cqspi_probe(struct platform_device *pdev) cqspi->current_cs = -1; cqspi->sclk = 0; + if (ddata->hwcaps_mask & CQSPI_SUPPORTS_MULTI_CHIPSELECT) + master->num_chipselect = cqspi->num_chipselect; + ret = cqspi_setup_flash(cqspi); if (ret) { dev_err(dev, "failed to setup flash parameters %d\n", ret); @@ -1391,6 +1405,7 @@ static const struct cqspi_driver_platdata am654_ospi = { }; static const struct cqspi_driver_platdata intel_lgm_qspi = { + .hwcaps_mask = CQSPI_SUPPORTS_MULTI_CHIPSELECT, .quirks = CQSPI_DISABLE_DAC_MODE, }; -- 2.11.0