diff options
Diffstat (limited to 'erts/emulator/beam/erl_arith.c')
| -rw-r--r-- | erts/emulator/beam/erl_arith.c | 22 | 
1 files changed, 11 insertions, 11 deletions
| diff --git a/erts/emulator/beam/erl_arith.c b/erts/emulator/beam/erl_arith.c index 861532f241..144fb56ea5 100644 --- a/erts/emulator/beam/erl_arith.c +++ b/erts/emulator/beam/erl_arith.c @@ -1,7 +1,7 @@  /*   * %CopyrightBegin%   * - * Copyright Ericsson AB 1999-2016. All Rights Reserved. + * Copyright Ericsson AB 1999-2018. All Rights Reserved.   *   * Licensed under the Apache License, Version 2.0 (the "License");   * you may not use this file except in compliance with the License. @@ -114,7 +114,7 @@ BIF_RETTYPE intdiv_2(BIF_ALIST_2)      }      if (is_both_small(BIF_ARG_1,BIF_ARG_2)){  	Sint ires = signed_val(BIF_ARG_1) / signed_val(BIF_ARG_2); -	if (MY_IS_SSMALL(ires)) +	if (IS_SSMALL(ires))  	    BIF_RET(make_small(ires));      }       BIF_RET(erts_int_div(BIF_P, BIF_ARG_1, BIF_ARG_2)); @@ -276,8 +276,12 @@ shift(Process* p, Eterm arg1, Eterm arg2, int right)  		goto do_bsl;  	    } else if (is_small(arg1) || is_big(arg1)) {  		/* -		 * N bsl PositiveBigNum is too large to represent. +		 * N bsl PositiveBigNum is too large to represent, +                 * unless N is 0.  		 */ +                if (arg1 == make_small(0)) { +                    BIF_RET(arg1); +                }  		BIF_ERROR(p, SYSTEM_LIMIT);  	    }  	     /* Fall through if the left argument is not an integer. */ @@ -336,8 +340,7 @@ erts_mixed_plus(Process* p, Eterm arg1, Eterm arg2)  		switch ((arg2 & _TAG_IMMED1_MASK) >> _TAG_PRIMARY_SIZE) {  		case (_TAG_IMMED1_SMALL >> _TAG_PRIMARY_SIZE):  		    ires = signed_val(arg1) + signed_val(arg2); -		    ASSERT(MY_IS_SSMALL(ires) == IS_SSMALL(ires)); -		    if (MY_IS_SSMALL(ires)) { +		    if (IS_SSMALL(ires)) {  			return make_small(ires);  		    } else {  			hp = HAlloc(p, 2); @@ -482,8 +485,7 @@ erts_mixed_minus(Process* p, Eterm arg1, Eterm arg2)  		switch ((arg2 & _TAG_IMMED1_MASK) >> _TAG_PRIMARY_SIZE) {  		case (_TAG_IMMED1_SMALL >> _TAG_PRIMARY_SIZE):  		    ires = signed_val(arg1) - signed_val(arg2); -		    ASSERT(MY_IS_SSMALL(ires) == IS_SSMALL(ires)); -		    if (MY_IS_SSMALL(ires)) { +		    if (IS_SSMALL(ires)) {  			return make_small(ires);  		    } else {  			hp = HAlloc(p, 2); @@ -1177,8 +1179,7 @@ erts_gc_mixed_plus(Process* p, Eterm* reg, Uint live)  		switch ((arg2 & _TAG_IMMED1_MASK) >> _TAG_PRIMARY_SIZE) {  		case (_TAG_IMMED1_SMALL >> _TAG_PRIMARY_SIZE):  		    ires = signed_val(arg1) + signed_val(arg2); -		    ASSERT(MY_IS_SSMALL(ires) == IS_SSMALL(ires)); -		    if (MY_IS_SSMALL(ires)) { +		    if (IS_SSMALL(ires)) {  			return make_small(ires);  		    } else {  			if (ERTS_NEED_GC(p, 2)) { @@ -1345,8 +1346,7 @@ erts_gc_mixed_minus(Process* p, Eterm* reg, Uint live)  		switch ((arg2 & _TAG_IMMED1_MASK) >> _TAG_PRIMARY_SIZE) {  		case (_TAG_IMMED1_SMALL >> _TAG_PRIMARY_SIZE):  		    ires = signed_val(arg1) - signed_val(arg2); -		    ASSERT(MY_IS_SSMALL(ires) == IS_SSMALL(ires)); -		    if (MY_IS_SSMALL(ires)) { +		    if (IS_SSMALL(ires)) {  			return make_small(ires);  		    } else {  			if (ERTS_NEED_GC(p, 2)) { | 
