Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1760191AbaGYLec (ORCPT ); Fri, 25 Jul 2014 07:34:32 -0400 Received: from top.free-electrons.com ([176.31.233.9]:55246 "EHLO mail.free-electrons.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1751478AbaGYLea convert rfc822-to-8bit (ORCPT ); Fri, 25 Jul 2014 07:34:30 -0400 Date: Fri, 25 Jul 2014 13:34:26 +0200 From: Boris BREZILLON To: jiri.prchal@aksignal.cz Cc: Bo Shen , nicolas.ferre@atmel.com, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, devicetree@vger.kernel.org Subject: Re: [PATCH] ARM: at91: at91sam9x5: sets NPCS0 (PA14) back to GPIO Message-ID: <20140725133426.57f5cf6e@bbrezillon> In-Reply-To: <53D23246.1010300@aksignal.cz> References: <1405074175-22444-1-git-send-email-voice.shen@atmel.com> <53D10C50.50305@aksignal.cz> <20140724162645.4e19c26c@bbrezillon> <53D12103.3020103@aksignal.cz> <20140724175848.44f5da10@bbrezillon> <53D1F5D0.1080006@aksignal.cz> <20140725095319.16a8465c@bbrezillon> <53D214E1.4050105@aksignal.cz> <20140725104553.403921b1@bbrezillon> <53D21B3F.7060006@aksignal.cz> <20140725110124.3f0dce6c@bbrezillon> <53D21FCF.7010402@aksignal.cz> <20140725113110.70c4aa41@bbrezillon> <53D22C26.4030208@aksignal.cz> <20140725121804.18b05a5d@bbrezillon> <53D23246.1010300@aksignal.cz> X-Mailer: Claws Mail 3.8.1 (GTK+ 2.24.20; x86_64-pc-linux-gnu) Mime-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8BIT Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, 25 Jul 2014 12:32:38 +0200 Jiří Prchal wrote: > > > Dne 25.7.2014 v 12:18 Boris BREZILLON napsal(a): > >> / # devmem 0xfffff408 > >> 0xF0E04018 > >> / # devmem 0xfffff418 > >> 0xE0C04000 > >> / # devmem 0xfffff438 > >> 0x00C04000 > >> / # devmem 0xfffff43c > >> 0x13FFD7FB > >> / # devmem 0xfffff458 > >> 0x00000000 > >> / # devmem 0xfffff468 > >> 0xFF223B4E > >> / # devmem 0xfffff470 > >> 0x0F000000 > >> / # devmem 0xfffff474 > >> 0x00000000 > >> / # devmem 0xfffff498 > >> 0xFFFFFFFF > >> > >> I get thought if is possible that in time of probe fm25 (it's first) is not configured PA14 (it 's last)? > > > > Oh, nice catch! > > I think you've found the origin of this bug. > > Indeed each device is instantiated sequentially and thus when the first > > device is probed (CS0) the last one has not requested it's cs_gpio yet > > (and PA14 is still assigned to periph A). > > > > Declaring cs-pins and referencing them in pinctrl-0 solves the issue > > because in this case all CS pins are requested during controller probe. > > > So, what would be the right fix up? I my patch it's not good idea since some other driver can request pin for other > peripheral earlier than spi. In board dts it could be new investigating for someone else who don't know this issue. I > think the best way would be request all cs in early spi init since cs depends on each other and must be all of them in > right state before any communication on bus. They are part of bus, like miso, mosi, clk, not part of chips. Also they > are defined in parent spi node, not in child chip node. > Am I right? Yes, you can take a look at [1] as an example. [1]http://lxr.free-electrons.com/source/drivers/spi/spi-efm32.c#L361 -- Boris Brezillon, Free Electrons Embedded Linux and Kernel engineering http://free-electrons.com -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/