summaryrefslogtreecommitdiff
path: root/src/backend/utils/adt/dbsize.c
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2011-04-25 16:22:24 -0400
committerTom Lane <tgl@sss.pgh.pa.us>2011-04-25 16:22:24 -0400
commit049e8b07fa076ac20662180152f122ba59f96f9f (patch)
treedda8b7b98c15f299e3c95a7c1e82dcd5ec8cf8e5 /src/backend/utils/adt/dbsize.c
parent3c34d7ee8e4617efd3d18999a4453f76bce93f55 (diff)
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.
Diffstat (limited to 'src/backend/utils/adt/dbsize.c')
-rw-r--r--src/backend/utils/adt/dbsize.c8
1 files changed, 7 insertions, 1 deletions
diff --git a/src/backend/utils/adt/dbsize.c b/src/backend/utils/adt/dbsize.c
index 768b04ee8d1..a6094ceaddb 100644
--- a/src/backend/utils/adt/dbsize.c
+++ b/src/backend/utils/adt/dbsize.c
@@ -427,9 +427,15 @@ pg_size_pretty(PG_FUNCTION_ARGS)
(size + mult / 2) / mult);
else
{
+ /* Here we have to worry about avoiding overflow */
+ int64 val;
+
mult *= 1024;
+ val = size / mult;
+ if ((size % mult) >= (mult / 2))
+ val++;
snprintf(VARDATA(result), 50, INT64_FORMAT " TB",
- (size + mult / 2) / mult);
+ val);
}
}
}