Priority inversion occurs in concurrent programs when low-priority threads hold shared resources needed by some high-priority thread, causing them to block indefinitely. Shared resources are usually guarded by low-level synchronization primitives such as mutual-exclusion locks, semaphores, or monitors. There are two existing solutions to priority inversion. The first, establishing high-level scheduling invariants over synchronization primitives to eliminate priority inversion a priori, is difficult in practice and undecidable in general. Alternatively, run-time avoidance mechanisms such as priority inheritance still force high-priority threads to wait until desired resources are released.
We describe a novel compiler and run-time solution to the problem of priority inversion, along with experimental evaluation of its effectiveness. Our approach allows preemption of any thread holding a resource needed by higher-priority threads, forcing it to release its claim on the resource, roll back its execution to the point at which the shared resource was first acquired, and discard any updates made in the interim.
The compiler inserts code at synchronization points, permitting rollback of thread execution, and efficient revocation of interim updates. Our design and implementation are realized in the context of IBM’s Jikes RVM, a high-quality compiler and runtime system for Java. Our performance results show that throughput of high-priority threads using our scheme can be improved by 30% to 100% when compared with a classical scheduler that does not address priority inversion.
@inproceedings{Welc+2004ICPP,
  author = {Welc, Adam and Hosking, Antony L. and Jagannathan, Suresh},
  title = {Preemption-Based Avoidance of Priority Inversion for {J}ava},
  booktitle = {IEEE International Conference on Parallel Processing},
  series = {ICPP},
  year = {2004},
  pages = {529--538},
  month = {August},
  address = {Montr{\'e}al, Canada},
  doi = {10.1109/ICPP.2004.1327963},
  gscholar = {20}
}