Blaisorblade wrote:
On Monday 16 January 2006 20:34, Jacob Bachmeyer wrote:
Has any thought been given to making SKAS4 suitably generic that it
could be used for more than just UML?
Not yet, thoughts welcome.
Let's see:
to support HURD (which uses the Mach ABI):
-- existing facilities plus trap lcall gates
to support WINE (which follows Win32 conventions (ick!)): (x86 only)
--existing facilities plus
-- trap on access to specified pages
Explanation: Win32 API calls are not syscalls in the normal
sense--rather they are made by calling into a system DLL. These DLLs
are mapped into the process' address space on Windows and under current
WINE, much like shared objects in normal Linux. This idea would enable
WINE to not actually map these DLLs, but rather simply set the pages
where the DLLs would be mapped as "fasttrap". Then, when the program
attempts to access a DLL's memory image, the kernel would intercept the
request and quickly pass it to a userspace thread, which handles the
"page fault". The page remains set as "fasttrap", and the control
process modifies the address space and CPU context appropriately before
allowing execution to continue.
-- read/write in guest address space
Explanation: mmap is fine for big changes to an address space
(such as loading modules), but one capability WINE would need for this
to be truly useful is 1/2/4/8/16-byte PEEK and POKE. (Some Win32
programs like to do wierd things with Windows' system code--in
conjunction with "fasttrap", this would allow WINE to keep such programs
happy.) As I understand, ptrace already provides this, hopefully
adequetely.
-- intercept arbitrary interrupts in guest address space
Explanation: Many older Windows programs (Win16 era)
occasionally directly invoke various soft interrupts (these are
basically DOS syscalls). The ability to intercept these is necessary,
but need not be particularly efficient or fast.
-- modify guest address space's LDT
Explanation: Again, Win16 support. Old Windows actually
allowed processes to request segments for whatever purpose. This may or
may not be doable on all modern hardware.
-- transparently use threads in guest address spaces, if desired
Explanation: WINE currently uses the host's scheduler.
Changing it to this new API shouldn't adversely affect that ability.
(And on second thought, using a UML library might not be an option.)
PS: If I understand correctly, UML with the current SKAS3 works by
swapping processes into and out of a single "user" address space.
I
propose a system where many distinct "user" address spaces are
maintained by the kernel and execution is placed whereever the user-mode
scheduler says.
What you say is not clear, but the most obvious understanding of the above
sentence is that you propose what already happens.
However, SKAS3 and current ideas for SKAS4, with different APIs but similar
semantics, say: implement all guest processes as user-level threads (totally
implemented within UML) with the exception that we allow different address
spaces.
So we have "switch the guest proc to a different address
space" (PTRACE_SWITCH_MM, in arch/i386/kernel/ptrace.c), manipulate with
mmap/munmap/mprotect any of these address spaces, and destroy it (all in
mm/proc_mm.c).
I shall clarify my proposal: each thread is assigned an address space,
while an address space can contain multiple threads. Each thread also
has a STOP/RUN flag, which if set to RUN, causes the host scheduler to
consider that thread for execution (along with all other runnable
threads). This flag allows either the userspace control process to make
scheduling decisions itself, (by only setting one of its threads to RUN)
or to punt and have the kernel handle all scheduling for its threads (by
setting them all to RUN and using STOP only to block a thread).
Could all SKAS4 APIs be multiplexed through one syscall? (Perhaps
simply as more ptrace functions, or as a new "skas4" syscall?)
-------------------------------------------------------
This SF.net email is sponsored by: Splunk Inc. Do you grep through log files
for problems? Stop! Download the new AJAX search engine that makes
searching your log files as easy as surfing the web. DOWNLOAD SPLUNK!
http://sel.as-us.falkag.net/sel?cmd=lnk&kid=103432&bid=230486&dat=121642
_______________________________________________
User-mode-linux-devel mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/user-mode-linux-devel