#else #define FNAME parasail_sw_diag_sse41_128_32 #endif #endif parasail_result_t* FNAME( const char * const restrict _s1, const int s1Len, const char * const restrict _s2, const int s2Len, const int open, const int gap, const parasail_matrix_t *matrix) { const int32_t N = 4; /* number of values in vector */ const int32_t PAD = N-1; const int32_t PAD2 = PAD*2; const int32_t s1Len_PAD = s1Len+PAD; const int32_t s2Len_PAD = s2Len+PAD; int32_t * const restrict s1 = parasail_memalign_int32_t(16, s1Len+PAD); int32_t * const restrict s2B= parasail_memalign_int32_t(16, s2Len+PAD2); int32_t * const restrict _H_pr = parasail_memalign_int32_t(16, s2Len+PAD2); int32_t * const restrict _F_pr = parasail_memalign_int32_t(16, s2Len+PAD2); int32_t * const restrict s2 = s2B+PAD; /* will allow later for negative indices */ int32_t * const restrict H_pr = _H_pr+PAD; int32_t * const restrict F_pr = _F_pr+PAD; #ifdef PARASAIL_TABLE parasail_result_t *result = parasail_result_new_table1(s1Len, s2Len); #else #ifdef PARASAIL_ROWCOL parasail_result_t *result = parasail_result_new_rowcol1(s1Len, s2Len); #else parasail_result_t *result = parasail_result_new(); #endif #endif
#else #define FNAME parasail_sw_diag_avx2_256_32 #endif #endif parasail_result_t* FNAME( const char * const restrict _s1, const int s1Len, const char * const restrict _s2, const int s2Len, const int open, const int gap, const parasail_matrix_t *matrix) { const int32_t N = 8; /* number of values in vector */ const int32_t PAD = N-1; const int32_t PAD2 = PAD*2; const int32_t s1Len_PAD = s1Len+PAD; const int32_t s2Len_PAD = s2Len+PAD; int32_t * const restrict s1 = parasail_memalign_int32_t(32, s1Len+PAD); int32_t * const restrict s2B= parasail_memalign_int32_t(32, s2Len+PAD2); int32_t * const restrict _tbl_pr = parasail_memalign_int32_t(32, s2Len+PAD2); int32_t * const restrict _del_pr = parasail_memalign_int32_t(32, s2Len+PAD2); int32_t * const restrict s2 = s2B+PAD; /* will allow later for negative indices */ int32_t * const restrict tbl_pr = _tbl_pr+PAD; int32_t * const restrict del_pr = _del_pr+PAD; #ifdef PARASAIL_TABLE parasail_result_t *result = parasail_result_new_table1(s1Len, s2Len); #else #ifdef PARASAIL_ROWCOL parasail_result_t *result = parasail_result_new_rowcol1(s1Len, s2Len); #else parasail_result_t *result = parasail_result_new(); #endif #endif