Return-path: Received: from mail-px0-f174.google.com ([209.85.212.174]:54335 "EHLO mail-px0-f174.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1758042Ab0G2QQU (ORCPT ); Thu, 29 Jul 2010 12:16:20 -0400 MIME-Version: 1.0 In-Reply-To: References: <1279733634-21974-1-git-send-email-ohad@wizery.com> <1279733634-21974-4-git-send-email-ohad@wizery.com> Date: Thu, 29 Jul 2010 18:16:19 +0200 Message-ID: Subject: Re: [PATCH v2 03/20] mmc: support embedded data field in mmc_host From: Vitaly Wool To: Ohad Ben-Cohen Cc: linux-wireless@vger.kernel.org, linux-mmc@vger.kernel.org, linux-omap@vger.kernel.org, Kalle Valo , Pandita Vikram , linux@arm.linux.org.uk, Nicolas Pitre , Tony Lindgren , Roger Quadros , San Mehat , Chikkature Rajashekar Madhusudhan , Luciano Coelho , akpm@linux-foundation.org, linux-arm-kernel@lists.infradead.org Content-Type: text/plain; charset=ISO-8859-1 Sender: linux-wireless-owner@vger.kernel.org List-ID: Hi Ohad, On Thu, Jul 29, 2010 at 8:00 AM, Ohad Ben-Cohen wrote: >> To my understanding, this data doesn't belong to mmc_host. It's not a >> host data at all. E. g. imagine a GPIO IRQ for some SDIO chip -- it's >> totally unrelated to host. >> >> I think a cleaner way would be to introduce something similar to what >> we have for SPI, e. g. struct sdio_board_info. This board info will >> contain platform-specific stuff and vendor id/chip id for each onboard >> SDIO device. Then the SDIO core will pick up the appropriate data >> basing on vendor id/chip id. > > Can you please elaborate some more about your proposal (specifically > where does this sdio_board_info get set and how do function drivers > access it) ? > > If I understand you correctly, you suggest to have a global, > board-specific table of sdio_board_info structures, which would be > accessible to the SDIO core (through the host driver ?). When a new > SDIO device is found the core would search this table for the > appropriate sdio_board_info struct and make it accessible to the SDIO > function driver ? Well, let's look at how it's implemented for SPI. There is the function spi_register_board_info in the SPI core which copies the board info into the local data structure (a linked list, actually). Whenever needed, the core walks through the list to find the appropriate board_info basing on some search key. I think this may be the way to go for SDIO as well. ~Vitaly