1. 15 10月, 2012 3 次提交
    • 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
  2. 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
  3. 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
  4. 11 10月, 2012 9 次提交
    • 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
    • T
      Set procost to 10 for each of the pg_foo_is_visible() functions. · a80889a7
      Tom Lane 提交于
      The idea here is to make sure the planner will evaluate these functions
      last not first among the filter conditions in psql pattern search and
      tab-completion queries.  We've discussed this several times, and there
      was consensus to do it back in August, but we didn't want to do it just
      before a release.  Now seems like a safer time.
      
      No catversion bump, since this catalog change doesn't create a backend
      incompatibility nor any regression test result changes.
      a80889a7
  5. 10 10月, 2012 4 次提交
    • T
      Fix PGXS support for building loadable modules on AIX. · 3f88fa97
      Tom Lane 提交于
      Building a shlib on AIX requires use of the mkldexport.sh script, but we
      failed to install that, preventing its use from non-source-tree contexts.
      Also, Makefile.aix had the wrong idea about where to find the installed
      copy of the postgres.imp symbol file used by AIX.
      
      Per report from John Pierce.  Patch all the way back, since this has been
      broken since the beginning of PGXS.
      3f88fa97
    • T
      Remove unnecessary overhead in backend's large-object operations. · 7e0cce02
      Tom Lane 提交于
      Do read/write permissions checks at most once per large object descriptor,
      not once per lo_read or lo_write call as before.  The repeated tests were
      quite useless in the read case since the snapshot-based tests were
      guaranteed to produce the same answer every time.  In the write case,
      the extra tests could in principle detect revocation of write privileges
      after a series of writes has started --- but there's a race condition there
      anyway, since we'd check privileges before performing and certainly before
      committing the write.  So there's no real advantage to checking every
      single time, and we might as well redefine it as "only check the first
      time".
      
      On the same reasoning, remove the LargeObjectExists checks in inv_write
      and inv_truncate.  We already checked existence when the descriptor was
      opened, and checking again doesn't provide any real increment of safety
      that would justify the cost.
      7e0cce02
    • H
      Fix silly bug in previous refactoring. · 2d8c81ac
      Heikki Linnakangas 提交于
      I extracted the refactoring patch from a larger patch that contained other
      changes too, but missed one unintentional change and didn't test enough...
      2d8c81ac
    • H
      Put the logic to wait for WAL in standby mode to a separate function. · ff8f160b
      Heikki Linnakangas 提交于
      This is just refactoring with no user-visible effect, to make the code more
      readable.
      ff8f160b
  6. 09 10月, 2012 12 次提交
  7. 08 10月, 2012 5 次提交
    • R
      Add #define for UUIDOID. · 08c8058c
      Robert Haas 提交于
      Phil Sorber and Thom Brown. Reviewed by Albe Laurenz.
      08c8058c
    • H
      Say ANALYZE, not VACUUM, in error message on analyze in hot standby. · b28cc92d
      Heikki Linnakangas 提交于
      Tomonaru Katsumata
      b28cc92d
    • H
      Fix walsender handling of postmaster shutdown, to not go into endless loop. · 9c0e2b91
      Heikki Linnakangas 提交于
      This bug was introduced by my patch to use the regular die/quickdie signal
      handlers in walsender processes. I tried to make walsender exit at next
      CHECK_FOR_INTERRUPTS() by setting ProcDiePending, but that's not enough, you
      need to set InterruptPending too. On second thoght, it was not a very good
      way to make walsender exit anyway, so use proc_exit(0) instead.
      
      Also, send a CommandComplete message before exiting; that's what we did
      before, and you get a nicer error message in the standby that way.
      
      Reported by Thom Brown.
      9c0e2b91
    • T
      Autoconfiscate selection of 64-bit int type for 64-bit large object API. · 95d035e6
      Tom Lane 提交于
      Get rid of the fundamentally indefensible assumption that "long long int"
      exists and is exactly 64 bits wide on every platform Postgres runs on.
      Instead let the configure script select the type to use for "pg_int64".
      
      This is a bit of a pain in the rear since we do not want to pollute client
      namespace with all the random symbols that pg_config.h defines; instead
      we have to create a separate generated header file, "pg_config_ext.h".
      But now that the infrastructure is there, we might have the ability to
      add some other stuff that's long been wanting in this area.
      95d035e6
    • A
      Fix typo in previous MSC commit. · ea72bb8a
      Andrew Dunstan 提交于
      ea72bb8a