Skip to content

Commit

Permalink
AbismalAlign.hpp: Changing the way loop vectorization is turned off f…
Browse files Browse the repository at this point in the history
…or the from_diag functions to now use __attribute__ instead of pragmas and hopefully fewer compilers will have a problem with this
  • Loading branch information
andrewdavidsmith committed Jun 2, 2024
1 parent 6d65456 commit a4810f0
Showing 1 changed file with 7 additions and 15 deletions.
22 changes: 7 additions & 15 deletions src/AbismalAlign.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -206,21 +206,15 @@ get_best_score(const std::vector<score_t> &table, const size_t n_cells,
return *best_cell_itr;
}

// ADS: it seems like with g++-13, on macos ventura on intel hardware
// the dynamic vectorized optimization of -O3 might be too aggressive
// and makes this function have strange behavior. Placing this pragma
// here helps, and below we restore it to the `-O3` default. Probably
// should move to attribute syntax soon.

#ifdef __APPLE__
#pragma GCC push_options
// ADS: below this won't make sense if the user wants no optimizations
// at all...
#pragma GCC optimize ("O2")
#endif
// ADS: it seems like with some versions of GCC, the optimization from
// `-O3`, which seems to include loop vectorizations, breaks the
// function below and the other overload named `from_diag`
// below. Using the __attribute__ helps with GCC, and it should be
// ignored if not supported.

template<score_t (*scr_fun)(const uint8_t, const uint8_t), class T,
class QueryConstItr>
__attribute__((optimize("no-tree-loop-vectorize")))
void
from_diag(T next_row, const T next_row_end, T cur_row, QueryConstItr query_seq,
uint8_t ref_base) {
Expand Down Expand Up @@ -251,6 +245,7 @@ from_left(T left_itr, T target, const T target_end) {
/********* SAME FUNCTIONS AS ABOVE BUT WITH TRACEBACK ********/
template<score_t (*scr_fun)(const uint8_t, const uint8_t), class T,
class QueryConstItr, class U>
__attribute__((optimize("no-tree-loop-vectorize")))
void
from_diag(T next_row, const T next_row_end, T cur_row, QueryConstItr query_seq,
uint8_t ref_base, U traceback) {
Expand Down Expand Up @@ -289,9 +284,6 @@ from_left(T left_itr, T target, const T target_end, U traceback) {
}
}

#ifdef __APPLE__
#pragma GCC pop_options
#endif

inline void
make_default_cigar(const uint32_t len, std::string &cigar) {
Expand Down

0 comments on commit a4810f0

Please sign in to comment.