• DocumentCode
    31420
  • Title

    Dynamic Scheduling of Irregular Stream Programs toward Many-Core Scalability

  • Author

    Changwoo Min ; Young Ik Eom

  • Author_Institution
    Coll. of Inf. & Commun. Eng., Sungkyunkwan Univ., Suwon, South Korea
  • Volume
    26
  • Issue
    6
  • fYear
    2015
  • fDate
    June 1 2015
  • Firstpage
    1594
  • Lastpage
    1607
  • Abstract
    The stream programming model has received much interest because it naturally exposes task, data, and pipeline parallelism. However, most priorwork has focused on the static scheduling of regular stream programs. Therefore, irregular applications cannot be handled in static scheduling, and the load imbalance caused by static scheduling faces scalability limitations in many-core systems. In this paper, we introduce the DANBI programming model, which supports irregular stream programs, and propose dynamic scheduling techniques. Scheduling irregular stream programs is very challenging, and the load imbalance becomes a major hurdle to achieving scalability. Our dynamic load-balancing scheduler exploits producer-consumer relationships already expressed in the DANBI program to achieve scalability. Moreover, it effectively avoids the thundering-herd problem and dynamically adapts to load imbalance in a probabilistic manner. It surpasses prior static stream scheduling approaches which are vulnerable to load imbalance and also surpasses prior dynamic stream scheduling approaches which result in many restrictions on supported program types, on the scope of dynamic scheduling, and on data ordering preservation. Our experimental results on a 40-core server show that DANBI achieves an almost linear scalability and outperforms state-of-the-art parallel runtimes by up to 2.8 times.
  • Keywords
    multiprocessing programs; resource allocation; scheduling; DANBI programming model; data ordering preservation; dynamic load-balancing scheduler; dynamic scheduling technique; irregular stream programs; many-core scalability; many-core systems; static scheduling; stream programming model; Dynamic scheduling; Kernel; Parallel processing; Programming; Runtime; Scalability; Schedules; Stream programming; irregular programs; load balancing; scheduling; software pipelining;
  • fLanguage
    English
  • Journal_Title
    Parallel and Distributed Systems, IEEE Transactions on
  • Publisher
    ieee
  • ISSN
    1045-9219
  • Type

    jour

  • DOI
    10.1109/TPDS.2014.2325833
  • Filename
    6824243