Skip to content

Commit

Permalink
USB: serial: omninet: clean up port setup
Browse files Browse the repository at this point in the history
These devices use the second bulk-out endpoint for writing. Instead of
using the resources of the second port structure setup by core, use the
new endpoint-remap functionality to simply ignore the first bulk-out
endpoint. This specifically avoids allocating resources for the unused
endpoint.

Note that the disconnect callback was always redundant as all URBs would
have been killed by USB core on disconnect.

Signed-off-by: Johan Hovold <johan@kernel.org>
  • Loading branch information
Johan Hovold committed Mar 28, 2017
1 parent 9525402 commit 2dc1071
Showing 1 changed file with 21 additions and 26 deletions.
47 changes: 21 additions & 26 deletions drivers/usb/serial/omninet.c
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,8 @@ static void omninet_write_bulk_callback(struct urb *urb);
static int omninet_write(struct tty_struct *tty, struct usb_serial_port *port,
const unsigned char *buf, int count);
static int omninet_write_room(struct tty_struct *tty);
static void omninet_disconnect(struct usb_serial *serial);
static int omninet_calc_num_ports(struct usb_serial *serial,
struct usb_serial_endpoints *epds);
static int omninet_port_probe(struct usb_serial_port *port);
static int omninet_port_remove(struct usb_serial_port *port);

Expand All @@ -54,15 +55,14 @@ static struct usb_serial_driver zyxel_omninet_device = {
},
.description = "ZyXEL - omni.net lcd plus usb",
.id_table = id_table,
.num_ports = 1,
.num_bulk_out = 2,
.calc_num_ports = omninet_calc_num_ports,
.port_probe = omninet_port_probe,
.port_remove = omninet_port_remove,
.write = omninet_write,
.write_room = omninet_write_room,
.write_bulk_callback = omninet_write_bulk_callback,
.process_read_urb = omninet_process_read_urb,
.disconnect = omninet_disconnect,
};

static struct usb_serial_driver * const serial_drivers[] = {
Expand Down Expand Up @@ -103,6 +103,16 @@ struct omninet_data {
__u8 od_outseq; /* Sequence number for bulk_out URBs */
};

static int omninet_calc_num_ports(struct usb_serial *serial,
struct usb_serial_endpoints *epds)
{
/* We need only the second bulk-out for our single-port device. */
epds->bulk_out[0] = epds->bulk_out[1];
epds->num_bulk_out = 1;

return 1;
}

static int omninet_port_probe(struct usb_serial_port *port)
{
struct omninet_data *od;
Expand Down Expand Up @@ -150,13 +160,9 @@ static void omninet_process_read_urb(struct urb *urb)
static int omninet_write(struct tty_struct *tty, struct usb_serial_port *port,
const unsigned char *buf, int count)
{
struct usb_serial *serial = port->serial;
struct usb_serial_port *wport = serial->port[1];

struct omninet_data *od = usb_get_serial_port_data(port);
struct omninet_header *header = (struct omninet_header *)
wport->write_urb->transfer_buffer;

port->write_urb->transfer_buffer;
int result;

if (count == 0) {
Expand All @@ -171,23 +177,23 @@ static int omninet_write(struct tty_struct *tty, struct usb_serial_port *port,

count = (count > OMNINET_PAYLOADSIZE) ? OMNINET_PAYLOADSIZE : count;

memcpy(wport->write_urb->transfer_buffer + OMNINET_HEADERLEN,
memcpy(port->write_urb->transfer_buffer + OMNINET_HEADERLEN,
buf, count);

usb_serial_debug_data(&port->dev, __func__, count,
wport->write_urb->transfer_buffer);
port->write_urb->transfer_buffer);

header->oh_seq = od->od_outseq++;
header->oh_len = count;
header->oh_xxx = 0x03;
header->oh_pad = 0x00;

/* send the data out the bulk port, always 64 bytes */
wport->write_urb->transfer_buffer_length = OMNINET_BULKOUTSIZE;
port->write_urb->transfer_buffer_length = OMNINET_BULKOUTSIZE;

result = usb_submit_urb(wport->write_urb, GFP_ATOMIC);
result = usb_submit_urb(port->write_urb, GFP_ATOMIC);
if (result) {
set_bit(0, &wport->write_urbs_free);
set_bit(0, &port->write_urbs_free);
dev_err_console(port,
"%s - failed submitting write urb, error %d\n",
__func__, result);
Expand All @@ -201,13 +207,10 @@ static int omninet_write(struct tty_struct *tty, struct usb_serial_port *port,
static int omninet_write_room(struct tty_struct *tty)
{
struct usb_serial_port *port = tty->driver_data;
struct usb_serial *serial = port->serial;
struct usb_serial_port *wport = serial->port[1];

int room = 0; /* Default: no room */

if (test_bit(0, &wport->write_urbs_free))
room = wport->bulk_out_size - OMNINET_HEADERLEN;
if (test_bit(0, &port->write_urbs_free))
room = port->bulk_out_size - OMNINET_HEADERLEN;

dev_dbg(&port->dev, "%s - returns %d\n", __func__, room);

Expand All @@ -231,14 +234,6 @@ static void omninet_write_bulk_callback(struct urb *urb)
usb_serial_port_softint(port);
}


static void omninet_disconnect(struct usb_serial *serial)
{
struct usb_serial_port *wport = serial->port[1];

usb_kill_urb(wport->write_urb);
}

module_usb_serial_driver(serial_drivers, id_table);

MODULE_AUTHOR(DRIVER_AUTHOR);
Expand Down

0 comments on commit 2dc1071

Please sign in to comment.