Dr. Mark Humphrys

School of Computing. Dublin City University.

Online coding site: Ancient Brain

coders   JavaScript worlds

Search:


OS structure

"Process" = A program running. Could be multiple copies of the same program running. (Multiple processes.)



Device speed

See History of OS.
What do we mean "I/O devices are slower than CPU" ?




Device controllers and Interrupts



CPU is kept free (responsive to user, able to run other code) while device I/O is going on.

Modern OS driven by interrupts.

Interrupts are to do with the massive asymmetry between CPU speeds and device speeds. They are how the OS program runs on hardware with slow devices.




Interrupts (IRQs) on Windows 10.
My Computer - Properties - Device Manager - View - Resources by Type - Interrupt Request (IRQ)
Note IRQ 0 - System timer.




Examples of Interrupts



Does an infinite loop cause an interrupt?

Does an infinite loop quickly (or eventually) cause an interrupt?

The Halting Problem (Turing, 1936).

Might just be a long loop. We have no way of knowing.
But still, even if long loop, control must switch occasionally - time-slicing.
It is a timer interrupt that switches control. But loop runs forever, time-sliced.



Unsolved problems in mathematics.
Note that if you could detect an infinite loop in general, then could solve all problems of the form:

Does there exist a solution to f(n)
for n > t?
by asking the OS if the following:
repeat
 n := n+1
 test solution
until solution
is an infinite loop, or just a long loop? Then our OS could solve many of the world's great mathematical problems.
Many mathematical problems can be phrased as infinite-loop problems.



Note that many "infinite loops" actually terminate with a crash, because they are using up some resource each time round the loop. e.g. This program:

f ( int x )
{
 f(x);
}

f(1);
will eventually crash with a stack overflow.
This program however:
while true { }
will run forever, time-sliced.




Interrupts - Keeping the OS in charge

Interrupt idea is a way of periodically keeping the OS in charge so nothing runs forever without reference to the OS. e.g. In time-slicing, periodic timer interrupt to give OS a chance to do something else with the CPU.

Remember, the CPU is just looking for a stream of instructions to process, whether they come from the "OS" or from "user programs". When the OS "runs" a program, it points the CPU towards a stream of instructions in the user program and basically hands over control. How do we know program cannot now control CPU for ever?

Note: Interrupt does not necessarily mean that OS immediately attends to the process that sent it (in the sense of giving it CPU time). It just means the OS is now aware that that process wants attention. The OS will note that its "state" has changed.

  

Asynchronous programming




CPU modes

CPU modes

There must be a concept of an "OS-type program" (which can do anything, including scheduling ordinary programs) and an "ordinary program" (which is restricted in what it can do on the machine).

The restrictions on the "ordinary program" are normally not a problem - they are basically just: "Other programs have to be able to run at the same time as you".

This obviously makes sense in a multi-user system, but in fact it makes sense on a PC as well. When you're writing a program and you make an error, you don't want your crashed program to be able to crash the whole OS. You still want to be able to turn to the OS (which should still be responsive) and say "terminate that program".

Code is executed either in kernel/system/monitor mode or in user mode.

boot in system mode, load OS
when run program, switch to user mode

when interrupt, switch to system mode 
 and jump to OS code

when resume, switch back to user mode
 and return to next instruction in user code
Privileged instructions can only be executed in system mode.
e.g. Perhaps any I/O at all - user can't do I/O, user has to ask OS to do I/O for it (OS will co-ordinate it with the I/O of other processes).

  

Superuser

A related but different issue is switching between "ordinary" users and users with administration rights.

On Linux, if you have admin (root/superuser) access to your own Linux, see these commands:




The kernel is the part of OS that is not scheduled

Consider the different types of code, OS or applications:


  1. Parts of OS that are not scheduled themselves. Are always in memory. Operate in kernel/system mode.
    This part of the OS is called the kernel.
    Includes:
    • memory management
    • process scheduling
    • device I/O

    
    
  2. Parts of OS that can be scheduled. Come in and out of memory. Operate in user mode.
    Includes:
    • command-line
    • GUI
    • OS utilities

    Parts of OS that could be in either of the above:

    • file system
    • network interface

    
    
  3. Applications. All scheduled. Come in and out of memory. Operate in user mode.




Windows has both kernel-mode drivers and user-mode drivers.
From Microsoft driver developer manual.




Virtual Machine (VM)



Virtual machine



Running Linux inside Windows with VMware.
I have used VMware in DCU labs to teach system administration of an imaginary multi-machine network all running on one machine.
Image from here.




Java Virtual Machine

The idea of Java and the JVM:


Promises of Java and the JVM:

  1. Portability. Write an application once, run everywhere.

  2. Run code from Internet on client-side. Even though from a site with different hardware, they will run on your hardware.
    Java applets. Client-side code on the Web. Written in Java, compiled bytecodes transmitted.
    Played an important role in the history of client-side code.
    But now obsolete. Mostly replaced by what language?


Types of languages:


New idea for the Web:




Most Popular Programming Languages 1965 - 2019.


  

What language is OS written in?

OS'es are written mainly in HLL, with some Assembly in Kernel.
Assembly fast but hardware-specific.
HLL much more portable, much easier to write/debug/change/maintain.






Languages used in Android.
From here.




Is Assembly needed?

Assembly is faster. But not needed everywhere.




In practice, C/C++ is often faster than Assembly. Why?
Because C/C++ compiler is probably a better optimiser of code than your hand-coded Assembly.
So often stick to a HLL like C/C++ even for performance-critical code.
Compiler often has a -optimise switch to take extra time analysing HLL code to generate faster Assembly.



Part of the Linux OS source. Written in C.
This is part of init/main.c in Linus Torvalds' Linux source.



ancientbrain.com      w2mind.org      humphrysfamilytree.com

On the Internet since 1987.      New 250 G VPS server.

Note: Links on this site to user-generated content like Wikipedia are highlighted in red as possibly unreliable. My view is that such links are highly useful but flawed.