1. 15 Nov, 2013 6 commits
    • Tom Lane's avatar
      Prevent leakage of cached plans and execution trees in plpgsql DO blocks. · c7b849a8
      Tom Lane authored
      plpgsql likes to cache query plans and simple-expression execution state
      trees across calls.  This is a considerable win for multiple executions
      of the same function.  However, it's useless for DO blocks, since by
      definition those are executed only once and discarded.  Nonetheless,
      we were allowing a DO block's expression execution trees to survive
      until end of transaction, resulting in a significant intra-transaction
      memory leak, as reported by Yeb Havinga.  Worse, if the DO block exited
      with an error, the compiled form of the block's code was leaked till
      end of session --- along with subsidiary plancache entries.
      
      To fix, make DO blocks keep their expression execution trees in a private
      EState that's deleted at exit from the block, and add a PG_TRY block
      to plpgsql_inline_handler to make sure that memory cleanup happens
      even on error exits.  Also add a regression test covering error handling
      in a DO block, because my first try at this broke that.  (The test is
      not meant to prove that we don't leak memory anymore, though it could
      be used for that with a much larger loop count.)
      
      Ideally we'd back-patch this into all versions supporting DO blocks;
      but the patch needs to add a field to struct PLpgSQL_execstate, and that
      would break ABI compatibility for third-party plugins such as the plpgsql
      debugger.  Given the small number of complaints so far, fixing this in
      HEAD only seems like an acceptable choice.
      c7b849a8
    • Tom Lane's avatar
      Minor comment corrections for sequence hashtable patch. · 80e3a470
      Tom Lane authored
      There were enough typos in the comments to annoy me ...
      80e3a470
    • Kevin Grittner's avatar
      Fix buffer overrun in isolation test program. · 7cb964ac
      Kevin Grittner authored
      Commit 061b88c7 saved argv0 to a
      global buffer without ensuring that it was zero terminated,
      allowing references to it to overrun the buffer and access other
      memory.  This probably would not have presented any security risk,
      but could have resulted in very confusing failures if the path to
      the executable was very long.
      
      Reported by David Rowley
      7cb964ac
    • Robert Haas's avatar
      doc: Restore proper alphabetical order. · 71dd54ad
      Robert Haas authored
      Colin 't Hart
      71dd54ad
    • Heikki Linnakangas's avatar
      Fix bogus hash table creation. · 5cb719be
      Heikki Linnakangas authored
      Andres Freund
      5cb719be
    • Heikki Linnakangas's avatar
      Use a hash table to store current sequence values. · 21025d4a
      Heikki Linnakangas authored
      This speeds up nextval() and currval(), when you touch a lot of different
      sequences in the same backend.
      
      David Rowley
      21025d4a
  2. 14 Nov, 2013 3 commits
  3. 13 Nov, 2013 8 commits
  4. 12 Nov, 2013 4 commits
  5. 11 Nov, 2013 4 commits
    • Tom Lane's avatar
      Fix failure with whole-row reference to a subquery. · ebefbb5f
      Tom Lane authored
      Simple oversight in commit 1cb108ef ---
      recursively examining a subquery output column is only sane if the
      original Var refers to a single output column.  Found by Kevin Grittner.
      ebefbb5f
    • Tom Lane's avatar
      Fix ruleutils pretty-printing to not generate trailing whitespace. · 0b7e660d
      Tom Lane authored
      The pretty-printing logic in ruleutils.c operates by inserting a newline
      and some indentation whitespace into strings that are already valid SQL.
      This naturally results in leaving some trailing whitespace before the
      newline in many cases; which can be annoying when processing the output
      with other tools, as complained of by Joe Abbate.  We can fix that in
      a pretty localized fashion by deleting any trailing whitespace before
      we append a pretty-printing newline.  In addition, we have to modify the
      code inserted by commit 2f582f76 so that
      we also delete trailing whitespace when transposing items from temporary
      buffers into the main result string, when a temporary item starts with a
      newline.
      
      This results in rather voluminous changes to the regression test results,
      but it's easily verified that they are only removal of trailing whitespace.
      
      Back-patch to 9.3, because the aforementioned commit resulted in many
      more cases of trailing whitespace than had occurred in earlier branches.
      0b7e660d
    • Tom Lane's avatar
      Re-allow duplicate aliases within aliased JOINs. · 648bd05b
      Tom Lane authored
      Although the SQL spec forbids duplicate table aliases, historically
      we've allowed queries like
          SELECT ... FROM tab1 x CROSS JOIN (tab2 x CROSS JOIN tab3 y) z
      on the grounds that the aliased join (z) hides the aliases within it,
      therefore there is no conflict between the two RTEs named "x".  The
      LATERAL patch broke this, on the misguided basis that "x" could be
      ambiguous if tab3 were a LATERAL subquery.  To avoid breaking existing
      queries, it's better to allow this situation and complain only if
      tab3 actually does contain an ambiguous reference.  We need only remove
      the check that was throwing an error, because the column lookup code
      is already prepared to handle ambiguous references.  Per bug #8444.
      648bd05b
    • Magnus Hagander's avatar
      Don't abort pg_basebackup when receiving empty WAL block · 705556a6
      Magnus Hagander authored
      This is a similar fix as c6ec8793aa59d1842082e14b4b4aae7d4bd883fd
      9.2. This should never happen in 9.3 and newer since the special case
      cannot happen there, but this patch synchronizes up the code so there
      is no confusion on why they're different. An empty block is as harmless
      in 9.3 as it was in 9.2, and can safely be ignored.
      705556a6
  6. 10 Nov, 2013 1 commit
  7. 09 Nov, 2013 1 commit
    • Robert Haas's avatar
      Fix ECPG compiler warning. · dca09ac5
      Robert Haas authored
      Commit 9b4d52f2 failed to notice
      that pg_regress_ecpg needed updating.
      
      This patch was independently submitted by both David Rowley
      and Andres Freund.
      dca09ac5
  8. 08 Nov, 2013 7 commits
    • Heikki Linnakangas's avatar
      Fix race condition in GIN posting tree page deletion. · ac4ab97e
      Heikki Linnakangas authored
      If a page is deleted, and reused for something else, just as a search is
      following a rightlink to it from its left sibling, the search would continue
      scanning whatever the new contents of the page are. That could lead to
      incorrect query results, or even something more curious if the page is
      reused for a different kind of a page.
      
      To fix, modify the search algorithm to lock the next page before releasing
      the previous one, and refrain from deleting pages from the leftmost branch
      of the tree.
      
      Add a new Concurrency section to the README, explaining why this works.
      There is a lot more one could say about concurrency in GIN, but that's for
      another patch.
      
      Backpatch to all supported versions.
      ac4ab97e
    • Robert Haas's avatar
      doc: Clarify under what circumstances pg_dump needs superuser access. · 636b868f
      Robert Haas authored
      Inspired by, but different from, a patch from Ivan Lezhnjov IV
      636b868f
    • Robert Haas's avatar
      Fix pg_isolation_regress to work outside its build directory. · 9b4d52f2
      Robert Haas authored
      This makes it possible to, for example, use the isolation tester to
      test a contrib module.
      
      Andres Freund
      9b4d52f2
    • Robert Haas's avatar
      Add the notion of REPLICA IDENTITY for a table. · 07cacba9
      Robert Haas authored
      Pending patches for logical replication will use this to determine
      which columns of a tuple ought to be considered as its candidate key.
      
      Andres Freund, with minor, mostly cosmetic adjustments by me
      07cacba9
    • Tom Lane's avatar
      Make contain_volatile_functions/contain_mutable_functions look into SubLinks. · b97ee66c
      Tom Lane authored
      This change prevents us from doing inappropriate subquery flattening in
      cases such as dangerous functions hidden inside a sub-SELECT in the
      targetlist of another sub-SELECT.  That could result in unexpected behavior
      due to multiple evaluations of a volatile function, as in a recent
      complaint from Etienne Dube.  It's been questionable from the very
      beginning whether these functions should look into subqueries (as noted in
      their comments), and this case seems to provide proof that they should.
      
      Because the new code only descends into SubLinks, not SubPlans or
      InitPlans, the change only affects the planner's behavior during
      prepjointree processing and not later on --- for example, you can still get
      it to use a volatile function in an indexqual if you wrap the function in
      (SELECT ...).  That's a historical behavior, for sure, but it's reasonable
      given that the executor's evaluation rules for subplans don't depend on
      whether there are volatile functions inside them.  In any case, we need to
      constrain the behavioral change as narrowly as we can to make this
      reasonable to back-patch.
      b97ee66c
    • Tom Lane's avatar
      Fix subtly-wrong volatility checking in BeginCopyFrom(). · 060b22a9
      Tom Lane authored
      contain_volatile_functions() is best applied to the output of
      expression_planner(), not its input, so that insertion of function
      default arguments and constant-folding have been done.  (See comments
      at CheckMutability, for instance.)  It's perhaps unlikely that anyone
      will notice a difference in practice, but still we should do it properly.
      
      In passing, change variable type from Node* to Expr* to reduce the net
      number of casts needed.
      
      Noted while perusing uses of contain_volatile_functions().
      060b22a9
    • Tom Lane's avatar
      Make LOCK_PRINT & PROCLOCK_PRINT expand to ((void) 0) when not in use. · 20803d78
      Tom Lane authored
      This avoids warnings from more-anal-than-average compilers, and might
      prevent hidden syntax problems in the future.
      
      Andres Freund
      20803d78
  9. 07 Nov, 2013 5 commits
    • Kevin Grittner's avatar
    • Tom Lane's avatar
      Prevent display of dropped columns in row constraint violation messages. · c28b289b
      Tom Lane authored
      ExecBuildSlotValueDescription() printed "null" for each dropped column in
      a row being complained of by ExecConstraints().  This has some sanity in
      terms of the underlying implementation, but is of course pretty surprising
      to users.  To fix, we must pass the target relation's descriptor to
      ExecBuildSlotValueDescription(), because the slot descriptor it had been
      using doesn't get labeled with attisdropped markers.
      
      Per bug #8408 from Maxim Boguk.  Back-patch to 9.2 where the feature of
      printing row values in NOT NULL and CHECK constraint violation messages
      was introduced.
      
      Michael Paquier and Tom Lane
      c28b289b
    • Tom Lane's avatar
      Fix generation of MergeAppend plans for optimized min/max on expressions. · 5e900bc0
      Tom Lane authored
      Before jamming a desired targetlist into a plan node, one really ought to
      make sure the plan node can handle projections, and insert a buffering
      Result plan node if not.  planagg.c forgot to do this, which is a hangover
      from the days when it only dealt with IndexScan plan types.  MergeAppend
      doesn't project though, not to mention that it gets unhappy if you remove
      its possibly-resjunk sort columns.  The code accidentally failed to fail
      for cases in which the min/max argument was a simple Var, because the new
      targetlist would be equivalent to the original "flat" tlist anyway.
      For any more complex case, it's been broken since 9.1 where we introduced
      the ability to optimize min/max using MergeAppend, as reported by Raphael
      Bauduin.  Fix by duplicating the logic from grouping_planner that decides
      whether we need a Result node.
      
      In 9.2 and 9.1, this requires back-porting the tlist_same_exprs() function
      introduced in commit 4387cf95, else we'd
      uselessly add a Result node in cases that worked before.  It's rather
      tempting to back-patch that whole commit so that we can avoid extra Result
      nodes in mainline cases too; but I'll refrain, since that code hasn't
      really seen all that much field testing yet.
      5e900bc0
    • Heikki Linnakangas's avatar
      Fix setting of right bound at GIN page split. · fde7172d
      Heikki Linnakangas authored
      Broken by my refactoring.
      fde7172d
    • Tom Lane's avatar
      Add #ifdef guards for some POSIX error symbols that Windows doesn't like. · 8dace66e
      Tom Lane authored
      Per buildfarm results.  It looks like the older the Windows version, the
      more errno codes it hasn't got ...
      8dace66e
  10. 06 Nov, 2013 1 commit
    • Tom Lane's avatar
      Be more robust when strerror() doesn't give a useful result. · 8e68816c
      Tom Lane authored
      glibc, at least, is capable of returning "???" instead of anything useful
      if it doesn't like the setting of LC_CTYPE.  If this happens, or in the
      previously-known case of strerror() returning an empty string, try to
      print the C macro name for the error code ("EACCES" etc).  Only if we
      don't have the error code in our compiled-in list of popular error codes
      (which covers most though not quite all of what's called out in the POSIX
      spec) will we fall back to printing a numeric error code.  This should
      simplify debugging.
      
      Note that this functionality is currently only provided for %m in backend
      ereport/elog messages.  That may be sufficient, since we don't fool with the
      locale environment in frontend clients, but it's foreseeable that we might
      want similar code in libpq for instance.
      
      There was some talk of back-patching this, but let's see how the buildfarm
      likes it first.  It seems likely that at least some of the POSIX-defined
      error code symbols don't exist on all platforms.  I don't want to clutter
      the entire list with #ifdefs, but we may need more than are here now.
      
      MauMau, edited by me
      8e68816c