1. 07 Dec, 2010 2 commits
    • Heikki Linnakangas's avatar
      Fix bugs in the hot standby known-assigned-xids tracking logic. If there's · 5a031a55
      Heikki Linnakangas authored
      an old transaction running in the master, and a lot of transactions have
      started and finished since, and a WAL-record is written in the gap between
      the creating the running-xacts snapshot and WAL-logging it, recovery will fail
      with "too many KnownAssignedXids" error. This bug was reported by
      Joachim Wieland on Nov 19th.
      
      In the same scenario, when fewer transactions have started so that all the
      xids fit in KnownAssignedXids despite the first bug, a more serious bug
      arises. We incorrectly initialize the clog code with the oldest still running
      transaction, and when we see the WAL record belonging to a transaction with
      an XID larger than one that committed already before the checkpoint we're
      recovering from, we zero the clog page containing the already committed
      transaction, leading to data loss.
      
      In hindsight, trying to track xids in the known-assigned-xids array before
      seeing the running-xacts record was too complicated. To fix that, hold
      XidGenLock while the running-xacts snapshot is taken and WAL-logged. That
      ensures that no transaction can begin or end in that gap, so that in recvoery
      we know that the snapshot contains all transactions running at that point in
      WAL.
      5a031a55
    • Tom Lane's avatar
      Add a stack overflow check to copyObject(). · 8b569280
      Tom Lane authored
      There are some code paths, such as SPI_execute(), where we invoke
      copyObject() on raw parse trees before doing parse analysis on them.  Since
      the bison grammar is capable of building heavily nested parsetrees while
      itself using only minimal stack depth, this means that copyObject() can be
      the front-line function that hits stack overflow before anything else does.
      Accordingly, it had better have a check_stack_depth() call.  I did a bit of
      performance testing and found that this slows down copyObject() by only a
      few percent, so the hit ought to be negligible in the context of complete
      processing of a query.
      
      Per off-list report from Toshihide Katayama.  Back-patch to all supported
      branches.
      8b569280
  2. 06 Dec, 2010 3 commits
  3. 05 Dec, 2010 1 commit
    • Tom Lane's avatar
      Reduce memory consumption inside inheritance_planner(). · d1001a78
      Tom Lane authored
      Avoid eating quite so much memory for large inheritance trees, by
      reclaiming the space used by temporary copies of the original parsetree and
      range table, as well as the workspace needed during planning.  The cost is
      needing to copy the finished plan trees out of the child memory context.
      Although this looks like it ought to slow things down, my testing shows
      it actually is faster, apparently because fewer interactions with malloc()
      are needed and/or we can do the work within a more readily cacheable amount
      of memory.  That result might be platform-dependent, but I'll take it.
      
      Per a gripe from John Papandriopoulos, in which it was pointed out that the
      memory consumption actually grew as O(N^2) for sufficiently many child
      tables, since we were creating N copies of the N-element range table.
      d1001a78
  4. 04 Dec, 2010 7 commits
    • Tom Lane's avatar
      Fix two small bugs in new gistget.c logic. · d1f5a92e
      Tom Lane authored
      1. Complain, rather than silently doing nothing, if an "invalid" tuple
      is found on a leaf page.  Per off-list discussion with Heikki.
      
      2. Fix oversight in code that removes a GISTSearchItem from the search
      queue: we have to reset lastHeap if this was the last heap item in the
      parent GISTSearchTreeItem.  Otherwise subsequent additions will do the
      wrong thing.  This was probably masked in early testing because in typical
      cases the parent item would now be completely empty and would be deleted on
      next call.  You'd need a queued non-leaf page at exactly the same distance
      as a heap tuple to expose the bug.
      d1f5a92e
    • Peter Eisentraut's avatar
      Make output width consistent for all ways of invoking a regression test · 387e468b
      Peter Eisentraut authored
      run_schedule() and run_single_test() were using different output widths, which
      would show up in bigcheck/bigtest, for example.
      387e468b
    • Tom Lane's avatar
      Update comment to match later code changes. · e194a942
      Tom Lane authored
      e194a942
    • Tom Lane's avatar
      Add KNNGIST support to contrib/pg_trgm. · b525bf77
      Tom Lane authored
      Teodor Sigaev, with some revision by Tom
      b525bf77
    • Tom Lane's avatar
      Add external documentation for KNNGIST. · b576757d
      Tom Lane authored
      b576757d
    • Tom Lane's avatar
      Put back gistgettuple's check for backwards scan request. · 04910a3a
      Tom Lane authored
      On reflection it's a bad idea for the KNNGIST patch to have removed that.
      We don't want it silently returning incorrect answers.
      04910a3a
    • Tom Lane's avatar
      KNNGIST, otherwise known as order-by-operator support for GIST. · 55450687
      Tom Lane authored
      This commit represents a rather heavily editorialized version of
      Teodor's builtin_knngist_itself-0.8.2 and builtin_knngist_proc-0.8.1
      patches.  I redid the opclass API to add a separate Distance method
      instead of turning the Consistent method into an illogical mess,
      fixed some bit-rot in the rbtree interfaces, and generally worked over
      the code style and comments.
      
      There's still no non-code documentation to speak of, but I'll work on
      that separately.  Some contrib-module changes are also yet to come
      (right now, point <-> point is the only KNN-ified operator).
      
      Teodor Sigaev and Tom Lane
      55450687
  5. 03 Dec, 2010 6 commits
  6. 02 Dec, 2010 5 commits
  7. 01 Dec, 2010 1 commit
    • Tom Lane's avatar
      Prevent inlining a SQL function with multiple OUT parameters. · 225f0aa3
      Tom Lane authored
      There were corner cases in which the planner would attempt to inline such
      a function, which would result in a failure at runtime due to loss of
      information about exactly what the result record type is.  Fix by disabling
      inlining when the function's recorded result type is RECORD.  There might
      be some sub-cases where inlining could still be allowed, but this is a
      simple and backpatchable fix, so leave refinements for another day.
      Per bug #5777 from Nate Carson.
      
      Back-patch to all supported branches.  8.1 happens to avoid a core-dump
      here, but it still does the wrong thing.
      225f0aa3
  8. 29 Nov, 2010 4 commits
    • Tom Lane's avatar
      Simplify and speed up mapping of index opfamilies to pathkeys. · c0b5fac7
      Tom Lane authored
      Formerly we looked up the operators associated with each index (caching
      them in relcache) and then the planner looked up the btree opfamily
      containing such operators in order to build the btree-centric pathkey
      representation that describes the index's sort order.  This is quite
      pointless for btree indexes: we might as well just use the index's opfamily
      information directly.  That saves syscache lookup cycles during planning,
      and furthermore allows us to eliminate the relcache's caching of operators
      altogether, which may help in reducing backend startup time.
      
      I added code to plancat.c to perform the same type of double lookup
      on-the-fly if it's ever faced with a non-btree amcanorder index AM.
      If such a thing actually becomes interesting for production, we should
      replace that logic with some more-direct method for identifying the
      corresponding btree opfamily; but it's not worth spending effort on now.
      
      There is considerably more to do pursuant to my recent proposal to get rid
      of sort-operator-based representations of sort orderings, but this patch
      grabs some of the low-hanging fruit.  I'll look at the remainder of that
      work after the current commitfest.
      c0b5fac7
    • Heikki Linnakangas's avatar
      3c42efce
    • Robert Haas's avatar
      Fix typo. · fab7fdb9
      Robert Haas authored
      Fujii Masao
      fab7fdb9
    • Simon Riggs's avatar
      Move call to GetTopTransactionId() earlier in LockAcquire(), · ed78384a
      Simon Riggs authored
      removing an infrequently occurring race condition in Hot Standby.
      An xid must be assigned before a lock appears in shared memory,
      rather than immediately after, else GetRunningTransactionLocks()
      may see InvalidTransactionId, causing assertion failures during
      lock processing on standby.
      
      Bug report and diagnosis by Fujii Masao, fix by me.
      ed78384a
  9. 27 Nov, 2010 7 commits
  10. 26 Nov, 2010 4 commits
    • Tom Lane's avatar
      Fix portability issues in new src/port/inet_net_ntop.c file. · 3840bc08
      Tom Lane authored
      1. Don't #include postgres.h in a frontend build.
      
      2. Don't assume that the backend's symbol PGSQL_AF_INET6 has anything to do
      with the constant that will be used by system library functions (because,
      in point of fact, it usually doesn't).  Fortunately, PGSQL_AF_INET is equal
      to AF_INET, so we can just cater for both sets of values in one case
      construct without fear of conflict.
      3840bc08
    • Robert Haas's avatar
      Add more ALTER <object> .. SET SCHEMA commands. · 55109313
      Robert Haas authored
      This adds support for changing the schema of a conversion, operator,
      operator class, operator family, text search configuration, text search
      dictionary, text search parser, or text search template.
      
      Dimitri Fontaine, with assorted corrections and other kibitzing.
      55109313
    • Tom Lane's avatar
      Remove bogus use of PGDLLIMPORT. · 1d9a0abe
      Tom Lane authored
      That macro should be attached to extern declarations, not actual
      definitions of variables.
      1d9a0abe
    • Tom Lane's avatar
      Fix significant memory leak in contrib/xml2 functions. · 4a2516a7
      Tom Lane authored
      Most of the functions that execute XPath queries leaked the data structures
      created by libxml2.  This memory would not be recovered until end of
      session, so it mounts up pretty quickly in any serious use of the feature.
      Per report from Pavel Stehule, though this isn't his patch.
      
      Back-patch to all supported branches.
      4a2516a7