diff --git a/main.c b/main.c index 2909ddc..c1ec8bb 100644 --- a/main.c +++ b/main.c @@ -6,7 +6,7 @@ #include "mmpriv.h" #include "getopt.h" -#define MM_VERSION "2.2-r421-dirty" +#define MM_VERSION "2.2-r424-dirty" #ifdef __linux__ #include diff --git a/map.c b/map.c index 04dcfe6..af0f78a 100644 --- a/map.c +++ b/map.c @@ -256,6 +256,17 @@ mm_reg1_t *mm_map_seg(const mm_idx_t *mi, int n_segs, int *qlens, const char *se max_gap_ref = opt->max_gap_ref >= 0? opt->max_gap_ref : opt->max_gap; n_u = mm_chain_dp(max_gap_ref, opt->max_gap, opt->bw, opt->max_chain_skip, opt->min_cnt, opt->min_chain_score, !!(opt->flag&MM_F_SPLICE), n_segs, n_a, a, &u, b->km); + if (n_u > 0) { // shrink _a_ because after chaining, the size of _a_ may be much reduced + int64_t n_a0 = n_a; + for (j = 0, n_a = 0; j < n_u; ++j) + n_a += (int32_t)u[j]; + if (n_a < n_a0>>1) { + mm128_t *a0 = a; + a = (mm128_t*)kmalloc(b->km, n_a * sizeof(mm128_t)); + memcpy(a, a0, n_a * sizeof(mm128_t)); // anything beyond n_a is not used + kfree(b->km, a0); + } + } regs = mm_gen_regs(b->km, qlen_sum, n_u, u, a); *n_regs = n_u;