[Patch v3] Add persistent memory support
Dave Young
dyoung at redhat.com
Tue Aug 25 00:37:19 PDT 2015
On 08/24/15 at 01:54pm, Toshi Kani wrote:
> On Thu, 2015-08-20 at 15:42 +0800, Dave Young wrote:
> > On 08/20/15 at 10:52am, Baoquan He wrote:
> > > On 08/20/15 at 10:38am, Dave Young wrote:
> > > > On 08/19/15 at 06:45pm, Baoquan He wrote:
> > > > > On 08/19/15 at 05:28pm, Dave Young wrote:
> > > > > > Hi,
> > > > > >
> > > > > > On 08/19/15 at 05:03pm, Baoquan He wrote:
> > > > >
> > > > > > > diff --git a/kexec/arch/i386/crashdump-x86.c
> > > > > > > b/kexec/arch/i386/crashdump-x86.c
> > > > > > > index 82bf239..598a78f 100644
> > > > > > > --- a/kexec/arch/i386/crashdump-x86.c
> > > > > > > +++ b/kexec/arch/i386/crashdump-x86.c
> > > > > > > @@ -301,6 +301,10 @@ static int get_crash_memory_ranges(struct
> > > > > > > memory_range **range, int *ranges,
> > > > > > > type = RANGE_ACPI;
> > > > > > > } else if(memcmp(str,"ACPI Non-volatile
> > > > > > > Storage\n",26) == 0 ) {
> > > > > > > type = RANGE_ACPI_NVS;
> > > > > > > + } else if(memcmp(str,"Persistent Memory
> > > > > > > (legacy)\n",27) == 0 ) {
> > > > > > > + type = RANGE_PRAM;
> > > > > > > + } else if(memcmp(str,"Persistent Memory\n",18)
> > > > > > > == 0 ) {
> > > > > > > + type = RANGE_PMEM;
> > > > > > > } else if(memcmp(str,"reserved\n",9) == 0 ) {
> > > > > > > type = RANGE_RESERVED;
> > > > > > > } else if (memcmp(str, "GART\n", 5) == 0) {
> > > > > > > @@ -640,6 +644,8 @@ static void cmdline_add_memmap_internal(char
> > > > > > > *cmdline, unsigned long startk,
> > > > > > > strcat (str_mmap, "K$");
> > > > > > > else if (type == RANGE_ACPI || type == RANGE_ACPI_NVS)
> > > > > > > strcat (str_mmap, "K#");
> > > > > > > + else if (type == RANGE_PRAM)
> > > > > > > + strcat (str_mmap, "K!");
> > > > > >
> > > > > > Since we have switched to use e820 it is not necessary to
> > > > > > supporting new things in legacy memmap interface?
> > > > >
> > > > > Well, I am not sure about this. Kexec-tools provides memmap method
> > > > > to pass the memory ranges, then either we continue supporting it or
> > > > > we delete it. Now is this OK we just keep legacy memmap code there
> > > > > and ignore it? If people check the man page and find --pass-memmap
> > > > > -cmdline and intend to try, then kexec/kdump fail, then how do we go
> > > > > with it?
> > > >
> > > > It is a legacy interface, IMO we should deprecate it and remove it
> > > > after a period like several release cycle.
> > >
> > > So if customers still want to specify memmap there isn't a way.
> > >
> >
> > Why do one use memmap with new kexec-tools?
> >
> > There's no reason to use the old interface, I do not think there's any
> > benefit since new interface works well and be more scalable.
>
> Unless --pass-memmap-cmdline has already been deprecated, I think it should
> keep up with the kernel update in the memmap cmd-line. IOW, if we do not
> keep it up, it should be marked as deprecated.
Hmm, after looking into old discussion, I found that the options is there for
the known issue for calgary iommu. I really doubt there's someone is using it
but who knows.
calgary code uses saved_max_pfn which is only calculaed when there's memmap=exactmap
cmdline params. So before removing the limitation we still need carry the old
interface.
Hence, I will not object Bao's changes in his patch any more.
Thanks
Dave
More information about the kexec
mailing list