[PATCH v2] ARM: OMAP: WiLink platform data for the PandaBoard

Pavan Savoy pavan.savoy at gmail.com
Sun Mar 11 16:13:43 EDT 2012


On Sun, Mar 11, 2012 at 2:05 PM, Mircea Gherzan <mgherzan at gmail.com> wrote:
> Am 09.03.2012 19:31, schrieb Tony Lindgren:
>> Hi Luca,
>>
>> * Mircea Gherzan <mgherzan at gmail.com> [120306 14:23]:
>>> The "uim" deamon requires sysfs entries that are filled in using
>>> this platform data.
>>>
>>> Signed-off-by: Mircea Gherzan <mgherzan at gmail.com>
>>> ---
>>>  arch/arm/mach-omap2/board-omap4panda.c |   14 ++++++++++++--
>>>  include/linux/ti_wilink_st.h           |    2 ++
>>>  2 files changed, 14 insertions(+), 2 deletions(-)
>>>
>>> diff --git a/arch/arm/mach-omap2/board-omap4panda.c b/arch/arm/mach-omap2/board-omap4panda.c
>>> index b1d74d6..339e781 100644
>>> --- a/arch/arm/mach-omap2/board-omap4panda.c
>>> +++ b/arch/arm/mach-omap2/board-omap4panda.c
>>> @@ -27,6 +27,7 @@
>>>  #include <linux/i2c/twl.h>
>>>  #include <linux/regulator/machine.h>
>>>  #include <linux/regulator/fixed.h>
>>> +#include <linux/ti_wilink_st.h>
>>>  #include <linux/wl12xx.h>
>>>
>>>  #include <mach/hardware.h>
>>> @@ -56,12 +57,21 @@
>>>  #define HDMI_GPIO_HPD  63 /* Hotplug detect */
>>>
>>>  /* wl127x BT, FM, GPS connectivity chip */
>>> -static int wl1271_gpios[] = {46, -1, -1};
>>> +static struct ti_st_plat_data wilink_platform_data = {
>>> +    .nshutdown_gpio = 46,
>>> +    .dev_name       = "/dev/ttyO1",
>>> +    .flow_cntrl     = 1,
>>> +    .baud_rate      = 3000000,
>>> +    .chip_enable    = NULL,
>>> +    .suspend        = NULL,
>>> +    .resume         = NULL,
>>> +};
>>> +
>>>  static struct platform_device wl1271_device = {
>>>      .name   = "kim",
>>>      .id     = -1,
>>>      .dev    = {
>>> -            .platform_data  = &wl1271_gpios,
>>> +            .platform_data  = &wilink_platform_data,
>>>      },
>>>  };
>>>
>>> diff --git a/include/linux/ti_wilink_st.h b/include/linux/ti_wilink_st.h
>>> index 2ef4385..3ca0269 100644
>>> --- a/include/linux/ti_wilink_st.h
>>> +++ b/include/linux/ti_wilink_st.h
>>> @@ -25,6 +25,8 @@
>>>  #ifndef TI_WILINK_ST_H
>>>  #define TI_WILINK_ST_H
>>>
>>> +#include <linux/skbuff.h>
>>> +
>>>  /**
>>>   * enum proto-type - The protocol on WiLink chips which share a
>>>   *  common physical interface like UART.
>>> --
>>
>> Just checking.. Can you please take a look at this patch
>> and confirm that this is how things are supposed to be done?
>>
>> To me passing some third driver's dev_name in pdata seems
>> pretty weird.. But then again maybe I just don't know how
>> this is supposed to work.
>
> This is what the ti_st driver expects in the platform data structure.
> More precisely, in kim_probe():
>
>        /* copying platform data */
>        strncpy(kim_gdata->dev_name, pdata->dev_name,UART_DEV_NAME_LEN);
>        kim_gdata->flow_cntrl = pdata->flow_cntrl;
>        kim_gdata->baud_rate = pdata->baud_rate;
>        pr_info("sysfs entries created\n");
>
> So IMHO the patch is a valid fix. However, one more patch [1] is still
> required to get BT and WLAN working on the PandaBoard.

The patch looks alright to me.
Yes, the UART to which BT chip is connected (along with other
technologies for which shared transport is required), the baud rate
which the UART supports & also a flag so as to check whether it
supports flow control - ideally is supposed to come from boot-loader,
device tree sort of configuration - if not can be hard-coded in the
relevant platform specific files like in this case.

This is picked up from ST as platform data as is read from the
user-space daemon, because unfortunately none of these configurations
can be done in kernel (the right way for TTY).

1 more patch or an addition to this patch to add the wl1271_device &
the btwilink device is also required to get ST probe & BT probe.
The btwilink driver is a platform device because UART devices don't
have a probe mechanism unlike say usb, i2c..

> Thanks,
> Mircea
>
> [1] http://elinux.org/images/8/8d/0001a-omap4-pandaboard-wlan-fix.patch
>



-- 
--Pavan Savoy



More information about the linux-arm-kernel mailing list