• DocumentCode
    3351689
  • Title

    Preemption-based avoidance of priority inversion for Java

  • Author

    Welc, Adam ; Hosking, Antony L. ; Jagannathan, Suresh

  • Author_Institution
    Dept. of Comput. Sci., Purdue Univ., West Lafayette, IN, USA
  • fYear
    2004
  • fDate
    15-18 Aug. 2004
  • Firstpage
    529
  • Abstract
    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.
  • Keywords
    Java; concurrency control; multi-threading; program compilers; resource allocation; scheduling; synchronisation; IBM Jikes RVM compiler; Java; concurrent programs; high-level scheduling invariants; low-priority threads hold shared resources; mutual-exclusion locks; priority inheritance; priority inversion; run-time avoidance mechanism; semaphores; synchronization primitives; thread execution rollback; Computer displays; Computer languages; Concurrent computing; Java; Libraries; Multithreading; Runtime; Space exploration; Throughput; Yarn;
  • fLanguage
    English
  • Publisher
    ieee
  • Conference_Titel
    Parallel Processing, 2004. ICPP 2004. International Conference on
  • ISSN
    0190-3918
  • Print_ISBN
    0-7695-2197-5
  • Type

    conf

  • DOI
    10.1109/ICPP.2004.1327963
  • Filename
    1327963