Tin học văn phòng - Chapter 7: Bộ nhớ thực

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 ? Giả sử kích thước trang nhớ là 4 K (= 212) ô 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)

pdf25 trang | Chia sẻ: huyhoang44 | Lượt xem: 680 | Lượt tải: 0download
Bạn đang xem trước 20 trang tài liệu Tin học văn phòng - Chapter 7: Bộ nhớ thực, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
11 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 2 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ý 3 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 24 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 5 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 library System library static linking dynamic linking 6 Thực hiện (static) linking  Linker chuyển đổi địa chỉ tương đối sang địa chỉ tuyệt đối Module A CALL B Return length L Module B CALL C Return length M Module C Return length N 0 L - 1 Module A JMP “L” Return Module B JMP “L+M” Return Module C Return L L  M - 1 L  M L  M  N - 1 relocatable object modules load module 0 L - 1 0 M - 1 0 N - 1 37 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 250 2000 2250 relative address physical memory symbolic address int i; goto p1; p1 8 Sinh địa chỉ tuyệt đối vào thời điểm biên dịch Symbolic addresses Absolute addresses Physical memory addresses PROGRAM JUMP i LOAD j DATA i j Source code 1024 JUMP 1424 LOAD 2224 1424 2224 Absolute load module Compile Load 1024 JUMP 1424 LOAD 2224 1424 2224 Process image 9 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) 410 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 11 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 12 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 513 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 14 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 15 Dynamic linking (2)  Nhắc lại static linking main: ... call printf printf: ... ret 0x08048000 program copy từ libc 616 Dynamic linking (3) main: ... call printf 0x40001234 printf: ... ret 0x08048000 program libc printf: call GOT[5] ... [5]: dlfixup ... PLT (r/o code) GOT (r/w data) dlfixup: GOT[5] = &printf call printf Fig from M. Rosenblum 17 Ư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 18 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 719 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ợ 20 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 21 Dynamic loading – Ví dụ 822 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” 23 Pass 1 70K Pass 2 80K Symbol table 20K Common routines 30K Assembler Total memory available = 150KB Kỹ thuật overlay (2/2) symbol table 20K common routines 30K overlay driver 10K pass 1 pass 2 80K70K Đơn vị: byte nạp và thực thi 24 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 925 Swapping -- Cơ chế 26 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) 27 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 10 28 Phân mảnh nội operating system (used) yêu cầu kế tiếp là 18.462 byte 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 29 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 đó 30 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 11 31 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 32 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 33 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 12 34 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 35 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 36 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 13 37 Chapter 7  Cơ chế phân trang (paging)  Cơ chế phân đoạn (segmentation)  Segmentation with paging 38 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, 39 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 14 40 Cơ chế phân trang (3/3) logical memory 1 4 3 5 0 1 2 3 page table page 0 page 2 physical memory frame number 0 1 2 3 page 14 5 page 3 page number 0 1 2 3 41 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  Nếu kích thước của không gian địa chỉ ảo là 2m và kích thước của trang là 2n ô nhớ (byte hay word tùy theo kiến trúc máy) Bảng phân trang sẽ có tổng cộng 2m/2n = 2m - n mục p d page number page offset m - n bit (định vị từ 0  2m - n - 1) n bit (định vị từ 0  2n - 1) 42 Paging hardware Nếu kích thước của bộ nhớ thực là 2l (byte), thì mỗi mục của bảng phân trang có l - n bit để chứa frame number frame number frame offset f, l - n bit d, n bit CPU p d f d f p page table logical address physical address physical memory f 0000 f 1111 f frame 15 43 Chuyển đổi địa chỉ nhớ trong paging  Ví dụ: 44 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ớ) 45 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 16 46 TLB  TLB tìm kiếm truy xuất dữ liệu của nó với tốc độ cực nhanh Page number Frame number Số mục của TLB khoảng 8 .. 2048 Khi có chuyển ngữ cảnh, TLB bị xóa TLB là cache của bảng phân trang Á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 Khi TLB đầy, thay thế mục dùng LRU 47 Paging hardware với TLB 48 Đá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 +  17 49 Đánh giá hiệu năng của TLB (2/2)  Ví dụ 1  Hit ratio = 0,8  EAT = (100 + 20)  0,8 + (200 + 20)  0,2 = 1,2  100 + 20 = 140  Ví dụ 2  Hit ratio = 0,98  EAT = (100 + 20)  0,98 + (200 + 20)  0,02 = 1,02  100 + 20 = 122  Giả sử (đơn vị thời gian: nano giây)  Tìm trong TLB = 20  Memory access = 100 50 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ệ 51 Bảo vệ bằng valid-invalid bit 00000 10468 12287 2 v 3 v 4 v 7 v 8 v 9 v - i - i frame number valid-invalid bit 0 1 2 3 4 5 6 7 0 1 2 page 0 3 page 1 4 page 2 5 6 7 page 3 8 page 4 9 page 5 ... 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 18 52 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  Giả sử kích thước trang nhớ là 4 K (= 212) ô 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) 53 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: 20 bit  Nếu mỗi mục dài 4 byte  Cần 220 4 byte = 4 MB 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  10-bit page number  10-bit page offset  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 page number offset p2 page offset dp1 10 bit10 bit 12 bit 20 bit 12 bit 54 Bảng phân trang 2 mức (3/5) các bảng phân trang mức 2 - 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 n2 bitn1 bit 19 55 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 56 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 57 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  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 page number page offset page numbers page offset page numbers page offset page numbers page offset 52 12 42 10 12 32 10 10 12 22 10 10 10 12 20 58 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 59 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 60 Chia sẻ các trang nhớ Process 1 ed 1 ed 2 ed 3 data 1 ed 1 ed 2 ed 2 data 3 Process 3 3 4 6 2 0 1 2 3 3 4 6 1 0 1 2 3 Process 2 ed 1 ed 2 ed 3 data 2 3 4 6 7 0 1 2 3 0 1 data 1 2 data 3 3 ed 1 4 ed 2 5 6 ed 3 7 data 2 8 9 10 Bộ nhớ thực 21 61 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, 62 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 dựng các segment  Ví dụ, trình biên dịch Pascal sẽ tạo ra các segment  Global variables  Procedure call stack  Procedure/function code  Local variable  Trình loader sẽ gán mỗi segment một số định danh riêng procedure stack symbol table function sqrt main program 63 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 22 64 Phân đoạn (3/3) logical address space physical memory space segment 1 segment 2 segment 3 segment 4 65 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 66 Một ví dụ về phân đoạn procedure stack symbol table function sqrt main program segment 0 segment 3 segment 1 segment 2 segment 4 procedure stack main symbol table function sqrt limit base 0 1000 1400 1 400 6300 2 400 4300 3 1100 3200 4 1000 4700 segment table logical address space physical memory space 1400 2400 3200 4300 4700 5700 6300 23 67 Phần cứng hỗ trợ phân đoạn CPU  + physical memory no trap; addressing error limit base s s d yes segment table 68 Phân đoạn: Chuyển đổi địa chỉ  Ví dụ 69 Chia sẻ các đoạn editor data 1 segment 0 segment 1 logical address space process P1 editor data 2 segment 0 segment 1 logical address space process P2 limit base 0 25286 43062 1 4425 68348 segment table process P1 limit base 0 25286 43062 1 8850 90003 segment table process P2 editor data 1 data 2 physical memory 43062 72773 68348 90003 98853 24 70 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 71 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 72 frame 0 frame 1 frame 2 frame 3 frame 4 frame 5 frame 6 Segmentation with paging (1/3) (STE: segment table entry PTE: page table entry) Fig from Gottlieb 25 73 Segmentation with paging (2/3) 74 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,

Các file đính kèm theo tài liệu này:

  • pdfchuong_7_bo_nho_4634.pdf