



# Embedded Operating Systems

*Trainer: Nilesh Ghule*







① RAM is divided in small equal sized partitions called as frames.  
 ② Process is divided in small equal sized parts called as pages. Page size is same as frame size.  
 ③ OS allocated one page to one empty frame. To keep track, page & frame addr mapping is stored in a table - called as - page table.  
 ④ Page table is associated in PCB of process.  
 ⑤ During Ctx switch page table entries of scheduled process will be loaded into MMU.  
 ⑥ Page size depends on CPU arch  
 a) @ x86 arch  $\rightarrow$  4KB or 4MB.  
 b) ARM arch  $\rightarrow$  1K, 4K, 64K or 1 MB.

In case of mem shortage, OS swap out one/more pages of machine process. When CPU req page (that is not in RAM), the page will be loaded from disk/swap  $\rightarrow$  Demand Paging

# Segmented Paging

| process    |
|------------|
| Stack (6K) |
| Heap (1K)  |
| Data (5K)  |
| Text (10K) |
| = 22KB     |



## Page Table

e.g. process 40 MB

page size = 4 KB

then

$$\begin{aligned} \text{num of pages} &= \frac{40 \text{ MB}}{4 \text{ KB}} \\ &= \frac{40 \times 1024 \times 1024}{4 \times 1024} \\ &= 10240 \end{aligned}$$

option 2: keep pg addr with pid (to avoid pg

addr conflict betn multiple processes).

pid + Pg addr = asid (addr space id).



Nilesh Ghule

## Two-level Paging



Primary Page Table = 1 Page (4KB).

Sum of max entries = 1024

⇒ max num of SEC page tables = 1024

Secondary page table  $\rightarrow$  Per page (4KB)

num of rows entries = 1024

⇒ more num of process pages = 1024

size of one process page = 4 KB

# Mark Process Side

= max num of SRC table page \*

num of page for sec p.t & size of page.

$$= 1024 \times 1024 \times 4 \times 1024 = 4 \underline{\text{GB}}$$

## Three-level paging

L1 P.T.  $\rightarrow$  L2 P.T.  $\rightarrow$  L3 P.T.  $\rightarrow$  Processed pages.

virtual addr  
space (32-bit)  
4GB



## Page Table entry → Invalid ?

- when page is not present in RAM
  - Ⓐ may be invalid page (dangling ptr).
  - Ⓑ may not be allocated yet.
  - Ⓒ may be in swap area
  - Ⓓ may be in disk (in exe file)



*Thank you!*

Nilesh Ghule <[nilesh@sunbeaminfo.com](mailto:nilesh@sunbeaminfo.com)>