KEMBAR78
Memory Management in LINUX | PDF | Kernel (Operating System) | Operating System
0% found this document useful (0 votes)
584 views16 pages

Memory Management in LINUX

This document contains two sections that discuss memory management in Linux and registers in computers. Section one discusses how Linux manages physical memory using buddy allocation and virtual memory using paging. It describes how programs are mapped into memory regions and pages, and swapped between physical memory and disk using a clock replacement policy. Section two will discuss processor registers, their types and uses, and how they are organized in computers.

Uploaded by

Shifan Demahom
Copyright
© Attribution Non-Commercial (BY-NC)
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
584 views16 pages

Memory Management in LINUX

This document contains two sections that discuss memory management in Linux and registers in computers. Section one discusses how Linux manages physical memory using buddy allocation and virtual memory using paging. It describes how programs are mapped into memory regions and pages, and swapped between physical memory and disk using a clock replacement policy. Section two will discuss processor registers, their types and uses, and how they are organized in computers.

Uploaded by

Shifan Demahom
Copyright
© Attribution Non-Commercial (BY-NC)
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
You are on page 1/ 16

Hardware Software Systems and Network Individual Assignment

TABLE OF CONTENTS

GANTT CHART ...2 ABSTRACT ...3 SECTION ONE Introduction ....4 Memory management in Linux ..5 Management of physical memory...5 Virtual memory ..6 Mapping of programs into memory ...8 Frequently asked questions 9 SECTION TWO Introduction 10 Registers .11 Types of registers ...12 Frequently asked questions 14 CONCLUSION ..15 REFERENCES ..16

Asia Pacific University College of Technology and Innovation

Hardware Software Systems and Network Individual Assignment

GANTT CHART

Asia Pacific University College of Technology and Innovation

Hardware Software Systems and Network Individual Assignment

ABSTRACT
This individual assignment is about operating systems and computer systems architecture. Both the topics will be discussed in two different sections: Section One and section Two. Section one will highlight on the Linux operating system. Mainly this section will highlight on the memory management of the Linux operating system. How the memory is managed, the mechanisms involved in memory management process and the strategies used. The section will also look into the problems faced by these techniques and solutions to overcome them. Section two is about the registers in modern computers. The section will manly discuss the usage of registers, different types of registers, different size of registers and organization of register in a computer.

Asia Pacific University College of Technology and Innovation

Hardware Software Systems and Network Individual Assignment

SECTION ONE
INTRODUCTION
This section is about the memory management in Linux operating system. Memory management is a very important process for any operating system. Different systems use different mechanisms and strategies for managing the memory. These mechanisms and strategies can have different advantages and disadvantages depending on the operating system. And minor or major problems occur in almost all the operating systems during the memory management process. Linux operating system is an operating system derived from Unix operating system. It is an open source operating system, which means the programmer codes are readily available to the public. The codes can be modified by anyone and can be distributed by anyone, but under the license of Linux operating system. Unix operating systems are mostly used in servers and workstations.

Asia Pacific University College of Technology and Innovation

Hardware Software Systems and Network Individual Assignment

MEMORY MANAGEMENT IN LINUX

Memory management refers to the aforethought organization of computer programs and its data into memory. Management of the computer memory is very important for any operating system in order to maximize the use of memory and to reduce waste. And makes it as simple and easy as possible for the programs to find space to be loaded and executed. Memory management by any operating system is done by a memory manager which keeps track of the memory in use and memory which are free. Management of memory in Linux consists of two components. First one which deals with allocation of physical memory and release of physical memory to pages, page groups and small memory blocks. And the second one which deals with memory which is mapped into the address space of running processes. This memory is also known as Virtual memory.

MANAGEMENT OF LINUX PHYSICAL MEMORY The primary physical memory in Linux is managed by the page allocator. It is an allocator in charge for allocation of all physical pages and freeing all physical pages. The available pages are kept in track with the help of an algorithm by the page allocator. The algorithm used is the buddy-heap algorithm. The allocatable memory is of several units and it is this algorithm which pairs the adjacent units together. In Linux, a single page is the smallest size allocatable by this mechanism. The figure 1 below shows how the buddy-heap algorithm works. The 16KB region is broken into two pieces of 8KB, and one of the 8KB piece is broken up again to two pieces of 4KB. This is how it process until there is availability of desired size.

8KB 16KB 8KB

8KB

4KB 4KB

Figure 1: Splitting of memory in a buddy heap.

Asia Pacific University College of Technology and Innovation

Hardware Software Systems and Network Individual Assignment It is either by drivers or page allocator through which all the memory allocations occur in Linux. The memory management subsystems like the virtual memory system, the kmalloc variable length allocator and the kernels buffer cache and the page cache manage their memory pool with the help of the page allocator. The kmalloc service allocates the page which is on demand, and breaks into smaller pieces. The kernel maintains the list of pages in use by the kmalloc service. Memory allocation involves getting a free available page from the list of pages and breaking it into pieces. Or allocating a page which is new and breaking it. The kmalloc allocators and the page are free from interrupts. Memory regions claimed by the kmalloc system allocated permanently until they are freed explicitly. It cannot relocate these regions in case of memory shortages. For devices like disk drives the kernel has a main cache called buffer cache. The page cache is the cache which caches all the pages of file contents. Networked data can also be cached with the page cache. The virtual address space of any processes contains several contents. These contents are managed by the virtual memory VIRTUAL MEMORY The address space of each and every process is maintained by the Virtual memory. The maintenance process is done by the virtual memory manager in two views, as a set of: Separate regions. Pages.

The logical view is the first view of address space. It describes the instructions received by the virtual memory system relating to the layout. The second view is the physical view. It is stored in the hardware page tables for the process. The exact current location of each page of virtual memory is determined by the page table entries. If there is no available page but still a process tries accessing it, a set of routines from kernels software interrupt handlers manages the physical view. Virtual memory regions There are several types of memory regions in Linux. The first property that characterizes the type of virtual memory is the backing stores for the region describing where the pages come. Most of the memory regions are backed by a file, or sometimes nothing. A region in place of demand zero memory is the simplest of virtual memory and it is when a region is backed by nothing. A virtual memory region is also defined by its reaction to writes. The mapping of a region into the address space can be either private or shared.

Asia Pacific University College of Technology and Innovation

Hardware Software Systems and Network Individual Assignment Lifetime of a Virtual Address Space The Linux kernel creates a new virtual address space in two situations 1. When a new program is run by the process with exec system call; upon execution of a new program, a new address space is given to the process. Loading and to populate the address space with virtual memory regions is up to the routines. 2. Creation of a new process by the fork system call; this involves creating a complete copy of the virtual address space of the existing process. After the fork, the child and the parent share the same physical pages in their address spaces. Swapping and Paging Relocating pages of memory from physical memory out to disk when it is needed is an important task of a virtual memory system. Earlier UNIX systems used swapping for relocation, but the modern UNIX systems use paging- the movement of individual pages of virtual memory between physical memory and disk. Linux uses the paging mechanism and does not implement whole process swapping. There are two sections in the paging system.. 1. The policy algorithm; which takes the decision of which pages to write and at what time to write. 2. The paging mechanism; which move and pages data back into physical memory when required again. Page out policy of Linux uses a modified version of standard clock algorithm. In Linux, it consists of a multiple pass clock and there is an age for every page that is attuned on each pass of the clock. The age is considered as how much activity the page has seen recently. Frequently used pages will acquire a higher age value. The age valuing helps the pager to select the pages to page out according to least frequently used policy. The paging mechanism supports paging to swap devices and partitions, and also to normal files. According to bitmap of used blocks, blocks are allocated from the swap devices. The allocator uses a next-fit algorithm to write out pages to continuous runs of disk blocks. The allocator records the fact that a page has been paged out using a feature of the page tables in modern processors. Kernel Virtual Memory In Linux, the page table entries that map to kernel pages are marked protected so that the pages are not modifiable when the processor is running in user mode. The kernel virtual memory consists of two main regions. The first section contains references of page-tables to each available physical page. The core of the kernel and the pages allocated by the page allocator resides in this section. The remainder of kernels reserved section of address space is not held in reserve for any purpose.

