execution_policy.h 4.54 KB
Newer Older
1
/*
2
 * Copyright (c) 2014-2015, Siemens AG. All rights reserved.
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are met:
 *
 * 1. Redistributions of source code must retain the above copyright notice,
 * this list of conditions and the following disclaimer.
 *
 * 2. Redistributions in binary form must reproduce the above copyright notice,
 * this list of conditions and the following disclaimer in the documentation
 * and/or other materials provided with the distribution.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 * POSSIBILITY OF SUCH DAMAGE.
 */

27 28
#ifndef EMBB_TASKS_EXECUTION_POLICY_H_
#define EMBB_TASKS_EXECUTION_POLICY_H_
29

30
#include <embb/mtapi/c/mtapi.h>
31 32

namespace embb {
33 34
namespace tasks {

35 36 37 38 39 40
/**
 * Describes the execution policy of a parallel algorithm.
 * The execution policy comprises
 *  - the affinity of tasks to MTAPI worker threads (not CPU cores) and
 *  - the priority of the spawned tasks.
 *
41 42 43 44
 * The priority is a number between 0 (denoting the highest priority) to
 * max_priorities - 1 as given during initialization using Node::Initialize().
 * The default value of max_priorities is 4.
 *
45
 * \ingroup CPP_TASKS
46 47 48 49 50 51 52 53 54 55 56 57 58 59
 */
class ExecutionPolicy{
 public:
  /**
   * Constructs the default execution policy.
   * Sets the affinity to all worker threads and the priority to the default
   * value.
   */
  ExecutionPolicy();

  /**
   * Constructs an execution policy with the specified affinity and priority.
   */
  ExecutionPolicy(
60 61 62 63 64
      bool initial_affinity,           /**< [in] \c true sets the affinity to
                                            all worker threads, \c false to no
                                            worker threads. */
      mtapi_uint_t priority            /**< [in] Priority for the execution
                                            policy. */
65 66 67 68 69 70 71
  );

  /**
   * Constructs an execution policy with the specified priority.
   * Sets the affinity to all worker threads.
   */
  explicit ExecutionPolicy(
72 73
      mtapi_uint_t priority            /**< [in] Priority for the execution
                                            policy. */
74 75 76 77 78 79 80
  );

  /**
   * Constructs an execution policy with the specified affinity.
   * Sets the priority to the default value.
   */
  explicit ExecutionPolicy(
81 82 83
      bool initial_affinity            /**< [in] \c true sets the affinity to
                                            all worker threads, \c false to no
                                            worker threads. */
84 85 86 87 88 89
  );

  /**
   *  Sets affinity to a specific worker thread.
   */
  void AddWorker(
90
    mtapi_uint_t worker                /**< [in] Worker thread index */
91 92 93 94 95 96
    );

  /**
   * Removes affinity to a specific worker thread.
   */
  void RemoveWorker(
97
    mtapi_uint_t worker                /**< [in] Worker thread index */
98 99 100 101 102 103 104 105
    );

  /**
   * Checks if affinity to a specific worker thread is set.
   *
   * \return \c true if affinity is set, otherwise \c false
   */
  bool IsSetWorker(
106
    mtapi_uint_t worker                /**< [in] Worker thread index */
107 108 109
    );

  /**
110 111 112 113 114 115 116
   * Returns the number of cores the policy is affine to.
   *
   * \return the number of cores
   */
  unsigned int GetCoreCount() const;

  /**
117 118 119 120
   * Returns the affinity
   *
   * \return the affinity
   */
121
  const mtapi_affinity_t &GetAffinity() const;
122 123 124 125 126 127 128

  /** Returns the priority
   *
   * \return the priority
   */
  mtapi_uint_t GetPriority() const;

129 130
  friend class Task;

131 132 133 134 135 136 137 138 139 140 141
 private:
  /**
   * Default priority.
   * Currently set to 0 = MAX priority.
   */
  static const mtapi_uint_t DefaultPriority;

  /**
   * Task Affinity.
   * Maps the affinity of tasks to MTAPI worker threads (not CPU cores).
   */
142
  mtapi_affinity_t affinity_;
143 144 145 146 147 148

  /**
   * Task Priority.
   */
  mtapi_uint_t priority_;
};
149 150

}  // namespace tasks
151 152
}  // namespace embb

153
#endif  // EMBB_TASKS_EXECUTION_POLICY_H_