Received: by 2002:a05:6a10:6d10:0:0:0:0 with SMTP id gq16csp3942145pxb; Tue, 19 Apr 2022 13:09:09 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwREfz+WaIOEQBVZAQ8sEk0X/l4Uj9VccgYmYx4BCt5dNZWiszG8E6jCxxNCfHX4vbMX5As X-Received: by 2002:a17:90b:3141:b0:1d2:9346:643b with SMTP id ip1-20020a17090b314100b001d29346643bmr290585pjb.125.1650398949442; Tue, 19 Apr 2022 13:09:09 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1650398949; cv=none; d=google.com; s=arc-20160816; b=TWOMiiMSjxiKYVlfHHeAj+oo8UQ1MkZYFebZLzq61GKsHr2XroWaUuc1qlj4kcoeLG Qjvtn9VentrdMirCcsENovsuT/JUWnQV6iQKZ6FitY1/h3OqVMTTIyQncLCpnydOapq/ WWtHhe3gfiMbhuVcpkungNb4TCvpofLASwLbqDlk06HYHE+UqMW9upzib/Vlpjk+LIuh Fro20qdNj8WOijCs9foFta91/A5wcO8IPwCYKxBzf6Y+AVPwUh0ZCXL9qCL+OKEAYhes eEhb5dt7ZroA9LOAYM8ZWea63EY7LzHeW2rn/fRdksQ0b0dxvagEaHupaY4rOrP1mYtg bWWg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=0FW9ej73Ju/nbZoxKEfpamc4LQmyF9G4wEBQy+GjUlc=; b=VBCU4YCSGewkpwIygw1dzYgHVJiGpoVx/b1ghQ9LnDAfsoqnnjo2QAgFsmqvWHgsn2 73cpjLZYH3/aSrz307yP61175uxL/IHdfSZDLF04R3xH0eg8WjavLqtpEHKkxmuIEIab CiB9iqSKUAd/qatNth2+p+SmIcg/7qpd+meN7jGO5PD4C1J9DJB0ksxRRpG/v6+r7hvL yLoSGuS/UHaQp+T2Kpm3pxO8h/inZPyTIVIGivtAZ7gOpnm3FMVhG4mVlbOZ66CdpWrG vtkSWXocDch1r+w7ZvjHPVawcUcCafxMs6y8+BsVs5YHxkKx+t6ClAfY0E9CHI+O1Jl4 PBcQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=cTZwfQvW; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id z6-20020a1709027e8600b00156b8ab0398si234311pla.203.2022.04.19.13.08.43; Tue, 19 Apr 2022 13:09:09 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=cTZwfQvW; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S239620AbiDRMqf (ORCPT + 99 others); Mon, 18 Apr 2022 08:46:35 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40062 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S239736AbiDRMiD (ORCPT ); Mon, 18 Apr 2022 08:38:03 -0400 Received: from ams.source.kernel.org (ams.source.kernel.org [IPv6:2604:1380:4601:e00::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 33A9F23BDB; Mon, 18 Apr 2022 05:28:32 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ams.source.kernel.org (Postfix) with ESMTPS id EB8A2B80EC4; Mon, 18 Apr 2022 12:28:30 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 13289C385A7; Mon, 18 Apr 2022 12:28:28 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1650284909; bh=6yRikiXgifF7TJwpdBeWfSQIjgxtM8EHGIus7nzIZwQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=cTZwfQvWqXZzB5om1DgoolE5RY//vW4PhXmNCcWrnabTSfdOEEqLtGK6F6ppX22K6 BZAKYU9LNoFke0wGkjBMLy3qYA0bvWm1tu7Q9hKKkSyHQZV22LHVxvP5Eg+3gKfjmH ZLnL3e1Bi7oipBYIH3TkNnKe8kOboOAIkyZGY3RE= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Takashi Iwai Subject: [PATCH 5.15 045/189] ALSA: maestro3: Fix the missing snd_card_free() call at probe error Date: Mon, 18 Apr 2022 14:11:05 +0200 Message-Id: <20220418121201.792916152@linuxfoundation.org> X-Mailer: git-send-email 2.35.3 In-Reply-To: <20220418121200.312988959@linuxfoundation.org> References: <20220418121200.312988959@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-7.7 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Takashi Iwai commit ae86bf5c2a8d81418eadf1c31dd9253b609e3093 upstream. The previous cleanup with devres may lead to the incorrect release orders at the probe error handling due to the devres's nature. Until we register the card, snd_card_free() has to be called at first for releasing the stuff properly when the driver tries to manage and release the stuff via card->private_free(). This patch fixes it by calling snd_card_free() on the error from the probe callback using a new helper function. Fixes: 5c0939253c3c ("ALSA: maestro3: Allocate resources with device-managed APIs") Cc: Link: https://lore.kernel.org/r/20220412102636.16000-21-tiwai@suse.de Signed-off-by: Takashi Iwai Signed-off-by: Greg Kroah-Hartman --- sound/pci/maestro3.c | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/sound/pci/maestro3.c b/sound/pci/maestro3.c index 056838ead21d..261850775c80 100644 --- a/sound/pci/maestro3.c +++ b/sound/pci/maestro3.c @@ -2637,7 +2637,7 @@ snd_m3_create(struct snd_card *card, struct pci_dev *pci, /* */ static int -snd_m3_probe(struct pci_dev *pci, const struct pci_device_id *pci_id) +__snd_m3_probe(struct pci_dev *pci, const struct pci_device_id *pci_id) { static int dev; struct snd_card *card; @@ -2702,6 +2702,12 @@ snd_m3_probe(struct pci_dev *pci, const struct pci_device_id *pci_id) return 0; } +static int +snd_m3_probe(struct pci_dev *pci, const struct pci_device_id *pci_id) +{ + return snd_card_free_on_error(&pci->dev, __snd_m3_probe(pci, pci_id)); +} + static struct pci_driver m3_driver = { .name = KBUILD_MODNAME, .id_table = snd_m3_ids, -- 2.35.2