Asia Pacific University College of Technology and Innovation

Hardware Software Systems and Network Individual Assignment MAPPING OF PROGRAMS INTO MEMORY In Linux, the binary loader does not load a binary file into physical memory. But the pages of binary file are mapped into regions of virtual memory. The kernels binary loader is responsible for setting up the initial memory mapping. The figure 2 below shows a typical memory layout set up by the ELF Loader.

Kernel virtual memory Stack

Memory invisible to user mode code

Memory-mapped region Memory-mapped region Memory-mapped region The brk pointer Run-time data Uninitialized data Initialized data Program text

Forbidden region

Figure 2: Memory layout for ELF programs The loader initializes the memory mapping of the stack and the programs text and data regions. The stack created at the top grows downwards towards the lower-numbered addresses. The other regions are created near the bottom end of the virtual memory. Each process has a pointer called brk which points the current extent of data region.

Asia Pacific University College of Technology and Innovation

Hardware Software Systems and Network Individual Assignment FREQUENTLY ASKED QUESTIONS 1. What is the main goal of memory management in an operating system? The main goal of memory management is to maximize the use of memory and to reduce waste. 2. What does a memory manger do? Memory manager keeps track of memory which are being used and memory which are free. 3. Who manages the primary physical memory in Linux operating system? Page allocator 4. What is paging? The breaking down of logical memory into blocks of same size called pages.

Asia Pacific University College of Technology and Innovation

Hardware Software Systems and Network Individual Assignment

SECTION TWO
INTRODUCTION
This section is about the processor registers in modern computers. what are registers? What does it do? How does it help the computer in performance? Answers to all these questions are discussed in this chapter. There are different types of registers with different sizes in capacity. All these will be discussed in this section of the assignment.

Asia Pacific University College of Technology and Innovation

10

Hardware Software Systems and Network Individual Assignment

REGISTERS
The data being worked on by the processor is held in storage areas of the processor. These fast memory local storage areas are called registers. Registers play an important role in a computer system. Earlier computers had only few registers to do the instructions. But the computers today have different categories of registers to perform different operations. The property of locality of reference of computer programs is acquired with the help of registers. Registers hold the frequently accessed values in it and helps in improving the program execution performance. A compiler performs the action of register allocation where frequently used variables are allocated to registers. Without suitable register allocation, it can be difficult to save and store intermediate computational values and, especially in early generation computing systems, register dancing was a serious problem. Poor register allocation could lead to register spillage. Register are in the top level of memory hierarchy and it helps in fast accessing of data than the memory elsewhere. The following diagram shows the memory hierarchy of a computer and where the registers stand in the hierarchy.

Figure 3: Computer memory hierarchy As we go down the hierarchy, the capacity and access time increases. But the frequency of access of the memory by the processor decreases. And hence, since the registers are on top, they are the fastest accessed memory

Asia Pacific University College of Technology and Innovation

11

