diff options
author | Sarah Sharp <sarah.a.sharp@linux.intel.com> | 2009-12-09 18:59:03 -0500 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@suse.de> | 2010-03-02 17:53:09 -0500 |
commit | a1d78c16bd31a715785e21967ac6110b386a3c1f (patch) | |
tree | b0df8ca079b2afad844276fdf2ece21dbcdc38fa /drivers/usb/host | |
parent | 412566bd716397e28e81fc9b20804bc6a6daf14d (diff) |
USB: xhci: Allow allocation of commands without input contexts.
The xhci_command structure is the basic structure for issuing commands to
the xHCI hardware. It contains a struct completion (so that the issuing
function can wait on the command), command status, and a input context
that is used to pass information to the hardware. Not all commands need
the input context, so make it optional to allocate. Allow
xhci_free_container_ctx() to be passed a NULL input context, to make
freeing the xhci_command structure simple.
Signed-off-by: Sarah Sharp <sarah.a.sharp@linux.intel.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/usb/host')
-rw-r--r-- | drivers/usb/host/xhci-hcd.c | 2 | ||||
-rw-r--r-- | drivers/usb/host/xhci-mem.c | 18 | ||||
-rw-r--r-- | drivers/usb/host/xhci.h | 3 |
3 files changed, 15 insertions, 8 deletions
diff --git a/drivers/usb/host/xhci-hcd.c b/drivers/usb/host/xhci-hcd.c index 451f53eec6d7..17f1caf2af64 100644 --- a/drivers/usb/host/xhci-hcd.c +++ b/drivers/usb/host/xhci-hcd.c | |||
@@ -1679,7 +1679,7 @@ int xhci_update_hub_device(struct usb_hcd *hcd, struct usb_device *hdev, | |||
1679 | xhci_warn(xhci, "Cannot update hub desc for unknown device.\n"); | 1679 | xhci_warn(xhci, "Cannot update hub desc for unknown device.\n"); |
1680 | return -EINVAL; | 1680 | return -EINVAL; |
1681 | } | 1681 | } |
1682 | config_cmd = xhci_alloc_command(xhci, true, mem_flags); | 1682 | config_cmd = xhci_alloc_command(xhci, true, true, mem_flags); |
1683 | if (!config_cmd) { | 1683 | if (!config_cmd) { |
1684 | xhci_dbg(xhci, "Could not allocate xHCI command structure.\n"); | 1684 | xhci_dbg(xhci, "Could not allocate xHCI command structure.\n"); |
1685 | return -ENOMEM; | 1685 | return -ENOMEM; |
diff --git a/drivers/usb/host/xhci-mem.c b/drivers/usb/host/xhci-mem.c index 1f1f8a0f2e66..8045bc69083d 100644 --- a/drivers/usb/host/xhci-mem.c +++ b/drivers/usb/host/xhci-mem.c | |||
@@ -267,6 +267,8 @@ struct xhci_container_ctx *xhci_alloc_container_ctx(struct xhci_hcd *xhci, | |||
267 | void xhci_free_container_ctx(struct xhci_hcd *xhci, | 267 | void xhci_free_container_ctx(struct xhci_hcd *xhci, |
268 | struct xhci_container_ctx *ctx) | 268 | struct xhci_container_ctx *ctx) |
269 | { | 269 | { |
270 | if (!ctx) | ||
271 | return; | ||
270 | dma_pool_free(xhci->device_pool, ctx->bytes, ctx->dma); | 272 | dma_pool_free(xhci->device_pool, ctx->bytes, ctx->dma); |
271 | kfree(ctx); | 273 | kfree(ctx); |
272 | } | 274 | } |
@@ -844,7 +846,8 @@ static void scratchpad_free(struct xhci_hcd *xhci) | |||
844 | } | 846 | } |
845 | 847 | ||
846 | struct xhci_command *xhci_alloc_command(struct xhci_hcd *xhci, | 848 | struct xhci_command *xhci_alloc_command(struct xhci_hcd *xhci, |
847 | bool allocate_completion, gfp_t mem_flags) | 849 | bool allocate_in_ctx, bool allocate_completion, |
850 | gfp_t mem_flags) | ||
848 | { | 851 | { |
849 | struct xhci_command *command; | 852 | struct xhci_command *command; |
850 | 853 | ||
@@ -852,11 +855,14 @@ struct xhci_command *xhci_alloc_command(struct xhci_hcd *xhci, | |||
852 | if (!command) | 855 | if (!command) |
853 | return NULL; | 856 | return NULL; |
854 | 857 | ||
855 | command->in_ctx = | 858 | if (allocate_in_ctx) { |
856 | xhci_alloc_container_ctx(xhci, XHCI_CTX_TYPE_INPUT, mem_flags); | 859 | command->in_ctx = |
857 | if (!command->in_ctx) { | 860 | xhci_alloc_container_ctx(xhci, XHCI_CTX_TYPE_INPUT, |
858 | kfree(command); | 861 | mem_flags); |
859 | return NULL; | 862 | if (!command->in_ctx) { |
863 | kfree(command); | ||
864 | return NULL; | ||
865 | } | ||
860 | } | 866 | } |
861 | 867 | ||
862 | if (allocate_completion) { | 868 | if (allocate_completion) { |
diff --git a/drivers/usb/host/xhci.h b/drivers/usb/host/xhci.h index 61747f3c5c8f..902be9647c60 100644 --- a/drivers/usb/host/xhci.h +++ b/drivers/usb/host/xhci.h | |||
@@ -1237,7 +1237,8 @@ void xhci_free_or_cache_endpoint_ring(struct xhci_hcd *xhci, | |||
1237 | struct xhci_virt_device *virt_dev, | 1237 | struct xhci_virt_device *virt_dev, |
1238 | unsigned int ep_index); | 1238 | unsigned int ep_index); |
1239 | struct xhci_command *xhci_alloc_command(struct xhci_hcd *xhci, | 1239 | struct xhci_command *xhci_alloc_command(struct xhci_hcd *xhci, |
1240 | bool allocate_completion, gfp_t mem_flags); | 1240 | bool allocate_in_ctx, bool allocate_completion, |
1241 | gfp_t mem_flags); | ||
1241 | void xhci_free_command(struct xhci_hcd *xhci, | 1242 | void xhci_free_command(struct xhci_hcd *xhci, |
1242 | struct xhci_command *command); | 1243 | struct xhci_command *command); |
1243 | 1244 | ||