[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <657d91c7-60ca-a64b-ad29-1d6dcc4b32ac@quicinc.com>
Date: Fri, 24 Feb 2023 09:14:35 -0800
From: Trilok Soni <quic_tsoni@...cinc.com>
To: Mukesh Ojha <quic_mojha@...cinc.com>,
Brian Masney <bmasney@...hat.com>
CC: <agross@...nel.org>, <andersson@...nel.org>,
<konrad.dybcio@...aro.org>, <keescook@...omium.org>,
<tony.luck@...el.com>, <gpiccoli@...lia.com>,
<catalin.marinas@....com>, <will@...nel.org>,
<linux-arm-msm@...r.kernel.org>,
<linux-remoteproc@...r.kernel.org>, <linux-kernel@...r.kernel.org>,
<linux-hardening@...r.kernel.org>,
<linux-arm-kernel@...ts.infradead.org>
Subject: Re: [RFC PATCH 0/6] Add basic Minidump kernel driver support
On 2/24/2023 2:40 AM, Mukesh Ojha wrote:
> Thanks Brian for your interest in this series.
>
> On 2/23/2023 6:07 PM, Brian Masney wrote:
>> On Tue, Feb 21, 2023 at 04:55:07PM +0530, Mukesh Ojha wrote:
>>> Minidump is a best effort mechanism to collect useful and predefined
>>> data
>>> for first level of debugging on end user devices running on Qualcomm
>>> SoCs.
>>> It is built on the premise that System on Chip (SoC) or subsystem
>>> part of
>>> SoC crashes, due to a range of hardware and software bugs. Hence, the
>>> ability to collect accurate data is only a best-effort. The data
>>> collected
>>> could be invalid or corrupted, data collection itself could fail, and
>>> so on.
>>>
>>> Qualcomm devices in engineering mode provides a mechanism for generating
>>> full system ramdumps for post mortem debugging. But in some cases it's
>>> however not feasible to capture the entire content of RAM. The minidump
>>> mechanism provides the means for selecting which snippets should be
>>> included in the ramdump.
>>>
>>> The core of minidump feature is part of Qualcomm's boot firmware code.
>>> It initializes shared memory (SMEM), which is a part of DDR and
>>> allocates a small section of SMEM to minidump table i.e also called
>>> global table of content (G-ToC). Each subsystem (APSS, ADSP, ...) has
>>> their own table of segments to be included in the minidump and all get
>>> their reference from G-ToC. Each segment/region has some details like
>>> name, physical address and it's size etc. and it could be anywhere
>>> scattered in the DDR.
>>>
>>> Existing upstream Qualcomm remoteproc driver[1] already supports
>>> minidump
>>> feature for remoteproc instances like ADSP, MODEM, ... where predefined
>>> selective segments of subsystem region can be dumped as part of
>>> coredump collection which generates smaller size artifacts compared to
>>> complete coredump of subsystem on crash.
>>>
>>> [1]
>>> https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/tree/drivers/remoteproc/qcom_common.c#n142
>>>
>>> In addition to managing and querying the APSS minidump description,
>>> the Linux driver maintains a ELF header in a segment. This segment
>>> gets updated with section/program header whenever a new entry gets
>>> registered.
>>
>> I'd like to test this series plus your series that sets the multiple
>> download modes.
>
> Sure, you are welcome, but for that you need a device running with
> Qualcomm SoC and if it has a upstream support.
>
> Also, testing of this patch needs some minimal out of tree patches and
> i can help you with that.
>
>> Can you include documentation about how to actually use
>> this new feature?
>
> Will surely do, Since this is still RFC, and i am doubtful on the path
> of it in documentation directory.
This is RFC anyways, you can start w/ the directory which you think best
fits here. The point here is to have the documentation file rather than
path to be fixed.
You can start w/ Documentation/features/debug and let's see what others
have any suggestion. Please add a file in your next revision without
worrying about the path for now.
---Trilok Soni
Powered by blists - more mailing lists