Hardware Software Systems and Network Individual Assignment TYPES OF REGISTERS Registers are generally measured by means of the number bits they can hold. In various machines they are implemented different ways. In some systems they are implemented using individual flip-flops, in some systems using core memory of high speed, and in some systems with using thin film memory, and many other ways in various machines. Depending on the content and instructions on registers there are different types of registers. User-accessible Registers: o Data registers and Address registers are the most common type of these registers. o Data registers These are registers used to hold integer values and floating-point values, and they are usually 16-bit in size. In earlier computers an Accumulator is used to perform these instructions. o Address registers These are registers which hold the memory addresses and they are used by the instruction which indirectly accesses the memory. These registers are usually 12bit in size. Conditional registers o Whether a certain instruction should be executed or not is determined by the truth values. It is the conditional registers which hold the these truth values and determines whether to execute or deny. General purpose registers o General purpose registers are registers which hold both data and addresses. And they are also referred to as combined data/address registers Floating point registers o A computer needs a way to store the floating point values for certain instructions. As the register name suggests, it is these registers who store the floating point numbers. Constant registers o Constant registers hold the read-only values. Read- only values are values such as 1, 0 and pi. Vector registers o The data for the processing of vector is done by some instructions. These instructions are called SIMD (Single Instruction, Multi Data) instructions. Vector registers hold the data for the process of vector processing.

Asia Pacific University College of Technology and Innovation

12

Hardware Software Systems and Network Individual Assignment Special purpose registers o These are registers which hold program state and are inclusive of program counter, stack pointer and status register. These registers are usually 12-bit in size. Instruction registers o These are registers which Stores the executed instructions. They are 16-bit in size. model-specific registers o The processor need to store its data and its settings in order to function well. So that it can recall the data and settings easily. The model-specific registers in the CPU are responsible for storing these data and settings. Model- specific registers are also called as machine specific registers.

Input and output registers o These registers are 8-bit in size and holds the input and output characters. Increment and decrement registers o These registers hold the increment and decrement operators of the system. An increment operator is an operator which increases the value of a variable. And a decrement operator decreases the value of a variable. Temporary registers o The temporary data of the system holds some important data. So some registers hold the temporary data of the system. These registers are called temporary registers. There are several other registers which fetch memory from Random Access Memory (RAM). These are usually in chips separate from the computer processing unit. In recent Intel core 2 duo processors there are about 16 integer registers and double floating point registers. The Intel core duo processors are of 8 integer registers and double floating point registers. The Pentium 4 processors also have 8 integer registers and double floating point registers and as the Pentium 4 with EM64T 16 integer registers and double floating point registers. The Athlon 64 processors also have 16 integer registers and double floating point registers. And Athlon MP Processors have 8 integer registers and double floating point registers. The Itanium 2 processors have 128 integer registers and double floating point registers. The UltraSPARC IIIi processors and Power 3 processors have 32 integer registers and double floating point registers. The 6502 processors have no double floating point registers. It has only 3 integer registers. PIC Microcontroller has just 1 integer register.

Asia Pacific University College of Technology and Innovation

13

Hardware Software Systems and Network Individual Assignment

FREQUENTLY ASKED QUESTIONS 1. What is the difference between registers and cache memory? Registers are fast memory storage areas in a CPU. Cache memory is the RAM (Random Access Memory) faster than the regular RAM. Registers are faster than cache memory. 2. What are the two types of locality of reference? Temporal locality and spatial locality 3. What is register allocation? Allocation of recurrently used variables to processor registers is called register allocation. 4. Can a computer function smoothly without a register? No

Asia Pacific University College of Technology and Innovation

14

Hardware Software Systems and Network Individual Assignment

CONCLUSION
Memory management in any operating system is very important task. Different operating systems use different mechanism and strategies of memory management. Linux operating system is a virtual memory system which mainly uses Paging and swapping for memory management. Registers are fast memory storage areas which plays an important role in a computer system. There are different categories of registers, and depending on the processor type the number of registers differs from one processor to other. Registers help in program execution and performance.

Asia Pacific University College of Technology and Innovation

15

Hardware Software Systems and Network Individual Assignment

REFERENCES
1. 2. 3. 4. 5. 6. Rubini, A, Corbet, J 2001, Linux Device Drivers, 2nd edition. http://www.osdata.com/topic/language/asm/register.htm http://www.makelinux.net/ldd3/chp-15-sect-1.shtml http://www.pcguide.com/ref/cpu/arch/int/compRegisters-c.html http://www.statemaster.com/encyclopedia/Processor-register

Asia Pacific University College of Technology and Innovation

16

You might also like