mirror of
https://github.com/gbdev/rgbds.git
synced 2025-11-20 10:12:06 +00:00
It seemed that the consensus in our discussions of signed integer overflow, which invokes undefined behavior in C, was that integer arithmetic should be two's complement and there should be no warning for overflows. I have implemented that by converting values to unsigned types when appropriate. These changes will mostly preserve existing behavior, except for a few cases that were being handled incorrectly before. The case of dividing INT_MIN by -1 previously resulted in a CPU exception and program termination. Now, that case is detected and results in a warning and a value of INT_MIN. Similarly, INT_MIN % -1 would have resulted in a CPU exception. Since this is a mathematically valid operation with a result of 0, it now simply gives that result without a warning. I noticed that in rpn.c, there were attempts in certain operation handlers to validate the nVal members of the source expressions even when the expressions may have been relocatable expressions with meaningless numbers for the nVal member. This could have caused spurious errors/warnings, so I made those handlers confirm that isReloc is false before validating nVal. Also, integer constants that are too large now result in a warning. The post-conversion values have not been changed, in order to preserve backward compatibility.
43 lines
445 B
NASM
43 lines
445 B
NASM
SECTION "sec", ROM0
|
|
|
|
print_x: MACRO
|
|
printv x
|
|
printt "\n"
|
|
ENDM
|
|
|
|
x = 2147483647
|
|
x = x + 1
|
|
dl 2147483647+1
|
|
print_x
|
|
|
|
x = -2147483648
|
|
x = x - 1
|
|
dl -2147483648-1
|
|
print_x
|
|
|
|
x = -2147483648
|
|
x = x * -1
|
|
dl -2147483648 * -1
|
|
print_x
|
|
|
|
x = -2147483648
|
|
x = x / -1
|
|
dl -2147483648 / -1
|
|
print_x
|
|
|
|
x = -2147483648
|
|
x = x % -1
|
|
dl -2147483648 % -1
|
|
print_x
|
|
|
|
x = -1
|
|
x = x << 1
|
|
dl -1 << 1
|
|
print_x
|
|
|
|
x = 4294967295
|
|
x = 4294967296
|
|
|
|
x = `33333333
|
|
x = `333333333
|