]> granicus.if.org Git - postgresql/commit
Be smarter about age-counter overflow in formatting.c caches.
authorTom Lane <tgl@sss.pgh.pa.us>
Tue, 16 Oct 2018 18:57:14 +0000 (14:57 -0400)
committerTom Lane <tgl@sss.pgh.pa.us>
Tue, 16 Oct 2018 18:57:14 +0000 (14:57 -0400)
commit2c300c680767a45450bf7afa4075095f40502dc4
treed6911de48b4bada82031b19df2581604fb2f8a09
parentf7a953c2d870185499faaabd06983526a83eb387
Be smarter about age-counter overflow in formatting.c caches.

The previous code here simply threw away whatever it knew about cache
entry ages whenever a counter overflow occurred.  Since the counter
is int width and will be bumped once per format function execution,
overflows are not really so rare as to not be worth thinking about.
Instead, let's deal with the situation by halving all the age values,
essentially rescaling the age metric.  In that way, we retain a
pretty accurate (if not quite perfect) idea of which entries are oldest.
src/backend/utils/adt/formatting.c