data:image/s3,"s3://crabby-images/88aab/88aab68b6a9d75d973014fd9b7a471b8413a288d" alt="" |
Making
a segment known to a process
data:image/s3,"s3://crabby-images/72c86/72c86b67469ffb55aa195502cfd3e58cae38411b" alt="" |
When
a process first refers a segment with pathname, new segment number
is allocated by the kernel. Then the mapping (pathname, segment
number) gets recorded to the KST[segment number] of the process |
data:image/s3,"s3://crabby-images/72c86/72c86b67469ffb55aa195502cfd3e58cae38411b" alt="" |
Each
KST entry KST[i] contains--note that i = segment number allocated by
the kernel:
data:image/s3,"s3://crabby-images/a1a06/a1a0639410c9b8043f0f36a7ef2bafdf1fa6d26a" alt="" |
pointer
to the segment descriptor
data:image/s3,"s3://crabby-images/a1a06/a1a0639410c9b8043f0f36a7ef2bafdf1fa6d26a" alt="" |
actually
the segment descriptor is tagged as missing segment |
data:image/s3,"s3://crabby-images/a1a06/a1a0639410c9b8043f0f36a7ef2bafdf1fa6d26a" alt="" |
later
access to this segment will trap "missing segment
fault" and segment fault handler will handle it |
|
data:image/s3,"s3://crabby-images/a1a06/a1a0639410c9b8043f0f36a7ef2bafdf1fa6d26a" alt="" |
pointer
to the directory entry (= branch) |
|
data:image/s3,"s3://crabby-images/72c86/72c86b67469ffb55aa195502cfd3e58cae38411b" alt="" |
Now
on the process can access the segment by segment number |
|
data:image/s3,"s3://crabby-images/88aab/88aab68b6a9d75d973014fd9b7a471b8413a288d" alt="" |
Process
refers a word by (segment number, offset in words). If DS[segment number]
has "missing segment" tag on, a trap will be issued and segment
fault handler will be called. Procedure:
data:image/s3,"s3://crabby-images/72c86/72c86b67469ffb55aa195502cfd3e58cae38411b" alt="" |
index
into KST[segment number] |
data:image/s3,"s3://crabby-images/72c86/72c86b67469ffb55aa195502cfd3e58cae38411b" alt="" |
follow
the pointer to directory entry |
data:image/s3,"s3://crabby-images/72c86/72c86b67469ffb55aa195502cfd3e58cae38411b" alt="" |
populate
the DS[segment number] with the values of the directory entry
data:image/s3,"s3://crabby-images/a1a06/a1a0639410c9b8043f0f36a7ef2bafdf1fa6d26a" alt="" |
if
page table has not been made for the segment
data:image/s3,"s3://crabby-images/a1a06/a1a0639410c9b8043f0f36a7ef2bafdf1fa6d26a" alt="" |
create
a new page table |
data:image/s3,"s3://crabby-images/a1a06/a1a0639410c9b8043f0f36a7ef2bafdf1fa6d26a" alt="" |
register
[segment, page table] entry to active segment table
data:image/s3,"s3://crabby-images/a1a06/a1a0639410c9b8043f0f36a7ef2bafdf1fa6d26a" alt="" |
inode
also copied to the active entry |
data:image/s3,"s3://crabby-images/a1a06/a1a0639410c9b8043f0f36a7ef2bafdf1fa6d26a" alt="" |
the
size of active segment table is fixed and maybe an
existing entry should be kicked out of the table
to make a room for the new segment being activated
data:image/s3,"s3://crabby-images/a1a06/a1a0639410c9b8043f0f36a7ef2bafdf1fa6d26a" alt="" |
segment
which has had no pages in main memory for
the longest time is the victim |
|
|
data:image/s3,"s3://crabby-images/a1a06/a1a0639410c9b8043f0f36a7ef2bafdf1fa6d26a" alt="" |
update
directory entry so that it points the [segment, page table]
entry |
|
data:image/s3,"s3://crabby-images/a1a06/a1a0639410c9b8043f0f36a7ef2bafdf1fa6d26a" alt="" |
DS[segment
number].page_table = pointer to the page table |
|
data:image/s3,"s3://crabby-images/72c86/72c86b67469ffb55aa195502cfd3e58cae38411b" alt="" |
=>
every information for page fault handler is in main memory |
|
data:image/s3,"s3://crabby-images/88aab/88aab68b6a9d75d973014fd9b7a471b8413a288d" alt="" |
Note
that each process has its own DS and KST, but active segment table and
page table are shared by all processes |