1. 30 Sep, 2019 2 commits
    • Michael Paquier's avatar
      Fix SSL test for libpq connection parameter channel_binding · a12c75a1
      Michael Paquier authored
      When compiling Postgres with OpenSSL 1.0.1 or older versions, SCRAM's
      channel binding cannot be supported as X509_get_signature_nid() is
      needed, which causes a regression test with channel_binding='require' to
      fail as the server cannot publish SCRAM-SHA-256-PLUS as SASL mechanism
      over an SSL connection.
      
      Fix the issue by using a method similar to c3d41ccf, making the test
      result conditional.  The test passes if X509_get_signature_nid() is
      present, and when missing we test for a connection failure.  Testing a
      connection failure is more useful than skipping the test as we should
      fail the connection if channel binding is required by the client but the
      server does not support it.
      
      Reported-by: Tom Lane, Michael Paquier
      Author: Michael Paquier
      Discussion: https://postgr.es/m/20190927024457.GA8485@paquier.xyz
      Discussion: https://postgr.es/m/24857.1569775891@sss.pgh.pa.us
      a12c75a1
    • Fujii Masao's avatar
      Make crash recovery ignore recovery target settings. · 7acf8a87
      Fujii Masao authored
      In v11 or before, recovery target settings could not take effect in
      crash recovery because they are specified in recovery.conf and
      crash recovery always starts without recovery.conf. But commit
      2dedf4d9 integrated recovery.conf into postgresql.conf and
      which unexpectedly allowed recovery target settings to take effect
      even in crash recovery. This is definitely not good behavior.
      
      To fix the issue, this commit makes crash recovery always ignore
      recovery target settings.
      
      Back-patch to v12.
      
      Author: Peter Eisentraut
      Reviewed-by: Fujii Masao
      Discussion: https://postgr.es/m/e445616d-023e-a268-8aa1-67b8b335340c@pgmasters.net
      7acf8a87
  2. 29 Sep, 2019 6 commits
    • Andres Freund's avatar
      jit: Re-allow JIT compilation of execGrouping.c hashtable comparisons. · ac88807f
      Andres Freund authored
      In the course of 5567d12c, 356687bd and 317ffdfe, I changed
      BuildTupleHashTable[Ext]'s call to ExecBuildGroupingEqual to not pass
      in the parent node, but NULL. Which in turn prevents the tuple
      equality comparator from being JIT compiled.  While that fixes
      bug #15486, it is not actually necessary after all of the above commits,
      as we don't re-build the comparator when using the new
      BuildTupleHashTableExt() interface (as the content of the hashtable
      are reset, but the TupleHashTable itself is not).
      
      Therefore re-allow jit compilation for callers that use
      BuildTupleHashTableExt with a separate context for "metadata" and
      content.
      
      As in the previous commit, there's ongoing work to make this easier to
      test to prevent such regressions in the future, but that
      infrastructure is not going to be backpatchable.
      
      The performance impact of not JIT compiling hashtable equality
      comparators can be substantial e.g. for aggregation queries that
      aggregate a lot of input rows to few output rows (when there are a lot
      of output groups, there will be fewer comparisons).
      
      Author: Andres Freund
      Discussion: https://postgr.es/m/20190927072053.njf6prdl3vb7y7qb@alap3.anarazel.de
      Backpatch: 11, just as 5567d12c
      ac88807f
    • Andres Freund's avatar
      Fix determination when slot types for upper executor nodes are fixed. · 97e971ee
      Andres Freund authored
      For many queries the fact that the tuple descriptor from the lower
      node was not taken into account when determining whether the type of a
      slot is fixed, lead to tuple deforming for such upper nodes not to be
      JIT accelerated.
      
      I broke this in 675af5c0.
      
      There is ongoing work to enable writing regression tests for related
      behavior (including a patch that would have detected this
      regression), by optionally showing such details in EXPLAIN. But as it
      seems unlikely that that will be suitable for stable branches, just
      merge the fix for now.
      
      While it's fairly close to the 12 release window, the fact that 11
      continues to perform JITed tuple deforming in these cases, that
      there's still cases where we do so in 12, and the fact that the
      performance regression can be sizable, weigh in favor of fixing it
      now.
      
      Author: Andres Freund
      Discussion: https://postgr.es/m/20190927072053.njf6prdl3vb7y7qb@alap3.anarazel.de
      Backpatch: 12-, where 675af5c0 was merged.
      97e971ee
    • Andrew Dunstan's avatar
      Allow SSL TAP tests to run on Windows · 258bf86a
      Andrew Dunstan authored
      Windows does not enforce key file permissions checks in libpq, and psql
      can produce CRLF line endings on Windows.
      
      Backpatch to Release 12 (CRLF) and Release 11 (permissions check)
      258bf86a
    • Peter Eisentraut's avatar
      doc: Further clarify how recovery target parameters are applied · e04a53a6
      Peter Eisentraut authored
      Recovery target parameters are all applied even in standby mode.  The
      previous documentation mostly wished they were not but this was never
      the case.
      
      Discussion: https://www.postgresql.org/message-id/flat/e445616d-023e-a268-8aa1-67b8b335340c%40pgmasters.net
      e04a53a6
    • Tom Lane's avatar
      Fix bogus order of error checks in new channel_binding code. · 2c97f734
      Tom Lane authored
      Coverity pointed out that it's pretty silly to check for a null pointer
      after we've already dereferenced the pointer.  To fix, just swap the
      order of the two error checks.  Oversight in commit d6e612f8.
      2c97f734
    • Peter Eisentraut's avatar
      doc: Add a link target · 92f1545d
      Peter Eisentraut authored
      Forward-patched from PostgreSQL 12 release notes patch, for
      consistency.
      92f1545d
  3. 28 Sep, 2019 3 commits
  4. 27 Sep, 2019 11 commits
  5. 26 Sep, 2019 6 commits
  6. 25 Sep, 2019 12 commits