Since we have a DSL for specifying syscalls, we can create a verificaton method for each syscall that can cover most argument (and eventually capability) verification instead of doing it piecemeal in each syscall implementation, which can be more error-prone. Now a new _syscall_verify_* function exists for every syscall, which calls the real implementation. The syscall table for the syscall handler now maps to these verify functions. Other changes: - Updated the definition grammar to allow options to have a "key:value" style, to eventually support capabilities. - Added an "optional" option for parameters that says a syscall will accept a null value. - Some bonnibel fixes, as definition file changes weren't always properly causing updates in the build dep graph. - The syscall implementation function signatures are no longer exposed in syscall.h. Also, the unused syscall enum has been removed.
36 lines
1.2 KiB
Modula-2
36 lines
1.2 KiB
Modula-2
import "objects/endpoint.def"
|
|
import "objects/vma.def"
|
|
|
|
# The system object represents a handle to kernel functionality
|
|
# needed by drivers and other priviledged services
|
|
object system : kobject {
|
|
uid fa72506a2cf71a30
|
|
|
|
# Get a log line from the kernel log
|
|
method get_log {
|
|
param buffer buffer [out optional] # Buffer for the log message data structure
|
|
}
|
|
|
|
# Ask the kernel to send this process messages whenever
|
|
# the given IRQ fires
|
|
method bind_irq {
|
|
param dest object endpoint # Endpoint that will receive messages
|
|
param irq uint # IRQ number to bind
|
|
}
|
|
|
|
# Create a VMA and map an area of physical memory into it,
|
|
# also mapping that VMA into the current process
|
|
method map_phys {
|
|
param area object vma [out] # Receives a handle to the VMA created
|
|
param phys address # The physical address of the area
|
|
param size size # Size of the area, in pages
|
|
param flags uint32 # Flags to apply to the created VMA
|
|
}
|
|
|
|
# Request the kernel change the IOPL for this process. The only values
|
|
# that make sense are 0 and 3.
|
|
method request_iopl {
|
|
param iopl uint # The IOPL to set for this process
|
|
}
|
|
}
|