Re: [PATCH v2 2/2] libnvdimm: Add a poison list and export badblocks

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Thu, Jan 7, 2016 at 3:22 PM, Dan Williams <dan.j.williams@xxxxxxxxx> wrote:
> On Thu, Jan 7, 2016 at 3:15 PM, Linda Knippers <linda.knippers@xxxxxxx> wrote:
>> On 1/7/2016 5:49 PM, Dan Williams wrote:
>>> On Thu, Jan 7, 2016 at 1:18 PM, Linda Knippers <linda.knippers@xxxxxxx> wrote:
>>>>
>>>> On 12/24/2015 9:21 PM, Vishal Verma wrote:
>>>>> During region creation, perform Address Range Scrubs (ARS) for the SPA
>>>>> (System Physical Address) ranges to retrieve known poison locations from
>>>>> firmware. Add a new data structure 'nd_poison' which is used as a list
>>>>> in nvdimm_bus to store these poison locations.
>>>>>
>>>>> When creating a pmem namespace, if there is any known poison associated
>>>>> with its physical address space, convert the poison ranges to bad sectors
>>>>> that are exposed using the badblocks interface.
>>>>>
>>>>> Signed-off-by: Vishal Verma <vishal.l.verma@xxxxxxxxx>
>>>>> ---
>>>>>  drivers/acpi/nfit.c       | 203 ++++++++++++++++++++++++++++++++++++++++++++++
>>>>>  drivers/nvdimm/core.c     | 187 ++++++++++++++++++++++++++++++++++++++++++
>>>>>  drivers/nvdimm/nd-core.h  |   3 +
>>>>>  drivers/nvdimm/nd.h       |   6 ++
>>>>>  drivers/nvdimm/pmem.c     |   6 ++
>>>>>  include/linux/libnvdimm.h |   1 +
>>>>>  6 files changed, 406 insertions(+)
>>>>>
>>>>> diff --git a/drivers/acpi/nfit.c b/drivers/acpi/nfit.c
>>>>
>>>> Why are the ARS function in acpi/nfit.c rather than in the core?
>>>> I realize that the interfaces are/will be defined in the ACPI spec but
>>>> it's not really part of the NFIT.
>>>>
>>>> Why isn't this part of the nvdimm core, where the calls are made?
>>>
>>> True.  acpi_nfit_find_poison() could easily become
>>> nvdimm_bus_find_poison() and move to the core.  However we only need
>>> to take that step when / if another nvdimm bus type show up that isn't
>>> nfit defined.  For now only nfit-defined nvdimms have a concept of
>>> ARS.
>>
>> Why not go ahead and move it now?
>>
>> I agree that ARS is related to NFIT, but practically everything else
>> in the core is as well.  It doesn't seem to belongs in nfit.c.  I
>> didn't even notice that's where it was since the subject line says
>> "libnvdimm".
>
> Should be straightforward, will do.

So this turns out to not be straightforward because the ars record
format is ACPI specific.  We would need to define a generic record
format to move the poison processing to the core, and I don't see this
being worth the effort until a non-ACPI ars record format appears.
--
To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [Linux Ext4 Filesystem]     [Union Filesystem]     [Filesystem Testing]     [Ceph Users]     [Ecryptfs]     [AutoFS]     [Kernel Newbies]     [Share Photos]     [Security]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux Cachefs]     [Reiser Filesystem]     [Linux RAID]     [Samba]     [Device Mapper]     [CEPH Development]
  Powered by Linux