Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp742338ybz; Wed, 15 Apr 2020 17:59:31 -0700 (PDT) X-Google-Smtp-Source: APiQypK2+PZZsJ4NlTarWXBlB607sCzOG3J5EHfrWJXk/DBDONCksVWigttAiSJ8aLv2uhCYQYQq X-Received: by 2002:a17:906:2b93:: with SMTP id m19mr7262853ejg.98.1586998770900; Wed, 15 Apr 2020 17:59:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586998770; cv=none; d=google.com; s=arc-20160816; b=slSInvawy7mKVEddOxw8wk5tjei2j9Uk6GpdCYgP5zygLU6TsGW/FsYswJgGZCn7sK lXnPtVCAYwZ9LBjSNTxU3CORhHwrZ0Ul/kIma2yJbpgc6njcaJBpX53cMzZp4tiF4UHV n7UczOGbZMBUTnPoX9qk4leHHqyUFfyvNDtNOrXekCj7t+vFn9Spz+DJaUZxF+D4wJq2 Qg3PA/YVcXTDAMnFz6t8Mcqtd/DWNhrBJUbzPskpIcN2hkuP1GV7jYngLxEwk/kmp0QU qsYRIn7uZ80/NOtUm3eEz3CuX1efg0QVtw6aP0fpRpRmHNdRTEe7bRFjejitB+oINmn+ 10vQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:dkim-signature:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:references:cc:to:from:subject; bh=SfIrbeIJ0Y7jZYhtTExZYIBHwkMpVtO0fMxSlIp8gmA=; b=tQ7nIqJzv5luR0P8tfUC6/p2SpIMm/rMhNrM/VcAr0atcX9QRbhVDJWWjh/qakKyiA s1oS8YoON/l4SSoJMCwXR40B88cBfL59qdViAtE6h/bBjbOMi7UxHh7UOKs+nJStUKcT lJOu7qW+XhZkRx24VX3AGu2/hMS33PhKZMNWaO3KPZENz9S3PdF1ck0sok5OKNCykEbu B6CMMgKOSnByBUG1LL8emz8HAs+TX100Z/f2yMhcPYRBNJBkuv+rItzkUcOSj6la7tm3 SLJudoFMPeKSM3yy26IhsHKow7zWbEBmGitMpQaZhffjsAoIku7qM/f9XGWj8aDjTfsJ SQXw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@nvidia.com header.s=n1 header.b=F0ocN5+J; 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=NONE dis=NONE) header.from=nvidia.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id g7si11467312edk.195.2020.04.15.17.59.07; Wed, 15 Apr 2020 17:59:30 -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=@nvidia.com header.s=n1 header.b=F0ocN5+J; 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=NONE dis=NONE) header.from=nvidia.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2441694AbgDOTOI (ORCPT + 99 others); Wed, 15 Apr 2020 15:14:08 -0400 Received: from hqnvemgate25.nvidia.com ([216.228.121.64]:6621 "EHLO hqnvemgate25.nvidia.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1416876AbgDOSxx (ORCPT ); Wed, 15 Apr 2020 14:53:53 -0400 Received: from hqpgpgate101.nvidia.com (Not Verified[216.228.121.13]) by hqnvemgate25.nvidia.com (using TLS: TLSv1.2, DES-CBC3-SHA) id ; Wed, 15 Apr 2020 11:52:54 -0700 Received: from hqmail.nvidia.com ([172.20.161.6]) by hqpgpgate101.nvidia.com (PGP Universal service); Wed, 15 Apr 2020 11:53:53 -0700 X-PGP-Universal: processed; by hqpgpgate101.nvidia.com on Wed, 15 Apr 2020 11:53:53 -0700 Received: from DRHQMAIL107.nvidia.com (10.27.9.16) by HQMAIL111.nvidia.com (172.20.187.18) with Microsoft SMTP Server (TLS) id 15.0.1473.3; Wed, 15 Apr 2020 18:53:52 +0000 Received: from [10.2.171.241] (10.124.1.5) by DRHQMAIL107.nvidia.com (10.27.9.16) with Microsoft SMTP Server (TLS) id 15.0.1473.3; Wed, 15 Apr 2020 18:53:51 +0000 Subject: Re: [RFC PATCH v7 6/9] media: tegra: Add Tegra210 Video input driver From: Sowjanya Komatineni To: Dmitry Osipenko , , , , , , CC: , , , , , References: <1586919463-30542-1-git-send-email-skomatineni@nvidia.com> <1586919463-30542-7-git-send-email-skomatineni@nvidia.com> <4118112f-f865-5460-6319-d71271fd78d1@gmail.com> <6afa951e-d904-f3c0-053f-82a02fb18979@nvidia.com> <5954a7e1-910e-7f48-56d3-e671b56ead74@nvidia.com> Message-ID: <786949a9-8507-7723-f29b-b91a216bfd28@nvidia.com> Date: Wed, 15 Apr 2020 11:53:50 -0700 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.9.0 MIME-Version: 1.0 In-Reply-To: X-Originating-IP: [10.124.1.5] X-ClientProxiedBy: HQMAIL111.nvidia.com (172.20.187.18) To DRHQMAIL107.nvidia.com (10.27.9.16) Content-Type: text/plain; charset="utf-8"; format=flowed Content-Transfer-Encoding: quoted-printable Content-Language: en-US DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nvidia.com; s=n1; t=1586976774; bh=SfIrbeIJ0Y7jZYhtTExZYIBHwkMpVtO0fMxSlIp8gmA=; h=X-PGP-Universal:Subject:From:To:CC:References:Message-ID:Date: User-Agent:MIME-Version:In-Reply-To:X-Originating-IP: X-ClientProxiedBy:Content-Type:Content-Transfer-Encoding: Content-Language; b=F0ocN5+Jv7SpG4hrBdRsUNb7Rccm7mDixvbpsyrM751MjhMbIDaBUbQuVVzqvBDrP ERBR9Mihzk1PcYJU1+iaqtxWQFEzUCn+JB9tosp3/DcnnEIuUhAe6vfflfsBzS/Iiz TGDgnUCbtTJM9JUivmMdAODCwJU2Ii3KLMJLO5ZdrZeMZfkmR9/ygEDdLFicpN376T 406MQt5xnhu1rhW1f58Tg+Qh5ypBwa2h2Hl/EYlIytnwV1hLCZb+oXim22AGvcrLkQ RF4yUyMBXgYUnSPRZOd75IBKC4TIVS6CNxEzFoLM+jQ4XpNkKsImfcUQbUp56nje9R q0FrM4cA+NUBg== Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 4/15/20 11:39 AM, Sowjanya Komatineni wrote: > > On 4/15/20 10:48 AM, Sowjanya Komatineni wrote: >> >> On 4/15/20 10:47 AM, Sowjanya Komatineni wrote: >>> >>> On 4/15/20 10:21 AM, Sowjanya Komatineni wrote: >>>> >>>> On 4/15/20 9:54 AM, Sowjanya Komatineni wrote: >>>>> >>>>> On 4/15/20 7:22 AM, Dmitry Osipenko wrote: >>>>>> External email: Use caution opening links or attachments >>>>>> >>>>>> >>>>>> 15.04.2020 05:57, Sowjanya Komatineni =D0=BF=D0=B8=D1=88=D0=B5=D1=82= : >>>>>>> +static int tegra_csi_remove(struct platform_device *pdev) >>>>>>> +{ >>>>>>> +=C2=A0=C2=A0=C2=A0=C2=A0 struct tegra_csi *csi =3D platform_get_dr= vdata(pdev); >>>>>>> +=C2=A0=C2=A0=C2=A0=C2=A0 int err; >>>>>>> + >>>>>>> +=C2=A0=C2=A0=C2=A0=C2=A0 err =3D host1x_client_unregister(&csi->cl= ient); >>>>>>> +=C2=A0=C2=A0=C2=A0=C2=A0 if (err < 0) { >>>>>>> +=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0= =C2=A0 dev_err(csi->dev, >>>>>>> +=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0= =C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0 "failed to unregiste= r host1x client:=20 >>>>>>> %d\n", err); >>>>>>> +=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0= =C2=A0 return err; >>>>>>> +=C2=A0=C2=A0=C2=A0=C2=A0 } >>>>>>> + >>>>>>> +=C2=A0=C2=A0=C2=A0=C2=A0 pm_runtime_disable(csi->dev); >>>>>>> +=C2=A0=C2=A0=C2=A0=C2=A0 kfree(csi); >>>>>> IIRC, the driver removal is invoked on the unbinding. Hence, I'm not >>>>>> sure how moving away from the resource-managed API helps here.=20 >>>>>> Could you >>>>>> please explain in a more details? >>>>>> >>>>>> Have you tried to test this driver under KASAN? I suspect that=20 >>>>>> you just >>>>>> masked the problem, instead of fixing it. Tested with kmemleak scan and did not see any memory leaks >>>>> Using devm_kzalloc for vi/csi structures based on prior feedback=20 >>>>> request to switch to use kzalloc all over this driver. >>>>> >>>>> Hi Hans, >>>>> >>>>> video devices lifetime is till video device nodes are released.=20 >>>>> So, v4l2 device release callback does the release of tegra channel=20 >>>>> allocation which hold video device. >>>>> >>>>> Below are the 3 possible cases of unbind/unload, >>>>> >>>>> 1. during tegra-video module unload, if v4l2 device refcnt is not=20 >>>>> 0 which is the case when any of video device node handle is kept=20 >>>>> opened then unloading module will not happen and module refcnt is=20 >>>>> also non-zero and unloading tegra-video module reports module in use. > v4l2 device is associated with host1x device where during=20 > v4l2_device_register get_device causes refcnt of tegra video host1x=20 > device to increase and prevents allowing module unload/load till v4l2=20 > device release happens. > > >>>>> 2. during tegra-video driver unbind, tegra-video driver removal=20 >>>>> will do vi/csi clients exit ops which unregisters video device=20 >>>>> allocated memory during release callback of v4l2 device. vi/csi=20 >>>>> structure allocation remains same as vi/csi driver removal will=20 >>>>> not happen in this case. >>>>> >>>>> >>>>> 3. during direct host1x client drivers vi/csi unbind, both=20 >>>>> host1x_clients vi/csi gets unregistered, deletes host1x logical=20 >>>>> device which executes tegra-video driver removal() -> vi/csi=20 >>>>> exit() before vi/csi memory gets freed in vi/csi driver remove(). >>>>> >>>>> So, any active streaming will stop and video devices are=20 >>>>> unregistered during direct client driver unbind prior to freeing=20 >>>>> vi/csi memory. >>>>> >>>>> Also vi/csi driver remove does explicit free vi/csi as its=20 >>>>> allocated with kzalloc. So not sure how using kzalloc is different=20 >>>>> to devm_kzalloc for vi/csi structure in terms of when vi/csi=20 >>>>> memory gets freed? >>>>> >>>>> Except for channel allocation which holds video device and as=20 >>>>> video device life time is beyond tegra-video module unbind->vi=20 >>>>> exit(), looks like we can use devm_kzalloc for vi/csi. >>>>> >>>>> >>>>> Can you please comment if you still think we need to use kzalloc=20 >>>>> rather than devm_kzalloc for vi/csi structure allocation? >>>>> >>>>> Thanks >>>>> >>>>> Sowjanya >>>>> >>>> One more case is when video device node is kept opened with=20 >>>> v4l2-ctl sleep (rather than streaming), where it will keep device=20 >>>> node open for specified time and if direct vi client driver unbind=20 >>>> happens then vi driver remove() will free vi memory before v4l2=20 >>>> device release happens. >>>> >>>> But I don't see any crash or errors with this case. > > In the above case, channels allocated memory release may not happen in=20 > this case as list head pointer will be gone when vi memory is freed=20 > during direct client unbind and by the time v4l2 device release=20 > callback gets executed vi channels list head is gone. > > Also, freeing vi structure memory can't be done in v4l2 device release=20 > callback either. > >>>> >>>> Also if we allow direct client driver unbind, then vi structure=20 >>>> memory lifetime should also be till v4l2 device release happens. >>>> >>>> But we can free vi in v4l2 device release callback as in case when=20 >>>> device node is not kept opened, video device release happens=20 >>>> immediate and we cant free vi that early. >>> >>> typo fix: >>> >>> But we can't free vi structure memory allocation in v4l2 device=20 >>> release callback as in case when device node is not kept opened,=20 >>> device release happens immediate and we can't free vi structure=20 >>> memory that early. >>> > >>>> Hans/Thierry, Can you please comment on this case? >>>> >>>> Thanks >>>> >>>> Sowjanya >>>> >> Also, Can you please help explain on cases where we do/need direct=20 >> host1x clients vi/csi drivers unbind?