On Thu, 25 Jul 2019, John Hubbard wrote:
> On 7/25/19 3:28 PM, H. Peter Anvin wrote:
> > On 7/25/19 3:03 PM, Thomas Gleixner wrote:
> >> On Thu, 25 Jul 2019, h...@zytor.com wrote:
> >>> On July 25, 2019 2:48:30 PM PDT, Thomas Gleixner <t...@linutronix.de> 
> >>> wrote:
> >>>>
> >>>> But seriously I think it's not completely insane what they are doing
> >>>> and the table based approach is definitely more readable and maintainable
> >>>> than the existing stuff.
> >>>
> >>> Doing this table based does seem like a good idea.
> >>
> >> The question is whether we use a 'toclear' table or a 'preserve' table. I'd
> >> argue that the 'preserve' approach is saner.
> >>
> > 
> > I agree.
> > 
> 
> OK, I can polish up something and post it, if you can help me with one more
> quick question: how did you want "to preserve" to work?
> 
> a) copy out fields to preserve, memset the area to zero, copy back preserved
> fields? This seems like it would have the same gcc warnings as we have now,
> due to the requirement to memset a range of a struct... 

Use the same trick I used for the toclear variant.

#define PRESERVE(m)                     \
        {                               \
                .start = offsetof(m),   \
                .len   = sizeof(m),     \
        }

sanitize_boot_params(bp, scratch)
{
        char *p1 = bp, *p2 = scratch;

        preserve[] = {
                PRESERVE(member1),
                ...
                PRESERVE(memberN),
        };

        for_each_preserve(pr)
                memcpy(p2 + pr->start, p1 + pr->start, pr->len)
        memcpy(bp, scratch, ...);
}


Thanks,

        tglx

Reply via email to