Storing a memory pointer consumes 4 or 8 bytes, depending on the architecture. The replaced buffers are 2 bytes, so this change not only avoids the overhead of memory allocation, but it also saves a small amount of stack storage. Signed-off-by: Michael Hanselmann <public@xxxxxxxxx> --- drivers/usb/serial/ch341.c | 32 ++++++++------------------------ 1 file changed, 8 insertions(+), 24 deletions(-) diff --git a/drivers/usb/serial/ch341.c b/drivers/usb/serial/ch341.c index c5ecdcd51ffc..6875da6e746c 100644 --- a/drivers/usb/serial/ch341.c +++ b/drivers/usb/serial/ch341.c @@ -255,16 +255,11 @@ static int ch341_set_handshake(struct usb_device *dev, u8 control) static int ch341_get_status(struct usb_device *dev, struct ch341_private *priv) { - const unsigned int size = 2; - char *buffer; + char buffer[2]; int r; unsigned long flags; - buffer = kmalloc(size, GFP_KERNEL); - if (!buffer) - return -ENOMEM; - - r = ch341_control_in(dev, CH341_REQ_READ_REG, 0x0706, 0, buffer, size); + r = ch341_control_in(dev, CH341_REQ_READ_REG, 0x0706, 0, buffer, sizeof(buffer)); if (r < 0) goto out; @@ -272,7 +267,7 @@ static int ch341_get_status(struct usb_device *dev, struct ch341_private *priv) priv->msr = (~(*buffer)) & CH341_BITS_MODEM_STAT; spin_unlock_irqrestore(&priv->lock, flags); -out: kfree(buffer); +out: return r; } @@ -280,16 +275,11 @@ out: kfree(buffer); static int ch341_configure(struct usb_device *dev, struct ch341_private *priv) { - const unsigned int size = 2; - char *buffer; + char buffer[2]; int r; - buffer = kmalloc(size, GFP_KERNEL); - if (!buffer) - return -ENOMEM; - /* expect two bytes 0x27 0x00 */ - r = ch341_control_in(dev, CH341_REQ_READ_VERSION, 0, 0, buffer, size); + r = ch341_control_in(dev, CH341_REQ_READ_VERSION, 0, 0, buffer, sizeof(buffer)); if (r < 0) goto out; dev_dbg(&dev->dev, "Chip version: 0x%02x\n", buffer[0]); @@ -304,7 +294,7 @@ static int ch341_configure(struct usb_device *dev, struct ch341_private *priv) r = ch341_set_handshake(dev, priv->mcr); -out: kfree(buffer); +out: return r; } @@ -486,18 +476,14 @@ static void ch341_break_ctl(struct tty_struct *tty, int break_state) struct usb_serial_port *port = tty->driver_data; int r; uint16_t reg_contents; - uint8_t *break_reg; - - break_reg = kmalloc(2, GFP_KERNEL); - if (!break_reg) - return; + uint8_t break_reg[2]; r = ch341_control_in(port->serial->dev, CH341_REQ_READ_REG, ch341_break_reg, 0, break_reg, 2); if (r < 0) { dev_err(&port->dev, "%s - USB control read error (%d)\n", __func__, r); - goto out; + return; } dev_dbg(&port->dev, "%s - initial ch341 break register contents - reg1: %x, reg2: %x\n", __func__, break_reg[0], break_reg[1]); @@ -518,8 +504,6 @@ static void ch341_break_ctl(struct tty_struct *tty, int break_state) if (r < 0) dev_err(&port->dev, "%s - USB control write error (%d)\n", __func__, r); -out: - kfree(break_reg); } static int ch341_tiocmset(struct tty_struct *tty, -- 2.20.1