From 15ce49d37f45a1ba458067600657d6634bb7f477 Mon Sep 17 00:00:00 2001 From: Chris Jefferson Date: Tue, 27 Mar 2018 21:57:19 +0100 Subject: [PATCH] Fix bug caused by garbage collection ProdInt can cause a garbage collection, which moves the memory that ptKnown points to. Also change ProdInt(-1, ...) to AInvInt --- src/permutat.c | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/src/permutat.c b/src/permutat.c index ef4e987136..267eb3241b 100644 --- a/src/permutat.c +++ b/src/permutat.c @@ -1168,6 +1168,8 @@ Obj PowPerm2Int ( /* compute the power by raising the cycles individually for large exps */ else if ( TNUM_OBJ(opR) == T_INTNEG ) { + /* do negation first as it can cause a garbage collection */ + opR = AInvInt(opR); /* make sure that the buffer bag is large enough */ UseTmpPerm(SIZE_OBJ(opL)); @@ -1178,7 +1180,6 @@ Obj PowPerm2Int ( ptKnown[p] = 0; /* get pointer to the permutation and the power */ - opR = ProdInt( INTOBJ_INT(-1), opR ); ptL = CONST_ADDR_PERM2(opL); ptP = ADDR_PERM2(pow); @@ -1430,6 +1431,8 @@ Obj PowPerm4Int ( /* compute the power by raising the cycles individually for large exps */ else if ( TNUM_OBJ(opR) == T_INTNEG ) { + /* do negation first as it can cause a garbage collection */ + opR = AInvInt(opR); /* make sure that the buffer bag is large enough */ UseTmpPerm(SIZE_OBJ(opL)); @@ -1440,7 +1443,6 @@ Obj PowPerm4Int ( ptKnown[p] = 0; /* get pointer to the permutation and the power */ - opR = ProdInt( INTOBJ_INT(-1), opR ); ptL = CONST_ADDR_PERM4(opL); ptP = ADDR_PERM4(pow);