1. 20 10月, 2012 2 次提交
    • T
      Fix hash_search to avoid corruption of the hash table on out-of-memory. · 4e32f8cd
      Tom Lane 提交于
      An out-of-memory error during expand_table() on a palloc-based hash table
      would leave a partially-initialized entry in the table.  This would not be
      harmful for transient hash tables, since they'd get thrown away anyway at
      transaction abort.  But for long-lived hash tables, such as the relcache
      hash, this would effectively corrupt the table, leading to crash or other
      misbehavior later.
      
      To fix, rearrange the order of operations so that table enlargement is
      attempted before we insert a new entry, rather than after adding it
      to the hash table.
      
      Problem discovered by Hitoshi Harada, though this is a bit different
      from his proposed patch.
      4e32f8cd
    • T
      Fix ruleutils to print "INSERT INTO foo DEFAULT VALUES" correctly. · 0d689505
      Tom Lane 提交于
      Per bug #7615 from Marko Tiikkaja.  Apparently nobody ever tried this
      case before ...
      0d689505
  2. 19 10月, 2012 9 次提交
    • S
      Fix orphan on cancel of drop index concurrently. · da857275
      Simon Riggs 提交于
      Canceling DROP INDEX CONCURRENTLY during
      wait could allow an orphaned index to be
      left behind which could not be dropped.
      
      Backpatch to 9.2
      
      Andres Freund, tested by Abhijit Menon-Sen
      da857275
    • T
      Further cleanup of catcache.c ilist changes. · 002191a1
      Tom Lane 提交于
      Remove useless duplicate initialization of bucket headers, don't use a
      dlist_mutable_iter in a performance-critical path that doesn't need it,
      make some other cosmetic changes for consistency's sake.
      002191a1
    • T
      Remove unnecessary "head" arguments from some dlist/slist functions. · dc5aeca1
      Tom Lane 提交于
      dlist_delete, dlist_insert_after, dlist_insert_before, slist_insert_after
      do not need access to the list header, and indeed insisting on that negates
      one of the main advantages of a doubly-linked list.
      
      In consequence, revert addition of "cache_bucket" field to CatCTup.
      dc5aeca1
    • T
      Code review for inline-list patch. · 8f8d7464
      Tom Lane 提交于
      Make foreach macros less syntactically dangerous, and fix some typos in
      evidently-never-tested ones.  Add missing slist_next_node and
      slist_head_node functions.  Fix broken dlist_check code.  Assorted comment
      improvements.
      8f8d7464
    • A
      Use a more portable platform test. · 2f2be747
      Andrew Dunstan 提交于
      2f2be747
    • H
      Further tweaking of the readfile() function in pg_ctl. · 2a49585e
      Heikki Linnakangas 提交于
      Don't leak a file descriptor if the file is empty or we can't read its size.
      
      Expect there to be a newline at the end of the last line, too. If there
      isn't, ignore anything after the last newline. This makes it a tiny bit
      more robust in case the file is appended to concurrently, so that we don't
      return the last line if it hasn't been fully written yet. And this makes
      the code a bit less obscure, anyway. Per Tom Lane's suggestion.
      
      Backpatch to all supported branches.
      2a49585e
    • S
      Isolation test for DROP INDEX CONCURRENTLY · 160984c8
      Simon Riggs 提交于
      for recent concurrent changes.
      
      Abhijit Menon-Sen
      160984c8
    • S
      Re-think guts of DROP INDEX CONCURRENTLY. · 2f0e480d
      Simon Riggs 提交于
      Concurrent behaviour was flawed when using
      a two-step process, so add an additional
      phase of processing to ensure concurrency
      for both SELECTs and INSERT/UPDATE/DELETEs.
      
      Backpatch to 9.2
      
      Andres Freund, tweaked by me
      2f0e480d
    • T
      Fix planning of non-strict equivalence clauses above outer joins. · 72a4231f
      Tom Lane 提交于
      If a potential equivalence clause references a variable from the nullable
      side of an outer join, the planner needs to take care that derived clauses
      are not pushed to below the outer join; else they may use the wrong value
      for the variable.  (The problem arises only with non-strict clauses, since
      if an upper clause can be proven strict then the outer join will get
      simplified to a plain join.)  The planner attempted to prevent this type
      of error by checking that potential equivalence clauses aren't
      outerjoin-delayed as a whole, but actually we have to check each side
      separately, since the two sides of the clause will get moved around
      separately if it's treated as an equivalence.  Bugs of this type can be
      demonstrated as far back as 7.4, even though releases before 8.3 had only
      a very ad-hoc notion of equivalence clauses.
      
      In addition, we neglected to account for the possibility that such clauses
      might have nonempty nullable_relids even when not outerjoin-delayed; so the
      equivalence-class machinery lacked logic to compute correct nullable_relids
      values for clauses it constructs.  This oversight was harmless before 9.2
      because we were only using RestrictInfo.nullable_relids for OR clauses;
      but as of 9.2 it could result in pushing constructed equivalence clauses
      to incorrect places.  (This accounts for bug #7604 from Bill MacArthur.)
      
      Fix the first problem by adding a new test check_equivalence_delay() in
      distribute_qual_to_rels, and fix the second one by adding code in
      equivclass.c and called functions to set correct nullable_relids for
      generated clauses.  Although I believe the second part of this is not
      currently necessary before 9.2, I chose to back-patch it anyway, partly to
      keep the logic similar across branches and partly because it seems possible
      we might find other reasons why we need valid values of nullable_relids in
      the older branches.
      
      Add regression tests illustrating these problems.  In 9.0 and up, also
      add test cases checking that we can push constants through outer joins,
      since we've broken that optimization before and I nearly broke it again
      with an overly simplistic patch for this problem.
      72a4231f
  3. 18 10月, 2012 5 次提交
    • A
      pg_dump: Output functions deterministically sorted · 7b583b20
      Alvaro Herrera 提交于
      Implementation idea from Tom Lane
      
      Author: Joel Jacobson
      Reviewed by Joachim Wieland
      7b583b20
    • S
      Revert tests for drop index concurrently. · 5ad72cee
      Simon Riggs 提交于
      5ad72cee
    • S
      Add isolation tests for DROP INDEX CONCURRENTLY. · 4e206744
      Simon Riggs 提交于
      Backpatch to 9.2 to ensure bugs are fixed.
      
      Abhijit Menon-Sen
      4e206744
    • T
      Close un-owned SMgrRelations at transaction end. · ff3f9c8d
      Tom Lane 提交于
      If an SMgrRelation is not "owned" by a relcache entry, don't allow it to
      live past transaction end.  This design allows the same SMgrRelation to be
      used for blind writes of multiple blocks during a transaction, but ensures
      that we don't hold onto such an SMgrRelation indefinitely.  Because an
      SMgrRelation typically corresponds to open file descriptors at the fd.c
      level, leaving it open when there's no corresponding relcache entry can
      mean that we prevent the kernel from reclaiming deleted disk space.
      (While CacheInvalidateSmgr messages usually fix that, there are cases
      where they're not issued, such as DROP DATABASE.  We might want to add
      some more sinval messaging for that, but I'd be inclined to keep this
      type of logic anyway, since allowing VFDs to accumulate indefinitely
      for blind-written relations doesn't seem like a good idea.)
      
      This code replaces a previous attempt towards the same goal that proved
      to be unreliable.  Back-patch to 9.1 where the previous patch was added.
      ff3f9c8d
    • T
      Revert "Use "transient" files for blind writes, take 2". · 9bacf0e3
      Tom Lane 提交于
      This reverts commit fba105b1.
      That approach had problems with the smgr-level state not tracking what
      we really want to happen, and with the VFD-level state not tracking the
      smgr-level state very well either.  In consequence, it was still possible
      to hold kernel file descriptors open for long-gone tables (as in recent
      report from Tore Halset), and yet there were also cases of FDs being closed
      undesirably soon.  A replacement implementation will follow.
      9bacf0e3
  4. 17 10月, 2012 4 次提交
    • A
      Embedded list interface · a66ee69a
      Alvaro Herrera 提交于
      Provide a common implementation of embedded singly-linked and
      doubly-linked lists.  "Embedded" in the sense that the nodes'
      next/previous pointers exist within some larger struct; this design
      choice reduces memory allocation overhead.
      
      Most of the implementation uses inlineable functions (where supported),
      for performance.
      
      Some existing uses of both types of lists have been converted to the new
      code, for demonstration purposes.  Other uses can (and probably will) be
      converted in the future.  Since dllist.c is unused after this conversion,
      it has been removed.
      
      Author: Andres Freund
      Some tweaks by me
      Reviewed by Tom Lane, Peter Geoghegan
      a66ee69a
    • S
      Fix typo in previous commit · f862a326
      Simon Riggs 提交于
      f862a326
    • S
      9f9695a0
    • B
      When outputting the session id in log_line_prefix (%c) or in CSV log · 22cc3b35
      Bruce Momjian 提交于
      output mode, cause the hex digits after the period to always be at least
      four hex digits, with zero-padding.
      22cc3b35
  5. 16 10月, 2012 1 次提交
  6. 15 10月, 2012 4 次提交
    • H
      Fix typo in comment. · 7d3ed5ae
      Heikki Linnakangas 提交于
      Fujii Masao
      7d3ed5ae
    • H
      Remove comment that is no longer true. · ff6c78c4
      Heikki Linnakangas 提交于
      AddToDataDirLockFile() supports out-of-order updates of the lockfile
      nowadays.
      ff6c78c4
    • H
      Fix race condition in pg_ctl reading postmaster.pid. · 5c89684e
      Heikki Linnakangas 提交于
      If postmaster changed postmaster.pid while pg_ctl was reading it, pg_ctl
      could overrun the buffer it allocated for the file. Fix by reading the
      whole file to memory with one read() call.
      
      initdb contains an identical copy of the readfile() function, but the files
      that initdb reads are static, not modified concurrently. Nevertheless, add
      a simple bounds-check there, if only to silence static analysis tools.
      
      Per report from Dave Vitek. Backpatch to all supported branches.
      5c89684e
    • T
      Split up process latch initialization for more-fail-soft behavior. · e81e8f93
      Tom Lane 提交于
      In the previous coding, new backend processes would attempt to create their
      self-pipe during the OwnLatch call in InitProcess.  However, pipe creation
      could fail if the kernel is short of resources; and the system does not
      recover gracefully from a FATAL error right there, since we have armed the
      dead-man switch for this process and not yet set up the on_shmem_exit
      callback that would disarm it.  The postmaster then forces an unnecessary
      database-wide crash and restart, as reported by Sean Chittenden.
      
      There are various ways we could rearrange the code to fix this, but the
      simplest and sanest seems to be to split out creation of the self-pipe into
      a new function InitializeLatchSupport, which must be called from a place
      where failure is allowed.  For most processes that gets called in
      InitProcess or InitAuxiliaryProcess, but processes that don't call either
      but still use latches need their own calls.
      
      Back-patch to 9.1, which has only a part of the latch logic that 9.2 and
      HEAD have, but nonetheless includes this bug.
      e81e8f93
  7. 13 10月, 2012 5 次提交
    • T
      Fix oversight in new code for printing rangetable aliases. · 8b728e5c
      Tom Lane 提交于
      In commit 11e13185, I missed the case of
      a CTE RTE that doesn't have a user-defined alias, but does have an
      alias assigned by set_rtable_names().  Per report from Peter Eisentraut.
      
      While at it, refactor slightly to reduce code duplication.
      8b728e5c
    • B
      In our source code, make a copy of getopt's 'optarg' string arguments, · 49ec6132
      Bruce Momjian 提交于
      rather than just storing a pointer.
      49ec6132
    • T
      Get rid of COERCE_DONTCARE. · a29f7ed5
      Tom Lane 提交于
      We don't need this hack any more.
      a29f7ed5
    • T
      Fix unportable format string. · 427fd885
      Tom Lane 提交于
      Per compiler warning.
      427fd885
    • T
      Make equal() ignore CoercionForm fields for better planning with casts. · 71e58dcf
      Tom Lane 提交于
      This change ensures that the planner will see implicit and explicit casts
      as equivalent for all purposes, except in the minority of cases where
      there's actually a semantic difference (as reflected by having a 3-argument
      cast function).  In particular, this fixes cases where the EquivalenceClass
      machinery failed to consider two references to a varchar column as
      equivalent if one was implicitly cast to text but the other was explicitly
      cast to text, as seen in bug #7598 from Vaclav Juza.  We have had similar
      bugs before in other parts of the planner, so I think it's time to fix this
      problem at the core instead of continuing to band-aid around it.
      
      Remove set_coercionform_dontcare(), which represents the band-aid
      previously in use for allowing matching of index and constraint expressions
      with inconsistent cast labeling.  (We can probably get rid of
      COERCE_DONTCARE altogether, but I don't think removing that enum value in
      back branches would be wise; it's possible there's third party code
      referring to it.)
      
      Back-patch to 9.2.  We could go back further, and might want to once this
      has been tested more; but for the moment I won't risk destabilizing plan
      choices in long-since-stable branches.
      71e58dcf
  8. 12 10月, 2012 2 次提交
    • A
      Unbreak MSVC builds after recent Makefile refactoring. · e583ffe9
      Andrew Dunstan 提交于
      Based on a suggestion by Peter Eisentraut.
      e583ffe9
    • T
      Fix cross-type case in partial row matching for hashed subplans. · 4816d2ea
      Tom Lane 提交于
      When hashing a subplan like "WHERE (a, b) NOT IN (SELECT x, y FROM ...)",
      findPartialMatch() attempted to match rows using the hashtable's internal
      equality operators, which of course are for x and y's datatypes.  What we
      need to use are the potentially cross-type operators for a=x, b=y, etc.
      Failure to do that leads to wrong answers or even crashes.  The scope for
      problems is limited to cases where we have different types with compatible
      hash functions (else we'd not be using a hashed subplan), but for example
      int4 vs int8 can cause the problem.
      
      Per bug #7597 from Bo Jensen.  This has been wrong since the hashed-subplan
      code was written, so patch all the way back.
      4816d2ea
  9. 11 10月, 2012 8 次提交
    • H
      Improve replication connection timeouts. · 6f60fdd7
      Heikki Linnakangas 提交于
      Rename replication_timeout to wal_sender_timeout, and add a new setting
      called wal_receiver_timeout that does the same at the walreceiver side.
      There was previously no timeout in walreceiver, so if the network went down,
      for example, the walreceiver could take a long time to notice that the
      connection was lost. Now with the two settings, both sides of a replication
      connection will detect a broken connection similarly.
      
      It is no longer necessary to manually set wal_receiver_status_interval to
      a value smaller than the timeout. Both wal sender and receiver now
      automatically send a "ping" message if more than 1/2 of the configured
      timeout has elapsed, and it hasn't received any messages from the other end.
      
      Amit Kapila, heavily edited by me.
      6f60fdd7
    • P
      Refactor flex and bison make rules · 8521d131
      Peter Eisentraut 提交于
      Numerous flex and bison make rules have appeared in the source tree
      over time, and they are all virtually identical, so we can replace
      them by pattern rules with some variables for customization.
      
      Users of pgxs will also be able to benefit from this.
      8521d131
    • P
      Remove _FORTIFY_SOURCE · ab112068
      Peter Eisentraut 提交于
      Apparently, on some glibc versions this causes warnings when
      optimization is not enabled.
      
      Altogether, there appear to be too many incompatibilities surrounding
      this.
      ab112068
    • T
      Remove configure-option-dependent test cases from dblink tests. · c3bf3ea2
      Tom Lane 提交于
      The HINTs generated for these error cases vary across builds.  We
      could try to work around that, but the test cases aren't really useful
      enough to justify taking any trouble.
      
      Per buildfarm.
      c3bf3ea2
    • T
      Update obsolete comment. · 864db116
      Tom Lane 提交于
      We no longer use GetNewOidWithIndex on pg_largeobject; rather,
      pg_largeobject_metadata's regular OID column is considered the repository
      of OIDs for large objects.  The special functionality is still needed for
      TOAST tables however.
      864db116
    • T
      Create an improved FDW option validator function for contrib/dblink. · 8255566f
      Tom Lane 提交于
      dblink now has its own validator function dblink_fdw_validator(), which is
      better than the core function postgresql_fdw_validator() because it gets
      the list of legal options from libpq instead of having a hard-wired list.
      
      Make the dblink extension module provide a standard foreign data wrapper
      dblink_fdw that encapsulates use of this validator, and recommend use of
      that wrapper instead of making up wrappers on the fly.
      
      Unfortunately, because ad-hoc wrappers *were* recommended practice
      previously, it's not clear when we can get rid of postgresql_fdw_validator
      without causing upgrade problems.  But this is a step in the right
      direction.
      
      Shigeru Hanada, reviewed by KaiGai Kohei
      8255566f
    • T
      Update obsolete text in fdwhandler.sgml. · 392b2e50
      Tom Lane 提交于
      Etsuro Fujita, with some wording adjustment by me.
      392b2e50
    • B
      In pg_upgrade, issue proper error message when we can't open PG_VERSION. · a9701a1d
      Bruce Momjian 提交于
      Backpatch to 9.2.
      a9701a1d