Jeremy Fitzhardinge <[EMAIL PROTECTED]> writes: > Eric W. Biederman wrote: >> Ok. Although we can hoist the bss zeroing, if everything needs it. >> > > It will if we're booting out of bzImage; the bss won't be clear in that > case. > >> Hmm. I'm wondering about the segment reload and how much of a problem >> that is. My memory says that segment reloads are not actually a >> privileged operation, so we may be able to support this even in >> paravirt mode. How hard would that be to support? The segment >> we reload is a fixed part of our boot protocol. >> > > The problem is not the reloads themselves, but what you're reloading > them with. If we come up under Xen, then it will provide a default GDT > and pre-load the segments with flat 4G(-ish) selectors - but the > selectors won't be the normal Linux ones. > > So if we reload using a constant selector, then that will break under > Xen. But if we do a: > > mov %cs, %eax > mov %eax, %ds > // etc
Hmm. If we made that: mov %cs, %eax add $0x10, %eax mov %eax, %ds That is likely even backwards compatible. If you don't mind having a fixed offset between the code and the data segments. As I recall code and data are not interchangeable. I'm trying to remember the reason for the reloads. As I recall loadlin intercepts code32_start from head.S and so it can do things just after we have switched to protected mode. Because historically we didn't load the segments before this jump loadlin had to do it. The code of loadlin appears to reload all of the segments just like head.S does and then not touch them. My two bootloaders that enter the kernel at the 32bit entry point already load the segments as well. Gujin looks like it loads just %es and %ds. It is hard to tell with elilo what it sets up, it preserves the descriptors from EFI, but sets up a linux boot protocol gdt. Since setup.S finally does the right thing in loading segment registers. It looks to me like we need to sit down and document the 32bit kernel interface, as it is today, and then extend things to just replicate %ds into the other segments, and kill any lss instructions. That is trivially compatible with our expectations of vmlinux. For the bzImage 32bit entry point it is a bit of an extension, but except for para-virtualization solutions I don't know of anything that doesn't support bzImage and vmlinux with the same code. I like it a lot better then trying to derive %ds from %cs. At the same time we are doing this it would be good to drop our boot protocol version into an ELF note so people booting vmlinux can discover when we have relaxed various restrictions and which fields in the real mode data we support. Eric - 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/