Kernels
the type of kernel that you use, and the OS architecture, depends on the application
Monolithic kernels
- main program invokes syscall
- kernel is underlying monolithic block:
- service procedures carry out syscalls
- utility procedures help implement service procedures
data:image/s3,"s3://crabby-images/a8738/a8738ffc04b270a9c4460e8d9c1b5ece63e759bb" alt="screenshot.png"
- separate applications and OS using privilege levels into user and kernel
- on x86, 4 privilege levels (but in practice mostly 2 are used)
- this is supported by the hardware directly
- if only goal is to separate untrustworthy apps from lower level shit, you only need 2 separate levels
- if you include more levels, there’s a cost associated with switching between levels, so why do it if it’s not needed
data:image/s3,"s3://crabby-images/9baeb/9baebc179588a0629e1aa64ec1cd25f17aecf2fb" alt="screenshot.png"
Virtualisation
- originally to separate multiprogramming from extended machine
- N independent system call interfaces
data:image/s3,"s3://crabby-images/dd1b7/dd1b73f3dd4bda0b2c702d27e02060ae9ced24a9" alt="screenshot.png"
- Virtual machine monitor (VMM/Hypervisor) emulates hardware
- types:
-
1: VMM runs on bare metal (like Xen)
data:image/s3,"s3://crabby-images/33f60/33f60090ac6f60503e6faf0de46383a75c9e61eb" alt="screenshot.png"
-
2: VMM hosted on OS (like QEMU)
data:image/s3,"s3://crabby-images/b4104/b4104b2e196a53f7481e15535700c85a46a0ecda" alt="screenshot.png"
-
Hybrid: VMM inside OS (like KVM)
Exokernel
- separate resource control from extended machine
- unlike VMM/Hypervisor, it:
- does not emulate hardware. only resource manager
- only provides safe low-level resource sharing
- service procedures are offered as library linked directly to application – “Library OS”
- different library OSes for different programs, allows application-level specialisation
Client/server model (microkernel)
- organise service procedures in programs running in separate processes (system services/drivers)
- high level of isolation
- processes communicate via message passing
- calls rely on the same mechanism (message passing)
- messaging is implemented in microkernel (minimal kernel)
- principle of least privilege – isolate every service in its own domain (address space, process, etc.)
- this is more secure, but lower performance (always a tradeoff). have to switch between modes and shit
data:image/s3,"s3://crabby-images/d7030/d70306d4b6692406010ad2d2edd7fff1a7281c97" alt="screenshot.png"
Microvisor
- combination of hypervisor and microkernel
- different OS architectures have different design points, people look at convergence and tradeoffs
data:image/s3,"s3://crabby-images/4a788/4a78847496d1475d03f3fb1fd93e8b1ca3074f04" alt="screenshot.png"
Unikernel
- “single simple application implementing whatever in the cloud, in most efficient way”
- squash application and OS kernel into one thing, don’t need all of the other stuff like process management
- gets rid of all of the overhead