Re: [Resend PATCH V3 3/4] usb/acpi: add the support of usb hub ports' acpi binding without attached devices.

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Wed, 13 Jun 2012, Lan Tianyu wrote:

> The usb port is a device in the acpi table but it's not in the linux
> usb subsystem. USB hub port doesn't have struct device. So the acpi
> glue framework only can cover the usb port connected with usb device
> and store the acpi handle to struct device.archdata.acpi_handle. This
> patch is to add member port_acpi_handle in the struct usb_hub_port to
> store acpi handle. The acpi method "_UPC" and "_PLD" can be accessed
> without attached device.
> 
> v2
>  replace struct usb_hub_port member platform_data with member port_acpi_handle
> to store acpi_handle

> --- a/drivers/usb/core/hub.c
> +++ b/drivers/usb/core/hub.c

> @@ -4933,3 +4941,37 @@ struct usb_device *usb_get_hub_child(struct usb_device *hdev,
>  }
>  EXPORT_SYMBOL_GPL(usb_get_hub_child);
>  
> +#ifdef CONFIG_ACPI
> +/**
> + * usb_set_hub_port_acpi_handle - Set the usb port's acpi handle
> + * @hdev: USB device belonging to the usb hub
> + * @port1: port num of the port
> + * @handle: port's acpi handle
> + */
> +void usb_set_hub_port_acpi_handle(struct usb_device *hdev, int port1,
> +	void *handle)
> +{
> +	struct usb_hub *hub = hdev_to_hub(hdev);
> +
> +	if (port1 < 1 || port1 > hdev->maxchild)
> +		return;

You don't need this test.  The function gets called from only one 
place, so you know that port1 is valid.

> +	hub->port_data[port1 - 1].port_acpi_handle = handle;
> +}
> +
> +/**
> + * usb_get_hub_port_acpi_handle - Get the usb port's acpi handle
> + * @hdev: USB device belonging to the usb hub
> + * @port1: port num of the port
> + *
> + * Return port's acpi handle if successful, NULL if params are
> + * invaild.
> + */
> +acpi_handle usb_get_hub_port_acpi_handle(struct usb_device *hdev, int port1)
> +{
> +	struct usb_hub *hub = hdev_to_hub(hdev);
> +
> +	if (port1 < 1 || port1 > hdev->maxchild)
> +		return NULL;

Same for this test.

Alan Stern

--
To unsubscribe from this list: send the line "unsubscribe linux-usb" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux Media]     [Linux Input]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [Old Linux USB Devel Archive]

  Powered by Linux