Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mohit17067/priority-scheduling-pintos
Priority scheduling, Priority donation and Alarm clock in Pintos.
https://github.com/mohit17067/priority-scheduling-pintos
alarm-clock pintos pintos-project pintos-threads priority-scheduling
Last synced: 8 days ago
JSON representation
Priority scheduling, Priority donation and Alarm clock in Pintos.
- Host: GitHub
- URL: https://github.com/mohit17067/priority-scheduling-pintos
- Owner: Mohit17067
- License: other
- Created: 2019-06-23T06:25:29.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2019-06-23T06:59:41.000Z (over 5 years ago)
- Last Synced: 2024-11-16T21:12:40.803Z (2 months ago)
- Topics: alarm-clock, pintos, pintos-project, pintos-threads, priority-scheduling
- Language: HTML
- Homepage:
- Size: 7.36 MB
- Stars: 8
- Watchers: 0
- Forks: 7
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Authors: AUTHORS
Awesome Lists containing this project
README
# PintOS
Pintos is a simple operating system framework for the 80x86 architecture. It supports kernel threads, loading and running user programs, and a file system, but it implements all of these in a very simple way. Pintos could, theoretically, run on a regular IBM-compatible PC. Unfortunately, it is impractical to supply every student a dedicated PC for use with Pintos. Therefore, we will run Pintos projects in a system simulator, that is, a program that simulates an 80x86 CPU and its peripheral devices accurately enough that unmodified operating systems and software can run under it. Bochs and QEMU simulators are used to run Pintos## Priority Scheduling
Priority scheduling is a non-preemptive algorithm and one of the most common scheduling algorithms in batch systems. Each process is assigned a priority. Process with the highest priority is to be executed first and so on.
When a thread is added to the ready list that has a higher priority than the currently running thread, the current thread immediately yields the processor to the new thread. Similarly, when threads are waiting for a lock, semaphore, or condition variable, the highest priority waiting thread is awakened first. A thread may raise or lower its own priority at any time, but lowering its priority such that it no longer has the highest priority causes it to immediately yield the CPU.### Priority Donation
Priority inversion is handelled in the scheduler. Consider high, medium, and low priority threads H, M, and L, respectively. If H needs to wait for L (for instance, for a lock held by L), and M is on the ready list, then H will never get the CPU because the low priority thread will not get any CPU time. The technique used to solve this issue is **priority donation**.## Alarm Clock
`timer_sleep()` function is reimplemented to avoid busy waiting and spinning in a loop checking the current time and calling `thread_yield()` until enough time has gone.**Read the entire documentation of Pintos** - [here](https://faculty.iiitd.ac.in/~piyus/pintos/doc/pintos.html)