1. 05 Apr, 2015 4 commits
  2. 04 Apr, 2015 3 commits
    • Tom Lane's avatar
      Fix incorrect matching of subexpressions in outer-join plan nodes. · ca680533
      Tom Lane authored
      Previously we would re-use input subexpressions in all expression trees
      attached to a Join plan node.  However, if it's an outer join and the
      subexpression appears in the nullable-side input, this is potentially
      incorrect for apparently-matching subexpressions that came from above
      the outer join (ie, targetlist and qpqual expressions), because the
      executor will treat the subexpression value as NULL when maybe it should
      not be.
      
      The case is fairly hard to hit because (a) you need a non-strict
      subexpression (else NULL is correct), and (b) we don't usually compute
      expressions in the outputs of non-toplevel plan nodes.  But we might do
      so if the expressions are sort keys for a mergejoin, for example.
      
      Probably in the long run we should make a more explicit distinction between
      Vars appearing above and below an outer join, but that will be a major
      planner redesign and not at all back-patchable.  For the moment, just hack
      set_join_references so that it will not match any non-Var expressions
      coming from nullable inputs to expressions that came from above the join.
      (This is somewhat overkill, in that a strict expression could still be
      matched, but it doesn't seem worth the effort to check that.)
      
      Per report from Qingqing Zhou.  The added regression test case is based
      on his example.
      
      This has been broken for a very long time, so back-patch to all active
      branches.
      ca680533
    • Tom Lane's avatar
      Fix TAP tests to use only standard command-line argument ordering. · c67a86f7
      Tom Lane authored
      Some of the TAP tests were supposing that PG programs would accept switches
      after non-switch arguments on their command lines.  While GNU getopt_long()
      does allow that, our own implementation does not, and it's nowhere
      suggested in our documentation that such cases should work.  Adjust the
      tests to use only the documented syntax.
      
      Back-patch to 9.4, since without this the TAP tests fail when run with
      src/port's getopt_long() implementation.
      
      Michael Paquier
      c67a86f7
    • Robert Haas's avatar
      Fix numeric abbreviation for --disable-float8-byval. · 368b7c60
      Robert Haas authored
      When committing abd94bca, I tried to make
      it decide what kind of abbreviation to use based only on SIZEOF_DATUM,
      without regard to USE_FLOAT8_BYVAL.  That attempt was a few bricks short
      of a load, so try to fix it, and add a comment explaining what we're
      about.
      
      Patch by me; review (but not a full endorsement) by Andrew Gierth.
      368b7c60
  3. 03 Apr, 2015 10 commits
    • Tom Lane's avatar
      Remove unnecessary variables in _hash_splitbucket(). · b7e1652d
      Tom Lane authored
      Commit ed9cc2b5 made it unnecessary to pass
      start_nblkno to _hash_splitbucket(), and for that matter unnecessary to
      have the internal nblkno variable either.  My compiler didn't complain
      about that, but some did.  I also rearranged the use of oblkno a bit to
      make that case more parallel.
      
      Report and initial patch by Petr Jelinek, rearranged a bit by me.
      Back-patch to all branches, like the previous patch.
      b7e1652d
    • Alvaro Herrera's avatar
      Transform ALTER TABLE/SET TYPE/USING expr during parse analysis · 9550e834
      Alvaro Herrera authored
      This lets later stages have access to the transformed expression; in
      particular it allows DDL-deparsing code during event triggers to pass
      the transformed expression to ruleutils.c, so that the complete command
      can be deparsed.
      
      This shuffles the timing of the transform calls a bit: previously,
      nothing was transformed during parse analysis, and only the
      RELKIND_RELATION case was being handled during execution.  After this
      patch, all expressions are transformed during parse analysis (including
      those for relkinds other than RELATION), and the error for other
      relation kinds is thrown only during execution.  So we do more work than
      before to reject some bogus cases.  That seems acceptable.
      9550e834
    • Alvaro Herrera's avatar
      Add log_min_autovacuum_duration per-table option · 4ff695b1
      Alvaro Herrera authored
      This is useful to control autovacuum log volume, for situations where
      monitoring only a set of tables is necessary.
      
      Author: Michael Paquier
      Reviewed by: A team led by Naoya Anzai (also including Akira Kurosawa,
      Taiki Kondo, Huong Dangminh), Fujii Masao.
      4ff695b1
    • Alvaro Herrera's avatar
      Have autovacuum workers listen to SIGHUP, too · a75fb9b3
      Alvaro Herrera authored
      They have historically ignored it, but it's been said to be useful at
      times to change their settings mid-flight.
      
      Author: Michael Paquier
      a75fb9b3
    • Fujii Masao's avatar
      Fix error handling of XLogReaderAllocate in case of OOM · 6e4bf4ec
      Fujii Masao authored
      Similarly to previous fix 9b8d4782, commit 2c03216d has switched
      XLogReaderAllocate() to use a set of palloc calls instead of malloc,
      causing any callers of this function to fail with an error instead of
      receiving a NULL pointer in case of out-of-memory error. Fix this by
      using palloc_extended with MCXT_ALLOC_NO_OOM that will safely return
      NULL in case of an OOM.
      
      Michael Paquier, slightly modified by me.
      6e4bf4ec
    • Robert Haas's avatar
      Change the way we decide whether to give up on abbreviated text keys. · f85155e1
      Robert Haas authored
      Be more aggressive about aborting early on if it looks like it's not
      helping, but be less aggressive about aborting later on, since it's
      more expensive at that point, and also since we're currently aborting
      in some cases where abbreviation can still deliver a substantial win.
      
      Peter Geoghegan. Extensive testing by Tomas Vondra.
      f85155e1
    • Fujii Masao's avatar
      Rework handling of OOM when allocating record buffer in XLOG reader. · 9b8d4782
      Fujii Masao authored
      Commit 2c03216d changed allocate_recordbuf() so that it uses a palloc to
      allocate the read buffer and fails immediately when an out-of-memory error
      shows up, even though its callers still expect that NULL is returned in that
      case. This bug is fixed making allocate_recordbuf() use a palloc_extended
      with MCXT_ALLOC_NO_OOM flag and return NULL in OOM case.
      
      Michael Paquier
      9b8d4782
    • Fujii Masao's avatar
      Add palloc_extended for frontend and backend. · 8c8a8862
      Fujii Masao authored
      This commit also adds pg_malloc_extended for frontend. These interfaces
      can be used to control at a lower level memory allocation using an interface
      similar to MemoryContextAllocExtended. For example, the callers can specify
      MCXT_ALLOC_NO_OOM if they want to suppress the "out of memory" error while
      allocating the memory and handle a NULL return value.
      
      Michael Paquier, reviewed by me.
      8c8a8862
    • Tom Lane's avatar
      Fix rare startup failure induced by MVCC-catalog-scans patch. · bc49d932
      Tom Lane authored
      While a new backend nominally participates in sinval signaling starting
      from the SharedInvalBackendInit call near the top of InitPostgres, it
      cannot recognize sinval messages for unshared catalogs of its database
      until it has set up MyDatabaseId.  This is not problematic for the catcache
      or relcache, which by definition won't have loaded any data from or about
      such catalogs before that point.  However, commit 568d4138
      introduced a mechanism for re-using MVCC snapshots for catalog scans, and
      made invalidation of those depend on recognizing relevant sinval messages.
      So it's possible to establish a catalog snapshot to read pg_authid and
      pg_database, then before we set MyDatabaseId, receive sinval messages that
      should result in invalidating that snapshot --- but do not, because we
      don't realize they are for our database.  This mechanism explains the
      intermittent buildfarm failures we've seen since commit 31eae602.
      That commit was not itself at fault, but it introduced a new regression
      test that does reconnections concurrently with the "vacuum full pg_am"
      command in vacuum.sql.  This allowed the pre-existing error to be exposed,
      given just the right timing, because we'd fail to update our information
      about how to access pg_am.  In principle any VACUUM FULL on a system
      catalog could have created a similar hazard for concurrent incoming
      connections.  Perhaps there are more subtle failure cases as well.
      
      To fix, force invalidation of the catalog snapshot as soon as we've
      set MyDatabaseId.
      
      Back-patch to 9.4 where the error was introduced.
      bc49d932
    • Fujii Masao's avatar
      5e3d289f
  4. 02 Apr, 2015 11 commits
    • Robert Haas's avatar
      Improve pgbench error reporting. · e41beea0
      Robert Haas authored
      This would have been worth doing on general principle anyway, but the
      recent addition of an expression syntax to pgbench makes it an even
      better idea than it would have been otherwise.
      
      Fabien Coelho
      e41beea0
    • Robert Haas's avatar
      05cce2f9
    • Robert Haas's avatar
      After a crash, don't restart workers with BGW_NEVER_RESTART. · b3a5e76e
      Robert Haas authored
      Amit Khandekar
      b3a5e76e
    • Robert Haas's avatar
      Use abbreviated keys for faster sorting of numeric datums. · abd94bca
      Robert Haas authored
      Andrew Gierth, reviewed by Peter Geoghegan, with further tweaks by me.
      abd94bca
    • Alvaro Herrera's avatar
      autovacuum: Fix polarity of "wraparound" variable · 00ee6c76
      Alvaro Herrera authored
      Commit 0d831389 inadvertently reversed the meaning of the
      wraparound variable.  This causes vacuums which are not required for
      wraparound to wait for locks to be acquired, and what is worse, it
      allows wraparound vacuums to skip locked pages.
      
      Bug reported by Jeff Janes in
      http://www.postgresql.org/message-id/CAMkU=1xmTEiaY=5oMHsSQo5vd9V1Ze4kNLL0qN2eH0P_GXOaYw@mail.gmail.com
      Analysis and patch by Kyotaro HORIGUCHI
      00ee6c76
    • Robert Haas's avatar
      Add missing calls to DatumGetUInt32. · c02ef232
      Robert Haas authored
      These were inadvertently ommitted from the commit that introduced
      abbreviated keys, commit 4ea51cdf.
      
      Peter Geoghegan
      c02ef232
    • Andres Freund's avatar
      Define integer limits independently from the system definitions. · 62e2a8dc
      Andres Freund authored
      In 83ff1618 we defined integer limits iff they're not provided by the
      system. That turns out not to be the greatest idea because there's
      different ways some datatypes can be represented. E.g. on OSX PG's 64bit
      datatype will be a 'long int', but OSX unconditionally uses 'long
      long'. That disparity then can lead to warnings, e.g. around printf
      formats.
      
      One way to fix that would be to back int64 using stdint.h's
      int64_t. While a good idea it's not that easy to implement. We would
      e.g. need to include stdint.h in our external headers, which we don't
      today. Also computing the correct int64 printf formats in that case is
      nontrivial.
      
      Instead simply prefix the integer limits with PG_ and define them
      unconditionally. I've adjusted all the references to them in code, but
      not the ones in comments; the latter seems unnecessary to me.
      
      Discussion: 20150331141423.GK4878@alap3.anarazel.de
      62e2a8dc
    • Alvaro Herrera's avatar
      psql: fix \connect with URIs and conninfo strings · e146ca68
      Alvaro Herrera authored
      This is the second try at this, after fcef1617 failed miserably and
      had to be reverted: as it turns out, libpq cannot depend on libpgcommon
      after all. Instead of shuffling code in the master branch, make that one
      just like 9.4 and accept the duplication.  (This was all my own mistake,
      not the patch submitter's).
      
      psql was already accepting conninfo strings as the first parameter in
      \connect, but the way it worked wasn't sane; some of the other
      parameters would get the previous connection's values, causing it to
      connect to a completely unexpected server or, more likely, not finding
      any server at all because of completely wrong combinations of
      parameters.
      
      Fix by explicitely checking for a conninfo-looking parameter in the
      dbname position; if one is found, use its complete specification rather
      than mix with the other arguments.  Also, change tab-completion to not
      try to complete conninfo/URI-looking "dbnames" and document that
      conninfos are accepted as first argument.
      
      There was a weak consensus to backpatch this, because while the behavior
      of using the dbname as a conninfo is nowhere documented for \connect, it
      is reasonable to expect that it works because it does work in many other
      contexts.  Therefore this is backpatched all the way back to 9.0.
      
      Author: David Fetter, Andrew Dunstan.  Some editorialization by me
      (probably earning a Gierth's "Sloppy" badge in the process.)
      Reviewers: Andrew Gierth, Erik Rijkers, Pavel Stěhule, Stephen Frost,
      Robert Haas, Andrew Dunstan.
      e146ca68
    • Robert Haas's avatar
      Fix another bug in DSM_CREATE_NULL_IF_MAXSEGMENTS handling. · f272098e
      Robert Haas authored
      Amit Kapila
      f272098e
    • Robert Haas's avatar
      Revert "psql: fix \connect with URIs and conninfo strings" · 4cd639ba
      Robert Haas authored
      This reverts commit fcef1617, about
      which both the buildfarm and my local machine are very unhappy.
      4cd639ba
    • Simon Riggs's avatar
      Correct comment to use RS_EPHEMERAL · 7dae3cf6
      Simon Riggs authored
      7dae3cf6
  5. 01 Apr, 2015 5 commits
    • Alvaro Herrera's avatar
      psql: fix \connect with URIs and conninfo strings · fcef1617
      Alvaro Herrera authored
      psql was already accepting conninfo strings as the first parameter in
      \connect, but the way it worked wasn't sane; some of the other
      parameters would get the previous connection's values, causing it to
      connect to a completely unexpected server or, more likely, not finding
      any server at all because of completely wrong combinations of
      parameters.
      
      Fix by explicitely checking for a conninfo-looking parameter in the
      dbname position; if one is found, use its complete specification rather
      than mix with the other arguments.  Also, change tab-completion to not
      try to complete conninfo/URI-looking "dbnames" and document that
      conninfos are accepted as first argument.
      
      There was a weak consensus to backpatch this, because while the behavior
      of using the dbname as a conninfo is nowhere documented for \connect, it
      is reasonable to expect that it works because it does work in many other
      contexts.  Therefore this is backpatched all the way back to 9.0.
      
      To implement this, routines previously private to libpq have been
      duplicated so that psql can decide what looks like a conninfo/URI
      string.  In back branches, just duplicate the same code all the way back
      to 9.2, where URIs where introduced; 9.0 and 9.1 have a simpler version.
      In master, the routines are moved to src/common and renamed.
      
      Author: David Fetter, Andrew Dunstan.  Some editorialization by me
      (probably earning a Gierth's "Sloppy" badge in the process.)
      Reviewers: Andrew Gierth, Erik Rijkers, Pavel Stěhule, Stephen Frost,
      Robert Haas, Andrew Dunstan.
      fcef1617
    • Bruce Momjian's avatar
      pg_upgrade: call 'postgres' binary to get data directory location · a0efc714
      Bruce Momjian authored
      This matches the binary 'pg_ctl' calls.  Previously we called the
      'postmaster'.
      
      Report by Christoph Berg
      a0efc714
    • Tom Lane's avatar
      Provide real selectivity estimators for inet/cidr operators. · 89840d7d
      Tom Lane authored
      This patch fills in the formerly-stub networksel() and networkjoinsel()
      estimation functions.  Those are used for << <<= >> >>= and && operators
      on inet/cidr types.  The estimation is not perfect, certainly, because
      we rely on the existing statistics collected for the inet btree operators.
      But it's a long way better than nothing, and it's not clear that asking
      ANALYZE to collect separate stats for these operators would be a win.
      
      Emre Hasegeli, with reviews from Dilip Kumar and Heikki Linnakangas,
      and some further hacking by me
      89840d7d
    • Heikki Linnakangas's avatar
      Move inet/cidr GiST opclass functions to correct place in header file. · f770870d
      Heikki Linnakangas authored
      They were accidentally placed under the GIN heading.
      
      Andreas Karlsson
      f770870d
    • Tom Lane's avatar
      Fix incorrect markup in documentation of window frame clauses. · f6caf5ac
      Tom Lane authored
      You're required to write either RANGE or ROWS to start a frame clause,
      but the documentation incorrectly implied this is optional.  Noted by
      David Johnston.
      f6caf5ac
  6. 31 Mar, 2015 6 commits
  7. 30 Mar, 2015 1 commit
    • Andrew Dunstan's avatar
      Run pg_upgrade and pg_resetxlog with restricted token on Windows · fa1e5afa
      Andrew Dunstan authored
      As with initdb these programs need to run with a restricted token, and
      if they don't pg_upgrade will fail when run as a user with Adminstrator
      privileges.
      
      Backpatch to all live branches. On the development branch the code is
      reorganized so that the restricted token code is now in a single
      location. On the stable bramches a less invasive change is made by
      simply copying the relevant code to pg_upgrade.c and pg_resetxlog.c.
      
      Patches and bug report from Muhammad Asif Naeem, reviewed by Michael
      Paquier, slightly edited by me.
      fa1e5afa