1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2026-01-13 01:31:00 +00:00
serenity/Base
Andreas Kling f598bbbb1d Kernel: Prevent executing I/O instructions in userspace
All threads were running with iomapbase=0 in their TSS, which the CPU
interprets as "there's an I/O permission bitmap starting at offset 0
into my TSS".

Because of that, any bits that were 1 inside the TSS would allow the
thread to execute I/O instructions on the port with that bit index.

Fix this by always setting the iomapbase to sizeof(TSS32), and also
setting the TSS descriptor's limit to sizeof(TSS32), effectively making
the I/O permissions bitmap zero-length.

This should make it no longer possible to do I/O from userspace. :^)
2020-01-01 17:31:41 +01:00
..
etc WindowServer: Remove Clock from server. 2019-12-27 22:47:31 +01:00
home/anon WindowServer+LibGUI: Implement basic color theming 2019-12-23 20:33:01 +01:00
res Base: Update Finnish keymap with proper AltGr support 2019-12-31 19:46:40 +01:00
usr Kernel: Prevent executing I/O instructions in userspace 2020-01-01 17:31:41 +01:00