1. 06 Sep, 2017 1 commit
  2. 05 Sep, 2017 12 commits
  3. 04 Sep, 2017 4 commits
    • Tom Lane's avatar
      Be more careful about newline-chomping in pgbench. · 0b707d6e
      Tom Lane authored
      process_backslash_command would drop the last character of the input
      command on the assumption that it was a newline.  Given a non newline
      terminated input file, this could result in dropping the last character
      of the command.  Fix that by doing an actual test that we're removing
      a newline.
      
      While at it, allow for Windows newlines (\r\n), and suppress multiple
      newlines if any.  I do not think either of those cases really occur,
      since (a) we read script files in text mode and (b) the lexer stops
      when it hits a newline.  But it's cheap enough and it provides a
      stronger guarantee about what the result string looks like.
      
      This is just cosmetic, I think, since the possibly-overly-chomped
      line was only used for display not for further processing.  So
      it doesn't seem necessary to back-patch.
      
      Fabien Coelho, reviewed by Nikolay Shaplov, whacked around a bit by me
      
      Discussion: https://postgr.es/m/alpine.DEB.2.20.1704171422500.4025@lancre
      0b707d6e
    • Tom Lane's avatar
      Fix some subtle problems in pgbench transaction stats counting. · c23bb6ba
      Tom Lane authored
      With --latency-limit, transactions might get skipped even beyond the
      transaction count limit specified by -t, throwing off the expected
      number of transactions and thus the denominator for later stats.
      Be sure to stop skipping transactions once -t is reached.
      
      Also, include skipped transactions in the "cnt" fields; this requires
      discounting them again in a couple of places, but most places are
      better off with this definition.  In particular this is needed to
      get correct overall stats for the combination of -R/-L/-t options.
      Merge some more processing into processXactStats() to simplify this.
      
      In passing, add a check that --progress-timestamp is specified only
      when --progress is.
      
      We might consider back-patching this, but given that it only matters
      for a combination of options, and given the lack of field complaints,
      consensus seems to be not to bother.
      
      Fabien Coelho, reviewed by Nikolay Shaplov
      
      Discussion: https://postgr.es/m/alpine.DEB.2.20.1704171422500.4025@lancre
      c23bb6ba
    • Tom Lane's avatar
      Adjust pgbench to allow non-ASCII characters in variable names. · 9d36a386
      Tom Lane authored
      This puts it in sync with psql's notion of what is a valid variable name.
      Like psql, we document that "non-Latin letters" are allowed, but actually
      any non-ASCII character is accepted.
      
      Fabien Coelho
      
      Discussion: https://postgr.es/m/20170405.094548.1184280384967203518.t-ishii@sraoss.co.jp
      9d36a386
    • Alvaro Herrera's avatar
  4. 03 Sep, 2017 2 commits
  5. 02 Sep, 2017 1 commit
  6. 01 Sep, 2017 17 commits
  7. 31 Aug, 2017 3 commits
    • Tom Lane's avatar
      Avoid memory leaks when a GatherMerge node is rescanned. · 2d44c58c
      Tom Lane authored
      Rescanning a GatherMerge led to leaking some memory in the executor's
      query-lifespan context, because most of the node's working data structures
      were simply abandoned and rebuilt from scratch.  In practice, this might
      never amount to much, given the cost of relaunching worker processes ---
      but it's still pretty messy, so let's fix it.
      
      We can rearrange things so that the tuple arrays are simply cleared and
      reused, and we don't need to rebuild the TupleTableSlots either, just
      clear them.  One small complication is that because we might get a
      different number of workers on each iteration, we can't keep the old
      convention that the leader's gm_slots[] entry is the last one; the leader
      might clobber a TupleTableSlot that we need for a worker in a future
      iteration.  Hence, adjust the logic so that the leader has slot 0 always,
      while the active workers have slots 1..n.
      
      Back-patch to v10 to keep all the existing versions of nodeGatherMerge.c
      in sync --- because of the renumbering of the slots, there would otherwise
      be a very large risk that any future backpatches in this module would
      introduce bugs.
      
      Discussion: https://postgr.es/m/8670.1504192177@sss.pgh.pa.us
      2d44c58c
    • Robert Haas's avatar
      Expand partitioned tables in PartDesc order. · 30833ba1
      Robert Haas authored
      Previously, we expanded the inheritance hierarchy in the order in
      which find_all_inheritors had locked the tables, but that turns out
      to block quite a bit of useful optimization.  For example, a
      partition-wise join can't count on two tables with matching bounds
      to get expanded in the same order.
      
      Where possible, this change results in expanding partitioned tables in
      *bound* order.  Bound order isn't well-defined for a list-partitioned
      table with a null-accepting partition or for a list-partitioned table
      where the bounds for a single partition are interleaved with other
      partitions.  However, when expansion in bound order is possible, it
      opens up further opportunities for optimization, such as
      strength-reducing MergeAppend to Append when the expansion order
      matches the desired sort order.
      
      Patch by me, with cosmetic revisions by Ashutosh Bapat.
      
      Discussion: http://postgr.es/m/CA+TgmoZrKj7kEzcMSum3aXV4eyvvbh9WD=c6m=002WMheDyE3A@mail.gmail.com
      30833ba1
    • Tom Lane's avatar
      Clean up shm_mq cleanup. · 6708e447
      Tom Lane authored
      The logic around shm_mq_detach was a few bricks shy of a load, because
      (contrary to the comments for shm_mq_attach) all it did was update the
      shared shm_mq state.  That left us leaking a bit of process-local
      memory, but much worse, the on_dsm_detach callback for shm_mq_detach
      was still armed.  That means that whenever we ultimately detach from
      the DSM segment, we'd run shm_mq_detach again for already-detached,
      possibly long-dead queues.  This accidentally fails to fail today,
      because we only ever re-use a shm_mq's memory for another shm_mq, and
      multiple detach attempts on the last such shm_mq are fairly harmless.
      But it's gonna bite us someday, so let's clean it up.
      
      To do that, change shm_mq_detach's API so it takes a shm_mq_handle
      not the underlying shm_mq.  This makes the callers simpler in most
      cases anyway.  Also fix a few places in parallel.c that were just
      pfree'ing the handle structs rather than doing proper cleanup.
      
      Back-patch to v10 because of the risk that the revenant shm_mq_detach
      callbacks would cause a live bug sometime.  Since this is an API
      change, it's too late to do it in 9.6.  (We could make a variant
      patch that preserves API, but I'm not excited enough to do that.)
      
      Discussion: https://postgr.es/m/8670.1504192177@sss.pgh.pa.us
      6708e447