Skip to content

Commit

Permalink
fixup! simplified pcancel
Browse files Browse the repository at this point in the history
  • Loading branch information
milroy committed Oct 20, 2024
1 parent 6458cef commit 31fe890
Show file tree
Hide file tree
Showing 4 changed files with 6 additions and 19 deletions.
1 change: 0 additions & 1 deletion resource/readers/resource_reader_base.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,6 @@ struct modify_data_t {
job_modify_t mod_type = job_modify_t::PARTIAL_CANCEL;
std::unordered_set<int64_t> ranks_removed;
std::unordered_map<const char *, int64_t> type_to_count;
std::unordered_set<vtx_t> brokerless_res;
};

/*! Base resource reader class.
Expand Down
1 change: 0 additions & 1 deletion resource/schema/data_std.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,6 @@ resource_type_t gpu_rt{"gpu"};
resource_type_t node_rt{"node"};
resource_type_t rack_rt{"rack"};
resource_type_t slot_rt{"slot"};
resource_type_t ssd_rt{"ssd"};

} // namespace resource_model
} // namespace Flux
Expand Down
1 change: 0 additions & 1 deletion resource/schema/data_std.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,6 @@ extern resource_type_t node_rt;
extern resource_type_t socket_rt;
extern resource_type_t gpu_rt;
extern resource_type_t core_rt;
extern resource_type_t ssd_rt;

template<class T, int likely_count = 2>
using subsystem_key_vec = intern::interned_key_vec<subsystem_t, T, likely_count>;
Expand Down
22 changes: 6 additions & 16 deletions resource/traversers/dfu_impl_update.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -540,10 +540,12 @@ int dfu_impl_t::mod_plan (vtx_t u, int64_t jobid, modify_data_t &mod_data)
if (mod_data.mod_type != job_modify_t::PARTIAL_CANCEL) {
(*m_graph)[u].schedule.allocations.erase (alloc_span);
} else {
// Add to brokerless resource set to execute in follow-up
// vertex cancel
if ((*m_graph)[u].type == ssd_rt)
mod_data.brokerless_res.insert (u);
// Switch to VTX_CANCEL and cancel the brokerless vertex.
// Since the job_modify_t is changed there won't be
// a recursive call.
mod_data.mod_type = job_modify_t::VTX_CANCEL;
rc = cancel_vertex (u, mod_data, jobid);
mod_data.mod_type = job_modify_t::PARTIAL_CANCEL;
goto done;
}
} else if ((res_span = (*m_graph)[u].schedule.reservations.find (jobid))
Expand Down Expand Up @@ -842,18 +844,6 @@ int dfu_impl_t::remove (vtx_t root,
m_color.reset ();
if (root_has_jtag) {
rc = mod_dfv (root, jobid, mod_data);

// Need to re-run VTX_CANCEL in case brokerless resources (e.g., SSDs)
// were found in the previous VTX_CANCEL
if (mod_data.brokerless_res.size () > 0) {
mod_data.mod_type = job_modify_t::VTX_CANCEL;
for (const vtx_t &vtx : mod_data.brokerless_res) {
if ((rc = cancel_vertex (vtx, mod_data, jobid)) != 0) {
errno = EINVAL;
return rc;
}
}
}
// Was the root vertex's job tag removed? If so, full_cancel
full_cancel =
((*m_graph)[root].idata.tags.find (jobid) == (*m_graph)[root].idata.tags.end ());
Expand Down

0 comments on commit 31fe890

Please sign in to comment.