1. 15 Nov, 2014 1 commit
    • Andres Freund's avatar
      Ensure unlogged tables are reset even if crash recovery errors out. · d3586fc8
      Andres Freund authored
      Unlogged relations are reset at the end of crash recovery as they're
      only synced to disk during a proper shutdown. Unfortunately that and
      later steps can fail, e.g. due to running out of space. This reset
      was, up to now performed after marking the database as having finished
      crash recovery successfully. As out of space errors trigger a crash
      restart that could lead to the situation that not all unlogged
      relations are reset.
      
      Once that happend usage of unlogged relations could yield errors like
      "could not open file "...": No such file or directory". Luckily
      clusters that show the problem can be fixed by performing a immediate
      shutdown, and starting the database again.
      
      To fix, just call ResetUnloggedRelations(UNLOGGED_RELATION_INIT)
      earlier, before marking the database as having successfully recovered.
      
      Discussion: 20140912112246.GA4984@alap3.anarazel.de
      
      Backpatch to 9.1 where unlogged tables were introduced.
      
      Abhijit Menon-Sen and Andres Freund
      d3586fc8
  2. 14 Nov, 2014 9 commits
    • Tom Lane's avatar
      Document evaluation-order considerations for aggregate functions. · 0ce627d4
      Tom Lane authored
      The SELECT reference page didn't really address the question of when
      aggregate function evaluation occurs, nor did the "expression evaluation
      rules" documentation mention that CASE can't be used to control whether
      an aggregate gets evaluated or not.  Improve that.
      
      Per discussion of bug #11661.  Original text by Marti Raudsepp and Michael
      Paquier, rewritten significantly by me.
      0ce627d4
    • Stephen Frost's avatar
      Clean up includes from RLS patch · 80eacaa3
      Stephen Frost authored
      The initial patch for RLS mistakenly included headers associated with
      the executor and planner bits in rewrite/rowsecurity.h.  Per policy and
      general good sense, executor headers should not be included in planner
      headers or vice versa.
      
      The include of execnodes.h was a mistaken holdover from previous
      versions, while the include of relation.h was used for Relation's
      definition, which should have been coming from utils/relcache.h.  This
      patch cleans these issues up, adds comments to the RowSecurityPolicy
      struct and the RowSecurityConfigType enum, and changes Relation->rsdesc
      to Relation->rd_rsdesc to follow Relation field naming convention.
      
      Additionally, utils/rel.h was including rewrite/rowsecurity.h, which
      wasn't a great idea since that was pulling in things not really needed
      in utils/rel.h (which gets included in quite a few places).  Instead,
      use 'struct RowSecurityDesc' for the rd_rsdesc field and add comments
      explaining why.
      
      Lastly, add an include into access/nbtree/nbtsort.c for
      utils/sortsupport.h, which was evidently missed due to the above mess.
      
      Pointed out by Tom in 16970.1415838651@sss.pgh.pa.us; note that the
      concerns regarding a similar situation in the custom-path commit still
      need to be addressed.
      80eacaa3
    • Alvaro Herrera's avatar
      Document BRIN's pages_per_range in CREATE INDEX · 79172a58
      Alvaro Herrera authored
      Author: Michael Paquier
      79172a58
    • Stephen Frost's avatar
      Revert change to ALTER TABLESPACE summary. · 155c0f24
      Stephen Frost authored
      When ALTER TABLESPACE MOVE ALL was changed to be ALTER TABLE ALL IN
      TABLESPACE, the ALTER TABLESPACE summary should have been adjusted back
      to its original definition.
      
      Patch by Thom Brown (thanks!).
      155c0f24
    • Alvaro Herrera's avatar
      Reduce disk footprint of brin regression test · 86cf9a56
      Alvaro Herrera authored
      Per complaint from Tom.
      
      While at it, throw in some extra tests for nulls as well, and make sure
      that the set of data we insert on the second round is not identical to
      the first one.  Both measures are intended to improve coverage of the
      test.
      
      Also uncomment the ON COMMIT DROP clause on the CREATE TEMP TABLE
      commands.  This doesn't have any effect for someone examining the
      regression database after the tests are done, but it reduces clutter for
      those that execute the script directly.
      86cf9a56
    • Alvaro Herrera's avatar
      Allow interrupting GetMultiXactIdMembers · 51f9ea25
      Alvaro Herrera authored
      This function has a loop which can lead to uninterruptible process
      "stalls" (actually infinite loops) when some bugs are triggered.  Avoid
      that unpleasant situation by adding a check for interrupts in a place
      that shouldn't degrade performance in the normal case.
      
      Backpatch to 9.3.  Older branches have an identical loop here, but the
      aforementioned bugs are only a problem starting in 9.3 so there doesn't
      seem to be any point in backpatching any further.
      51f9ea25
    • Andres Freund's avatar
      Move BufferGetBlockNumber() out of heap_page_is_all_visible()'s inner loop. · 0c5af0a5
      Andres Freund authored
      In some workloads BufferGetBlockNumber() shows up in profiles due to
      the sheer number of calls to it (and because it causes cache
      misses). The compiler can't move it out of the loop because it's a
      full extern function call...
      0c5af0a5
    • Andres Freund's avatar
      Add valgrind suppression for pg_atomic_init_u64. · 6c878edc
      Andres Freund authored
      pg_atomic_init_u64 (indirectly) uses compare/exchange to guarantee
      atomic writes on platforms where compare/exchange is available, but
      64bit writes aren't atomic (yes, those exist). That leads to a
      harmless read of the initial value of variable.
      6c878edc
    • Peter Eisentraut's avatar
      Improve logical decoding log messages · a15d387c
      Peter Eisentraut authored
      suggestions from Robert Haas
      a15d387c
  3. 13 Nov, 2014 10 commits
    • Andres Freund's avatar
      Adapt valgrind.supp to the XLogInsert() split. · 473f162c
      Andres Freund authored
      The CRC computation now happens in XLogInsertRecord(), not
      XLogInsert() itself anymore.
      473f162c
    • Tom Lane's avatar
      Fix pg_dumpall to restore its ability to dump from ancient servers. · be09ceb2
      Tom Lane authored
      Fix breakage induced by commits d8d3d2a4
      and 463f2625: pg_dumpall has crashed when
      attempting to dump from pre-8.1 servers since then, due to faulty
      construction of the query used for dumping roles from older servers.
      The query was erroneous as of the earlier commit, but it wasn't exposed
      unless you tried to use --binary-upgrade, which you presumably wouldn't
      with a pre-8.1 server.  However commit 463f2625 made it fail always.
      
      In HEAD, also fix additional breakage induced in the same query by
      commit 491c029d, which evidently wasn't
      tested against pre-8.1 servers either.
      
      The bug is only latent in 9.1 because 463f2625 hadn't landed yet, but
      it seems best to back-patch all branches containing the faulty query.
      
      Gilles Darold
      be09ceb2
    • Andres Freund's avatar
      Fix and improve cache invalidation logic for logical decoding. · 89fd41b3
      Andres Freund authored
      There are basically three situations in which logical decoding needs
      to perform cache invalidation. During/After replaying a transaction
      with catalog changes, when skipping a uninteresting transaction that
      performed catalog changes and when erroring out while replaying a
      transaction. Unfortunately these three cases were all done slightly
      differently - partially because 8de3e410, which greatly simplifies
      matters, got committed in the midst of the development of logical
      decoding.
      
      The actually problematic case was when logical decoding skipped
      transaction commits (and thus processed invalidations). When used via
      the SQL interface cache invalidation could access the catalog - bad,
      because we didn't set up enough state to allow that correctly. It'd
      not be hard to setup sufficient state, but the simpler solution is to
      always perform cache invalidation outside a valid transaction.
      
      Also make the different cache invalidation cases look as similar as
      possible, to ease code review.
      
      This fixes the assertion failure reported by Antonin Houska in
      53EE02D9.7040702@gmail.com. The presented testcase has been expanded
      into a regression test.
      
      Backpatch to 9.4, where logical decoding was introduced.
      89fd41b3
    • Andres Freund's avatar
      Fix xmin/xmax horizon computation during logical decoding initialization. · 5a2c1840
      Andres Freund authored
      When building the initial historic catalog snapshot there were
      scenarios where snapbuild.c would use incorrect xmin/xmax values when
      starting from a xl_running_xacts record. The values used were always a
      bit suspect, but happened to be correct in the easy to test
      cases. Notably the values used when the the initial snapshot was
      computed while no other transactions were running were correct.
      
      This is likely to be the cause of the occasional buildfarm failures on
      animals markhor and tick; but it's quite possible to reproduce
      problems without CLOBBER_CACHE_ALWAYS.
      
      Backpatch to 9.4, where logical decoding was introduced.
      5a2c1840
    • Heikki Linnakangas's avatar
      Fix race condition between hot standby and restoring a full-page image. · 81c45081
      Heikki Linnakangas authored
      There was a window in RestoreBackupBlock where a page would be zeroed out,
      but not yet locked. If a backend pinned and locked the page in that window,
      it saw the zeroed page instead of the old page or new page contents, which
      could lead to missing rows in a result set, or errors.
      
      To fix, replace RBM_ZERO with RBM_ZERO_AND_LOCK, which atomically pins,
      zeroes, and locks the page, if it's not in the buffer cache already.
      
      In stable branches, the old RBM_ZERO constant is renamed to RBM_DO_NOT_USE,
      to avoid breaking any 3rd party extensions that might use RBM_ZERO. More
      importantly, this avoids renumbering the other enum values, which would
      cause even bigger confusion in extensions that use ReadBufferExtended, but
      haven't been recompiled.
      
      Backpatch to all supported versions; this has been racy since hot standby
      was introduced.
      81c45081
    • Alvaro Herrera's avatar
      Tweak row-level locking documentation · 35fed516
      Alvaro Herrera authored
      Move the meat of locking levels to mvcc.sgml, leaving only a link to it
      in the SELECT reference page.
      
      Michael Paquier, with some tweaks by Álvaro
      35fed516
    • Robert Haas's avatar
      Move the guts of our Levenshtein implementation into core. · c0828b78
      Robert Haas authored
      The hope is that we can use this to produce better diagnostics in
      some cases.
      
      Peter Geoghegan, reviewed by Michael Paquier, with some further
      changes by me.
      c0828b78
    • Peter Eisentraut's avatar
      1d69ae41
    • Heikki Linnakangas's avatar
    • Fujii Masao's avatar
      Rename pending_list_cleanup_size to gin_pending_list_limit. · c291503b
      Fujii Masao authored
      Since this parameter is only for GIN index, it's better to
      add "gin" to the parameter name for easier understanding.
      c291503b
  4. 12 Nov, 2014 5 commits
    • Tom Lane's avatar
      Explicitly support the case that a plancache's raw_parse_tree is NULL. · 67770803
      Tom Lane authored
      This only happens if a client issues a Parse message with an empty query
      string, which is a bit odd; but since it is explicitly called out as legal
      by our FE/BE protocol spec, we'd probably better continue to allow it.
      
      Fix by adding tests everywhere that the raw_parse_tree field is passed to
      functions that don't or shouldn't accept NULL.  Also make it clear in the
      relevant comments that NULL is an expected case.
      
      This reverts commits a73c9dba and
      2e9650cb, which fixed specific crash
      symptoms by hacking things at what now seems to be the wrong end, ie the
      callee functions.  Making the callees allow NULL is superficially more
      robust, but it's not always true that there is a defensible thing for the
      callee to do in such cases.  The caller has more context and is better
      able to decide what the empty-query case ought to do.
      
      Per followup discussion of bug #11335.  Back-patch to 9.2.  The code
      before that is sufficiently different that it would require development
      of a separate patch, which doesn't seem worthwhile for what is believed
      to be an essentially cosmetic change.
      67770803
    • Andres Freund's avatar
      Fix several weaknesses in slot and logical replication on-disk serialization. · ec5896ae
      Andres Freund authored
      Heikki noticed in 544E23C0.8090605@vmware.com that slot.c and
      snapbuild.c were missing the FIN_CRC32 call when computing/checking
      checksums of on disk files. That doesn't lower the the error detection
      capabilities of the checksum, but is inconsistent with other usages.
      
      In a followup mail Heikki also noticed that, contrary to a comment,
      the 'version' and 'length' struct fields of replication slot's on disk
      data where not covered by the checksum. That's not likely to lead to
      actually missed corruption as those fields are cross checked with the
      expected version and the actual file length. But it's wrong
      nonetheless.
      
      As fixing these issues makes existing on disk files unreadable, bump
      the expected versions of on disk files for both slots and logical
      decoding historic catalog snapshots.  This means that loading old
      files will fail with
      ERROR: "replication slot file ... has unsupported version 1"
      and
      ERROR: "snapbuild state file ... has unsupported version 1 instead of
      2" respectively. Given the low likelihood of anybody already using
      these new features in a production setup that seems acceptable.
      
      Fixing these issues made me notice that there's no regression test
      covering the loading of historic snapshot from disk - so add one.
      
      Backpatch to 9.4 where these features were introduced.
      ec5896ae
    • Andres Freund's avatar
      Add interrupt checks to contrib/pg_prewarm. · bd4ae0f3
      Andres Freund authored
      Currently the extension's pg_prewarm() function didn't check
      interrupts once it started "warming" data. Since individual calls can
      take a long while it's important for them to be interruptible.
      
      Backpatch to 9.4 where pg_prewarm was introduced.
      bd4ae0f3
    • Noah Misch's avatar
      Use just one database connection in the "tablespace" test. · 28245b84
      Noah Misch authored
      On Windows, DROP TABLESPACE has a race condition when run concurrently
      with other processes having opened files in the tablespace.  This led to
      a rare failure on buildfarm member frogmouth.  Back-patch to 9.4, where
      the reconnection was introduced.
      28245b84
    • Peter Eisentraut's avatar
      Message improvements · 8339f33d
      Peter Eisentraut authored
      8339f33d
  5. 11 Nov, 2014 6 commits
    • Robert Haas's avatar
      Remove incorrect comment. · f1abd78b
      Robert Haas authored
      This was introduced by commit 5ea86e6e.
      
      Peter Geoghegan
      f1abd78b
    • Tom Lane's avatar
      Loop when necessary in contrib/pgcrypto's pktreader_pull(). · f2ad2bdd
      Tom Lane authored
      This fixes a scenario in which pgp_sym_decrypt() failed with "Wrong key
      or corrupt data" on messages whose length is 6 less than a power of 2.
      
      Per bug #11905 from Connor Penhale.  Fix by Marko Tiikkaja, regression
      test case from Jeff Janes.
      f2ad2bdd
    • Tom Lane's avatar
      Fix dependency searching for case where column is visited before table. · 2edfc021
      Tom Lane authored
      When the recursive search in dependency.c visits a column and then later
      visits the whole table containing the column, it needs to propagate the
      drop-context flags for the table to the existing target-object entry for
      the column.  Otherwise we might refuse the DROP (if not CASCADE) on the
      incorrect grounds that there was no automatic drop pathway to the column.
      Remarkably, this has not been reported before, though it's possible at
      least when an extension creates both a datatype and a table using that
      datatype.
      
      Rather than just marking the column as allowed to be dropped, it might
      seem good to skip the DROP COLUMN step altogether, since the later DROP
      of the table will surely get the job done.  The problem with that is that
      the datatype would then be dropped before the table (since the whole
      situation occurred because we visited the datatype, and then recursed to
      the dependent column, before visiting the table).  That seems pretty risky,
      and the case is rare enough that it doesn't seem worth expending a lot of
      effort or risk to make the drops happen in a safe order.  So we just play
      dumb and delete the column separately according to the existing drop
      ordering rules.
      
      Per report from Petr Jelinek, though this is different from his proposed
      patch.
      
      Back-patch to 9.1, where extensions were introduced.  There's currently
      no evidence that such cases can arise before 9.1, and in any case we would
      also need to back-patch cb5c2ba2 to 9.0
      if we wanted to back-patch this.
      2edfc021
    • Fujii Masao's avatar
      Add generate_series(numeric, numeric). · 1871c892
      Fujii Masao authored
      Платон Малюгин
      Reviewed by Michael Paquier, Ali Akbar and Marti Raudsepp
      1871c892
    • Fujii Masao's avatar
      Add GUC and storage parameter to set the maximum size of GIN pending list. · a1b395b6
      Fujii Masao authored
      Previously the maximum size of GIN pending list was controlled only by
      work_mem. But the reasonable value of work_mem and the reasonable size
      of the list are basically not the same, so it was not appropriate to
      control both of them by only one GUC, i.e., work_mem. This commit
      separates new GUC, pending_list_cleanup_size, from work_mem to allow
      users to control only the size of the list.
      
      Also this commit adds pending_list_cleanup_size as new storage parameter
      to allow users to specify the size of the list per index. This is useful,
      for example, when users want to increase the size of the list only for
      the GIN index which can be updated heavily, and decrease it otherwise.
      
      Reviewed by Etsuro Fujita.
      a1b395b6
    • Heikki Linnakangas's avatar
      Really fix compilation failure on MIPS. · ae667f77
      Heikki Linnakangas authored
      I missed an additional colon in previous patch. Oops. to make that mistake
      less likely in the future, add comments as placeholders for unused inputs
      and outputs in inline assembly.
      ae667f77
  6. 10 Nov, 2014 8 commits
    • Heikki Linnakangas's avatar
      Fix compilation failure on MIPS. · baf7b3a5
      Heikki Linnakangas authored
      Rémi Zara
      baf7b3a5
    • Alvaro Herrera's avatar
      BRIN: fix bug in xlog backup block counting · a590f266
      Alvaro Herrera authored
      The code that generates the BRIN_XLOG_UPDATE removes the buffer
      reference when the page that's target for the updated tuple is freshly
      initialized.  This is a pretty usual optimization, but was breaking the
      case where the revmap buffer, which is referenced in the same WAL
      record, is getting a backup block: the replay code was using backup
      block index 1, which is not valid when the update target buffer gets
      pruned; the revmap buffer gets assigned 0 instead.  Make sure to use the
      correct backup block index for revmap when replaying.
      
      Bug reported by Fujii Masao.
      a590f266
    • Robert Haas's avatar
      Fix potential NULL-pointer dereference. · c8df9477
      Robert Haas authored
      Commit 2781b4be arranged to defer
      the setup of after-trigger-related data structures, but
      AfterTriggerPendingOnRel didn't get the memo.
      c8df9477
    • Tom Lane's avatar
      Ensure that RowExprs and whole-row Vars produce the expected column names. · bf7ca158
      Tom Lane authored
      At one time it wasn't terribly important what column names were associated
      with the fields of a composite Datum, but since the introduction of
      operations like row_to_json(), it's important that looking up the rowtype
      ID embedded in the Datum returns the column names that users would expect.
      That did not work terribly well before this patch: you could get the column
      names of the underlying table, or column aliases from any level of the
      query, depending on minor details of the plan tree.  You could even get
      totally empty field names, which is disastrous for cases like row_to_json().
      
      To fix this for whole-row Vars, look to the RTE referenced by the Var, and
      make sure its column aliases are applied to the rowtype associated with
      the result Datums.  This is a tad scary because we might have to return
      a transient RECORD type even though the Var is declared as having some
      named rowtype.  In principle it should be all right because the record
      type will still be physically compatible with the named rowtype; but
      I had to weaken one Assert in ExecEvalConvertRowtype, and there might be
      third-party code containing similar assumptions.
      
      Similarly, RowExprs have to be willing to override the column names coming
      from a named composite result type and produce a RECORD when the column
      aliases visible at the site of the RowExpr differ from the underlying
      table's column names.
      
      In passing, revert the decision made in commit 398f70ec to add
      an alias-list argument to ExecTypeFromExprList: better to provide that
      functionality in a separate function.  This also reverts most of the code
      changes in d6858148, which we don't need because we're no longer
      depending on the tupdesc found in the child plan node's result slot to be
      blessed.
      
      Back-patch to 9.4, but not earlier, since this solution changes the results
      in some cases that users might not have realized were buggy.  We'll apply a
      more restricted form of this patch in older branches.
      bf7ca158
    • Alvaro Herrera's avatar
      Further code and wording tweaks in BRIN · 1e0b4365
      Alvaro Herrera authored
      Besides a couple of typo fixes, per David Rowley, Thom Brown, and Amit
      Langote, and mentions of BRIN in the general CREATE INDEX page again per
      David, this includes silencing MSVC compiler warnings (thanks Microsoft)
      and an additional variable initialization per Coverity scanner.
      1e0b4365
    • Kevin Grittner's avatar
      Fix compiler warning for non-assert builds. · 96a73fcd
      Kevin Grittner authored
      Reported by Peter Geoghegan
      David Rowley
      96a73fcd
    • Robert Haas's avatar
      Tab complete second argument to \c with role names. · 095d4012
      Robert Haas authored
      Ian Barwick
      095d4012
    • Bruce Momjian's avatar
      C comment: mention 1500-02-29 as an invalid date · 67067f9a
      Bruce Momjian authored
      It is invalid because the Gregorian calendar is used for all years.
      67067f9a
  7. 08 Nov, 2014 1 commit
    • Alvaro Herrera's avatar
      Fix some coding issues in BRIN · b89ee54e
      Alvaro Herrera authored
      Reported by David Rowley: variadic macros are a problem.  Get rid of
      them using a trick suggested by Tom Lane: add extra parentheses where
      needed.  In the future we might decide we don't need the calls at all
      and remove them, but it seems appropriate to keep them while this code
      is still new.
      
      Also from David Rowley: brininsert() was trying to use a variable before
      initializing it.  Fix by moving the brin_form_tuple call (which
      initializes the variable) to within the locked section.
      
      Reported by Peter Eisentraut: can't use "new" as a struct member name,
      because C++ compilers will choke on it, as reported by cpluspluscheck.
      b89ee54e