Giáo trình Hệ điều hành - Chương 7: Bộ nhớ thực

pdf 25 trang huongle 2960
Bạn đang xem 20 trang mẫu của tài liệu "Giáo trình Hệ điều hành - Chương 7: Bộ nhớ thực", để tải tài liệu gốc về máy bạn click vào nút DOWNLOAD ở trên

Tài liệu đính kèm:

  • pdfgiao_trinh_he_dieu_hanh_chuong_7_bo_nho_thuc.pdf

Nội dung text: Giáo trình Hệ điều hành - Chương 7: Bộ nhớ thực

  1. Chapter 7: Bộ Nhớ Thực Các kiểu địa chỉ nhớ Chuyển đổi địa chỉ nhớ Overlay và swapping Vấn đề cấp phát bộ nhớ liên tục (contiguous memory allocation)  Giải pháp fixed partitioning  Giải pháp dynamic partitioning 1 Quản lý bộ nhớ Kernel chiếm một vùng cố định của bộ nhớ, vùng còn lại dành để cấp phát cho các process Cấp phát vùng nhớ cho các process sao cho hệ thốâng hoạt động hiệu quả  Vd: Nạp càng nhiều process vào bộ nhớ càng tốt để gia tăng mức độ multiprogramming Quản lý bộ nhớ  Cấp phát vùng nhớ cho các process  Bảo vệ: kiểm tra truy xuất bộ nhớ có hợp lệ không  Chia sẻ: cho phép các process chia sẻ vùng nhớ chung  Chuyển đổi địa chỉ luận lý sang địa chỉ vật lý 2 Các kiểu địa chỉ nhớ (1/2) Địa chỉ vật lý physical (memory) address là địa chỉ mà CPU, hay MMU (nếu có), gửi đến bộ nhớ chính Địa chỉ luận lý (logical address) là địa chỉ mà một quá trình sinh ra Các địa chỉ sinh bởi trình biên dịch (compiler) là  tương đối hay khả tái định vị (relocatable): compiler giả thiết không gian địa chỉ của đơn vị biên dịch (compilation unit) bắt đầu từ địa chỉ 0 hoặc  tuyệt đối: kết quả biên dịch có thể nạp được ngay vào bộ nhớ để thực thi; ít được dùng 3 1
  2. Các kiểu địa chỉ nhớ (2/2) Khi một lệnh được thực thi, các địa chỉ luận lý phải được chuyển đổi thành địa chỉ vật lý  Sự chuyển đổi này thường có sự hỗ trợ của phần cứng để đạt hiệu năng cao 4 Từ mã nguồn đến file thực thi được Linker: kết hợp các object module thành một file thực thi được  tái định vị địa chỉ tương đối và phân giải các external reference  kết hợp các object module thành một load module (file nhị phân khả thực thi) System static linking library dynamic linking System library 5 Thực hiện (static) linking Linker chuyển đổi địa chỉ tương đối sang địa chỉ tuyệt đối 0 0 Module A relocatable Module A object modules CALL B length L JMP “L” L - 1 Return L - 1 Return L Module B 0 Module B load module JMP “L+M” CALL C length M L M - 1 Return M - 1 Return L M Module C 0 Module C length N L M N - 1 Return N - 1 Return 6 2
  3. Chuyển đổi địa chỉ Chuyển đổi địa chỉ: quá trình ánh xạ một địa chỉ từ không gian địa chỉ này sang không gian địa chỉ khác Biểu diễn địa chỉ nhớ  Trong source code: symbolic (các biến, hằng, pointer )  Thời điểm biên dịch: thường là địa chỉ tương đối  Ví dụ: a ở vị trí 14 byte so với vị trí bắt đầu của module  Thời điểm linking/loading: có thể là địa chỉ tuyệt đối 0 2000 int i; goto p1; p1 250 2250 symbolic address relative address physical memory 7 Sinh địa chỉ tuyệt đối vào thời điểm biên dịch Symbolic Absolute Physical memory addresses addresses addresses PROGRAM 1024 1024 JUMP i JUMP 1424 JUMP 1424 i 1424 1424 LOAD j LOAD 2224 LOAD 2224 Compile Load DATA j 2224 2224 Source code Absolute load module Process image 8 Chuẩn bị sinh địa chỉ vật lý (1) Vào thời điểm biên dịch  Compiler sinh địa chỉ tuyệt đối  Cần thông tin cho biết load module sẽ được nạp ở đâu  Không cần linker  Loader rất đơn giản  Hiếm được dùng (MSDOS .COM files) 9 3
  4. Chuẩn bị sinh địa chỉ vật lý (2) Vào thời điểm link-edit  Compiler  Sinh địa chỉ tương đối (a.k.a. relocatable) cho mỗi đơn vị biên dịch  Tham chiếu đến địa chỉ ngoài  Linkage editor  Chuyển đổi địa chỉ relocatable sang địa chỉ tuyệt đối  Phân giải các tham chiếu đến địa chỉ ngoài  Cần thông tin cho biết linked program sẽ được nạp ở đâu  Loader vẫn còn rất đơn giản  Yêu cầu về phần cứng thấp  Một chương trình chỉ có thể được nạp tại nơi đã được đặc tả và không thể dịch chuyển sau khi được nạp  Không còn được dùng nhiều 10 Chuẩn bị sinh địa chỉ vật lý (3) Vào thời điểm nạp  Tương tự thời điểm link-edit, nhưng không giữ cố định địa chỉ bắt đầu  Chương trình có thể được nạp ở bất cứ đâu  Chương trình có thể dịch chuyển nhưng không tách được  Chỉ cần phần cứng đơn giản: các thanh ghi base/limit  Loader thiết lập trị cho các thanh ghi base/limit  Không còn được dùng phổ biến 11 Sinh địa chỉ vật lý Vào thời điểm thực thi  Địa chỉ được chuyển đổi động trong khi thực thi  Cần có phần cứng để chuyển đổi địa chỉ ảo sang địa chỉ vật lý được nhanh  “Phân trang” (“paging”)  “Phân đoạn” (“segmentation”)  Rất phổ biến hiện nay 12 4
  5. Sử dụng vùng nhớ bớt phí phạm Các kỹ thuật hỗ trợ sử dụng vùng nhớ bớt phí phạm:  Dynamic linking  Dynamic loading  Overlay  Swapping 13 Dynamic linking (1) Trong dynamic linking Việc link một load module L đến một module ngoài (external module) được thực hiện sau khi đã tạo xong L  MS Windows: module ngoài là các file .dll  Unix: module ngoài là các file .so (shared library) Load module chứa các stub tham chiếu (refer) đến các routine của external module  Khi process gọi routine lần đầu, stub sẽ nạp routine vào bộ nhớ (nếu routine chưa được nạp trước đó), thay thế địa chỉ mình bằng địa chỉ routine, và gọi routine để thực thi  Các lần gọi routine sau sẽ xảy ra bình thường, không tốn overhead 14 Dynamic linking (2) Nhắc lại static linking 0x08048000 main: program call printf printf: copy từ libc ret 15 5
  6. Dynamic linking (3) 0x08048000 main: dlfixup: program GOT[5] = &printf call printf call printf PLT printf: (r/o code) call GOT[5] GOT [5]: dlfixup (r/w data) 0x40001234 printf: libc ret Fig from M. Rosenblum 16 Ưu điểm của dynamic linking Chương trình thực thi có thể gọi phiên bản mới (ví dụ phiên bản đã sửa lỗi) của external module mà không cần được sửa đổi và/hay biên dịch lại Chia sẻ mã (code sharing): chỉ cần nạp external module vào bộ nhớ một lần  Các process sử dụng dynamic link với external module này chia sẻ vùng mã của external module tiết kiệm không gian nhớ và không gian đĩa 17 Dynamic linking Các external module thường là thư viện cung cấp các tiện ích (như libc) Stub cần sự hỗ trợ của OS  Kiểm tra xem routine đã được nạp vào bộ nhớ chưa 18 6
  7. Dynamic loading (1) Chỉ khi nào cần được gọi đến thì một thủ tục mới được nạp vào bộ nhớ chính  Các thủ tục không được gọi đến sẽ không chiếm chỗ trong bộ nhớ Rất hiệu quả khi chương trình có khối lượng lớn mã có tần suất sử dụng thấp (ví dụ các thủ tục xử lý lỗi) Chính quá trình tự điều khiển dynamic loading  Hệ điều hành cung cấp một số thủ tục thư viện hỗ trợ 19 Dynamic loading (2) Các thủ tục để người dùng thực hiện dynamic loading trong UNIX:  dlopen() – Open một file thư viện  dlsym() – Dò tìm một ký hiệu trong file thư viện  dlclose() – Close một file thư viện 20 Dynamic loading – Ví dụ 21 7
  8. Kỹ thuật overlay (1/2) Chỉ giữ trong bộ nhớ những lệnh hoặc dữ liệu cần thiết, giải phóng các lệnh/dữ liệu chưa hoặc không cần dùng đến Kỹ thuật này rất hữu dụng khi kích thước một process lớn hơn kích thước vùng nhớ cấp cho nó Quá trình tự điều khiển việc overlay (có sự hỗ trợ của thư viện lập trình) Có thể được xem là tiền thân của kỹ thuật “bộ nhớ ảo” 22 Kỹ thuật overlay (2/2) Pass 1 70K Đơn vị: byte symbol Pass 2 80K 20K Symbol table 20K table Common routines 30K common Assembler 30K routines Total memory available = 150KB overlay 10K driver nạp và thực thi pass 1 pass 2 70K 80K 23 Swapping Cơ chế: di chuyển một process khỏi bộ nhớ chính và lưu trên bộ nhớ phụ (swap out). Khi thích hợp, nạp process vào bộ nhớ (swap in) để có thể tiếp tục thực thi Chính sách:  Round-robin: swap out P1 (vừa tiêu thụ hết quantum của nó), swap in P2 , thực thi P3 ,  Roll out, roll in: dùng trong định thời theo độ ưu tiên (priority- based scheduling)  Process có độ ưu tiên thấp hơn sẽ bị swap out nhường chỗ cho process có độ ưu tiên cao hơn vừa đến 24 8
  9. Swapping Cơ chế 25 Vấn đề cấp phát bộ nhớ liên tục Trong phần còn lại của chương này, mô hình quản lý bộ nhớ là một mô hình đơn giản [không dùng “bộ nhớ ảo”]  Một process phải được nạp hoàn toàn và liên tục vào bộ nhớ (ngoại trừ khi dùng kỹ thuật overlay) Sẽ thảo luận các giải pháp cấp phát bộ nhớ sau  Phân chia cố định (fixed partitioning)  Phân chia động (dynamic partitioning) 26 Hiện tượng phân mảnh Phân mảnh ngoại (external fragmentation)  Vùng nhớ còn trống đủ lớn để thỏa mãn một yêu cầu cấp phát, nhưng lại không liên tục  Có thể dùng kết khối (compacting) để gom lại thành vùng nhớ liên tục Phân mảnh nội (internal fragmentation)  Vùng nhớ được cấp phát lớn hơn vùng nhớ yêu cầu  Ví dụ: cấp một khoảng trống 18.464 byte cho một process yêu cầu 18.462 byte  Thường xảy ra khi bộ nhớ thực được chia thành các khối kích thước cố định (fixed-sized block) và các process được cấp phát theo đơn vị khối 27 9
  10. Phân mảnh nội operating yêu cầu kế tiếp là system 18.462 byte (used) hole kích thước 18.464 byte Để tránh overhead quản lý chỉ 2 byte, OS sẽ cấp phát hẳn khối 18.464 byte cho process dư ra 2 byte không dùng 28 Fixed partitioning (1) Khi khởi động hệ thống, bộ nhớ chính được chia thành nhiều phần cố định rời nhau, gọi là các partition, có kích thước bằng nhau hoặc khác nhau Process nào có kích thước nhỏ hơn hoặc bằng kích thước partition thì có thể được nạp vào partition đó 29 Giải pháp fixed partitioning (2) Nếu process có kích thước lớn hơn partition thì phải dùng kỹ thuật overlay Không hiệu quả do bị phân mảnh nội: một chương trình dù lớn hay nhỏ đều được cấp phát trọn một partition 30 10
  11. Chiến lược placement khi fixed partitioning (1/3) Trường hợp các partition có kích thước bằng nhau  Nếu còn partition trống process mới sẽ được nạp vào partition đó  Nếu không còn partition trống, nhưng có process đang bị blocked swap out process đó ra bộ nhớ phụ, dành partition cho process mới 31 Chiến lược placement khi fixed partitioning (2/3) Trường hợp các partition có kích thước không bằng nhau  Giải pháp 1  Gán mỗi process vào partition nhỏ nhất (trống hay không trống) đủ chứa nó [best fit]  Có hàng đợi cho mỗi partition  Điểm yếu của giải pháp 1: có thể có một số hàng đợi trống (vì không có process với kích thước tương ứng) và một số hàng đợi dài 32 Chiến lược placement khi fixed partitioning (3/3) Trường hợp các partition có kích thước không bằng nhau  Giải pháp 2  Khi cần nạp một process vào bộ nhớ chính chọn partition nhỏ nhất còn trống và đủ chứa nó [best fit]  Chỉ có một hàng đợi chung cho mọi partition 33 11
  12. Giải pháp dynamic partitioning Số lượng và vị trí partition không cố định và partition có thể có kích thước khác nhau Mỗi process được cấp phát chính xác dung lượng bộ nhớ cần thiết Gây ra hiện tượng phân mảnh ngoại 34 Chiến lược placement khi dynamic partitioning Quyết định cấp phát khối bộ nhớ trống nào cho một process Mục tiêu: giảm chi phí compaction Các chiến lược placement  Best-fit: chọn khối nhớ trống nhỏ nhất  First-fit: chọn khối nhớ trống phù hợp đầu tiên kể từ đầu bộ nhớ  Next-fit: chọn khối nhớ trống phù hợp đầu tiên kể từ vị trí cấp phát cuối cùng  Worst-fit: chọn khối nhớ trống lớn nhất 35 Nhận xét Cả hai giải pháp fixed và dynamic partitioning hầu như không còn được dùng trong các hệ thống hiện đại 36 12
  13. Chapter 7 Cơ chế phân trang (paging) Cơ chế phân đoạn (segmentation) Segmentation with paging 37 Cơ chế phân trang (1/3) Cơ chế phân trang (paging) cho phép không gian địa chỉ vật lý (physical address space) của một process có thể không liên tục nhau Bộ nhớ thực được chia thành các khối cố định và có kích thước bằng nhau gọi là frame  Thông thường kích thước của frame là lũy thừa của 2, từ khoảng 512 byte đến 16 MB Nhắc lại, bộ nhớ luận lý (logical memory) hay không gian địa chỉ luận lý là tập mọi địa chỉ luận lý của quá trình – Địa chỉ luận lý có thể được quá trình sinh ra bằng cách dùng indexing, base register, segment register, 38 Cơ chế phân trang (2/3) Bộ nhớ luận lý cũng được chia thành các khối cố định có cùng kích thước gọi là trang nhớ (page) Frame và trang nhớ có kích thước bằng nhau Hệ điều hành phải thiết lập một bảng phân trang (page table) để chuyển đổi (translate) địa chỉ luận lý thành địa chỉ thực  Mỗi process được cấp phát một bảng phân trang  Thiết lập bảng phân trang cho process là một phần của chuyển ngữ cảnh Kỹ thuật phân trang khiến bộ nhớ có thể bị phân mảnh nội, nhưng khắc phục được phân mảnh ngoại 39 13
  14. Cơ chế phân trang (3/3) page frame number number 0 0 0 1 1 page 0 1 1 4 2 2 2 3 3 page 2 3 3 5 4 page 1 logical memory page table 5 page 3 physical memory 40 Chuyển đổi địa chỉ trong paging Địa chỉ luận lý gồm có:  Page number, p, là chỉ mục (index) vào bảng phân trang. Mỗi mục (entry) trong bảng phân trang chứa chỉ số frame, gọi là số frame cho gọn, chứa trang tương ứng trong bộ nhớ thực  Page offset, d, được kết hợp với địa chỉ nền (base address) của frame để cho địa chỉ thực m Nếu kích thước của không gian địa chỉ ảo là 2 và kích thước của trang là 2n ô nhớ (byte hay word tùy theo kiến trúc máy) page number page offset p d m - n bit n bit (định vị từ 0  2m - n - 1) (định vị từ 0  2n - 1) Bảng phân trang sẽ có tổng cộng 2m/2n = 2m - n mục 41 Paging hardware f frame logical physical address address f 00 00 CPU p d f d f 11 11 p f physical Nếu kích thước của bộ nhớ memory thực là 2l (byte), thì mỗi mục page table của bảng phân trang có l - n frame number frame offset bit để chứa frame number f, l - n bit d, n bit 42 14
  15. Chuyển đổi địa chỉ nhớ trong paging Ví dụ: 43 Hiện thực bảng phân trang (1) Bảng phân trang được giữ trong bộ nhớ chính  Mỗi process được cấp một bảng phân trang  Thanh ghi page-table base (PTBR) trỏ đến bảng phân trang  Thanh ghi page-table length (PTLR) chứa kích thước của bảng phân trang (có thể được dùng trong cơ chế bảo vệ bộ nhớ) 44 Hiện thực bảng phân trang (2) Mỗi truy cập dữ liệu/lệnh cần hai thao tác truy xuất vùng nhớ 1. Dùng page number p làm index để truy xuất mục trong bảng phân trang nhằm lấy số frame 2. Dùng page offset d để truy xuất dữ liệu/lệnh trong frame Do đó, thường dùng một cache phần cứng có tốc độ truy xuất và tìm kiếm cao, gọi là thanh ghi kết hợp (associative register) hoặc translation look-aside buffers (TLBs)  Nguyên lý locality 45 15
  16. TLB TLB tìm kiếm truy xuất dữ liệu của nó với tốc độ cực nhanh Số mục của TLB Page number Frame number khoảng 8 2048 TLB là cache của bảng phân trang Khi có chuyển ngữ cảnh, TLB bị xóa Khi TLB đầy, thay thế mục dùng LRU Ánh xạ page number – Nếu page number có trong TLB (“hit”, trúng) lấy ngay được frame number tiết kiệm được việc truy cập bộ nhớ để lấy frame number từ bảng phân trang – Ngược lại (“miss”, trật), phải lấy frame number từ bảng phân trang như bình thường 46 Paging hardware với TLB 47 Đánh giá hiệu năng của TLB (1/2) • Tính thời gian truy xuất hiệu dụng (Effective access time, EAT) Thời gian tìm kiếm trong TLB:  Thời gian một chu kỳ truy xuất bộ nhớ: x Hit ratio : tỉ số giữa số lần page number được tìm thấy (hit) trong TLB và số lần truy xuất khởi nguồn từ CPU  0 1 Tính thời gian cần thiết để truy xuất ô nhớ:  Khi page number có trong TLB (“hit”)  + x  Khi page number không có trong TLB (“miss”)  + x + x Thời gian truy xuất hiệu dụng EAT = ( + x) + ( + 2x)(1 – ) = (2 – )x +  48 16
  17. Đánh giá hiệu năng của TLB (2/2) Giả sử (đơn vị thời gian: nano giây)  Tìm trong TLB = 20  Memory access = 100 Ví dụ 1 Ví dụ 2  Hit ratio = 0,8  Hit ratio = 0,98  EAT = (100 + 20) 0,8 +  EAT = (100 + 20) 0,98 + (200 + 20) 0,2 (200 + 20) 0,02 = 1,2 100 + 20 = 1,02 100 + 20 = 140 = 122 49 Bảo vệ bộ nhớ Việc bảo vệ bộ nhớ được hiện thực bằng cách dùng các bit bảo vệ (protection bit) được giữ trong mỗi mục của bảng phân trang. Các bit này biểu thị các thuộc tính của trang như  read-only, read-write, execute-only Ngoài ra, còn có một valid-invalid bit gắn với mỗi mục trong bảng phân trang; trị của bit có thể là  “valid”: cho biết là trang của process, do đó là một trang hợp lệ  “invalid”: cho biết là trang không của process, do đó là một trang bất hợp lệ 50 Bảo vệ bằng valid-invalid bit 00000 frame valid-invalid 0 number bit 1 0 2 v 2 page 0 1 3 v 3 page 1 2 4 v 4 page 2 3 7 v 5 4 8 v 6 10468 12287 5 9 v 7 page 3 6 - i 8 page 4 9 page 5 7 - i page n Mỗi trang nhớ có kích thước 2K = 2048 ô nhớ Process có kích thước 10.468 phân mảnh nội ở frame 9 (chứa page 5), các địa chỉ ảo > 12287 là các địa chỉ invalid Dùng PTLR để kiểm tra truy xuất đến bảng phân trang có nằm trong bảng hay không 51 17
  18. Bảng phân trang 2 mức (1/5) Các hệ thống hiện đại đều hỗ trợ không gian địa chỉ ảo rất lớn (232 đến 264), ở đây giả sử là 232 12  Giả sử kích thước trang nhớ là 4 K (= 2 ) ô nhớ không gian địa chỉ ảo sẽ gồm 232/212 = 220 = 1 M page bảng phân trang sẽ có 1 M mục  Giả sử mỗi mục của bảng phân trang gồm 4 byte thì mỗi process cần 4 MB cho bảng phân trang, và 100 quá trình sẽ cần Một giải pháp là, thay vì dùng một bảng phân trang duy nhất cho mỗi process, “paging” bảng phân trang này, và chỉ sinh những bảng phân trang cần thiết bảng phân trang 2 mức (two-level page table) 52 Bảng phân trang 2 mức (2/5) • Ví dụ Một địa chỉ luận lý trên hệ thống 32-bit với trang nhớ 4K được chia thành các phần sau: page number offset  Page number: 20 bit  Nếu mỗi mục dài 4 byte 20 Cần 2 4 byte = 4 MB 20 bit 12 bit cho mỗi page table  Page offset: 12 bit Bây giờ, bảng phân trang cũng được chia nhỏ nên page number cũng được chia nhỏ thành 2 phần, vd page offset  10-bit page number p1 p2 d  10-bit page offset 10 bit 10 bit 12 bit Vì vậy, một địa chỉ luận lý sẽ như hình vẽ bên • p1 : chỉ số của mục trong bảng phân trang mức 1 (outer-page table) • p2 : chỉ số của mục trong bảng phân trang mức 2 53 Bảng phân trang 2 mức (3/5) n1 bit n2 bit - Có 2n1 mục trong bảng phân trang mức 1 - Mỗi bảng phân trang mức 2 chứa 2n2 mục các bảng phân trang mức 2 54 18
  19. Bảng phân trang 2 mức (4/5) Sơ đồ chuyển đổi địa chỉ (address-translation scheme) cho kỹ thuật phân trang 2 mức, với 32-bit địa chỉ page table mức 2 55 Bảng phân trang 2 mức (5/5) Bảng phân trang 2 mức giúp tiết kiệm bộ nhớ:  Vùng màu đỏ tương ứng với phần không được sử dụng của không gian địa chỉ ảo  Các mục màu đỏ được đánh dấu là không có frame  Hình: để dễ thấy, các frame đã được cấp sao cho text, data, stack, nằm liên tục giống như trong không gian địa chỉ ảo Fig from Gottlieb 56 Bảng phân trang đa mức Ví dụ: Không gian địa chỉ luận lý 64-bit với trang nhớ 4K  Bảng phân trang 2-mức vẫn còn quá lớn! Tương tự bảng phân trang 2 mức, ta có bảng phân trang 3, 4, , n mức page number page offset page numbers page offset 52 12 42 10 12 page numbers page offset page numbers page offset 32 10 10 12 22 10 10 10 12 Tiết kiệm chổ trong bộ nhớ chính bằng cách chỉ sinh các bảng phân trang mà process cần 57 19
  20. Bảng phân trang băm (1/2) Nhận xét: Phí phạm vùng nhớ cho page table khi quá trình chỉ truy cập một số lượng nhỏ các trang Dùng kỹ thuật băm để giảm kích thước bảng phân trang  Phổ biến trong các hệ thống có địa chỉ lớn hơn 32 bit Để giải quyết đụng độ khi lưu, mỗi mục của bảng băm được gắn một danh sách liên kết mà mỗi phần tử là một cặp (chỉ số trang, chỉ số frame):  Chỉ số trang được biến đổi qua hàm băm thành một hashed value  Kế đó, cặp (chỉ số trang, chỉ số frame) sẽ được lưu vào danh sách liên kết tại mục có chỉ số là hashed value 58 Bảng phân trang băm (2/2) Giải thuật tìm trang: Chỉ số trang được biến đổi thành hashed value chỉ số của mục cần truy cập trong bảng băm. Sau đó, trong danh sách liên kết của mục, tìm phần tử chứa chỉ số trang để trích ra được chỉ số frame 59 Chia sẻ các trang nhớ Process 1 0 ed 1 0 3 1 data 1 ed 2 1 4 2 data 3 6 Process 2 ed 3 2 3 ed 1 3 1 ed 1 4 ed 2 data 1 0 3 ed 2 1 4 5 2 6 6 ed 3 ed 3 ed 1 3 7 7 data 2 0 3 data 2 8 ed 2 1 4 9 ed 2 2 6 2 10 data 3 3 Process 3 Bộ nhớ thực 60 20
  21. Phân đoạn (1/3) Dưới góc nhìn của user, một chương trình cấu thành từ nhiều đơn vị luận lý gọi là đoạn (segment)  Lệnh: main program, procedure, function  Dữ liệu: local variables, global variables, common block, stack, symbol table, arrays, 61 User view của một chương trình Thông thường, một chương trình được biên dịch. Trình biên dịch sẽ tự động xây stack procedure dựng các segment Ví dụ, trình biên dịch Pascal symbol sẽ tạo ra các segment table  Global variables function sqrt  Procedure call stack main program  Procedure/function code  Local variable Trình loader sẽ gán mỗi segment một số định danh riêng 62 Phân đoạn (2/3) Dùng cơ chế phân đoạn (segmentation) trong quản lý bộ nhớ có hỗ trợ user view  Không gian địa chỉ ảo là một tập các đoạn, mỗi đoạn có tên và kích thước riêng  Một địa chỉ luận lý gồm tên đoạn và độ dời (offset) bên trong đoạn đó (so sánh với phân trang!)  Cho phép không gian địa chỉ vật lý cấp cho process có thể không liên tục nhau 63 21
  22. Phân đoạn (3/3) logical address space physical memory space segment 1 segment 2 segment 3 segment 4 64 Hiện thực phân đoạn Địa chỉ luận lý là một cặp (segment number, offset) Bảng phân đoạn (segment table): gồm nhiều mục, mỗi mục mô tả một segment và chứa  limit, xác định kích thước của segment  base, chứa địa chỉ khởi đầu của segment trong bộ nhớ Segment-table base register (STBR): trỏ đến vị trí bảng phân đoạn trong bộ nhớ Segment-table length register (STLR): số lượng segment của chương trình Một chỉ số segment s là hợp lệ nếu s < STLR 65 Một ví dụ về phân đoạn stack 1400 procedure procedure segment 3 limit base 2400 segment 0 0 1000 1400 symbol 3200 table 1 400 6300 stack 2 400 4300 function segment 4 sqrt 4300 3 1100 3200 main main program 4 1000 4700 4700 segment 1 segment symbol table segment 2 table 5700 6300 function sqrt logical address space physical memory space 66 22
  23. Phần cứng hỗ trợ phân đoạn segment s table limit base CPU s d yes physical + memory no trap; addressing error 67 Phân đoạn: Chuyển đổi địa chỉ Ví dụ 68 Chia sẻ các đoạn editor limit base 43062 data 1 0 25286 43062 1 4425 68348 segment 0 segment 1 editor segment table process P1 logical address space 68348 process P data 1 1 72773 editor limit base data 2 0 25286 43062 90003 data 2 segment 1 1 8850 90003 segment 0 98853 segment table process P2 logical address space physical memory process P2 69 23
  24. Kết hợp phân trang và phân đoạn (1/2) Kết hợp phân trang và phân đoạn nhằm tận dụng các ưu điểm và hạn chế các khuyết điểm của chúng:  Vấn đề của phân đoạn: một đoạn có thể không nạp được vào bộ nhớ, mặc dù đủ không gian trống, do phân mảnh ngoại  Ý tưởng giải quyết: paging đoạn, cho phép các page của đoạn được nạp vào các frame không cần nằm liên tục nhau 70 Kết hợp phân trang và phân đoạn (2/2) Có nhiều cách kết hợp. Một cách đơn giản là segmentation with paging • Mỗi process sẽ được cấp:  Một bảng phân đoạn  Nhiều bảng phân trang: mỗi đoạn có một bảng phân trang Một địa chỉ luận lý (địa chỉ ảo) bao gồm:  segment number: là chỉ số của một mục trong bảng phân đoạn, mục này chứa địa chỉ nền (base address) của bảng phân trang cho đoạn đó  page number: là chỉ số của một mục trong bảng phân trang, mục này chứa chỉ số frame trong bộ nhớ thực  offset: độ dời của vị trí ô nhớ trong frame nói trên 71 Segmentation with paging (1/3) frame 0 frame 1 frame 2 frame 3 frame 4 (STE: segment table entry frame 5 PTE: page table entry) frame 6 Fig from Gottlieb 72 24
  25. Segmentation with paging (2/3) 73 Segmentation with paging (3/3) Segment base: địa chỉ thực của bảng phân trang của segment present (hay valid-invalid) bit và modified bit chỉ tồn tại trong bảng phân trang Các thông tin bảo vệ và chia sẻ vùng nhớ thường nằm trong bảng phân đoạn  Ví dụ: read-only/read-write bit, 74 25