Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754611AbbBZViN (ORCPT ); Thu, 26 Feb 2015 16:38:13 -0500 Received: from cantor2.suse.de ([195.135.220.15]:49883 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754513AbbBZViL (ORCPT ); Thu, 26 Feb 2015 16:38:11 -0500 Message-ID: <54EF923F.8010409@suse.de> Date: Thu, 26 Feb 2015 22:38:07 +0100 From: Alexander Graf User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.10; rv:31.0) Gecko/20100101 Thunderbird/31.4.0 MIME-Version: 1.0 To: Stuart Yoder , "arnd@arndb.de" CC: Jose Rivera , "linux-kernel@vger.kernel.org" , "gregkh@linuxfoundation.org" Subject: Re: [PATCH 0/3 v6] drivers/bus: Freescale Management Complex bus driver patch series References: <1421456477-27041-1-git-send-email-German.Rivera@freescale.com> <54EF2EA9.8080107@suse.de> In-Reply-To: Content-Type: text/plain; charset=windows-1252 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2893 Lines: 83 On 26.02.15 21:32, Stuart Yoder wrote: > > >> -----Original Message----- >> From: Alexander Graf [mailto:agraf@suse.de] >> Sent: Thursday, February 26, 2015 8:33 AM >> To: Yoder Stuart-B08248; arnd@arndb.de >> Cc: Rivera Jose-B46482; linux-kernel@vger.kernel.org; gregkh@linuxfoundation.org >> Subject: Re: [PATCH 0/3 v6] drivers/bus: Freescale Management Complex bus driver patch series >> >> >> >> On 27.01.15 15:35, Stuart Yoder wrote: >>> Hi Arnd/Alex, >>> >>> German has posted an example driver for the fsl-mc bus in his RFC >>> "[RFC PATCH 1/1] drivers/bus: fsl-mc object allocator driver". >>> >>> In addition I have made available the skeleton for a driver for >>> one of the objects/devices (crypto) that will be discovered on >>> the bus: >>> https://github.com/stuyoder/linux >>> branch: fsl-ms-bus >>> >>> ...it is not functional yet, but shows how a driver registers with >>> the bus, get's probed, performs initialization. >> >> Ok, so if I grasp this correctly the idea is that we have a driver >> attaching to an individual device on the fsl-mc bus. > > Yes. > >> That driver then >> goes and allocates / blocks more devices from that bus as it initializes. > > Yes, there are certain devices/objects on the bus that by themselves > are not standalone, functional devices. An example is a "buffer pool". > Network interface drivers, crypto driver, decompression driver, etc need > one or more hardware buffer pools. There is a buffer depletion interrupt > associated with the device. > > The buffer pools itself binds to a resource allocation driver in > the kernel, which then can hand out buffer pools as required by > other drivers. Ok, so there are 2 things on the bus * devices * resources Someone really needs to sit down and write some nice ASCII art about all of this and include all the abbreviations in it as well, so that anyone not deeply involved in the architecture has the chance to grasp what this is about. >> Is that model always possible? > > Yes, why would it not be? > >> Which device would a NIC bind to for >> example? > > Network interface / Ethernet driver requires some number > of buffer pools, plus a management complex portal device > (DPMCP) used for sending commands to manage the hardware. Ok, so there is always one object that basically "owns" a particular device. And then there is a cloud of resources that drivers grab as they go. I think I got it by now and the concept makes a lot of sense. I'm not sure whether there's any particular benefit or downside of having resources be devices, but looking at the resource manager code it probably doesn't hurt. Alex -- 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/