Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp3616318pxj; Mon, 24 May 2021 10:38:08 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzf5y7Aq10/x6cU93hL5OAIGdqAQlDNZ+BICgYoyI1g7OPgH0SNafVeYLo8IYj80Kj9xEJ4 X-Received: by 2002:a05:6e02:1b8f:: with SMTP id h15mr17265298ili.151.1621877887990; Mon, 24 May 2021 10:38:07 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1621877887; cv=none; d=google.com; s=arc-20160816; b=suJ6rc85e/QDf36V+OGY0NNz2071C9dg1RpfkfJxsU1JCk1OCqq145Z2mLST1EUPyy 4oAMEpUPVGJN6xs3EszrkSyPvv9/0phcPGdwhg5x8LtfSuclJ0GgQzL98AqoigizvxPF 1MbCwKGgyF8mtFcaKW5bWAzBKuf+S1IwxBbeYvF6D154DMgAvMDEbV8noHU1pfdOAaYg YpXtLz7UE6I16HOrxkI+6dCcXdpMV4RBmN+vGw0J6TtlRbQ5dc6ojBO97m62LmqXdEKy 9DybiNY0OaoLp3N0c4FM6UfLGBZ8A+RvtBn3WK1hNW9IS1vl1BC2nfg1S3zXnkDmuxj1 UimQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-disposition:mime-version:message-id :subject:cc:to:from:date:dkim-signature; bh=aE0iQJWz3axz8pF6095x9rK/n7tnpnSurvnaFSIQj8o=; b=Ne56JJLVUNFsXjLvHEyAPdljLYOJLIjDFjWv0Tpr0UHGsPjVTGkGRIOYHs7kb0f3tK oNoMy0eEfkSvhqlW2mN7TyIc8HFPcDzDb9E0+0nXuN7vyCX543CselryiORLJMNeYm4j UVsu5GOjuqan+Z12PXyxF1nvPZ3P8DhGnnFlkeFHzWEo3O1RaSxUmjt8vZpi8/qa6I2w nQgFBN+2lqjMnWK55kZfkgJaCYKvKAUFGN8nc3DTO/YndmlfvAP4Qr96GCA+WCgq72+L DmJIf2HYwWnJmkesMpQVT9pV5MvyBQ1LmTULjOrX5zmoQ7Utyq55lry9UyqWKeN2/P5n 2O0w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=YrXVnXcf; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id p31si16904205jac.95.2021.05.24.10.37.54; Mon, 24 May 2021 10:38:07 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=YrXVnXcf; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233358AbhEXRiU (ORCPT + 99 others); Mon, 24 May 2021 13:38:20 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46834 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232983AbhEXRiU (ORCPT ); Mon, 24 May 2021 13:38:20 -0400 Received: from mail-pf1-x432.google.com (mail-pf1-x432.google.com [IPv6:2607:f8b0:4864:20::432]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id CD71DC061574 for ; Mon, 24 May 2021 10:36:50 -0700 (PDT) Received: by mail-pf1-x432.google.com with SMTP id f22so13024921pfn.0 for ; Mon, 24 May 2021 10:36:50 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=date:from:to:cc:subject:message-id:mime-version:content-disposition; bh=aE0iQJWz3axz8pF6095x9rK/n7tnpnSurvnaFSIQj8o=; b=YrXVnXcfSwt5QnDj262YSEd1ENwB6g2QmZoeEPKL1B5oEsiw1CjPy6y6051sv0xpEj Y1cCdF2vpziIlWYbZAhQZiWqoRQ9OtIqHDiPWA6/bRFJMuASR+rqJ5ul27u9bBwY1XHa edFpnnTOq8KOg7KlV5w28fEXxyL/7icCBymLEEmJ7koo9Hl/ng3IE59lF60hBekYwTrB tqU1MlDrpB/h+gwF1PNg14aAghJt3iaQxGAtZfwyb7PiI98NX5ljM/sl344mCGZeRnEk pc/z5gXcgpGXNFUfw4mX2pMI1fqt6Y/e6r4rSHiBcUFigkCA4vI0e/Uhe8ICvz0Oc4Tz C0gA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:mime-version :content-disposition; bh=aE0iQJWz3axz8pF6095x9rK/n7tnpnSurvnaFSIQj8o=; b=o9rE6CVnv5GJfLLw3KmNqsLCLIB46hs+74e6ENlZgsLjo0yKA/iCg/97oFiGAJbZ2h O8yfVCVaHzfzmPnUIsj18TGgiT4XVfl6x6tQUbi6f+sgf84mOeoa1hD39hLYzQAQwwaw /QPLoiyiY45CynSje8AG/Ehn1YZHFQiLNQztlMqGBLOHPY/rkxixbo/+AbSZ6d7LabNS ViZmAfW+rctpDABzNvl6vwWwPeHGSRuHShyRfLtXE7JEMJfRoMxaCb1NombVu4qWJvVx ImmThyI6wN3wPJtyik3jTByW4Xe7MaPAB1SzhlaV6clYMyNQF+eew+JjoSmWL7ZsVZ0X KPUQ== X-Gm-Message-State: AOAM532o2lKkOnKCMyQ6lqzu1mwkx8qSCEgiuXqui+sBpFuRoAnlEe4f YkgHnfAla08LvAfQ27eqrX8= X-Received: by 2002:a62:d0c2:0:b029:2d9:529f:f4ef with SMTP id p185-20020a62d0c20000b02902d9529ff4efmr26270999pfg.41.1621877810401; Mon, 24 May 2021 10:36:50 -0700 (PDT) Received: from hyeyoo ([183.99.11.150]) by smtp.gmail.com with ESMTPSA id x29sm11951643pgl.49.2021.05.24.10.36.47 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 24 May 2021 10:36:49 -0700 (PDT) Date: Tue, 25 May 2021 02:36:44 +0900 From: Hyeonggon Yoo <42.hyeyoo@gmail.com> To: Jaroslav Kysela , Takashi Iwai , Greg Kroah-Hartman , Hyeonggon Yoo <42.hyeyoo@gmail.com>, Oliver Neukum , Vasily Khoruzhick Cc: alsa-devel@alsa-project.org, linux-kernel@vger.kernel.org Subject: [PATCH] ALSA: line6: Improve poor error handling in line6_init_cap_control Message-ID: <20210524173644.GA116662@hyeyoo> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org line6_init_cap_control doesn't free resources properly when allocations like kmalloc, usb_alloc_urb fails. It can cause memory leak when some allocations succeed, and then an error occurs. This patch makes line6_init_cap_control to properly free the resources, freeing previously allocated resources when there's an error. Signed-off-by: Hyeonggon Yoo <42.hyeyoo@gmail.com> --- sound/usb/line6/driver.c | 36 +++++++++++++++++++++++++++--------- 1 file changed, 27 insertions(+), 9 deletions(-) diff --git a/sound/usb/line6/driver.c b/sound/usb/line6/driver.c index 9602929b7de9..6991cb855023 100644 --- a/sound/usb/line6/driver.c +++ b/sound/usb/line6/driver.c @@ -688,34 +688,52 @@ static int line6_init_cap_control(struct usb_line6 *line6) /* initialize USB buffers: */ line6->buffer_listen = kmalloc(LINE6_BUFSIZE_LISTEN, GFP_KERNEL); - if (!line6->buffer_listen) - return -ENOMEM; + if (!line6->buffer_listen) { + ret = -ENOMEM; + goto fail_ret; + } line6->urb_listen = usb_alloc_urb(0, GFP_KERNEL); - if (!line6->urb_listen) - return -ENOMEM; + if (!line6->urb_listen) { + ret = -ENOMEM; + goto fail1; + } if (line6->properties->capabilities & LINE6_CAP_CONTROL_MIDI) { line6->buffer_message = kmalloc(LINE6_MIDI_MESSAGE_MAXLEN, GFP_KERNEL); - if (!line6->buffer_message) - return -ENOMEM; + if (!line6->buffer_message) { + ret = -ENOMEM; + goto fail2; + } ret = line6_init_midi(line6); if (ret < 0) - return ret; + goto fail3; } else { ret = line6_hwdep_init(line6); if (ret < 0) - return ret; + goto fail2; } ret = line6_start_listen(line6); if (ret < 0) { dev_err(line6->ifcdev, "cannot start listening: %d\n", ret); - return ret; + if (line6->properties->capabilities & LINE6_CAP_CONTROL_MIDI) + goto fail3; + else + goto fail2; } return 0; + +fail3: + kfree(line6->buffer_message); +fail2: + usb_free_urb(line6->urb_listen); +fail1: + kfree(line6->buffer_listen); +fail_ret: + return ret; } static void line6_startup_work(struct work_struct *work) -- 2.25.1