1. 17 1月, 2014 8 次提交
    • H
      Prevent integer overflow with --progress >= 2148 · 27727998
      Heikki Linnakangas 提交于
      If --progress=2148 or higher was given, the calculation of the next time
      to report overflowed, and pgbench would print a progress report very
      frequently.
      
      Kingter Wang
      27727998
    • B
      doc: rename "Equals" to "Equal" · d8a0b96c
      Bruce Momjian 提交于
      d8a0b96c
    • B
      doc: fix := description typo. · 93c4bbc9
      Bruce Momjian 提交于
      93c4bbc9
    • B
      7e1955b8
    • H
      Fix Hot Standby feedback sending when streaming busily. · a472ae1e
      Heikki Linnakangas 提交于
      Commit 6f60fdd7 accidentally removed a
      call to XLogWalRcvSendHSFeedback() after flushing received WAL to disk.
      The consequence is that when walsender is busy streaming WAL, it doesn't
      send HS feedback messages. One is sent if nothing is received from the
      master for 100ms, but if there's a steady stream of WAL, it never happens.
      
      Backpatch to 9.3.
      
      Andres Freund and Amit Kapila
      a472ae1e
    • A
      Split ecpg_execute() in constituent parts · 61bee9f7
      Alvaro Herrera 提交于
      Split the rather long ecpg_execute() function into ecpg_build_params(),
      ecpg_autostart_transaction(), a smaller ecpg_execute() and
      ecpg_process_output().  There is no user-visible change here, only code
      reorganization to support future patches.
      
      Author: Zoltán Böszörményi
      
      Reviewed by Antonin Houska.  Larger, older versions of this patch were
      reviewed by Noah Misch and Michael Meskes.
      61bee9f7
    • T
      Add display of oprcode (the underlying function's name) to psql's \do+. · 515d2c59
      Tom Lane 提交于
      The + modifier of \do didn't use to do anything, but now it adds an oprcode
      column.  This is useful both as an additional form of documentation of what
      the operator does, and to save a step when finding out properties of the
      underlying function.
      
      Marko Tiikkaja, reviewed by Rushabh Lathia, adjusted a bit by me
      515d2c59
    • A
      Split ECPGdo() in constituent parts · 32913013
      Alvaro Herrera 提交于
      This splits ECPGdo() into ecpg_prologue(), ecpg_do() and
      ecpg_epilogue(), and renames free_params() into ecpg_free_params() and
      exports it.  This makes it possible for future code to use these
      routines for their own purposes.
      
      There is no user-visible functionality change here, only code
      reorganization.
      
      Zoltán Böszörményi
      
      Reviewed by Antonin Houska.  Larger, older versions of this patch were
      reviewed by Noah Misch and Michael Meskes.
      32913013
  2. 16 1月, 2014 5 次提交
  3. 15 1月, 2014 11 次提交
    • R
      test_shm_mq: Fix checks for negative queue size. · b5763ced
      Robert Haas 提交于
      Noted while addressing compiler warnings pointed out on pgsql-hackers.
      b5763ced
    • R
      Fix compiler warning. · d89746c7
      Robert Haas 提交于
      Kevin Gritter reports that his compiler complains about inq and outq
      being possibly-uninitialized at the point where they are passed to
      shm_mq_attach().  They are initialized by the call to
      setup_dynamic_shared_memory, but apparently his compiler is inlining
      that function and then having doubts about whether the for loop will
      always execute at least once.  Fix by initializing them to NULL.
      d89746c7
    • R
      Fix compiler warning: Size isn't 64 bits on 32 bit platforms. · be361ef2
      Robert Haas 提交于
      Report by Peter Eisentraut.
      be361ef2
    • T
      Improve FILES section of psql reference page. · 5df99f64
      Tom Lane 提交于
      Primarily, explain where to find the system-wide psqlrc file, per recent
      gripe from John Sutton.  Do some general wordsmithing and improve the
      markup, too.
      
      Also adjust psqlrc.sample so its comments about file location are somewhat
      trustworthy.  (Not sure why we bother with this file when it's empty,
      but whatever.)
      
      Back-patch to 9.2 where the startup file naming scheme was last changed.
      5df99f64
    • T
      Fix multiple bugs in index page locking during hot-standby WAL replay. · 061b079f
      Tom Lane 提交于
      In ordinary operation, VACUUM must be careful to take a cleanup lock on
      each leaf page of a btree index; this ensures that no indexscans could
      still be "in flight" to heap tuples due to be deleted.  (Because of
      possible index-tuple motion due to concurrent page splits, it's not enough
      to lock only the pages we're deleting index tuples from.)  In Hot Standby,
      the WAL replay process must likewise lock every leaf page.  There were
      several bugs in the code for that:
      
      * The replay scan might come across unused, all-zero pages in the index.
      While btree_xlog_vacuum itself did the right thing (ie, nothing) with
      such pages, xlogutils.c supposed that such pages must be corrupt and
      would throw an error.  This accounts for various reports of replication
      failures with "PANIC: WAL contains references to invalid pages".  To
      fix, add a ReadBufferMode value that instructs XLogReadBufferExtended
      not to complain when we're doing this.
      
      * btree_xlog_vacuum performed the extra locking if standbyState ==
      STANDBY_SNAPSHOT_READY, but that's not the correct test: we won't open up
      for hot standby queries until the database has reached consistency, and
      we don't want to do the extra locking till then either, for fear of reading
      corrupted pages (which bufmgr.c would complain about).  Fix by exporting a
      new function from xlog.c that will report whether we're actually in hot
      standby replay mode.
      
      * To ensure full coverage of the index in the replay scan, btvacuumscan
      would emit a dummy WAL record for the last page of the index, if no
      vacuuming work had been done on that page.  However, if the last page
      of the index is all-zero, that would result in corruption of said page,
      since the functions called on it weren't prepared to handle that case.
      There's no need to lock any such pages, so change the logic to target
      the last normal leaf page instead.
      
      The first two of these bugs were diagnosed by Andres Freund, the other one
      by me.  Fixes based on ideas from Heikki Linnakangas and myself.
      
      This has been wrong since Hot Standby was introduced, so back-patch to 9.0.
      061b079f
    • R
      Documentation for test_shm_mq. · 16cad3e8
      Robert Haas 提交于
      Commit 4db3744f added this contrib
      module but neglected to document it.  Oops.
      16cad3e8
    • R
      Mention that VACUUM FREEZE also effectively zeroes the table freeze age. · b6827094
      Robert Haas 提交于
      Maciek Sakrejda, reviewed by Amit Kapila
      b6827094
    • R
      Fix typo in comment. · 246a9a8d
      Robert Haas 提交于
      Etsuro Fujita
      246a9a8d
    • R
      Test code for shared memory message queue facility. · 4db3744f
      Robert Haas 提交于
      This code is intended as a demonstration of how the dynamic shared
      memory and dynamic background worker facilities can be used to establish
      a group of coooperating processes which can coordinate their activities
      using the shared memory message queue facility.  By itself, the code
      does nothing particularly interesting: it simply allows messages to
      be passed through a loop of workers and back to the original process.
      But it's a useful unit test, in addition to its demonstration value.
      4db3744f
    • R
      Single-reader, single-writer, lightweight shared message queue. · ec9037df
      Robert Haas 提交于
      This code provides infrastructure for user backends to communicate
      relatively easily with background workers.  The message queue is
      structured as a ring buffer and allows messages of arbitary length
      to be sent and received.
      
      Patch by me.  Review by KaiGai Kohei and Andres Freund.
      ec9037df
    • R
      Simple table of contents for a shared memory segment. · 6ddd5137
      Robert Haas 提交于
      This interface is intended to make it simple to divide a dynamic shared
      memory segment into different regions with distinct purposes.  It
      therefore serves much the same purpose that ShmemIndex accomplishes for
      the main shared memory segment, but it is intended to be more
      lightweight.
      
      Patch by me.  Review by Andres Freund.
      6ddd5137
  4. 14 1月, 2014 3 次提交
    • R
      Code improvements for ALTER SYSTEM .. SET. · 05ff5062
      Robert Haas 提交于
      Move FreeConfigVariables() later to make sure ErrorConfFile is valid
      when we use it, and get rid of an unnecessary string copy operation.
      
      Amit Kapila, kibitzed by me.
      05ff5062
    • R
      Make bitmap heap scans show exact/lossy block info in EXPLAIN ANALYZE. · 2bb1f14b
      Robert Haas 提交于
      Etsuro Fujita
      2bb1f14b
    • T
      Fix possible buffer overrun in contrib/pg_trgm. · c3ccc9ee
      Tom Lane 提交于
      Allow for the possibility that folding a string to lower case makes it
      longer (due to replacing a character with a longer multibyte character).
      This doesn't change the number of trigrams that will be extracted, but
      it does affect the required size of an intermediate buffer in
      generate_trgm().  Per bug #8821 from Ufuk Kayserilioglu.
      
      Also install some checks that the input string length is not so large
      as to cause overflow in the calculations of palloc request sizes.
      
      Back-patch to all supported versions.
      c3ccc9ee
  5. 13 1月, 2014 4 次提交
  6. 12 1月, 2014 5 次提交
    • T
      Disallow LATERAL references to the target table of an UPDATE/DELETE. · 158b7fa6
      Tom Lane 提交于
      On second thought, commit 0c051c90 was
      over-hasty: rather than allowing this case, we ought to reject it for now.
      That leaves the field clear for a future feature that allows the target
      table to be re-specified in the FROM (or USING) clause, which will enable
      left-joining the target table to something else.  We can then also allow
      LATERAL references to such an explicitly re-specified target table.
      But allowing them right now will create ambiguities or worse for such a
      feature, and it isn't something we documented 9.3 as supporting.
      
      While at it, add a convenience subroutine to avoid having several copies
      of the ereport for disalllowed-LATERAL-reference cases.
      158b7fa6
    • T
      Fix possible crashes due to using elog/ereport too early in startup. · 910bac59
      Tom Lane 提交于
      Per reports from Andres Freund and Luke Campbell, a server failure during
      set_pglocale_pgservice results in a segfault rather than a useful error
      message, because the infrastructure needed to use ereport hasn't been
      initialized; specifically, MemoryContextInit hasn't been called.
      One known cause of this is starting the server in a directory it
      doesn't have permission to read.
      
      We could try to prevent set_pglocale_pgservice from using anything that
      depends on palloc or elog, but that would be messy, and the odds of future
      breakage seem high.  Moreover there are other things being called in main.c
      that look likely to use palloc or elog too --- perhaps those things
      shouldn't be there, but they are there today.  The best solution seems to
      be to move the call of MemoryContextInit to very early in the backend's
      real main() function.  I've verified that an elog or ereport occurring
      immediately after that is now capable of sending something useful to
      stderr.
      
      I also added code to elog.c to print something intelligible rather than
      just crashing if MemoryContextInit hasn't created the ErrorContext.
      This could happen if MemoryContextInit itself fails (due to malloc
      failure), and provides some future-proofing against someone trying to
      sneak in new code even earlier in server startup.
      
      Back-patch to all supported branches.  Since we've only heard reports of
      this type of failure recently, it may be that some recent change has made
      it more likely to see a crash of this kind; but it sure looks like it's
      broken all the way back.
      910bac59
    • B
      Revert fd2ace80 · d84c584e
      Bruce Momjian 提交于
      Seems we want to document '=' plpgsql assignment instead.
      d84c584e
    • T
      Fix compute_scalar_stats() for case that all values exceed WIDTH_THRESHOLD. · 62865262
      Tom Lane 提交于
      The standard typanalyze functions skip over values whose detoasted size
      exceeds WIDTH_THRESHOLD (1024 bytes), so as to limit memory bloat during
      ANALYZE.  However, we (I think I, actually :-() failed to consider the
      possibility that *every* non-null value in a column is too wide.  While
      compute_minimal_stats() seems to behave reasonably anyway in such a case,
      compute_scalar_stats() just fell through and generated no pg_statistic
      entry at all.  That's unnecessarily pessimistic: we can still produce
      valid stanullfrac and stawidth values in such cases, since we do include
      too-wide values in the average-width calculation.  Furthermore, since the
      general assumption in this code is that too-wide values are probably all
      distinct from each other, it seems reasonable to set stadistinct to -1
      ("all distinct").
      
      Per complaint from Kadri Raudsepp.  This has been like this since roughly
      neolithic times, so back-patch to all supported branches.
      62865262
    • B
      docs: remove undocumented assign syntax in plpgsql examples · fd2ace80
      Bruce Momjian 提交于
      Pavel Stehule
      fd2ace80
  7. 11 1月, 2014 4 次提交