Commit af0f2009 authored by Tom Lane's avatar Tom Lane

Fix pg_size_pretty() to avoid overflow for inputs close to INT64_MAX.

The expression that tried to round the value to the nearest TB could
overflow, leading to bogus output as reported in bug #5993 from Nicola
Cossu.  This isn't likely to ever happen in the intended usage of the
function (if it could, we'd be needing to use a wider datatype instead);
but it's not hard to give the expected output, so let's do so.
parent f8ebe3bc
...@@ -490,9 +490,15 @@ pg_size_pretty(PG_FUNCTION_ARGS) ...@@ -490,9 +490,15 @@ pg_size_pretty(PG_FUNCTION_ARGS)
(size + mult / 2) / mult); (size + mult / 2) / mult);
else else
{ {
/* Here we have to worry about avoiding overflow */
int64 val;
mult *= 1024; mult *= 1024;
val = size / mult;
if ((size % mult) >= (mult / 2))
val++;
snprintf(buf, sizeof(buf), INT64_FORMAT " TB", snprintf(buf, sizeof(buf), INT64_FORMAT " TB",
(size + mult / 2) / mult); val);
} }
} }
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment