I would like to propose an interface change to the following
paravirt-ops calls:
void (fastcall *write_ldt_entry)(void *dt, int entrynum, u64 entry);
void (fastcall *write_gdt_entry)(void *dt, int entrynum, u64 entry);
void (fastcall *write_idt_entry)(void *dt, int entrynum, u64 entry);
Can we consolidate the dt and entrynum parameters and just pass
dt+entrynum*8? I don't know if this makes things harder for the Xen
case, but I seem to distantly recall that we used to pass a pure pointer
- actually we used to have a pure post-update call, but changed the
interface to accommodate Xen. When we did that, the interface changed
to take the new descriptor value as a parameter, as a raw write to the
GDT / LDT would not be allowed. And during that step, the new entrynum
parameter was added.
Since it's fairly easy to merely subtract the entry offset from the
descriptor base, and descriptor tables are virtually mapped, obtaining
the page number, if it is required, is still a very easy task. I
believe we added the entrynum field so the page number could be
computed, but I just don't remember why, and don't see any reason for it
now.
So I propose changing the convention here to eliminate the entrynum
field, thus allowing all the parameters to fit within the fastcall
convention, which affords us three registers. The primary motivation
being, the call to write_gdt_entry is on the fast path in context switch.
Any objections?
Zach
_______________________________________________
Virtualization mailing list
[email protected]
https://lists.osdl.org/mailman/listinfo/virtualization