1. 03 Aug, 2017 8 commits
  2. 02 Aug, 2017 7 commits
    • Alvaro Herrera's avatar
      Fix pg_dump's errno checking for zlib I/O · 4d57e838
      Alvaro Herrera authored
      Some error reports were reporting strerror(errno), which for some error
      conditions coming from zlib are wrong, resulting in confusing reports
      such as
        pg_restore: [compress_io] could not read from input file: Success
      which makes no sense.  To correctly extract the error message we need to
      use gzerror(), so let's do that.
      
      This isn't as comprehensive or as neat as I would like, but at least it
      should improve things in many common cases.  The zlib abstraction in
      compress_io does not seem to be applied consistently enough; we could
      perhaps improve that, but it seems master-only material, not a bug fix
      for back-patching.
      
      This problem goes back all the way, but I decided to apply back to 9.4
      only, because older branches don't contain commit 14ea8936 which this
      change depends on.
      
      Authors: Vladimir Kunschikov, Álvaro Herrera
      Discussion: https://postgr.es/m/1498120508308.9826@infotecs.ru
      4d57e838
    • Tom Lane's avatar
      Add pgtcl back to the list of externally-maintained client interfaces. · 80215156
      Tom Lane authored
      FlightAware is still maintaining this, and indeed is seemingly being
      more active with it than the pgtclng fork is.  List both, for the
      time being anyway.
      
      In the back branches, also back-port commit e20f679f and other
      recent updates to the client-interfaces list.  I think these are
      probably of current interest to users of back branches.  I did
      not touch the list of externally maintained PLs in the back
      branches, though.  Those are much more likely to be server version
      sensitive, and I don't know which of these PLs work all the way back.
      
      Discussion: https://postgr.es/m/20170730162612.1449.58796@wrigleys.postgresql.org
      80215156
    • Tom Lane's avatar
      Remove broken and useless entry-count printing in HASH_DEBUG code. · 9d4e5669
      Tom Lane authored
      init_htab(), with #define HASH_DEBUG, prints a bunch of hashtable
      parameters.  It used to also print nentries, but commit 44ca4022 changed
      that to "hash_get_num_entries(hctl)", which is wrong (the parameter should
      be "hashp").
      
      Rather than correct the coding, though, let's just remove that field from
      the printout.  The table must be empty, since we just finished building
      it, so expensively calculating the number of entries is rather pointless.
      Moreover hash_get_num_entries makes assumptions (about not needing locks)
      which we could do without in debugging code.
      
      Noted by Choi Doo-Won in bug #14764.  Back-patch to 9.6 where the
      faulty code was introduced.
      
      Discussion: https://postgr.es/m/20170802032353.8424.12274@wrigleys.postgresql.org
      9d4e5669
    • Peter Eisentraut's avatar
      Get a snapshot before COPY in table sync · cf652018
      Peter Eisentraut authored
      This fixes a crash if the local table has a function index and the
      function makes non-immutable calls.
      Reported-by: default avatarScott Milliken <scott@deltaex.com>
      Author: Masahiko Sawada <sawada.mshk@gmail.com>
      cf652018
    • Tom Lane's avatar
      Remove duplicate setting of SSL_OP_SINGLE_DH_USE option. · f352f91c
      Tom Lane authored
      Commit c0a15e07 moved the setting of OpenSSL's SSL_OP_SINGLE_DH_USE option
      into a new subroutine initialize_dh(), but forgot to remove it from where
      it was.  SSL_CTX_set_options() is a trivial function, amounting indeed to
      just "ctx->options |= op", hence there's no reason to contort the code or
      break separation of concerns to avoid calling it twice.  So separating the
      DH setup from disabling of old protocol versions is a good change, but we
      need to finish the job.
      
      Noted while poking into the question of SSL session tickets.
      f352f91c
    • Peter Eisentraut's avatar
      Fix OBJECT_TYPE/OBJECT_DOMAIN confusion · 41cefbb6
      Peter Eisentraut authored
      This doesn't have a significant impact except that now SECURITY LABEL ON
      DOMAIN rejects types that are not domains.
      Reported-by: default avatar高增琦 <pgf00a@gmail.com>
      41cefbb6
    • Tom Lane's avatar
      Revert test case added by commit 1e165d05. · 32ca22b0
      Tom Lane authored
      The buildfarm is still showing at least three distinct behaviors for
      a bad locale name in CREATE COLLATION.  Although this test was helpful
      for getting the error reporting code into some usable shape, it doesn't
      seem worth carrying multiple expected-files in order to support the
      test in perpetuity.  So pull it back out.
      
      Discussion: https://postgr.es/m/CAKKotZS-wcDcofXDCH=sidiuajE+nqHn2CGjLLX78anyDmi3gQ@mail.gmail.com
      32ca22b0
  3. 01 Aug, 2017 7 commits
    • Tom Lane's avatar
      Second try at getting useful errors out of newlocale/_create_locale. · 514f6132
      Tom Lane authored
      The early buildfarm returns for commit 1e165d05 are pretty awful:
      not only does Windows not return a useful error, but it looks like
      a lot of Unix-ish platforms don't either.  Given the number of
      different errnos seen so far, guess that what's really going on is
      that some newlocale() implementations fail to set errno at all.
      Hence, let's try zeroing errno just before newlocale() and then
      if it's still zero report as though it's ENOENT.  That should cover
      the Windows case too.
      
      It's clear that we'll have to drop the regression test case, unless
      we want to maintain a separate expected-file for platforms without
      HAVE_LOCALE_T.  But I'll leave it there awhile longer to see if this
      actually improves matters or not.
      
      Discussion: https://postgr.es/m/CAKKotZS-wcDcofXDCH=sidiuajE+nqHn2CGjLLX78anyDmi3gQ@mail.gmail.com
      514f6132
    • Tom Lane's avatar
      Suppress less info in regression tests using DROP CASCADE. · 8e753726
      Tom Lane authored
      DROP CASCADE doesn't currently promise to visit dependent objects in
      a fixed order, so when the regression tests use it, we typically need
      to suppress the details of which objects get dropped in order to have
      predictable test output.  Traditionally we've done that by setting
      client_min_messages higher than NOTICE, but there's a better way:
      we can "\set VERBOSITY terse" in psql.  That suppresses the DETAIL
      message with the object list, but we still get the basic notice telling
      how many objects were dropped.  So at least the test case can verify
      that the expected number of objects were dropped.
      
      The VERBOSITY method was already in use in a few places, but run
      around and use it wherever it makes sense.
      
      Discussion: https://postgr.es/m/10766.1501608885@sss.pgh.pa.us
      8e753726
    • Tom Lane's avatar
      Try to deliver a sane message for _create_locale() failure on Windows. · 1e165d05
      Tom Lane authored
      We were just printing errno, which is certainly not gonna work on
      Windows.  Now, it's not entirely clear from Microsoft's documentation
      whether _create_locale() adheres to standard Windows error reporting
      conventions, but let's assume it does and try to map the GetLastError
      result to an errno.  If this turns out not to work, probably the best
      thing to do will be to assume the error is always ENOENT on Windows.
      
      This is a longstanding bug, but given the lack of previous field
      complaints, I'm not excited about back-patching it.
      
      Per report from Murtuza Zabuawala.
      
      Discussion: https://postgr.es/m/CAKKotZS-wcDcofXDCH=sidiuajE+nqHn2CGjLLX78anyDmi3gQ@mail.gmail.com
      1e165d05
    • Peter Eisentraut's avatar
      doc: Fix typo · c1bb7870
      Peter Eisentraut authored
      Author: Fabien COELHO <coelho@cri.ensmp.fr>
      c1bb7870
    • Tom Lane's avatar
      Allow creation of C/POSIX collations without depending on libc behavior. · f9725657
      Tom Lane authored
      Most of our collations code has special handling for the locale names
      "C" and "POSIX", allowing those collations to be used whether or not
      the system libraries think those locale names are valid, or indeed
      whether said libraries even have any locale support.  But we missed
      handling things that way in CREATE COLLATION.  This meant you couldn't
      clone the C/POSIX collations, nor explicitly define a new collation
      using those locale names, unless the libraries allow it.  That's pretty
      pointless, as well as being a violation of pg_newlocale_from_collation's
      API specification.
      
      The practical effect of this change is quite limited: it allows creating
      such collations even on platforms that don't HAVE_LOCALE_T, and it allows
      making "POSIX" collation objects on Windows, which before this would only
      let you make "C" collation objects.  Hence, even though this is a bug fix
      IMO, it doesn't seem worth the trouble to back-patch.
      
      In passing, suppress the DROP CASCADE detail messages at the end of the
      collation regression test.  I'm surprised we've never been bit by
      message ordering issues there.
      
      Per report from Murtuza Zabuawala.
      
      Discussion: https://postgr.es/m/CAKKotZS-wcDcofXDCH=sidiuajE+nqHn2CGjLLX78anyDmi3gQ@mail.gmail.com
      f9725657
    • Tom Lane's avatar
      Further improve consistency of configure's program searching. · b21c569c
      Tom Lane authored
      Peter Eisentraut noted that commit 40b9f192 had broken a configure
      behavior that some people might rely on: AC_CHECK_PROGS(FOO,...) will
      allow the search to be overridden by specifying a value for FOO on
      configure's command line or in its environment, but AC_PATH_PROGS(FOO,...)
      accepts such an override only if it's an absolute path.  We had worked
      around that behavior for some, but not all, of the pre-existing uses
      of AC_PATH_PROGS by just skipping the macro altogether when FOO is
      already set.  Let's standardize on that workaround for all uses of
      AC_PATH_PROGS, new and pre-existing, by wrapping AC_PATH_PROGS in a
      new macro PGAC_PATH_PROGS.  While at it, fix a deficiency of the old
      workaround code by making sure we report the setting to configure's log.
      
      Eventually I'd like to improve PGAC_PATH_PROGS so that it converts
      non-absolute override inputs to absolute form, eg "PYTHON=python3"
      becomes, say, PYTHON = /usr/bin/python3.  But that will take some
      nontrivial coding so it doesn't seem like a thing to do in late beta.
      
      Discussion: https://postgr.es/m/90a92a7d-938e-507a-3bd7-ecd2b4004689@2ndquadrant.com
      b21c569c
    • Dean Rasheed's avatar
      Comment fix for partition_rbound_cmp(). · 4de62168
      Dean Rasheed authored
      This was an oversight in d363d42b.
      
      Beena Emerson
      4de62168
  4. 31 Jul, 2017 12 commits
    • Tatsuo Ishii's avatar
      Fix comment. · e662ef0f
      Tatsuo Ishii authored
      XLByteToSeg and XLByteToPrevSeg calculate only a segment number.  The
      definition of these macros were modified by commit
      dfda6eba but the comment remain
      unchanged.
      
      Patch by Yugo Nagata. Back patched to 9.3 and beyond.
      e662ef0f
    • Peter Eisentraut's avatar
      Fix typo · 0b02e3f1
      Peter Eisentraut authored
      Author: Masahiko Sawada <sawada.mshk@gmail.com>
      0b02e3f1
    • Peter Eisentraut's avatar
      Fix typo · f40254a7
      Peter Eisentraut authored
      Author: Etsuro Fujita <fujita.etsuro@lab.ntt.co.jp>
      f40254a7
    • Heikki Linnakangas's avatar
    • Heikki Linnakangas's avatar
      Always use 2048 bit DH parameters for OpenSSL ephemeral DH ciphers. · c0a15e07
      Heikki Linnakangas authored
      1024 bits is considered weak these days, but OpenSSL always passes 1024 as
      the key length to the tmp_dh callback. All the code to handle other key
      lengths is, in fact, dead.
      
      To remedy those issues:
      
      * Only include hard-coded 2048-bit parameters.
      * Set the parameters directly with SSL_CTX_set_tmp_dh(), without the
        callback
      * The name of the file containing the DH parameters is now a GUC. This
        replaces the old hardcoded "dh1024.pem" filename. (The files for other
        key lengths, dh512.pem, dh2048.pem, etc. were never actually used.)
      
      This is not a new problem, but it doesn't seem worth the risk and churn to
      backport. If you care enough about the strength of the DH parameters on
      old versions, you can create custom DH parameters, with as many bits as you
      wish, and put them in the "dh1024.pem" file.
      
      Per report by Nicolas Guini and Damian Quiroga. Reviewed by Michael Paquier.
      
      Discussion: https://www.postgresql.org/message-id/CAMxBoUyjOOautVozN6ofzym828aNrDjuCcOTcCquxjwS-L2hGQ@mail.gmail.com
      c0a15e07
    • Tom Lane's avatar
      Doc: specify that the minimum supported version of Perl is 5.8.3. · dea6ba93
      Tom Lane authored
      Previously the docs just said "5.8 or later".  Experimentation shows
      that while you can build on Unix from a git checkout with 5.8.0,
      compiling recent PL/Perl requires at least 5.8.1, and you won't be
      able to run the TAP tests with less than 5.8.3 because that's when
      they added "prove".  (I do not have any information on just what the
      MSVC build scripts require.)
      
      Since all these versions are quite ancient, let's not split hairs
      in the docs, but just say that 5.8.3 is the minimum requirement.
      
      Discussion: https://postgr.es/m/16894.1501392088@sss.pgh.pa.us
      dea6ba93
    • Tom Lane's avatar
      Record full paths of programs sought by "configure". · 40b9f192
      Tom Lane authored
      Previously we had a mix of uses of AC_CHECK_PROG[S] and AC_PATH_PROG[S].
      The only difference between those macros is that the latter emits the
      full path to the program it finds, eg "/usr/bin/prove", whereas the
      former emits just "prove".  Let's standardize on always emitting the
      full path; this is better for documentation of the build, and it might
      prevent some types of failures if later build steps are done with
      a different PATH setting.
      
      I did not touch the AC_CHECK_PROG[S] calls in ax_pthread.m4 and
      ax_prog_perl_modules.m4.  There seems no need to make those diverge from
      upstream, since we do not record the programs sought by the former, while
      the latter's call to AC_CHECK_PROG(PERL,...) will never be reached.
      
      Discussion: https://postgr.es/m/25937.1501433410@sss.pgh.pa.us
      40b9f192
    • Tom Lane's avatar
      Tighten coding for non-composite case in plperl's return_next. · b4cc35fb
      Tom Lane authored
      Coverity complained about this code's practice of using scalar variables
      as single-element arrays.  While that's really just nitpicking, it probably
      is more readable to declare them as arrays, so let's do that.  A more
      important point is that the code was just blithely assuming that the
      result tupledesc has exactly one column; if it doesn't, we'd likely get
      a crash of some sort in tuplestore_putvalues.  Since the tupledesc is
      manufactured outside of plperl, that seems like an uncomfortably long
      chain of assumptions.  We can nail it down at little cost with a sanity
      check earlier in the function.
      b4cc35fb
    • Stephen Frost's avatar
      Fix function comment for dumpACL() · d2a51e3e
      Stephen Frost authored
      The comment for dumpACL() got neglected when initacls and initracls were
      added and the discussion of what 'racls' is wasn't very clear either.
      
      Per complaint from Tom.
      d2a51e3e
    • Tatsuo Ishii's avatar
      Add missing comment in postgresql.conf. · 393d47ed
      Tatsuo Ishii authored
      current_source requires to restart server to reflect the new
      value. Per Yugo Nagata and Masahiko Sawada.
      
      Back patched to 9.2 and beyond.
      393d47ed
    • Tatsuo Ishii's avatar
      Add missing comment in postgresql.conf. · 8b015dd7
      Tatsuo Ishii authored
      dynamic_shared_memory_type requires to restart server to reflect
      the new value. Per Yugo Nagata and Masahiko Sawada.
      
      Back pached to 9.4 and beyond.
      8b015dd7
    • Tatsuo Ishii's avatar
      Add missing comment in postgresql.conf. · 9fe63092
      Tatsuo Ishii authored
      max_logical_replication_workers requires to restart server to reflect
      the new value. Per Yugo Nagata. Minor editing by me.
      9fe63092
  5. 30 Jul, 2017 2 commits
    • Andres Freund's avatar
      Move ExecProcNode from dispatch to function pointer based model. · cc9f08b6
      Andres Freund authored
      This allows us to add stack-depth checks the first time an executor
      node is called, and skip that overhead on following
      calls. Additionally it yields a nice speedup.
      
      While it'd probably have been a good idea to have that check all
      along, it has become more important after the new expression
      evaluation framework in b8d7f053 - there's no stack depth
      check in common paths anymore now. We previously relied on
      ExecEvalExpr() being executed somewhere.
      
      We should move towards that model for further routines, but as this is
      required for v10, it seems better to only do the necessary (which
      already is quite large).
      
      Author: Andres Freund, Tom Lane
      Reported-By: Julien Rouhaud
      Discussion:
          https://postgr.es/m/22833.1490390175@sss.pgh.pa.us
          https://postgr.es/m/b0af9eaa-130c-60d0-9e4e-7a135b1e0c76@dalibo.com
      cc9f08b6
    • Andres Freund's avatar
      Move interrupt checking from ExecProcNode() to executor nodes. · d47cfef7
      Andres Freund authored
      In a followup commit ExecProcNode(), and especially the large switch
      it contains, will largely be replaced by a function pointer directly
      to the correct node. The node functions will then get invoked by a
      thin inline function wrapper. To avoid having to include miscadmin.h
      in headers - CHECK_FOR_INTERRUPTS() - move the interrupt checks into
      the individual executor routines.
      
      While looking through all executor nodes, I noticed a number of
      arguably missing interrupt checks, add these too.
      
      Author: Andres Freund, Tom Lane
      Reviewed-By: Tom Lane
      Discussion:
          https://postgr.es/m/22833.1490390175@sss.pgh.pa.us
      d47cfef7
  6. 28 Jul, 2017 3 commits
    • Tom Lane's avatar
      Include publication owner's name in the output of \dRp+. · 9dea962b
      Tom Lane authored
      Without this, \dRp prints information that \dRp+ does not, which
      seems pretty odd.
      
      Daniel Gustafsson
      
      Discussion: https://postgr.es/m/3641F19B-336A-431A-86CE-A80562505C5E@yesql.se
      9dea962b
    • Tom Lane's avatar
      PL/Perl portability fix: absorb relevant -D switches from Perl. · 3c163a7f
      Tom Lane authored
      The Perl documentation is very clear that stuff calling libperl should
      be built with the compiler switches shown by Perl's $Config{ccflags}.
      We'd been ignoring that up to now, and mostly getting away with it,
      but recent Perl versions contain ABI compatibility cross-checks that
      fail on some builds because of this omission.  In particular the
      sizeof(PerlInterpreter) can come out different due to some fields being
      added or removed; which means we have a live ABI hazard that we'd better
      fix rather than continuing to sweep it under the rug.
      
      However, it still seems like a bad idea to just absorb $Config{ccflags}
      verbatim.  In some environments Perl was built with a different compiler
      that doesn't even use the same switch syntax.  -D switch syntax is pretty
      universal though, and absorbing Perl's -D switches really ought to be
      enough to fix the problem.
      
      Furthermore, Perl likes to inject stuff like -D_LARGEFILE_SOURCE and
      -D_FILE_OFFSET_BITS=64 into $Config{ccflags}, which affect libc ABIs on
      platforms where they're relevant.  Adopting those seems dangerous too.
      It's unclear whether a build wherein Perl and Postgres have different ideas
      of sizeof(off_t) etc would work, or whether anyone would care about making
      it work.  But it's dead certain that having different stdio ABIs in
      core Postgres and PL/Perl will not work; we've seen that movie before.
      Therefore, let's also ignore -D switches for symbols beginning with
      underscore.  The symbols that we actually need to import should be the ones
      mentioned in perl.h's PL_bincompat_options stanza, and none of those start
      with underscore, so this seems likely to work.  (If it turns out not to
      work everywhere, we could consider intersecting the symbols mentioned in
      PL_bincompat_options with the -D switches.  But that will be much more
      complicated, so let's try this way first.)
      
      This will need to be back-patched, but first let's see what the
      buildfarm makes of it.
      
      Ashutosh Sharma, some adjustments by me
      
      Discussion: https://postgr.es/m/CANFyU97OVQ3+Mzfmt3MhuUm5NwPU=-FtbNH5Eb7nZL9ua8=rcA@mail.gmail.com
      3c163a7f
    • Tom Lane's avatar
      PL/Perl portability fix: avoid including XSUB.h in plperl.c. · bebe174b
      Tom Lane authored
      In Perl builds that define PERL_IMPLICIT_SYS, XSUB.h defines macros
      that replace a whole lot of basic libc functions with Perl functions.
      We can't tolerate that in plperl.c; it breaks at least PG_TRY and
      probably other stuff.  The core idea of this patch is to include XSUB.h
      only in the .xs files where it's really needed, and to move any code
      broken by PERL_IMPLICIT_SYS out of the .xs files and into plperl.c.
      
      The reason this hasn't been a problem before is that our build techniques
      did not result in PERL_IMPLICIT_SYS appearing as a #define in PL/Perl,
      even on some platforms where Perl thinks it is defined.  That's about to
      change in order to fix a nasty portability issue, so we need this work to
      make the code safe for that.
      
      Rather unaccountably, the Perl people chose XSUB.h as the place to provide
      the versions of the aTHX/aTHX_ macros that are needed by code that's not
      explicitly aware of the MULTIPLICITY API conventions.  Hence, just removing
      XSUB.h from plperl.c fails miserably.  But we can work around that by
      defining PERL_NO_GET_CONTEXT (which would make the relevant stanza of
      XSUB.h a no-op anyway).  As explained in perlguts.pod, that means we need
      to add a "dTHX" macro call in every C function that calls a Perl API
      function.  In most of them we just add this at the top; but since the
      macro fetches the current Perl interpreter pointer, more care is needed
      in functions that switch the active interpreter.  Lack of the macro is
      easily recognized since it results in bleats about "my_perl" not being
      defined.
      
      (A nice side benefit of this is that it significantly reduces the number
      of fetches of the current interpreter pointer.  On my machine, plperl.so
      gets more than 10% smaller, and there's probably some performance win too.
      We could reduce the number of fetches still more by decorating the code
      with pTHX_/aTHX_ macros to pass the interpreter pointer around, as
      explained by perlguts.pod; but that's a task for another day.)
      
      Formatting note: pgindent seems happy to treat "dTHX;" as a declaration
      so long as it's the first thing after the left brace, as we'd already
      observed with respect to the similar macro "dSP;".  If you try to put
      it later in a set of declarations, pgindent puts ugly extra space
      around it.
      
      Having removed XSUB.h from plperl.c, we need only move the support
      functions for spi_return_next and util_elog (both of which use PG_TRY)
      out of the .xs files and into plperl.c.  This seems sufficient to
      avoid the known problems caused by PERL_IMPLICIT_SYS, although we
      could move more code if additional issues emerge.
      
      This will need to be back-patched, but first let's see what the
      buildfarm makes of it.
      
      Patch by me, with some help from Ashutosh Sharma
      
      Discussion: https://postgr.es/m/CANFyU97OVQ3+Mzfmt3MhuUm5NwPU=-FtbNH5Eb7nZL9ua8=rcA@mail.gmail.com
      bebe174b
  7. 27 Jul, 2017 1 commit