Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752784AbaGBMb2 (ORCPT ); Wed, 2 Jul 2014 08:31:28 -0400 Received: from mout.kundenserver.de ([212.227.126.187]:60116 "EHLO mout.kundenserver.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751594AbaGBMb0 (ORCPT ); Wed, 2 Jul 2014 08:31:26 -0400 From: Arnd Bergmann To: linux-arm-kernel@lists.infradead.org Cc: Liviu Dudau , Sinan Kaya , linaro-kernel , Benjamin Herrenschmidt , Device Tree ML , linux-pci , Jingoo Han , Liviu Dudau , LKML , Will Deacon , Grant Likely , Kukjin Kim , Tanmay Inamdar , Suravee Suthikulanit , Catalin Marinas , Bjorn Helgaas Subject: Re: [PATCH v8 3/9] pci: Introduce pci_register_io_range() helper function. Date: Wed, 02 Jul 2014 14:30:31 +0200 Message-ID: <7343032.WUqPgbXNQS@wuerfel> User-Agent: KMail/4.11.5 (Linux/3.11.0-18-generic; KDE/4.11.5; x86_64; ; ) In-Reply-To: <20140701204508.GA19569@bart.dudau.co.uk> References: <1404240214-9804-1-git-send-email-Liviu.Dudau@arm.com> <8556461.i7qCGvGY5a@wuerfel> <20140701204508.GA19569@bart.dudau.co.uk> MIME-Version: 1.0 Content-Transfer-Encoding: 7Bit Content-Type: text/plain; charset="us-ascii" X-Provags-ID: V02:K0:JVDZsIw9q8/DHL3eGZy9Te0auZGnj232/hqM3+n1DYD stwzE2fjasaCxyBVXuMqCWgrxhFAANTkErLQ4qmCXlLKesYA55 Bg+H8DGsNHQYBhHPWawbGLl08ya0FOw0gzFVWHdmxsNEsEFVgT PL9DVO3JiJB9SLG++EdZiD2uo9VjVMTbCWtMG6V9iMwSxu10M1 q+GyscKQrS030hiJqNO9WwjRN8GC5GZXYQUqpFWbtsBx8fgjXn SxupPZeJ+y4ZIjJ0rcaUQoyhW+7lYSXNFkV+QerjAmuvAZ0wDQ q+FfX4jW4g0MBgVrfOPxFk74khJ1H3ALNIcKy8Msn5bkIbHdN4 s+1YWzDCfeDGiJwvw8VM= Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tuesday 01 July 2014 21:45:09 Liviu Dudau wrote: > On Tue, Jul 01, 2014 at 09:36:10PM +0200, Arnd Bergmann wrote: > > On Tuesday 01 July 2014 19:43:28 Liviu Dudau wrote: > > > > This still conflicts with the other allocator you have in patch 9 > > for pci_remap_iospace: nothing guarantees that the mapping is the > > same for both. > > > > Also, this is a completely pointless exercise at this moment, because > > nobody cares about the result of pci_address_to_pio on architectures > > that don't already provide this function. If we ever get a proper > > Open Firmware implementation that wants to put hardcoded PCI devices > > into DT, we can add an implementation, but for now this seems overkill. > > > > The allocator in pci_register_io_range seems reasonable, why not merge > > this function with pci_remap_iospace() as I have asked you multiple > > times before? Just make it return the io_offset so the caller can > > put that into the PCI host resources. > > Hi Arnd, > > While I agree with you that at some moment the allocators were inconsistent > wrt each other, for this version I would respectfully disagree on this. > The allocator in pci_register_io_range() only makes sure that the ranges > are not overlapping, it doesn't do any mapping whatsoever, while > pci_remap_iospace() does only an ioremap_page_range(). The idea is that > you get the offset out of pci_address_to_pio() and apply it to > pci_remap_iospace(). Ok, got it now, I'm sorry I didn't read this properly at first. Your solution looks correct to me, just using different tradeoffs to what I was expecting: You get a working pci_address_to_pio() function, which is probably never needed, but in turn you need to keep the state of each host bridge in a global list. Arnd -- 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/