On Mon, Aug 29, 2005 at 07:13:47PM +0200, Andi Kleen wrote: > On Monday 29 August 2005 18:10, Tom Rini wrote: > > > +void __init early_setup_per_cpu_area(void) > > +{ > > + static char cpu0[PERCPU_ENOUGH_ROOM] > > + __attribute__ ((aligned (SMP_CACHE_BYTES))); > > + char *ptr = cpu0; > > + > > + cpu_pda[0].data_offset = ptr - __per_cpu_start; > > + memcpy(ptr, __per_cpu_start, __per_cpu_end - __per_cpu_start); > > +} > > What is that? It looks totally bogus. Can you tell exactly where you > believe early per cpu data is needed?
Bob did this part (forgot to CC him, oops). But I believe it's needed for setting traps so much earlier. > > + > > /* > > * Great future plan: > > * Declare PDA itself and support (irqstack,tss,pgd) as per cpu data. > > @@ -97,7 +107,9 @@ void __init setup_per_cpu_areas(void) > > for (i = 0; i < NR_CPUS; i++) { > > char *ptr; > > > > - if (!NODE_DATA(cpu_to_node(i))) { > > + if (cpu_pda[i].data_offset) > > + continue; > > And that looks broken too. I believe that's to takecare of the case where something is covered in early_setup_cpu_areas(). > In general I would also advise to mix any other changes outside kgdb* into > the > x86-64 kgdb patch. Either the patch should be merged into mainline in a > separate patch or kgdb reworked to not need this. ok. > > + if (notify_die(DIE_PAGE_FAULT, "no context", regs, error_code, 14, > > + SIGSEGV) == NOTIFY_STOP) > > + return; > > + > > I can see the point of that. It's ok if you submit it as a separate patch. I can split that out into one that follows the KDB_VECTOR rename easily enough. > Regarding early trap init: I would have no problem to move all of traps_init > into setup_arch (and leave traps_init empty for generic code). I actually > don't know why it runs so late. But doing it half way is ugly. Should I make setup_per_cpu_area and trap_init empty and turn the real ones into early_foo? -- Tom Rini http://gate.crashing.org/~trini/ - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/