1. 11 Nov, 2020 2 commits
    • Tom Lane's avatar
      Fix and simplify some usages of TimestampDifference(). · ec29427c
      Tom Lane authored
      Introduce TimestampDifferenceMilliseconds() to simplify callers
      that would rather have the difference in milliseconds, instead of
      the select()-oriented seconds-and-microseconds format.  This gets
      rid of at least one integer division per call, and it eliminates
      some apparently-easy-to-mess-up arithmetic.
      
      Two of these call sites were in fact wrong:
      
      * pg_prewarm's autoprewarm_main() forgot to multiply the seconds
      by 1000, thus ending up with a delay 1000X shorter than intended.
      That doesn't quite make it a busy-wait, but close.
      
      * postgres_fdw's pgfdw_get_cleanup_result() thought it needed to compute
      microseconds not milliseconds, thus ending up with a delay 1000X longer
      than intended.  Somebody along the way had noticed this problem but
      misdiagnosed the cause, and imposed an ad-hoc 60-second limit rather
      than fixing the units.  This was relatively harmless in context, because
      we don't care that much about exactly how long this delay is; still,
      it's wrong.
      
      There are a few more callers of TimestampDifference() that don't
      have a direct need for seconds-and-microseconds, but can't use
      TimestampDifferenceMilliseconds() either because they do need
      microsecond precision or because they might possibly deal with
      intervals long enough to overflow 32-bit milliseconds.  It might be
      worth inventing another API to improve that, but that seems outside
      the scope of this patch; so those callers are untouched here.
      
      Given the fact that we are fixing some bugs, and the likelihood
      that future patches might want to back-patch code that uses this
      new API, back-patch to all supported branches.
      
      Alexey Kondratov and Tom Lane
      
      Discussion: https://postgr.es/m/3b1c053a21c07c1ed5e00be3b2b855ef@postgrespro.ru
      ec29427c
    • Bruce Momjian's avatar
      doc: fix spelling "connction" to "connection" · b8b6a012
      Bruce Momjian authored
      Was wrong in commit 1a9388bd.
      
      Reported-by: Tom Lane, Justin Pryzby
      
      Discussion: https://postgr.es/m/20201102063333.GE22691@telsasoft.com
      
      Backpatch-through: 9.5
      b8b6a012
  2. 10 Nov, 2020 5 commits
  3. 09 Nov, 2020 8 commits
  4. 08 Nov, 2020 4 commits
    • Tom Lane's avatar
      In INSERT/UPDATE, use the table's real tuple descriptor as target. · 8b39345a
      Tom Lane authored
      This back-patches commit 20d3fe90 into the v12 and v13 branches.
      At the time I thought that commit was not fixing any observable
      bug, but Bertrand Drouvot showed otherwise: adding a dropped column
      to the previously-considered scenario crashes v12 and v13, unless the
      dropped column happens to be an integer.  That is, of course, because
      the tupdesc we derive from the plan output tlist fails to describe
      the dropped column accurately, so that we'll do the wrong thing with
      a tuple in which that column isn't NULL.
      
      There is no bug in pre-v12 branches because they already did use
      the table's real tuple descriptor for any trigger-returned tuple.
      It seems that this set of bugs can be blamed on the changes that
      removed es_trig_tuple_slot, though I've not attempted to pin that
      down precisely.
      
      Although there's no code change needed in HEAD, update the test case
      to include a dropped column there too.
      
      Discussion: https://postgr.es/m/db5d97c8-f48a-51e2-7b08-b73d5434d425@amazon.com
      Discussion: https://postgr.es/m/16644-5da7ef98a7ac4545@postgresql.org
      8b39345a
    • Thomas Munro's avatar
      Fix assertion in collation version lookup. · d50e3b1f
      Thomas Munro authored
      Commit 257836a7 included an assertion that a version lookup routine is
      not trying to look up "C" or "POSIX", but that case is reachable with
      the user-facing SQL function pg_collation_actual_version().  Remove the
      assertion.
      d50e3b1f
    • Peter Eisentraut's avatar
      Fix test for error message change · 8cff66d3
      Peter Eisentraut authored
      fix for 6be725e7
      8cff66d3
    • Peter Geoghegan's avatar
      Improve nbtree README's LP_DEAD section. · 5a2f154a
      Peter Geoghegan authored
      The description of how LP_DEAD bit setting by index scans works
      following commit 2ed5b87f was rather unclear.  Clean that up a bit.
      
      Also refer to LP_DEAD bit setting within _bt_check_unique() at the start
      of the same section.  This mechanism may actually be more important than
      the generic kill_prior_tuple mechanism that the section focuses on, so
      it at least deserves to be mentioned in passing.
      5a2f154a
  5. 07 Nov, 2020 9 commits
  6. 06 Nov, 2020 6 commits
  7. 05 Nov, 2020 4 commits
    • Peter Geoghegan's avatar
      Fix wal_consistency_checking nbtree bug. · efc5dcfd
      Peter Geoghegan authored
      wal_consistency_checking indicated an inconsistency in certain cases
      involving nbtree page deletion.  The underlying issue is that there was
      a minor difference between the page image produced after a REDO routine
      ran and the corresponding page image following original execution.
      
      This harmless inconsistency has been around forever.  We more or less
      expect total consistency among even deleted nbtree pages these days,
      though, so this won't do anymore.
      
      To fix, tweak the REDO routine to match original execution.
      
      Oversight in commit f47b5e13.
      efc5dcfd
    • Tom Lane's avatar
      Don't throw an error for LOCK TABLE on a self-referential view. · 5b7bfc39
      Tom Lane authored
      LOCK TABLE has complained about "infinite recursion" when applied
      to a self-referential view, ever since we made it recurse into views
      in v11.  However, that breaks pg_dump's new assumption that it's
      okay to lock every relation.  There doesn't seem to be any good
      reason to throw an error: if we just abandon the recursion, we've
      still satisfied the requirement of locking every referenced relation.
      
      Per bug #16703 from Andrew Bille (via Alexander Lakhin).
      
      Discussion: https://postgr.es/m/16703-e348f58aab3cf6cc@postgresql.org
      5b7bfc39
    • Peter Geoghegan's avatar
      Fix nbtree cleanup-only VACUUM stats inaccuracies. · 48e12913
      Peter Geoghegan authored
      Logic for counting heap TIDs from posting list tuples (added by commit
      0d861bbb) was faulty.  It didn't count any TIDs/index tuples in the
      event of no callback being set.  This meant that we incorrectly counted
      no index tuples in clean-up only VACUUMs, which could lead to
      pg_class.reltuples being spuriously set to 0 in affected indexes.
      
      To fix, go back to counting items from the page in cases where there is
      no callback.  This approach isn't very accurate, but it works well
      enough in practice while avoiding the expense of accessing every index
      tuple during cleanup-only VACUUMs.
      
      Author: Peter Geoghegan <pg@bowt.ie>
      Reported-By: default avatarJehan-Guillaume de Rorthais <jgdr@dalibo.com>
      https://postgr.es/m/20201023174451.69e358f1@firost
      Backpatch: 13-, where nbtree deduplication was introduced
      48e12913
    • Thomas Munro's avatar
      Fix unlinking of SLRU segments. · c732c3f8
      Thomas Munro authored
      Commit dee663f7 intended to drop any queued up fsync requests before
      unlinking segment files, but missed a code path.  Fix, by centralizing
      the forget-and-unlink code into a single function.
      Reported-by: default avatarTomas Vondra <tomas.vondra@2ndquadrant.com>
      Discussion: https://postgr.es/m/20201104013205.icogbi773przyny5%40development
      c732c3f8
  8. 04 Nov, 2020 2 commits