mirror of
https://github.com/X11Libre/xserver.git
synced 2026-03-24 01:34:11 +00:00
os: make FormatInt64() handle LONG_MIN correctly
When compiling with gcc 15.2.0 using -O3 -m64 on Solaris SPARC & x64, we'd get a test failure of: Assertion failed: strcmp(logmsg, expected) == 0, file ../test/signal-logging.c, line 339, function logging_format because 'num *= -1' produced a value that was out of the range of the int64_t it was being stored in. (Compiling with -O2 worked fine with the same compiler/configuration/platform though.) Signed-off-by: Alan Coopersmith <alan.coopersmith@oracle.com> Part-of: <https://gitlab.freedesktop.org/xorg/xserver/-/merge_requests/2117>
This commit is contained in:
committed by
Enrico Weigelt, metux IT consult
parent
3a367c5a47
commit
2a41522349
6
os/fmt.c
6
os/fmt.c
@@ -16,12 +16,14 @@
|
||||
void
|
||||
FormatInt64(int64_t num, char *string)
|
||||
{
|
||||
uint64_t unum = num;
|
||||
|
||||
if (num < 0) {
|
||||
string[0] = '-';
|
||||
num *= -1;
|
||||
unum = num * -1;
|
||||
string++;
|
||||
}
|
||||
FormatUInt64(num, string);
|
||||
FormatUInt64(unum, string);
|
||||
}
|
||||
|
||||
/* Format a number into a string in a signal safe manner. The string should be
|
||||
|
||||
Reference in New Issue
Block a user