Ch 2. Getting Started with the Kernel

Slides:



Advertisements
Similar presentations
Copyright © 2000, Daniel W. Lewis. All Rights Reserved. CHAPTER 10 SHARED MEMORY.
Advertisements

More on Processes Chapter 3. Process image _the physical representation of a process in the OS _an address space consisting of code, data and stack segments.
Chapter 7: User-Defined Functions II
Architectural Support for OS March 29, 2000 Instructor: Gary Kimura Slides courtesy of Hank Levy.
Introduction to Operating Systems – Windows process and thread management In this lecture we will cover Threads and processes in Windows Thread priority.
Embedded Real-time Systems The Linux kernel. The Operating System Kernel Resident in memory, privileged mode System calls offer general purpose services.
Advanced OS Chapter 3p2 Sections 3.4 / 3.5. Interrupts These enable software to respond to signals from hardware. The set of instructions to be executed.
Process in Unix, Linux and Windows CS-3013 C-term Processes in Unix, Linux, and Windows CS-3013 Operating Systems (Slides include materials from.
Process in Unix, Linux, and Windows CS-3013 A-term Processes in Unix, Linux, and Windows CS-3013 Operating Systems (Slides include materials from.
Recall: Three I/O Methods Synchronous: Wait for I/O operation to complete. Asynchronous: Post I/O request and switch to other work. DMA (Direct Memory.
Lecture 3 Process Concepts. What is a Process? A process is the dynamic execution context of an executing program. Several processes may run concurrently,
CE Operating Systems Lecture 11 Windows – Object manager and process management.
Operating Systems 1 K. Salah Module 1.2: Fundamental Concepts Interrupts System Calls.
Operating Systems CSE 411 CPU Management Sept Lecture 10 Instructor: Bhuvan Urgaonkar.
Embedding Assembly Code in C Programs תרגול 7 שילוב קוד אסמבלי בקוד C.
Introduction Contain two or more CPU share common memory and peripherals. Provide greater system throughput. Multiple processor executing simultaneous.
Operating Systems Unit 2: – Process Context switch Interrupt Interprocess communication – Thread Thread models Operating Systems.
LECTURE 3 Translation. PROCESS MEMORY There are four general areas of memory in a process. The text area contains the instructions for the application.
Embedded Real-Time Systems Processing interrupts Lecturer Department University.
Getting Started with the Kernel. Obtaining the Kernel Source
A Single Intermediate Language That Supports Multiple Implemtntation of Exceptions Delvin Defoe Washington University in Saint Louis Department of Computer.
Lecture 3 Translation.
Chapter 4 – Thread Concepts
Getting Started with the Kernel
Using Ada-C/C++ Changer as a Converter Automatically convert to C/C++ to reuse or redeploy your Ada code Eliminate the need for a costly and.
MODERN OPERATING SYSTEMS Third Edition ANDREW S
Processes and threads.
User-Written Functions
Process concept.
CSC201: Computer Programming
Process Management Process Concept Why only the global variables?
© 2016 Pearson Education, Ltd. All rights reserved.
CS 6560: Operating Systems Design
Operating Systems •The kernel is a program that constitutes the central core of a computer operating system. It has complete control over everything that.
Session 3 Memory Management
Protection of System Resources
Computer Architecture
Chapter 4 – Thread Concepts
Objectives Identify the built-in data types in C++
Run-time organization
C Basics.
Structure of Processes
Chapter 3: Windows7 Part 2.
Chapter 3 Process Management.
Threads and Data Sharing
Chapter 3: Windows7 Part 2.
Format String.
Pointers.
Chapter 2: The Linux System Part 3
Operating System Concepts
Classes and Objects.
Fast Communication and User Level Parallelism
Architectural Support for OS
CSE 451: Operating Systems Autumn 2003 Lecture 2 Architectural Support for Operating Systems Hank Levy 596 Allen Center 1.
CSE 451: Operating Systems Autumn 2001 Lecture 2 Architectural Support for Operating Systems Brian Bershad 310 Sieg Hall 1.
Introduction to Data Structure
CSE 451: Operating Systems Winter 2007 Module 2 Architectural Support for Operating Systems Brian Bershad 562 Allen Center 1.
Unix Process Control B.Ramamurthy 4/11/2019 B.Ramamurthy.
Submitted By : Veenu Saini Lecturer (IT)
CSE 451: Operating Systems Winter 2003 Lecture 2 Architectural Support for Operating Systems Hank Levy 412 Sieg Hall 1.
Outline Operating System Organization Operating System Examples
Architectural Support for OS
The C Language: Intro.
Process Description and Control in Unix
Foundations and Definitions
Process Description and Control in Unix
Lecture 4: Instruction Set Design/Pipelining
Structure of Processes
In Today’s Class.. General Kernel Responsibilities Kernel Organization
Presentation transcript:

Ch 2. Getting Started with the Kernel

A Beast of a Different Nature (1) The kernel has several differences compared to normal user-space applications The kernel does not have access to the C library. The kernel is coded in GNU C The kernel lacks memory protection like user-space. The kernel cannot easily use floating point The kernel has a small fixed-size stack The kernel is preemptive It has asynchronous interrupts Synchronization and concurrency are major concerns within the kernel Portability is important

A Beast of a Different Nature (2) No libc Unlike a user-space application, the kernel is not linked against the standard C library The full C library, or even a decent subset of it, is too large and too inefficient for the kernel Many of the usual libc functions have been implemented inside the kernel e.g., the common string manipulation functions are in lib/string.c. Just include <linux/string.h>. Of the missing functions, the most familiar is printf()

A Beast of a Different Nature (3) The kernel does not have access to printf() It does have access to printk() The printk() function copies the formatted string into the kernel log buffer Normally read by the syslog program Usage is similar to printf(): printk("Hello world! A string: %s and an integer: %d\n", a_string, an_integer); printk() allows you to specify a priority flag This flag is used by syslogd to decide where to display kernel messages e.g., printk(KERN_ERR "this is an error!\n");

A Beast of a Different Nature (4) GNU C Like any self-respecting Unix kernel, the Linux kernel is programmed in C The kernel is not programmed in strict ANSI C The kernel developers make use of various language extensions available in gcc The kernel developers use both ISO C99 and GNU C extensions to the C language Some of the more interesting extensions that may show up in kernel code

A Beast of a Different Nature (5) Inline Functions GNU C supports inline functions Inserted inline into each function call site This eliminates the overhead of function invocation and return (register saving and restore) Allows for potentially more optimization The compiler can optimize the caller and the called function together Code size increases, which increases memory consumption The contents of the function are copied to all the callers Kernel developers use inline functions for small time-critical functions

A Beast of a Different Nature (6) Making large functions inline is frowned upon by the kernel developers Especially those that are used more than once or are not time critical An inline function is declared when the keywords static and inline are used as part of the function definition static inline void dog(unsigned long tail_size) The function declaration must precede any usage Or else the compiler cannot make the function inline Common practice is to place inline functions in header files

A Beast of a Different Nature (7) Inline Assembly The gcc C compiler enables the embedding of assembly instructions in normal C functions This feature is used in only those parts of the kernel that are unique to a given system architecture The asm() compiler directive is used to inline assembly code The Linux kernel is programmed in a mixture of C and assembly With assembly relegated to low-level architecture and fast path code The vast majority of kernel code is programmed in straight C

A Beast of a Different Nature (8) Branch Annotation The gcc C compiler has a built-in directive that optimizes conditional branches As either very likely taken or very unlikely taken Consider an if statement such as the following if (foo) { /* ... */ } To mark this branch as very unlikely taken, i.e. we predict foo is nearly always zero: if (unlikely(foo)) { /* ... */ } Conversely, to mark a branch as very likely taken:, i.e. we predict foo is nearly always nonzero: if (likely(foo)) { /* ... */ }

A Beast of a Different Nature (9) Only use these directives when the branch direction is overwhelmingly a known priori or when you want to optimize a specific case at the cost of the other case These directives result in a performance boost when the branch is correctly predicted A performance loss when the branch is mispredicted A very common usage for unlikely() and likely() is error conditions unlikely() finds much more use in the kernel because if statements tend to indicate a special case No Memory Protection

A Beast of a Different Nature (10) The kernel can trap the error, send SIGSEGV, and kill the process When a user-space application attempts an illegal memory access If the kernel attempts an illegal memory access, the results are less controlled Memory violations in the kernel result in a major kernel error Must not illegally access memory, such as dereferencing a NULL pointer Kernel memory is not pageable Every byte of memory you consume is one less byte of available physical memory.

A Beast of a Different Nature (11) No (Easy) Use of Floating Point The kernel manages the transition from integer to floating point mode When a user-space process uses floating-point instructions What the kernel has to do when using floating-point instructions Unlike user-space, the kernel does not have the seamless support for floating point because it cannot trap itself Using floating point inside the kernel requires manually saving and restoring the floating point registers, among possible other chores

A Beast of a Different Nature (12) Small, Fixed-Size Stack User-space can statically allocate tons of variables on the stack, including huge structures and many-element arrays This behavior is legal because user-space has a large stack that can grow in size dynamically The kernel stack is neither large nor dynamic It is small and fixed in size The exact size of the kernel's stack varies by architecture On x86, the stack size is configurable at compile-time and can be either 4 or 8KB The kernel stack is two pages Generally implies that it is 8KB on 32-bit architectures and 16KB on 64-bit architectures This size is fixed and absolute Each process receives its own stack

A Beast of a Different Nature (13) Synchronization and Concurrency The kernel is susceptible to race conditions Unlike a single-threaded user-space application, a number of properties of the kernel allow for concurrent access of shared resources Require synchronization to prevent races Linux is a preemptive multi-tasking operating system Processes are scheduled and rescheduled at the whim of the kernel's process scheduler The kernel must synchronize between these tasks The Linux kernel supports multiprocessing Without proper protection, kernel code executing on two or more processors can access the same resource

A Beast of a Different Nature (14) Interrupts occur asynchronously with respect to the currently executing code Without proper protection, an interrupt can occur in the midst of accessing a shared resource and the interrupt handler can then access the same resource The Linux kernel is preemptive Without protection, kernel code can be preempted in favor of different code that then accesses the same resource Typical solutions to race conditions include spinlocks and semaphores

A Beast of a Different Nature (15) Portability Is Important Linux is a portable operating system and should remain one Architecture-independent C code must correctly compile and run on a wide range of systems Architecture-dependent code must be properly segregated in system-specific directories in the kernel source tree A handful of rules such as remain endian neutral, be 64-bit clean, do not assume the word or page size, and so on, go a long way