Received: by 2002:a05:6358:489b:b0:bb:da1:e618 with SMTP id x27csp2160107rwn; Fri, 9 Sep 2022 09:18:02 -0700 (PDT) X-Google-Smtp-Source: AA6agR7jeLKo0Mc84Hns8f33mYWq54qf11hQa6wujrH/X+rf2ao/Za3whAITRQ2RAjpTUs2UaZjt X-Received: by 2002:a17:907:1ca9:b0:741:4f9a:5984 with SMTP id nb41-20020a1709071ca900b007414f9a5984mr10540769ejc.86.1662740282520; Fri, 09 Sep 2022 09:18:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1662740282; cv=none; d=google.com; s=arc-20160816; b=JeXvHBu47jx8RXNxKObGC4sVAvRv/UUqAKKiMXFZNJwFmWXsclr5Y79MTvbGLzX/7n 3rU2hewEZq8ySxEoK7ae5Oc0jiMIAtVCz4GeRgTE19GliWv58c5uIMgjKg0vtC6Z+Ww2 t8wJTSWkN0xxdGKq7QqZBupDB05JgyE+m5LeQkFExqGYZ/cHH6S8s0r2Zx7IKuuzstWI HLTXcj6o7jWoweXFGxXz64MoZQwrsN3wWX6zoRNEcAANvZR4zczYIBNI6tA3yv29mJmK c4jnapECydjT7lJfON7cSxZUm6f8gqzu6HV6oHUHwZdGosYwUKp7rGsF+LDBANWGx4Y+ D03g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=3nHT9uBcMm+Mg6mZ509Ukrc3RClGASZLYFpwg58jTGE=; b=dA6vzBqtAAeLM6lRS74Ki/hQ5pUCs2G2tHZatT6bIEAik7CkGGTjDGdeFSOLLOFS8K UiGRusQzze9xX7qN9qd/vrcEha8wRVA8oIJMF31GCqKobfF0CYaGPYIYsNUAt0DQA9RK 8xuj6w/3yRXjsD9qiwti0HUCxg3yhaXChhhOwfawVwcrURktRvka3NzZKjcmPJUf1Vpv YYBVD+zoACDED+EAiuZ3/TIyNofTO+Vypuq63gbvJtEhonsA6/cu1k9vI8DnTmFMxGo1 JWIKw0f+McMEDyLTc1F0cfDTjAe/pMGfvzYTmjPZCuqGf33Ik4spdIA9GcTpYaf4XRJq KUeA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@cirrus.com header.s=PODMain02222019 header.b=q44sG+gY; 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=REJECT sp=REJECT dis=NONE) header.from=cirrus.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id i17-20020a05640242d100b0044699451386si995944edc.9.2022.09.09.09.17.36; Fri, 09 Sep 2022 09:18:02 -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=@cirrus.com header.s=PODMain02222019 header.b=q44sG+gY; 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=REJECT sp=REJECT dis=NONE) header.from=cirrus.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231759AbiIIP5b (ORCPT + 99 others); Fri, 9 Sep 2022 11:57:31 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44472 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231348AbiIIP5Y (ORCPT ); Fri, 9 Sep 2022 11:57:24 -0400 Received: from mx0b-001ae601.pphosted.com (mx0b-001ae601.pphosted.com [67.231.152.168]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 78B0811B00B; Fri, 9 Sep 2022 08:57:18 -0700 (PDT) Received: from pps.filterd (m0077474.ppops.net [127.0.0.1]) by mx0b-001ae601.pphosted.com (8.17.1.5/8.17.1.5) with ESMTP id 2896qFNo009110; Fri, 9 Sep 2022 10:55:49 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=cirrus.com; h=message-id : date : mime-version : subject : to : cc : references : from : in-reply-to : content-type : content-transfer-encoding; s=PODMain02222019; bh=3nHT9uBcMm+Mg6mZ509Ukrc3RClGASZLYFpwg58jTGE=; b=q44sG+gY/lsPHBrCOUP9ij9NNoi6qLerKsYnCAC1xTgMMribA0s/oERPxSBmAN0mndrq PQLuwqJXl8iJxn8J7bM2LLSiSBLYB2Yrt9O+jdjw0B7ziPc+ESoK3mmRwm3Lddoqgu+p PBFm6W2lVIGndfsEFK6aA+YOmaN7QG9eqoMDZgmamGRXJu4rPCiP2695debKqeW0H6Sd 2qyIiCz7Xk/WxHl0KIfYjlmUNoCo8RNcJhCygFPMbyaL4Gjm8/QjA5oLqSBpHPvO1nPe BM/iOsk5/bXiplWteN8UMeZe+18u8CV+CUwNSx2CqoccqJYX7BANkxhtV7bR5TNpza8a 3w== Received: from ediex01.ad.cirrus.com ([84.19.233.68]) by mx0b-001ae601.pphosted.com (PPS) with ESMTPS id 3jc3bq1774-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Fri, 09 Sep 2022 10:55:49 -0500 Received: from ediex02.ad.cirrus.com (198.61.84.81) by ediex01.ad.cirrus.com (198.61.84.80) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.1118.12; Fri, 9 Sep 2022 10:55:48 -0500 Received: from ediswmail.ad.cirrus.com (198.61.86.93) by anon-ediex02.ad.cirrus.com (198.61.84.81) with Microsoft SMTP Server id 15.2.1118.12 via Frontend Transport; Fri, 9 Sep 2022 10:55:48 -0500 Received: from [198.90.251.95] (edi-sw-dsktp-006.ad.cirrus.com [198.90.251.95]) by ediswmail.ad.cirrus.com (Postfix) with ESMTP id 87CF72C5; Fri, 9 Sep 2022 15:55:41 +0000 (UTC) Message-ID: <20342329-8525-9081-e1c1-f67067883c72@opensource.cirrus.com> Date: Fri, 9 Sep 2022 16:55:41 +0100 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.12.0 Subject: Re: [PATCH 04/10] ASoC: cs42l42: Split probe() and remove() into stages Content-Language: en-US To: =?UTF-8?Q?Martin_Povi=c5=a1er?= , James Schulman , David Rhodes , "Lucas Tanure" , Liam Girdwood , Mark Brown , Rob Herring , "Krzysztof Kozlowski" , Jaroslav Kysela , Takashi Iwai CC: Charles Keepax , ChiYuan Huang , Pierre-Louis Bossart , Lukas Bulwahn , Matt Flax , - , , , , References: <20220909135334.98220-1-povik+lin@cutebit.org> <20220909135334.98220-5-povik+lin@cutebit.org> From: Richard Fitzgerald In-Reply-To: <20220909135334.98220-5-povik+lin@cutebit.org> Content-Type: text/plain; charset="UTF-8"; format=flowed Content-Transfer-Encoding: 8bit X-Proofpoint-GUID: sCliLYKo1kOmkbqQ3fdYLmEc-YZZcr8n X-Proofpoint-ORIG-GUID: sCliLYKo1kOmkbqQ3fdYLmEc-YZZcr8n X-Proofpoint-Spam-Reason: safe X-Spam-Status: No, score=-4.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_EF,NICE_REPLY_A,RCVD_IN_DNSWL_NONE,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 On 09/09/2022 14:53, Martin PoviĊĦer wrote: > +static int cs42l42_init(struct cs42l42_private *cs42l42) > +{ > + unsigned int reg; > + int devid, ret; > + > /* initialize codec */ > devid = cirrus_read_device_id(cs42l42->regmap, CS42L42_DEVID_AB); > if (devid < 0) { > @@ -2320,15 +2331,15 @@ static int cs42l42_i2c_probe(struct i2c_client *i2c_client) > /* Setup headset detection */ > cs42l42_setup_hs_type_detect(cs42l42); > > + /* > + * Set init_done before unmasking interrupts so any triggered > + * immediately will be handled. > + */ > + cs42l42->init_done = true; > + > /* Mask/Unmask Interrupts */ > cs42l42_set_interrupt_masks(cs42l42); > > - /* Register codec for machine driver */ > - ret = devm_snd_soc_register_component(cs42l42->dev, > - &soc_component_dev_cs42l42, &cs42l42_dai, 1); > - if (ret < 0) > - goto err_shutdown; > - > return 0; > > err_shutdown: > @@ -2337,34 +2348,69 @@ static int cs42l42_i2c_probe(struct i2c_client *i2c_client) > regmap_write(cs42l42->regmap, CS42L42_PWR_CTL1, 0xff); > > err_disable: > - if (i2c_client->irq) > - free_irq(i2c_client->irq, cs42l42); > - These 3 lines should not be removed. cs42l42_init() must free the irq in the error paths.