Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp478519imu; Mon, 5 Nov 2018 04:09:53 -0800 (PST) X-Google-Smtp-Source: AJdET5eHZ1puupl7N8eCoLk5OhQZN2ng6z65PRbZp20p5KEfe9LvPtRfMNUcKS0OAdNmwRSvo4gZ X-Received: by 2002:a63:4b60:: with SMTP id k32mr19868336pgl.186.1541419793614; Mon, 05 Nov 2018 04:09:53 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1541419793; cv=none; d=google.com; s=arc-20160816; b=Ruj2L7J73WHAhY3vQjt/idPMzxpszCX41aB5XIy/eyxTUcfGIHhhAf42lbCsG/YjCa jlzECd7PKQsx7drQEwrv4PSPYUYZXZRvCWuEvdfYymfJKB5BEN9v5vxVA1OA8Ifnf2LE irR41zWFjl9JWxaIl2rgZhFwwXRD/tpdxKmAIqU3uNt1EIFT0UdigcVw1g8lqnnNodMu /0Bs1z9zmwMh/c8Xi7Ch9Klp52zbaptKkx4UodgNMNIFOXOCB5KsSYWZLfxppZ97+1P5 z0wAVvBXWSUfNVRLt6M1jSGMY6J3x6d23S1v9GuMuruwSbjyc60UnE2R6Qe5/zTOZLN7 4fsw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:date:message-id:in-reply-to:subject:cc:to :from:dkim-signature; bh=mIBRuY6R59xSLIH+ecT3OCqw2NUx1YMcGtIqjnuPT/M=; b=IXPoGlrf2Gw9DnOamj4tg40XryyVJ2qiNY0BIZ+Kmlvw41pXdRNWOSKercW8XKxxQm 1ezIXBWmsrxqk1o9NnF1vYzCPi4IipAOgzoChhAWqFptfVVwccA0MpG6l7sWKT8jvLk0 9YTqDPtXAmgP5tCXgegcrBDw3Ye5GDhzWbFNEUjkS4rkHJ9RvMnx6MW7Ijd7P+MLRERw ojpJvsnGkOWrzqUNG6/Jmt5e1PBd8UyBgLum4eoTJAsKe2eRtRANTb/4pQV7N8wUFJVJ ly+R2VE/OVXVItjQf3FGDGicd1PQKbkMRjJQEOGQBPiTKgTQ31j34+niZ3kRpLP8UZ+D 8ISg== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@sirena.org.uk header.s=20170815-heliosphere header.b=KmUYYljo; 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=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id t69si12786208pgb.365.2018.11.05.04.09.38; Mon, 05 Nov 2018 04:09:53 -0800 (PST) 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; dkim=fail header.i=@sirena.org.uk header.s=20170815-heliosphere header.b=KmUYYljo; 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=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729714AbeKEV0D (ORCPT + 99 others); Mon, 5 Nov 2018 16:26:03 -0500 Received: from heliosphere.sirena.org.uk ([172.104.155.198]:53134 "EHLO heliosphere.sirena.org.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727337AbeKEV0C (ORCPT ); Mon, 5 Nov 2018 16:26:02 -0500 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=sirena.org.uk; s=20170815-heliosphere; h=Date:Message-Id:In-Reply-To: Subject:Cc:To:From:Sender:Reply-To:MIME-Version:Content-Type: Content-Transfer-Encoding:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:References: List-Id:List-Help:List-Unsubscribe:List-Subscribe:List-Post:List-Owner: List-Archive; bh=mIBRuY6R59xSLIH+ecT3OCqw2NUx1YMcGtIqjnuPT/M=; b=KmUYYljoARGc CDmDgmlwUPo0QzTAFVU7+lK8XQNPBK2/3Bsnp0tf3vrCtjEtw8IUbYxB9GLI0lYGvGmgUfftxLYSH 8Xnk+q7ds0u5IGw0t2EswmXCa7Nzr+sRWuPKqKk5iqhl/i+S9b6YAiJqr96A26SQJBnSwwwM85aRE aruQ4=; Received: from cpc102320-sgyl38-2-0-cust46.18-2.cable.virginm.net ([82.37.168.47] helo=debutante.sirena.org.uk) by heliosphere.sirena.org.uk with esmtpa (Exim 4.89) (envelope-from ) id 1gJdeI-0008Nb-Ea; Mon, 05 Nov 2018 12:06:30 +0000 Received: by debutante.sirena.org.uk (Postfix, from userid 1000) id 2BE051124D98; Mon, 5 Nov 2018 12:06:30 +0000 (GMT) From: Mark Brown To: Emil Renner Berthing Cc: Heiko Stuebner , Mark Brown , linux-spi@vger.kernel.org, Addy Ke , Mark Brown , Heiko Stuebner , linux-arm-kernel@lists.infradead.org, linux-rockchip@lists.infradead.org, linux-kernel@vger.kernel.org, linux-spi@vger.kernel.org Subject: Applied "spi: rockchip: remove master pointer from dev data" to the spi tree In-Reply-To: <20181031105711.19575-9-esmil@mailme.dk> Message-Id: <20181105120630.2BE051124D98@debutante.sirena.org.uk> Date: Mon, 5 Nov 2018 12:06:30 +0000 (GMT) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The patch spi: rockchip: remove master pointer from dev data has been applied to the spi tree at https://git.kernel.org/pub/scm/linux/kernel/git/broonie/spi.git All being well this means that it will be integrated into the linux-next tree (usually sometime in the next 24 hours) and sent to Linus during the next merge window (or sooner if it is a bug fix), however if problems are discovered then the patch may be dropped or reverted. You may get further e-mails resulting from automated or manual testing and review of the tree, please engage with people reporting problems and send followup patches addressing any issues that are reported if needed. If any updates are required or you are submitting further changes they should be sent as incremental updates against current git, existing patches will not be replaced. Please add any relevant lists and maintainers to the CCs when replying to this mail. Thanks, Mark From d790c342e689ea77a5cf72d5b993299911ee5276 Mon Sep 17 00:00:00 2001 From: Emil Renner Berthing Date: Wed, 31 Oct 2018 11:57:05 +0100 Subject: [PATCH] spi: rockchip: remove master pointer from dev data In almost all cases we already have a pointer to the spi master structure where we have the driver data. The only exceptions are the dma callbacks which are easily fixed by passing them the master and using spi_master_get_devdata to retrieve the driver data. Signed-off-by: Emil Renner Berthing Tested-by: Heiko Stuebner Signed-off-by: Mark Brown --- drivers/spi/spi-rockchip.c | 21 ++++++++++----------- 1 file changed, 10 insertions(+), 11 deletions(-) diff --git a/drivers/spi/spi-rockchip.c b/drivers/spi/spi-rockchip.c index f3fe6d4cf6f6..45a1479c1a29 100644 --- a/drivers/spi/spi-rockchip.c +++ b/drivers/spi/spi-rockchip.c @@ -159,7 +159,6 @@ struct rockchip_spi { struct device *dev; - struct spi_master *master; struct clk *spiclk; struct clk *apb_pclk; @@ -350,19 +349,21 @@ static int rockchip_spi_pio_transfer(struct rockchip_spi *rs) static void rockchip_spi_dma_rxcb(void *data) { - struct rockchip_spi *rs = data; + struct spi_master *master = data; + struct rockchip_spi *rs = spi_master_get_devdata(master); int state = atomic_fetch_andnot(RXDMA, &rs->state); if (state & TXDMA) return; spi_enable_chip(rs, false); - spi_finalize_current_transfer(rs->master); + spi_finalize_current_transfer(master); } static void rockchip_spi_dma_txcb(void *data) { - struct rockchip_spi *rs = data; + struct spi_master *master = data; + struct rockchip_spi *rs = spi_master_get_devdata(master); int state = atomic_fetch_andnot(TXDMA, &rs->state); if (state & RXDMA) @@ -372,7 +373,7 @@ static void rockchip_spi_dma_txcb(void *data) wait_for_idle(rs); spi_enable_chip(rs, false); - spi_finalize_current_transfer(rs->master); + spi_finalize_current_transfer(master); } static int rockchip_spi_prepare_dma(struct rockchip_spi *rs, @@ -401,7 +402,7 @@ static int rockchip_spi_prepare_dma(struct rockchip_spi *rs, return -EINVAL; rxdesc->callback = rockchip_spi_dma_rxcb; - rxdesc->callback_param = rs; + rxdesc->callback_param = master; } txdesc = NULL; @@ -426,7 +427,7 @@ static int rockchip_spi_prepare_dma(struct rockchip_spi *rs, } txdesc->callback = rockchip_spi_dma_txcb; - txdesc->callback_param = rs; + txdesc->callback_param = master; } /* rx must be started before tx due to spi instinct */ @@ -633,7 +634,6 @@ static int rockchip_spi_probe(struct platform_device *pdev) spi_enable_chip(rs, false); - rs->master = master; rs->dev = &pdev->dev; rs->max_freq = clk_get_rate(rs->spiclk); @@ -746,9 +746,8 @@ static int rockchip_spi_suspend(struct device *dev) { int ret; struct spi_master *master = dev_get_drvdata(dev); - struct rockchip_spi *rs = spi_master_get_devdata(master); - ret = spi_master_suspend(rs->master); + ret = spi_master_suspend(master); if (ret < 0) return ret; @@ -773,7 +772,7 @@ static int rockchip_spi_resume(struct device *dev) if (ret < 0) return ret; - ret = spi_master_resume(rs->master); + ret = spi_master_resume(master); if (ret < 0) { clk_disable_unprepare(rs->spiclk); clk_disable_unprepare(rs->apb_pclk); -- 2.19.0.rc2