An instance of a running program is called a process.
|=======================
Every time you run a shell command, a program is run and a process is created for it.
|Command| Meaning
|ls| Displays a list of files in the current working directory.
|cd directory| change directories
In any modern operating system there can be more than one instance of a program loaded in memory at the same time.
|passwd |change the password for the current user
|file filename| display file type of file with name filename
== Linux process management
|cat textfile| throws content of textfile on the screen
|pwd| display present working directory
Operating systems need some ways to create processes.
|exit or logout| leave this session
|man command| read man pages on command
* In a very simple system designed for running only a single application (e.g., the controller in a microwave oven), it may be possible to have all the processes that will ever be needed be present when the system comes up.
|=======================
* In general-purpose systems, however, some way is needed to create and terminate processes as needed during operation.
=== Key combinations
[NOTE]
.Key combinations
====
[options="header,footer"]
|=======================
*There are four principal events that cause a process to be created:*
|Key or key combination| Function
|Ctrl+C| End a running program and return the prompt
* System initialization.
|Ctrl+Z| Suspend a program
* Execution of process creation system call by a running process.
|ArrowUp and ArrowDown| Browse history. Go to the line that you want to repeat, edit details if necessary, and press Enter to save time.
* A user request to create a new process.
|Tab| Command or filename completion; when multiple choices are possible, the system will either signal with an audio or visual bell, or, if too many choices are possible, ask you if you want to see them all.
* Initiation of a batch job.
|Tab Tab| Shows file or command completion possibilities.
====
|Shift+PageUp and Shift+PageDown| Browse terminal buffer (to see text that has "scrolled off" the screen).
|=======================
Process creation in UNIX and Linux are done through *fork()* or *clone()* system calls.
=== ls -l
There are several steps involved in process creation.
-rw-rw-r-- 1 zeus zeus 1517 Οκτ 23 21:55 INSTALL.md
=== process state
-rw-rw-r-- 1 zeus zeus 33883 Οκτ 15 14:28 LICENSE
-rw-rw-r-- 1 zeus zeus 691 Οκτ 17 11:13 README.md
An operating system kernel that allows multitasking needs processes to have certain states. Names for these states are not standardised, but they have similar functionality.
----
==== File types
[.float-group]
--
This table gives an overview of the characters determining the file type:
[.right]
image:./Process_states.png[350,350,role="related thumb right"]
NOTE: **d**rwxrwxr-x 4 zeus zeus 4096 Οκτ 14 20:24 install
* the process is *"created"*.
.File types in a long list
* After that the process scheduler assigns it the *"waiting"* state.
[options="header,footer"]
* While the process is *"waiting"*, it waits for the scheduler to do a so-called context switch.
|=======================
* The context switch loads the process into the processor and changes the state to *"running"* while the previously *"running"* process is stored in a *"waiting"* state.
|Symbol| Meaning
* If a process in the *"running"* state needs to wait for a resource, it is assigned the *"blocked"* state.
|-| Regular file
* The process state is changed back to *"waiting"* when the process no longer needs to wait (in a blocked state).
|d| Directory
* Once the process *finishes execution*, or is *terminated* by the operating system, it is no longer needed.
|l| Link
* The process is *removed instantly* or is moved to the *"terminated"* state.
|c| Special file
* When removed, it just waits to be *removed from main memory*.
|s| Socket
|p| Named pipe
|b| Block device
--
|=======================
NOTE: -**rw-**rw-r-- 1 zeus zeus 1517 Οκτ 23 21:55 INSTALL.md
=== Inter-process communication
==== Access rights
When processes need to communicate with each other they must share parts of their address spaces or use other forms of inter-process communication (IPC).
.Access rights
* For instance in a shell pipeline, the output of the first process need to pass to the second one.
[options="header,footer"]
* another example is a task that can be decomposed into cooperating but partially independent processes which can run at once
|=======================
** (i.e., using concurrency, or true parallelism - the latter model is a particular case of concurrent execution and is feasible whenever enough CPU cores are available for all the processes that are ready to run).
|Code| Meaning
|0 or -|The access right that is supposed to be on this place is not granted.
NOTE: It is even possible for two or more processes to be running on different machines that may run different operating system (OS), therefore some mechanisms for communication and synchronization (called communications protocols for distributed computing) are needed (e.g., the *Message Passing Interface, often simply called MPI*).
|4 or r|read access is granted to the user category defined in this place
|2 or w|write permission is granted to the user category defined in this place
|1 or x|execute permission is granted to the user category defined in this place
==== communication between processes
|=======================
Processes can communicate with each other through:
==== User group codes
* Shared Memory
* Message passing
.User group codes
[options="header,footer"]
|=======================
[.float-group]
|Code| Meaning|
--
|u| user permissions|-**rw-**rw-r--
[.right]
|g| group permissions|-rw-**rw-**r--
image:./1-76.png[350,350,role="related thumb right"]
|o| permissions for others|-rw-rw-**rw-**
[.left]
|=======================
image:./2-50.png[350,350,role="related thumb left"]