1. 29 Apr, 2015 2 commits
  2. 28 Apr, 2015 6 commits
    • Bruce Momjian's avatar
      Warn about tablespace creation in PGDATA · 33cb8ff6
      Bruce Momjian authored
      Also add warning to pg_upgrade
      
      Report by Josh Berkus
      33cb8ff6
    • Tom Lane's avatar
      Fix another test for RELKIND_RELATION that should allow foreign tables now. · 290713e3
      Tom Lane authored
      I thought I'd gone through all of these before, but a fresh review found
      this one too.  (Perhaps it would be better to just delete this test and
      let the failure occur later, but for the moment I'll preserve the logic.)
      
      The case that this was rejecting is like
      	CREATE FOREIGN TABLE ft (f1 int ...) ...;
      	CREATE TABLE c1 (UNIQUE(f1)) INHERITS(ft);
      290713e3
    • Tom Lane's avatar
      Fix ATSimpleRecursion() to allow recursion from a foreign table. · ad9f08f7
      Tom Lane authored
      This is necessary in view of the changes to allow foreign tables to be
      full members of inheritance hierarchies, but I (tgl) unaccountably missed
      it in commit cb1ca4d8.
      
      Noted by Amit Langote, patch by Etsuro Fujita
      ad9f08f7
    • Alvaro Herrera's avatar
      Code review for multixact bugfix · d3821e70
      Alvaro Herrera authored
      Reword messages, rename a confusingly named function.
      
      Per Robert Haas.
      d3821e70
    • Andrew Dunstan's avatar
      Fix MSVC builds for contrib transforms modules. · cbf9f0ec
      Andrew Dunstan authored
      With this patch the MSVC build and installation will work correctly with
      the transforms. However the python transform tests for hstore and ltree
      are still disabled pending some further adjustments.
      
      Michael Paquier with some tweaks from me.
      cbf9f0ec
    • Alvaro Herrera's avatar
      Protect against multixact members wraparound · b69bf30b
      Alvaro Herrera authored
      Multixact member files are subject to early wraparound overflow and
      removal: if the average multixact size is above a certain threshold (see
      note below) the protections against offset overflow are not enough:
      during multixact truncation at checkpoint time, some
      pg_multixact/members files would be removed because the server considers
      them to be old and not needed anymore.  This leads to loss of files that
      are critical to interpret existing tuples's Xmax values.
      
      To protect against this, since we don't have enough info in pg_control
      and we can't modify it in old branches, we maintain shared memory state
      about the oldest value that we need to keep; we use this during new
      multixact creation to abort if an old still-needed file would get
      overwritten.  This value is kept up to date by checkpoints, which makes
      it not completely accurate but should be good enough.  We start emitting
      warnings sometime earlier, so that the eventual multixact-shutdown
      doesn't take DBAs completely by surprise (more precisely: once 20
      members SLRU segments are remaining before shutdown.)
      
      On troublesome average multixact size: The threshold size depends on the
      multixact freeze parameters. The oldest age is related to the greater of
      multixact_freeze_table_age and multixact_freeze_min_age: anything
      older than that should be removed promptly by autovacuum.  If autovacuum
      is keeping up with multixact freezing, the troublesome multixact average
      size is
      	(2^32-1) / Max(freeze table age, freeze min age)
      or around 28 members per multixact.  Having an average multixact size
      larger than that will eventually cause new multixact data to overwrite
      the data area for older multixacts.  (If autovacuum is not able to keep
      up, or there are errors in vacuuming, the actual maximum is
      multixact_freeeze_max_age instead, at which point multixact generation
      is stopped completely.  The default value for this limit is 400 million,
      which means that the multixact size that would cause trouble is about 10
      members).
      
      Initial bug report by Timothy Garnett, bug #12990
      Backpatch to 9.3, where the problem was introduced.
      
      Authors: Álvaro Herrera, Thomas Munro
      Reviews: Thomas Munro, Amit Kapila, Robert Haas, Kevin Grittner
      b69bf30b
  3. 27 Apr, 2015 3 commits
    • Andres Freund's avatar
      Use a fd opened for read/write when syncing slots during startup. · dfbaed45
      Andres Freund authored
      Some operating systems, including the reporter's windows, return EBADFD
      or similar when fsync() is invoked on a O_RDONLY file descriptor.
      Unfortunately RestoreSlotFromDisk() does exactly that; which causes
      failures after restarts in at least some scenarios.
      
      If you hit the bug the error message will be something like
      ERROR: could not fsync file "pg_replslot/$name/state": Bad file descriptor
      
      Simply use O_RDWR instead of O_RDONLY when opening the relevant file
      descriptor to fix the bug.  Unfortunately I have no way of verifying the
      fix, but we've seen similar problems in the past.
      
      This bug goes back to 9.4 where slots were introduced. Backpatch
      accordingly.
      
      Reported-By: Patrice Drolet
      Bug: #13143:
      Discussion: 20150424101006.2556.60897@wrigleys.postgresql.org
      dfbaed45
    • Stephen Frost's avatar
      Improve qual pushdown for RLS and SB views · dcbf5948
      Stephen Frost authored
      The original security barrier view implementation, on which RLS is
      built, prevented all non-leakproof functions from being pushed down to
      below the view, even when the function was not receiving any data from
      the view.  This optimization improves on that situation by, instead of
      checking strictly for non-leakproof functions, it checks for Vars being
      passed to non-leakproof functions and allows functions which do not
      accept arguments or whose arguments are not from the current query level
      (eg: constants can be particularly useful) to be pushed down.
      
      As discussed, this does mean that a function which is pushed down might
      gain some idea that there are rows meeting a certain criteria based on
      the number of times the function is called, but this isn't a
      particularly new issue and the documentation in rules.sgml already
      addressed similar covert-channel risks.  That documentation is updated
      to reflect that non-leakproof functions may be pushed down now, if
      they meet the above-described criteria.
      
      Author: Dean Rasheed, with a bit of rework to make things clearer,
      along with comment and documentation updates from me.
      dcbf5948
    • Andrew Dunstan's avatar
      Fix vcbuild failures and chkpass dependency caused by 854adb83 · 06ca28d5
      Andrew Dunstan authored
      Switching the Windows build scripts to use forward slashes instead of
      backslashes has caused a couple of issues in VC builds:
      - The file tree list was not correctly generated, build script
        generating vcproj file missing tree dependencies when listing items in
        Filter.
      - VC builds do not accept file paths with forward slashes, perhaps it
        could be possible to use a Condition but it seems safer to simply
        enforce the file paths to use backslashes in the vcproj files.
      - chkpass had an unneeded dependency with libpgport and libpgcommon to
        make build succeed but actually it is not necessary as crypt.c is
        already listed for this project and should be replaced with a fake name
        as it is a unique file.
      
      Michael Paquier
      06ca28d5
  4. 26 Apr, 2015 10 commits
    • Peter Eisentraut's avatar
      Fix hstore_plperl regression tests on some platforms · f9542547
      Peter Eisentraut authored
      On some platforms, plperl and plperlu cannot be loaded at the same
      time.  So split the test into two separate test files.
      f9542547
    • Andres Freund's avatar
      Also correct therefor to therefore. · 2e3ca04e
      Andres Freund authored
      Since both forms are arguably legal I wasn't sure about changing
      this. But then Tom argued for 'therefore'...
      
      Author: Dmitriy Olshevskiy
      Discussion: 34789.1430067832@sss.pgh.pa.us
      2e3ca04e
    • Andres Freund's avatar
      Fix various typos and grammar errors in comments. · 6aab1f45
      Andres Freund authored
      Author: Dmitriy Olshevskiy
      Discussion: 553D00A6.4090205@bk.ru
      6aab1f45
    • Andres Freund's avatar
      Fix possible division by zero in pg_xlogdump. · 9fe1d9ac
      Andres Freund authored
      When displaying stats it was possible that a floating point division by
      zero occured when no FPIs were issued for a type of record.
      
      Author: Abhijit Menon-Sen
      Discussion: 20150417091811.GA14008@toroid.org
      9fe1d9ac
    • Peter Eisentraut's avatar
      Add transforms feature · cac76582
      Peter Eisentraut authored
      This provides a mechanism for specifying conversions between SQL data
      types and procedural languages.  As examples, there are transforms
      for hstore and ltree for PL/Perl and PL/Python.
      
      reviews by Pavel Stěhule and Andres Freund
      cac76582
    • Tom Lane's avatar
      Fix typo in linux startup script. · f320cbb6
      Tom Lane authored
      Missed a "$" in what was meant to be a variable substitution.  Careless
      mistake in commit f23425fa.
      f320cbb6
    • Tom Lane's avatar
      Add comments warning against generalizing default_with_oids. · 0bd11d97
      Tom Lane authored
      pg_dump has historically assumed that default_with_oids affects only plain
      tables and not other relkinds.  Conceivably we could make it apply to some
      newly invented relkind if we did so from the get-go, but changing the
      behavior for existing object types will break existing dump scripts.
      Add code comments warning about this interaction.
      
      Also, make sure that default_with_oids doesn't cause parse_utilcmd.c to
      think that CREATE FOREIGN TABLE will create an OID column.  I think this is
      only a latent bug right now, since we don't allow UNIQUE/PKEY constraints
      in CREATE FOREIGN TABLE, but it's better to be consistent and future-proof.
      0bd11d97
    • Andrew Dunstan's avatar
      Try to unbreak some MSVC builds following forward slash change. · 04f1542d
      Andrew Dunstan authored
      Michael Paquier.
      04f1542d
    • Bruce Momjian's avatar
      Revert: Honor OID status of CREATE LIKE'd tables · 764ce22a
      Bruce Momjian authored
      Reverts d992f8a8
      
      Report by Tom Lane
      764ce22a
    • Peter Eisentraut's avatar
      Don't overwrite EXTRA_INSTALL · ee8d3927
      Peter Eisentraut authored
      The temp-install target sets EXTRA_INSTALL to install the current
      directory.  But when doing so, it should append instead of overwrite,
      otherwise settings of EXTRA_INSTALL from a makefile won't take effect.
      This would cause the earthdistance test to fail when called directly,
      because it would miss installing the cube module.
      ee8d3927
  5. 25 Apr, 2015 4 commits
    • Tom Lane's avatar
      Prevent improper reordering of antijoins vs. outer joins. · 3cf86860
      Tom Lane authored
      An outer join appearing within the RHS of an antijoin can't commute with
      the antijoin, but somehow I missed teaching make_outerjoininfo() about
      that.  In Teodor Sigaev's recent trouble report, this manifests as a
      "could not find RelOptInfo for given relids" error within eqjoinsel();
      but I think silently wrong query results are possible too, if the planner
      misorders the joins and doesn't happen to trigger any internal consistency
      checks.  It's broken as far back as we had antijoins, so back-patch to all
      supported branches.
      3cf86860
    • Peter Eisentraut's avatar
      Replace backslashes by forward slashes in MSVC build code · 854adb83
      Peter Eisentraut authored
      This makes it possible to run some stages of these build scripts on
      non-Windows systems.  That way, we can more easily test whether file
      moves or makefile changes might break the MSVC build.
      
      Peter Eisentraut and Michael Paquier
      854adb83
    • Stephen Frost's avatar
      Fix file comment for test_rls_hooks.c · 410cbfd6
      Stephen Frost authored
      The file-level comment wasn't updated when it was copied from the shared
      memory queue test module.  Fixed.
      
      Noted by Dean Rasheed.
      410cbfd6
    • Stephen Frost's avatar
      Perform RLS WITH CHECK before constraints, etc · e89bd02f
      Stephen Frost authored
      The RLS capability is built on top of the WITH CHECK OPTION
      system which was added for auto-updatable views, however, unlike
      WCOs on views (which are mandated by the SQL spec to not fire until
      after all other constraints and checks are done), it makes much more
      sense for RLS checks to happen earlier than constraint and uniqueness
      checks.
      
      This patch reworks the structure which holds the WCOs a bit to be
      explicitly either VIEW or RLS checks and the RLS-related checks are
      done prior to the constraint and uniqueness checks.  This also allows
      better error reporting as we are now reporting when a violation is due
      to a WITH CHECK OPTION and when it's due to an RLS policy violation,
      which was independently noted by Craig Ringer as being confusing.
      
      The documentation is also updated to include a paragraph about when RLS
      WITH CHECK handling is performed, as there have been a number of
      questions regarding that and the documentation was previously silent on
      the matter.
      
      Author: Dean Rasheed, with some kabitzing and comment changes by me.
      e89bd02f
  6. 24 Apr, 2015 10 commits
    • Noah Misch's avatar
      Remove obsolete -I options from ECPG library compilation. · c8aa8938
      Noah Misch authored
      The MSVC build system already omitted these.
      c8aa8938
    • Noah Misch's avatar
      Remove superfluous -DFRONTEND. · bcd7e889
      Noah Misch authored
      The majority practice is to add -DFRONTEND in directories building files
      that are, at other times, built for the backend.  Some directories
      lacking that property added a noise -DFRONTEND in one build system.
      Remove the excess flags, for consistency.
      bcd7e889
    • Noah Misch's avatar
      Build every ECPG library with -DFRONTEND. · 151e7471
      Noah Misch authored
      Each of the libraries incorporates src/port files, which often check
      FRONTEND.  Build systems disagreed on whether to build libpgtypes this
      way.  Only libecpg incorporates files that rely on it today.  Back-patch
      to 9.0 (all supported versions) to forestall surprises.
      151e7471
    • Tom Lane's avatar
      Fix up .gitignore and cleanup actions in some src/test/ subdirectories. · 732b33f8
      Tom Lane authored
      examples/, locale/, and thread/ lacked .gitignore files and were also
      not connected up to top-level "make clean" etc.  This had escaped notice
      because none of those directories are built in normal scenarios.  Still,
      they have working Makefiles, so if someone does a "make" in one of these
      directories it would be good if (a) git doesn't bleat about the product
      files and (b) cleaning up removes them.
      
      This is a longstanding oversight, but since this behavior is probably
      only of interest to developers, there seems no need for back-patching.
      
      Michael Paquier and Tom Lane
      732b33f8
    • Tom Lane's avatar
      Fix obsolete comment in set_rel_size(). · 70d44dd9
      Tom Lane authored
      The cross-reference to set_append_rel_pathlist() was obsoleted by
      commit e2fa76d8, which split what
      had been set_rel_pathlist() and child routines into two sets of
      functions.  But I (tgl) evidently missed updating this comment.
      
      Back-patch to 9.2 to avoid unnecessary divergence among branches.
      
      Amit Langote
      70d44dd9
    • Heikki Linnakangas's avatar
    • Peter Eisentraut's avatar
      doc: Move ALTER TABLE IF EXISTS description to better place · d64a9c8c
      Peter Eisentraut authored
      It was previously mixed in with the description of ALTER TABLE
      subcommands.  Move it to the Parameters section, which is where it is on
      other reference pages.
      
      pointed out by Amit Langote
      d64a9c8c
    • Peter Eisentraut's avatar
      Fix misspellings · 9ba978c8
      Peter Eisentraut authored
      Amit Langote and Thom Brown
      9ba978c8
    • Stephen Frost's avatar
      Copy the relation name for error reporting in WCOs · cb087ec0
      Stephen Frost authored
      In get_row_security_policies(), we need to make a copy of the relation
      name when building the WithCheckOptions structure, since
      RelationGetRelationName just returns a pointer into the local Relation
      structure.  The relation name in the WCO structure is only used for
      error reporting.
      
      Pointed out by Robert and Christian Ullrich, who noted that the
      buildfarm members with -DCLOBBER_CACHE_ALWAYS were failing.
      cb087ec0
    • Heikki Linnakangas's avatar
      Move functions related to index maintenance to separate source file. · 62420ae7
      Heikki Linnakangas authored
      There is enough code here to deserve a file of their own, not be buried
      in the middle of execUtils.c.
      62420ae7
  7. 23 Apr, 2015 3 commits
    • Heikki Linnakangas's avatar
      Fix deadlock at startup, if max_prepared_transactions is too small. · 2c47fe16
      Heikki Linnakangas authored
      When the startup process recovers transactions by scanning pg_twophase
      directory, it should clear MyLockedGxact after it's done processing each
      transaction. Like we do during normal operation, at PREPARE TRANSACTION.
      Otherwise, if the startup process exits due to an error, it will try to
      clear the locking_backend field of the last recovered transaction. That's
      usually harmless, but if the error happens in MarkAsPreparing, while
      holding TwoPhaseStateLock, the shmem-exit hook will try to acquire
      TwoPhaseStateLock again, and deadlock with itself.
      
      This fixes bug #13128 reported by Grant McAlister. The bug was introduced
      by commit bb38fb0d, so backpatch to all supported versions like that
      commit.
      2c47fe16
    • Peter Eisentraut's avatar
      Fix shell error on Solaris · 2aa0fb03
      Peter Eisentraut authored
      Apparently, the Bourne shell on Solaris doesn't like "for" loops with an
      empty list, so have "make" skip the loop in that case.
      2aa0fb03
    • Peter Eisentraut's avatar
      Improve speed of make check-world · dcae5fac
      Peter Eisentraut authored
      Before, make check-world would create a new temporary installation for
      each test suite, which is slow and wasteful.  Instead, we now create one
      test installation that is used by all test suites that are part of a
      make run.
      
      The management of the temporary installation is removed from pg_regress
      and handled in the makefiles.  This allows for better control, and
      unifies the code with that of test suites not run through pg_regress.
      
      review and msvc support by Michael Paquier <michael.paquier@gmail.com>
      
      more review by Fabien Coelho <coelho@cri.ensmp.fr>
      dcae5fac
  8. 22 Apr, 2015 2 commits
    • Alvaro Herrera's avatar
      Use the right type OID after creating a shell type · 50a16e30
      Alvaro Herrera authored
      Commit a2e35b53 neglected to update the type OID to use further
      down in DefineType when TypeShellMake was changed to return
      ObjectAddress instead of OID (it got it right in DefineRange, however.)
      This resulted in an internal error message being issued when looking up
      I/O functions.
      
      Author: Michael Paquier
      
      Also add Asserts() to a couple of other places to ensure that the type
      OID being used is as expected.
      50a16e30
    • Stephen Frost's avatar
      Fix installcheck for test_rls_hooks · 450fa1b5
      Stephen Frost authored
      As pointed out by the buildfarm, test_rls_hooks wasn't functioning
      properly with a clean installcheck.  test_rls_hooks needs to explicitly
      load the library with the hooks in it, to allow installcheck to work;
      using the --temp-config doesn't help since that isn't used when running
      installcheck and it isn't exactly fair to the buildfarm to modify the
      installed config prior to calling installcheck.
      
      Also, have test_rls_hooks clean up after itself.
      450fa1b5