- bool result = true;
- message* msg;
- m_host_t from;
- while ((ctrl_close_pending ||
- data_close_pending) && comm.recv(msg, from, wait_for_close)) {
- switch (msg->get_type()) {
- case message::INFO:
- DEBUG0("received INFO");
- // fixme: update neighbor
- // need a map m_host_t -> neighbor&
- break;
- case message::CREDIT:
- DEBUG0("received CREDIT");
- expected_load += msg->get_amount();
- break;
- case message::LOAD:
- DEBUG0("received LOAD");
- load += msg->get_amount();
- break;
- case message::CTRL_CLOSE:
- DEBUG0("received CTRL_CLOSE");
- if (--ctrl_close_pending == 1)
- comm.next_close_on_ctrl_is_last();
- result = false;
- break;
- case message::DATA_CLOSE:
- DEBUG0("received DATA_CLOSE");
- if (--data_close_pending == 1)
- comm.next_close_on_data_is_last();
- result = false;
- break;
+ if (lb_iter == 1) // warn only once
+ XBT_WARN("process::load_balance() is a no-op!");
+}
+
+void process::send(neighbor& nb, double amount)
+{
+ set_load(get_load() - amount);
+ nb.set_to_send(nb.get_to_send() + amount);
+ nb.set_load(nb.get_load() + amount);
+}
+
+#define print_loads_generic(vec, verbose, logp, cat) \
+ if (_XBT_LOG_ISENABLEDV((*cat), logp)) { \
+ using std::tr1::bind; \
+ using std::tr1::placeholders::_1; \
+ XBT_XCLOG(cat, logp, "My load: %g (real); %g (expected). " \
+ "Neighbor loads:", real_load, expected_load); \
+ std::for_each(vec.begin(), vec.end(), \
+ bind(&neighbor::print, _1, verbose, logp, cat)); \
+ } else ((void)0)
+
+void process::print_loads(bool verbose,
+ e_xbt_log_priority_t logp,
+ xbt_log_category_t cat) const
+{
+ print_loads_generic(neigh, verbose, logp, cat);
+}
+
+void process::print_loads_p(bool verbose,
+ e_xbt_log_priority_t logp,
+ xbt_log_category_t cat) const
+{
+ print_loads_generic(pneigh, verbose, logp, cat);
+}
+
+#undef print_loads_generic
+
+void process::ctrl_send(neighbor& nb)
+{
+ double info_to_send = get_load();
+ if (info_to_send != prev_load_broadcast)
+ comm.ctrl_send(nb.get_ctrl_mbox(),
+ new message(message::INFO, info_to_send));
+ if (opt::bookkeeping) {
+ double debt_to_send = nb.get_to_send();
+ if (debt_to_send > 0.0) {
+ nb.set_to_send(0.0);
+ nb.set_debt(nb.get_debt() + debt_to_send);
+ comm.ctrl_send(nb.get_ctrl_mbox(),
+ new message(message::CREDIT, debt_to_send));