* [PATCH 1/2] net/usb: hso: allocate URB setup_packets as separate buffers
@ 2013-08-07 13:29 Jussi Kivilinna
[not found] ` <20130807132902.14451.37517.stgit-bi+AKbBUZKagILUCTcTcHdKyNwTtLsGr@public.gmane.org>
2013-08-07 15:46 ` [PATCH 1/2] net/usb: hso: allocate URB setup_packets as separate buffers Dan Williams
0 siblings, 2 replies; 4+ messages in thread
From: Jussi Kivilinna @ 2013-08-07 13:29 UTC (permalink / raw)
To: netdev; +Cc: Greg Kroah-Hartman, linux-usb, David S. Miller, Jan Dumon
URB setup packets must not be allocated as part of larger structure because
DMA coherence issues.
Patch changes hso to allocate ctrl_req_[tr]x members of 'struct hso_serial'
as separate buffers.
Patch is only compile tested.
Cc: <stable@vger.kernel.org>
Signed-off-by: Jussi Kivilinna <jussi.kivilinna@iki.fi>
---
drivers/net/usb/hso.c | 18 ++++++++++++++----
1 file changed, 14 insertions(+), 4 deletions(-)
diff --git a/drivers/net/usb/hso.c b/drivers/net/usb/hso.c
index cba1d46..fc082c0 100644
--- a/drivers/net/usb/hso.c
+++ b/drivers/net/usb/hso.c
@@ -237,8 +237,8 @@ struct hso_serial {
u16 tx_data_length; /* should contain allocated length */
u16 tx_data_count;
u16 tx_buffer_count;
- struct usb_ctrlrequest ctrl_req_tx;
- struct usb_ctrlrequest ctrl_req_rx;
+ struct usb_ctrlrequest *ctrl_req_tx;
+ struct usb_ctrlrequest *ctrl_req_rx;
struct usb_endpoint_descriptor *in_endp;
struct usb_endpoint_descriptor *out_endp;
@@ -1847,7 +1847,7 @@ static int hso_mux_serial_read(struct hso_serial *serial)
USB_CDC_GET_ENCAPSULATED_RESPONSE,
serial->parent->port_spec & HSO_PORT_MASK,
serial->rx_urb[0],
- &serial->ctrl_req_rx,
+ serial->ctrl_req_rx,
serial->rx_data[0], serial->rx_data_length);
}
@@ -1916,7 +1916,7 @@ static int hso_mux_serial_write_data(struct hso_serial *serial)
USB_CDC_SEND_ENCAPSULATED_COMMAND,
serial->parent->port_spec & HSO_PORT_MASK,
serial->tx_urb,
- &serial->ctrl_req_tx,
+ serial->ctrl_req_tx,
serial->tx_data, serial->tx_data_count);
}
@@ -2264,6 +2264,10 @@ static void hso_serial_common_free(struct hso_serial *serial)
usb_free_urb(serial->tx_urb);
kfree(serial->tx_data);
tty_port_destroy(&serial->port);
+
+ /* free control URB setup packet buffers */
+ kfree(serial->ctrl_req_tx);
+ kfree(serial->ctrl_req_rx);
}
static int hso_serial_common_create(struct hso_serial *serial, int num_urbs,
@@ -2292,6 +2296,12 @@ static int hso_serial_common_create(struct hso_serial *serial, int num_urbs,
spin_lock_init(&serial->serial_lock);
serial->num_rx_urbs = num_urbs;
+ /* allocate control URB setup packet buffers */
+ serial->ctrl_req_tx = kzalloc(sizeof(*serial->ctrl_req_tx), GFP_KERNEL);
+ serial->ctrl_req_rx = kzalloc(sizeof(*serial->ctrl_req_rx), GFP_KERNEL);
+ if (!serial->ctrl_req_tx || !serial->ctrl_req_rx)
+ goto exit;
+
/* RX, allocate urb and initialize */
/* prepare our RX buffer */
^ permalink raw reply related [flat|nested] 4+ messages in thread
* [PATCH 2/2] net/usb: hso: allocate serial_state_notification as separate buffer
[not found] ` <20130807132902.14451.37517.stgit-bi+AKbBUZKagILUCTcTcHdKyNwTtLsGr@public.gmane.org>
@ 2013-08-07 13:29 ` Jussi Kivilinna
2013-08-07 15:47 ` Dan Williams
0 siblings, 1 reply; 4+ messages in thread
From: Jussi Kivilinna @ 2013-08-07 13:29 UTC (permalink / raw)
To: netdev-u79uwXL29TY76Z2rM5mHXA
Cc: Greg Kroah-Hartman, linux-usb-u79uwXL29TY76Z2rM5mHXA,
David S. Miller, Jan Dumon
URB transfer_buffers must not be allocated as part of larger structure because
DMA coherence issues.
Patch changes hso to allocate serial_state_notification member of
'struct hso_tiocmget' as separate buffer.
Patch is only compile tested.
Cc: <stable-u79uwXL29TY76Z2rM5mHXA@public.gmane.org>
Signed-off-by: Jussi Kivilinna <jussi.kivilinna-X3B1VOXEql0@public.gmane.org>
---
drivers/net/usb/hso.c | 18 ++++++++++++++----
1 file changed, 14 insertions(+), 4 deletions(-)
diff --git a/drivers/net/usb/hso.c b/drivers/net/usb/hso.c
index fc082c0..21ffa6f 100644
--- a/drivers/net/usb/hso.c
+++ b/drivers/net/usb/hso.c
@@ -211,7 +211,7 @@ struct hso_tiocmget {
int intr_completed;
struct usb_endpoint_descriptor *endp;
struct urb *urb;
- struct hso_serial_state_notification serial_state_notification;
+ struct hso_serial_state_notification *serial_state_notification;
u16 prev_UART_state_bitmap;
struct uart_icount icount;
};
@@ -1465,7 +1465,7 @@ static int tiocmget_submit_urb(struct hso_serial *serial,
usb_rcvintpipe(usb,
tiocmget->endp->
bEndpointAddress & 0x7F),
- &tiocmget->serial_state_notification,
+ tiocmget->serial_state_notification,
sizeof(struct hso_serial_state_notification),
tiocmget_intr_callback, serial,
tiocmget->endp->bInterval);
@@ -1499,7 +1499,7 @@ static void tiocmget_intr_callback(struct urb *urb)
if (!tiocmget)
return;
usb = serial->parent->usb;
- serial_state_notification = &tiocmget->serial_state_notification;
+ serial_state_notification = tiocmget->serial_state_notification;
if (serial_state_notification->bmRequestType != BM_REQUEST_TYPE ||
serial_state_notification->bNotification != B_NOTIFICATION ||
le16_to_cpu(serial_state_notification->wValue) != W_VALUE ||
@@ -2608,6 +2608,7 @@ static void hso_free_tiomget(struct hso_serial *serial)
usb_free_urb(tiocmget->urb);
tiocmget->urb = NULL;
serial->tiocmget = NULL;
+ kfree(tiocmget->serial_state_notification);
kfree(tiocmget);
}
}
@@ -2664,6 +2665,13 @@ static struct hso_device *hso_create_bulk_serial_device(
*/
if (serial->tiocmget) {
tiocmget = serial->tiocmget;
+
+ tiocmget->serial_state_notification = kzalloc(
+ sizeof(struct hso_serial_state_notification),
+ GFP_KERNEL);
+ if (!tiocmget->serial_state_notification)
+ goto tiocmget_fail;
+
tiocmget->urb = usb_alloc_urb(0, GFP_KERNEL);
if (tiocmget->urb) {
mutex_init(&tiocmget->mutex);
@@ -2672,8 +2680,10 @@ static struct hso_device *hso_create_bulk_serial_device(
interface,
USB_ENDPOINT_XFER_INT,
USB_DIR_IN);
- } else
+ } else {
+tiocmget_fail:
hso_free_tiomget(serial);
+ }
}
}
else
--
To unsubscribe from this list: send the line "unsubscribe linux-usb" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
^ permalink raw reply related [flat|nested] 4+ messages in thread
* Re: [PATCH 1/2] net/usb: hso: allocate URB setup_packets as separate buffers
2013-08-07 13:29 [PATCH 1/2] net/usb: hso: allocate URB setup_packets as separate buffers Jussi Kivilinna
[not found] ` <20130807132902.14451.37517.stgit-bi+AKbBUZKagILUCTcTcHdKyNwTtLsGr@public.gmane.org>
@ 2013-08-07 15:46 ` Dan Williams
1 sibling, 0 replies; 4+ messages in thread
From: Dan Williams @ 2013-08-07 15:46 UTC (permalink / raw)
To: Jussi Kivilinna
Cc: netdev, Greg Kroah-Hartman, linux-usb, David S. Miller, Jan Dumon
On Wed, 2013-08-07 at 16:29 +0300, Jussi Kivilinna wrote:
> URB setup packets must not be allocated as part of larger structure because
> DMA coherence issues.
>
> Patch changes hso to allocate ctrl_req_[tr]x members of 'struct hso_serial'
> as separate buffers.
>
> Patch is only compile tested.
Tested-by: Dan Williams <dcbw@redhat.com>
> Cc: <stable@vger.kernel.org>
> Signed-off-by: Jussi Kivilinna <jussi.kivilinna@iki.fi>
> ---
> drivers/net/usb/hso.c | 18 ++++++++++++++----
> 1 file changed, 14 insertions(+), 4 deletions(-)
>
> diff --git a/drivers/net/usb/hso.c b/drivers/net/usb/hso.c
> index cba1d46..fc082c0 100644
> --- a/drivers/net/usb/hso.c
> +++ b/drivers/net/usb/hso.c
> @@ -237,8 +237,8 @@ struct hso_serial {
> u16 tx_data_length; /* should contain allocated length */
> u16 tx_data_count;
> u16 tx_buffer_count;
> - struct usb_ctrlrequest ctrl_req_tx;
> - struct usb_ctrlrequest ctrl_req_rx;
> + struct usb_ctrlrequest *ctrl_req_tx;
> + struct usb_ctrlrequest *ctrl_req_rx;
>
> struct usb_endpoint_descriptor *in_endp;
> struct usb_endpoint_descriptor *out_endp;
> @@ -1847,7 +1847,7 @@ static int hso_mux_serial_read(struct hso_serial *serial)
> USB_CDC_GET_ENCAPSULATED_RESPONSE,
> serial->parent->port_spec & HSO_PORT_MASK,
> serial->rx_urb[0],
> - &serial->ctrl_req_rx,
> + serial->ctrl_req_rx,
> serial->rx_data[0], serial->rx_data_length);
> }
>
> @@ -1916,7 +1916,7 @@ static int hso_mux_serial_write_data(struct hso_serial *serial)
> USB_CDC_SEND_ENCAPSULATED_COMMAND,
> serial->parent->port_spec & HSO_PORT_MASK,
> serial->tx_urb,
> - &serial->ctrl_req_tx,
> + serial->ctrl_req_tx,
> serial->tx_data, serial->tx_data_count);
> }
>
> @@ -2264,6 +2264,10 @@ static void hso_serial_common_free(struct hso_serial *serial)
> usb_free_urb(serial->tx_urb);
> kfree(serial->tx_data);
> tty_port_destroy(&serial->port);
> +
> + /* free control URB setup packet buffers */
> + kfree(serial->ctrl_req_tx);
> + kfree(serial->ctrl_req_rx);
> }
>
> static int hso_serial_common_create(struct hso_serial *serial, int num_urbs,
> @@ -2292,6 +2296,12 @@ static int hso_serial_common_create(struct hso_serial *serial, int num_urbs,
> spin_lock_init(&serial->serial_lock);
> serial->num_rx_urbs = num_urbs;
>
> + /* allocate control URB setup packet buffers */
> + serial->ctrl_req_tx = kzalloc(sizeof(*serial->ctrl_req_tx), GFP_KERNEL);
> + serial->ctrl_req_rx = kzalloc(sizeof(*serial->ctrl_req_rx), GFP_KERNEL);
> + if (!serial->ctrl_req_tx || !serial->ctrl_req_rx)
> + goto exit;
> +
> /* RX, allocate urb and initialize */
>
> /* prepare our RX buffer */
>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-usb" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH 2/2] net/usb: hso: allocate serial_state_notification as separate buffer
2013-08-07 13:29 ` [PATCH 2/2] net/usb: hso: allocate serial_state_notification as separate buffer Jussi Kivilinna
@ 2013-08-07 15:47 ` Dan Williams
0 siblings, 0 replies; 4+ messages in thread
From: Dan Williams @ 2013-08-07 15:47 UTC (permalink / raw)
To: Jussi Kivilinna
Cc: netdev, Greg Kroah-Hartman, linux-usb, David S. Miller, Jan Dumon
On Wed, 2013-08-07 at 16:29 +0300, Jussi Kivilinna wrote:
> URB transfer_buffers must not be allocated as part of larger structure because
> DMA coherence issues.
>
> Patch changes hso to allocate serial_state_notification member of
> 'struct hso_tiocmget' as separate buffer.
>
> Patch is only compile tested.
Tested-by: Dan Williams <dcbw@redhat.com>
> Cc: <stable@vger.kernel.org>
> Signed-off-by: Jussi Kivilinna <jussi.kivilinna@iki.fi>
> ---
> drivers/net/usb/hso.c | 18 ++++++++++++++----
> 1 file changed, 14 insertions(+), 4 deletions(-)
>
> diff --git a/drivers/net/usb/hso.c b/drivers/net/usb/hso.c
> index fc082c0..21ffa6f 100644
> --- a/drivers/net/usb/hso.c
> +++ b/drivers/net/usb/hso.c
> @@ -211,7 +211,7 @@ struct hso_tiocmget {
> int intr_completed;
> struct usb_endpoint_descriptor *endp;
> struct urb *urb;
> - struct hso_serial_state_notification serial_state_notification;
> + struct hso_serial_state_notification *serial_state_notification;
> u16 prev_UART_state_bitmap;
> struct uart_icount icount;
> };
> @@ -1465,7 +1465,7 @@ static int tiocmget_submit_urb(struct hso_serial *serial,
> usb_rcvintpipe(usb,
> tiocmget->endp->
> bEndpointAddress & 0x7F),
> - &tiocmget->serial_state_notification,
> + tiocmget->serial_state_notification,
> sizeof(struct hso_serial_state_notification),
> tiocmget_intr_callback, serial,
> tiocmget->endp->bInterval);
> @@ -1499,7 +1499,7 @@ static void tiocmget_intr_callback(struct urb *urb)
> if (!tiocmget)
> return;
> usb = serial->parent->usb;
> - serial_state_notification = &tiocmget->serial_state_notification;
> + serial_state_notification = tiocmget->serial_state_notification;
> if (serial_state_notification->bmRequestType != BM_REQUEST_TYPE ||
> serial_state_notification->bNotification != B_NOTIFICATION ||
> le16_to_cpu(serial_state_notification->wValue) != W_VALUE ||
> @@ -2608,6 +2608,7 @@ static void hso_free_tiomget(struct hso_serial *serial)
> usb_free_urb(tiocmget->urb);
> tiocmget->urb = NULL;
> serial->tiocmget = NULL;
> + kfree(tiocmget->serial_state_notification);
> kfree(tiocmget);
> }
> }
> @@ -2664,6 +2665,13 @@ static struct hso_device *hso_create_bulk_serial_device(
> */
> if (serial->tiocmget) {
> tiocmget = serial->tiocmget;
> +
> + tiocmget->serial_state_notification = kzalloc(
> + sizeof(struct hso_serial_state_notification),
> + GFP_KERNEL);
> + if (!tiocmget->serial_state_notification)
> + goto tiocmget_fail;
> +
> tiocmget->urb = usb_alloc_urb(0, GFP_KERNEL);
> if (tiocmget->urb) {
> mutex_init(&tiocmget->mutex);
> @@ -2672,8 +2680,10 @@ static struct hso_device *hso_create_bulk_serial_device(
> interface,
> USB_ENDPOINT_XFER_INT,
> USB_DIR_IN);
> - } else
> + } else {
> +tiocmget_fail:
> hso_free_tiomget(serial);
> + }
> }
> }
> else
>
> --
> To unsubscribe from this list: send the line "unsubscribe netdev" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2013-08-07 15:43 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2013-08-07 13:29 [PATCH 1/2] net/usb: hso: allocate URB setup_packets as separate buffers Jussi Kivilinna
[not found] ` <20130807132902.14451.37517.stgit-bi+AKbBUZKagILUCTcTcHdKyNwTtLsGr@public.gmane.org>
2013-08-07 13:29 ` [PATCH 2/2] net/usb: hso: allocate serial_state_notification as separate buffer Jussi Kivilinna
2013-08-07 15:47 ` Dan Williams
2013-08-07 15:46 ` [PATCH 1/2] net/usb: hso: allocate URB setup_packets as separate buffers Dan Williams
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).