[alsa-devel] [PATCH v4 9/9] davinci: USB1.1 support for Omapl138-Hawkboard
Victor Rodriguez
vm.rod25 at gmail.com
Mon Oct 18 16:59:26 CEST 2010
On Fri, Oct 15, 2010 at 11:32 AM, Sergei Shtylyov <sshtylyov at mvista.com> wrote:
> Hello.
>
> On 10/15/10 07:08, vm.rod25 at gmail.com wrote:
>
>> From: Victor Rodriguez<victor.rodriguez at sasken.com>
>
>> This patch adds USB1.1 support for the Hawkboard-L138 system
>
>> Signed-off-by: Victor Rodriguez<victor.rodriguez at sasken.com>
>
> [...]
>
>> diff --git a/arch/arm/mach-davinci/board-omapl138-hawk.c
>> b/arch/arm/mach-davinci/board-omapl138-hawk.c
>> index 87dea28..4658498 100644
>> --- a/arch/arm/mach-davinci/board-omapl138-hawk.c
>> +++ b/arch/arm/mach-davinci/board-omapl138-hawk.c
>
> [...]
>>
>> @@ -178,6 +181,109 @@ static struct davinci_mmc_config da850_mmc_config =
>> {
>> .version = MMC_CTLR_VERSION_2,
>> };
>>
>> +static irqreturn_t omapl138_hawk_usb_ocic_irq(int irq, void *dev_id);
>> +static da8xx_ocic_handler_t hawk_usb_ocic_handler;
>> +
>> +static const short da850_hawk_usb11_pins[] = {
>> + DA850_GPIO2_4, DA850_GPIO6_13,
>> + -1
>> +};
>
> An empty wouldn't hurt here. Sorry if I overlooked this before...
>
>> +static int hawk_usb_set_power(unsigned port, int on)
>> +{
>> + gpio_set_value(DA850_USB1_VBUS_PIN, on);
>> + return 0;
>> +}
>> +
>> +static int hawk_usb_get_power(unsigned port)
>> +{
>> + return gpio_get_value(DA850_USB1_VBUS_PIN);
>> +}
>> +
>> +static int hawk_usb_get_oci(unsigned port)
>> +{
>> + return !gpio_get_value(DA850_USB1_OC_PIN);
>> +}
>> +
>> +static int hawk_usb_ocic_notify(da8xx_ocic_handler_t handler)
>> +{
>> + int irq = gpio_to_irq(DA850_USB1_OC_PIN);
>> + int error = 0;
>> +
>> + if (handler != NULL) {
>> + hawk_usb_ocic_handler = handler;
>> +
>> + error = request_irq(irq, omapl138_hawk_usb_ocic_irq,
>> + IRQF_DISABLED |
>> IRQF_TRIGGER_RISING |
>> + IRQF_TRIGGER_FALLING,
>> + "OHCI over-current indicator",
>> NULL);
>> + if (error)
>> + printk(KERN_ERR "%s: could not request IRQ to
>> watch "
>> + "over-current indicator changes\n",
>> __func__);
>
> pr_err() please.
>
>> + } else
>> + free_irq(irq, NULL);
>> +
>> + return error;
>> +}
>> +
>> +static struct da8xx_ohci_root_hub omapl138_hawk_usb11_pdata = {
>> + .set_power = hawk_usb_set_power,
>> + .get_power = hawk_usb_get_power,
>> + .get_oci = hawk_usb_get_oci,
>> + .ocic_notify = hawk_usb_ocic_notify,
>> + /* TPS2087 switch @ 5V */
>> + .potpgt = (3 + 1) / 2, /* 3 ms max */
>> +};
>> +
>> +static irqreturn_t omapl138_hawk_usb_ocic_irq(int irq, void *dev_id)
>> +{
>> + hawk_usb_ocic_handler(&omapl138_hawk_usb11_pdata, 1);
>> + return IRQ_HANDLED;
>> +}
>> +
>> +static __init void omapl138_hawk_usb_init(void)
>> +{
>> + int ret;
>> + u32 cfgchip2;
>> +
>> + ret = davinci_cfg_reg_list(da850_hawk_usb11_pins);
>> + if (ret) {
>> + pr_warning("%s: USB 1.1 PinMux setup failed: %d\n",
>> + __func__, ret);
>> + return;
>> + }
>> +
>> + /*
>> + * Setup the Ref. clock frequency for the HAWK at 24 MHz.
>> + */
>> + cfgchip2 = __raw_readl(DA8XX_SYSCFG0_VIRT(DA8XX_CFGCHIP2_REG));
>> + cfgchip2 &= ~CFGCHIP2_REFFREQ;
>> + cfgchip2 |= CFGCHIP2_REFFREQ_24MHZ;
>> + __raw_writel(cfgchip2, DA8XX_SYSCFG0_VIRT(DA8XX_CFGCHIP2_REG));
>> +
>> + ret = gpio_request(DA850_USB1_VBUS_PIN, "USB1 VBUS\n");
>> + if (ret) {
>> + printk(KERN_ERR "%s: failed to request GPIO for USB 1.1
>> port "
>> + "power control: %d\n", __func__, ret);
>
> pr_err() please.
>
>> + return;
>> + }
>> + gpio_direction_output(DA850_USB1_VBUS_PIN, 0);
>> +
>> + ret = gpio_request(DA850_USB1_OC_PIN, "USB1 OC");
>> + if (ret) {
>> + printk(KERN_ERR "%s: failed to request GPIO for USB 1.1
>> port "
>> + "over-current indicator: %d\n", __func__, ret);
>
> pr_err() please.
>
>> + return;
>> + }
>> + gpio_direction_input(DA850_USB1_OC_PIN);
>> +
>> + ret = da8xx_register_usb11(&omapl138_hawk_usb11_pdata);
>> + if (ret) {
>> + pr_warning("%s: USB 1.1 registration failed: %d\n",
>> + __func__, ret);
>> + return;
>
> 'return' is useless here...
Thanks for the feedback if I erase the return here I think I also have
to erase the { ...} am I right ?
Regards
Victor Rodriguez
>> + }
>> +}
>> +
>> static struct davinci_uart_config omapl138_hawk_uart_config __initdata =
>> {
>> .enabled_uarts = 0x7,
>> };
>
> WBR, Sergei
>
More information about the Alsa-devel
mailing list