Received: by 2002:a05:6a10:1a4d:0:0:0:0 with SMTP id nk13csp1346834pxb; Wed, 2 Feb 2022 02:55:29 -0800 (PST) X-Google-Smtp-Source: ABdhPJyvTLG3GWWZ0U/8B39xGr1LrKnPXdjvQxNvccTkSpzKglXfH5BVqrsf+d9KiFOu3jMarTqO X-Received: by 2002:a63:8ac9:: with SMTP id y192mr24137973pgd.598.1643799329256; Wed, 02 Feb 2022 02:55:29 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1643799329; cv=none; d=google.com; s=arc-20160816; b=hOf0WHdSHw0TaLGYJ7anY2zCyEx12ohNIji1CipPHRD5JZs+KFdfTTaXuqVKiJHqEp z+TMbtCopF2SxBYIMEM5r1xr0LqG/Y2szjAM/oUgec6UTaiSCBzARzkZq7VXCHGFvf9l jWdtVWQ+2RtILzZVqvIaQBtQryX9arYVU6t1FVa3w/4zZW39waaNDUgOsIPxWpAzrSTH /Q5zxIycfUvHmgAo9pOtJg0MONJ75EJu6yjxjb3x+F34W7h/8/EsncBcLGZeMBa3cK7c BQ4sQ8drVcioOvR0z6cyxxIPBQH+pIjeSicf5pqGB2JM0FOhbAYYf9DLgdj2+zmSkesN 3Y9g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-language:content-transfer-encoding :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:dmarc-filter:sender:dkim-signature; bh=Le/t5Scxc7BaBZuub3JG4KIMkCg08hl4Pp9cMhmC3+o=; b=iGMPqUL30GhkOVkyzoW1g/alSQrFNAs9ECAiyiCy5e4DvfHgiJxsCAb/0FyNcX+aJ9 5xpFWFgrX2HoibqJ4r/cQAZwJ6y0HDhESc45cHIdHuWqnlKAjD3RxJns6lJBO3kWXFQJ YAScvwPpYu9h5MWdu8aD4MZeGQN+H5Pi8G+26buMY2D6DnejEop5S/vKpkwIAftVAUo9 R6Hmn4MbdkyONIH4bcHi3j+3C/6bzX0frX4p09jTmkJkFYm09A8d5HGyi83lQNxa+/Q2 m2C9gKhXFJLo9NiYi4hVox59qCk0W8HHrzH0Bb8qXYms8NZLrce3RGS7u3lK7bkeFM/g pLdA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@mg.codeaurora.org header.s=smtp header.b=JifpaReS; 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 Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id w184si18963668pgd.90.2022.02.02.02.55.16; Wed, 02 Feb 2022 02:55:29 -0800 (PST) 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=@mg.codeaurora.org header.s=smtp header.b=JifpaReS; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237074AbiBBH2S (ORCPT + 99 others); Wed, 2 Feb 2022 02:28:18 -0500 Received: from m43-7.mailgun.net ([69.72.43.7]:50820 "EHLO m43-7.mailgun.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236798AbiBBH2Q (ORCPT ); Wed, 2 Feb 2022 02:28:16 -0500 DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=mg.codeaurora.org; q=dns/txt; s=smtp; t=1643786896; h=Content-Transfer-Encoding: Content-Type: In-Reply-To: MIME-Version: Date: Message-ID: From: References: Cc: To: Subject: Sender; bh=Le/t5Scxc7BaBZuub3JG4KIMkCg08hl4Pp9cMhmC3+o=; b=JifpaReSvQlwTjhJmBhBxEdlAt1ZqSn9kF5loOyI4z6PatJFxtyaT5X3W/NdCOicU0i4q2zX GvKoz5rpa2OYojVC1GgDcAPILQs4U5oGh3777T51N9CW+SNOX9plEQ/cJM19ybbEY7c2B0Bu zS+0Q9LQxrF7wRJqugdMX93CdFc= X-Mailgun-Sending-Ip: 69.72.43.7 X-Mailgun-Sid: WyI0MWYwYSIsICJsaW51eC1rZXJuZWxAdmdlci5rZXJuZWwub3JnIiwgImJlOWU0YSJd Received: from smtp.codeaurora.org (ec2-35-166-182-171.us-west-2.compute.amazonaws.com [35.166.182.171]) by smtp-out-n02.prod.us-east-1.postgun.com with SMTP id 61fa31c42042dbe581b4a64c (version=TLS1.2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256); Wed, 02 Feb 2022 07:24:52 GMT Sender: sricharan=codeaurora.org@mg.codeaurora.org Received: by smtp.codeaurora.org (Postfix, from userid 1001) id 6AC0CC43616; Wed, 2 Feb 2022 07:24:51 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-caf-mail-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.9 required=2.0 tests=ALL_TRUSTED,BAYES_00, NICE_REPLY_A,SPF_FAIL,T_SCC_BODY_TEXT_LINE autolearn=no autolearn_force=no version=3.4.0 Received: from [192.168.0.104] (unknown [183.82.28.99]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: sricharan) by smtp.codeaurora.org (Postfix) with ESMTPSA id BE470C4338F; Wed, 2 Feb 2022 07:24:44 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.4.1 smtp.codeaurora.org BE470C4338F Authentication-Results: aws-us-west-2-caf-mail-1.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: aws-us-west-2-caf-mail-1.web.codeaurora.org; spf=fail smtp.mailfrom=codeaurora.org Subject: Re: [PATCH] mtd: nand: raw: qcom_nandc: Don't clear_bam_transaction on READID To: Konrad Dybcio , Miquel Raynal Cc: Manivannan Sadhasivam , pragalla@codeaurora.org, ~postmarketos/upstreaming@lists.sr.ht, martin.botka@somainline.org, angelogioacchino.delregno@somainline.org, marijn.suijten@somainline.org, jamipkettunen@somainline.org, Richard Weinberger , Vignesh Raghavendra , linux-mtd@lists.infradead.org, linux-arm-msm@vger.kernel.org, linux-kernel@vger.kernel.org, mdalam@codeaurora.org, bbhatt@codeaurora.org, hemantk@codeaurora.org References: <20220113184427.2259509-1-konrad.dybcio@somainline.org> <20220114082718.32a2fc83@xps13> <20220126111613.3ab0021e@xps13> <20220126103316.GA212068@thinkpad> <20220126114200.4cc3c21b@xps13> <0a8d6550-aa19-0af1-abae-66bf34c91ea8@somainline.org> <12cad24a-fa2f-9a82-cf43-241a0a6fe4f6@somainline.org> <20220201145204.54646475@xps13> From: Sricharan Ramabadhran Message-ID: Date: Wed, 2 Feb 2022 12:54:42 +0530 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.11.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Konrad/Miquel, On 2/1/2022 9:21 PM, Konrad Dybcio wrote: > > On 01/02/2022 14:52, Miquel Raynal wrote: >> Hi Konrad, >> >> konrad.dybcio@somainline.org wrote on Mon, 31 Jan 2022 20:54:12 +0100: >> >>> On 31/01/2022 15:13, Sricharan Ramabadhran wrote: >>>> Hi Konrad, >>>> >>>> On 1/31/2022 3:39 PM, Konrad Dybcio wrote: >>>>> On 28/01/2022 18:50, Sricharan Ramabadhran wrote: >>>>>> Hi Konrad, >>>>>> >>>>>> On 1/28/2022 9:55 AM, Sricharan Ramabadhran wrote: >>>>>>> Hi Miquel, >>>>>>> >>>>>>> On 1/26/2022 4:12 PM, Miquel Raynal wrote: >>>>>>>> Hi Mani, >>>>>>>> >>>>>>>> mani@kernel.org wrote on Wed, 26 Jan 2022 16:03:16 +0530: >>>>>>>>> On Wed, Jan 26, 2022 at 11:16:13AM +0100, Miquel Raynal wrote: >>>>>>>>>> Hello, >>>>>>>>>> >>>>>>>>>> miquel.raynal@bootlin.com wrote on Fri, 14 Jan 2022 08:27:18 >>>>>>>>>> +0100: >>>>>>>>>>> Hi Konrad, >>>>>>>>>>> >>>>>>>>>>> konrad.dybcio@somainline.org wrote on Thu, 13 Jan 2022 >>>>>>>>>>> 19:44:26 >>>>>>>> +0100: >>>>>>>>>>>> While I have absolutely 0 idea why and how, running >>>>>>>>>>>> >>>>>>>>> clear_bam_transaction >>>>>>>>>>>> when READID is issued makes the DMA totally clog up and >>>>>>>>>>>> refuse >>>>>>>>> to function >>>>>>>>>>>> at all on mdm9607. In fact, it is so bad that all the data >>>>>>>>>>>> >>>>>>>>> gets garbled >>>>>>>>>>>> and after a short while in the nand probe flow, the CPU >>>>>>>>>>>> >>>>>>>>> decides that >>>>>>>>>>>> sepuku is the only option. >>>>>>>>>>>> >>>>>>>>>>>> Removing _READID from the if condition makes it work like a >>>>>>>>>>>> >>>>>>>>> charm, I can >>>>>>>>>>>> read data and mount partitions without a problem. >>>>>>>>>>>> >>>>>>>>>>>> Signed-off-by: Konrad Dybcio >>>>>>>>>>>> --- >>>>>>>>>>>> This is totally just an observation which took me an >>>>>>>>>>>> inhumane >>>>>>>>> amount of >>>>>>>>>>>> debug prints to find.. perhaps there's a better reason >>>>>>>>>>>> behind >>>>>>>>> this, but >>>>>>>>>>>> I can't seem to find any answers.. Therefore, this is a BIG >>>>>>>>>>>> RFC! >>>>>>>>>>> I'm adding two people from codeaurora who worked a lot on >>>>>>>>>>> this >>>>>>>> driver. >>>>>>>>>>> Hopefully they will have an idea :) >>>>>>>>>> Sadre, I've spent a significant amount of time reviewing your >>>>>>>>>> >>>>>>> patches, >>>>>>>>>> now it's your turn to not take a month to answer to your peers >>>>>>>>>> proposals. >>>>>>>>>> >>>>>>>>>> Please help reviewing this patch. >>>>>>>>> Sorry. I was hoping that Qcom folks would chime in as I don't >>>>>>>>> >>>>>> have any idea >>>>>>>>> about the mdm9607 platform. It could be that the mail server >>>>>>>>> >>>>>> migration from >>>>>>>>> codeaurora to quicinc put a barrier here. >>>>>>>>> >>>>>>>>> Let me ping them internally. >>>>>>>> Oh, ok, I didn't know. Thanks! >>>>>>>     Sorry Miquel, somehow we did not get this email in our inbox. >>>>>>>     Thanks to Mani for pinging us, we will test this up today >>>>>>> and >>>> get back. >>>>>>        While we could not reproduce this issue on our ipq boards >>>>>> (do >>> not have a mdm9607 right now) and >>>>>>         issue does not look any obvious. >>>>>>        can you please give the debug logs that you did for the >>>>>> above >>> stage by stage ? >>>>> I won't have access to the board for about two weeks, sorry. >>>>> >>>>> When I get to it, I'll surely try to send you the logs, though there >>>>> >>>>> wasn't much more than just something jumping to who-knows-where >>>>> >>>>> after clear_bam_transaction was called, resulting in values >> >>>>> associated with >>>>> >>>>> the NAND being all zeroed out in pr_err/_debug/etc. >>>>> >>>>      Ok sure. So was the READID command itself failing (or) the > >>>> subsequent one ? >>>>     We can check which parameter reset by the clear_bam_transaction >>>> is > causing the >>>>     failure.  Meanwhile, looping in Pradeep who has access to the > >>>> board, so in a better >>>>     position to debug. >>> I'm sorry I have so few details on hand, and no kernel tree (no >>> access to that machine either, for now). >>> >>> >>> I will try to describe to the best of my abilities what I recall. >>> >>> >>> My methodology of making sure things don't go haywire was to print >>> the oob size >>> >>> of our NAND basically every two lines of code (yes, i was very >>> desperate at one point), >>> >>> as that was zeroed out when *the bug* happened, >> This does look like a pointer error at some point and some kernel data >> has been corrupted very badly by the driver. >> >>> leading to a kernel bug/panic/stall >>> >>> (can't recall what exactly it was, but it said something along the >>> lines of "no support for >>> >>> oob size 0" and then it didn't fail graceully, leading to some bad >>> jumps and ultimately >>> >>> a dead platform..) >>> >>> >>> after hours of digging, I found out that everything goes fine until >>> clear_bam_transaction is called, >> Do you remember if this function was called for the first time when >> this happened? > > I think so, if I recall correctly there are no more callers in this > path, as readid is the first nand command executed in flash probe flow. > > > >> >>> after that gets executed every nand op starts reading all zeroes >>> (for example in JEDEC ID check) >>> >>> so I added the changes from this patch, and things magically started >>> working... My suspicion is >>> >>> that the underlying FIFO isn't fully drained (is it a FIFO on 9607? >>> bah, i work on too many socs at once) >> I don't see it in the list of supported devices, what's the exact >> compatible used? > > qcom,ipq4019-nand > > > >> >>> and this function only makes Linux think it is, without actually >>> draining it, and the leftover >>> >>> commands get executed with some parts of them getting overwritten, >>> resulting in the >>> >>> famous garbage in - garbage out situation, but that's only a >>> guesstimate.. >> I would bet for a non allocated bam-ish pointer that is reset to zero >> in the clear_bam_transaction() helper. >> >> Can you get your hands on the board again? > > Sure, but as I mentioned previously, only in about 2 weeks, I can't > really do any dev before then.. :( > > > >> It would be nice to check if the allocation always occurs before use, >> and if yes on how much bytes. >> >> If the pointer is not dangling, then perhaps something else smashes >> that pointer. > > > Konrad > >> >>> Do note this somehow worked fine on 5.11 and then broke on 5.12/13. >>> I went as far as replacing most >>> >>> of the kernel with the updated/downgraded parts via git checkout (i >>> tried many combinations), >>> >>> to no avail.. I even tried different compilers and optimization >>> levels, thinking it could have been >>> >>> a codegen issue, but no luck either. >>> >>> >>> I.. do understand this email is a total mess to read, as much as it >>> was to write, but >>> >>> without access to my code and the machine itself I can't give you >>> solid details, and >>> >>> the fact this situation is far from ordinary doesn't help either.. >>> >>> >>> The latest (ancient, not quite pretty, but probably working if my >>> memory is correct) version of my patches >>> >>> for the mdm9607 is available at [1], I will push the new revision >>> after I get access to the workstation. >>>   + few more who have access to the board.    Going by the description, for kernel corruption, we can try out a KASAN build.    Since you have mentioned it worked till 5.11, you bisected the driver till 5.11 head and it worked ? Regards,    Sricharan