1. 16 May, 2014 8 commits
    • Tom Lane's avatar
      Suppress some more valgrind whining about btree_gist. · af215d81
      Tom Lane authored
      A couple of functions didn't bother to zero out pad bytes in datums that
      would ultimately go to disk.  Harmless, but valgrind doesn't know that.
      af215d81
    • Tom Lane's avatar
      Fix a second cause of undersized pallocs for btree_gist indexes on macaddr. · 39586bc1
      Tom Lane authored
      gbt_macad_union also allocated 12-byte structs where we really need 16.
      
      Per report from Andres Freund.  No back-patch since there's no current
      risk of a real problem.
      39586bc1
    • Tom Lane's avatar
      Fix valgrind warning for btree_gist indexes on macaddr. · 82bbb60c
      Tom Lane authored
      The macaddr opclass stores two macaddr structs (each of size 6) in an
      index column that's declared as being of type gbtreekey16, ie 16 bytes.
      In the original coding this led to passing a palloc'd value of size 12
      to the index insertion code, so that data would be fetched past the
      end of the allocated value during index tuple construction.  This makes
      valgrind unhappy.  In principle it could result in a SIGSEGV, though
      with the current implementation of palloc there's no risk since
      the 12-byte request size would be rounded up to 16 bytes anyway.
      
      To fix, add a field to struct gbtree_ninfo showing the declared size of
      the index datums, and use that in the palloc requests; and use palloc0
      to be sure that any wasted bytes are cleanly initialized.
      
      Per report from Andres Freund.  No back-patch since there's no current
      risk of a real problem.
      82bbb60c
    • Heikki Linnakangas's avatar
      d900e192
    • Heikki Linnakangas's avatar
      Fix test_decoding test case's check that slot has been dropped. · afd0fcbc
      Heikki Linnakangas authored
      pg_stat_replication shows connected replication clients. The ddl test case
      never has any replication clients connected, so querying pg_stat_replication
      is pointless. To check that a slot has been dropped correctly, query
      pg_replication_slots instead.
      
      Andres Freund
      afd0fcbc
    • Heikki Linnakangas's avatar
      Fix thinko in logical decoding of commit-prepared records. · 03e2b101
      Heikki Linnakangas authored
      The decoding of prepared transaction commits accidentally used the XID of
      the transaction performing the COMMIT PREPARED, not the XID of the prepared
      transaction. Before bb38fb0d that lead to those transactions not being
      decoded, afterwards to a assertion failure.
      03e2b101
    • Heikki Linnakangas's avatar
      Open output file before sleeping in pg_recvlogical. · e7873b74
      Heikki Linnakangas authored
      Let's complain about e.g an invalid path or permission problem sooner rather
      than later. Before this patch, we would only try to open the output file
      after receiving the first decoded message from the server.
      e7873b74
    • Heikki Linnakangas's avatar
      Initialize tsId and dbId fields in WAL record of COMMIT PREPARED. · 07a4a93a
      Heikki Linnakangas authored
      Commit dd428c79 added dbId and tsId to the xl_xact_commit struct but missed
      that prepared transaction commits reuse that struct. Fix that.
      
      Because those fields were left unitialized, replaying a commit prepared WAL
      record in a hot standby node would fail to remove the relcache init file.
      That can lead to "could not open file" errors on the standby. Relcache init
      file only needs to be removed when a system table/index is rewritten in the
      transaction using two phase commit, so that should be rare in practice. In
      HEAD, the incorrect dbId/tsId values are also used for filtering in logical
      replication code, causing the transaction to always be filtered out.
      
      Analysis and fix by Andres Freund. Backpatch to 9.0 where hot standby was
      introduced.
      07a4a93a
  2. 15 May, 2014 12 commits
    • Tom Lane's avatar
      Fix unportable setvbuf() usage in initdb. · f62d4178
      Tom Lane authored
      In yesterday's commit 2dc4f011, I tried
      to force buffering of stdout/stderr in initdb to be what it is by
      default when the program is run interactively on Unix (since that's how
      most manual testing is done).  This tripped over the fact that Windows
      doesn't support _IOLBF mode.  We dealt with that a long time ago in
      syslogger.c by falling back to unbuffered mode on Windows.  Export that
      solution in port.h and use it in initdb.
      
      Back-patch to 8.4, like the previous commit.
      f62d4178
    • Peter Eisentraut's avatar
      Fix whitespace · 2f8e68bd
      Peter Eisentraut authored
      2f8e68bd
    • Heikki Linnakangas's avatar
      Fix a couple of bugs in pg_recvlogical output to stdout. · 00c26b6a
      Heikki Linnakangas authored
      Don't close stdout on SIGHUP. Also, when a SIGHUP is received, close the
      file immediately, rather than only after receiving some more data from
      the server. Rename a variable, to avoid mentally dealing with double
      negatives (not unsynced means synced).
      00c26b6a
    • Heikki Linnakangas's avatar
      Handle duplicate XIDs in txid_snapshot. · 8f9b9590
      Heikki Linnakangas authored
      The proc array can contain duplicate XIDs, when a transaction is just being
      prepared for two-phase commit. To cope, remove any duplicates in
      txid_current_snapshot(). Also ignore duplicates in the input functions, so
      that if e.g. you have an old pg_dump file that already contains duplicates,
      it will be accepted.
      
      Report and fix by Jan Wieck. Backpatch to all supported versions.
      8f9b9590
    • Heikki Linnakangas's avatar
      Fix race condition in preparing a transaction for two-phase commit. · bb38fb0d
      Heikki Linnakangas authored
      To lock a prepared transaction's shared memory entry, we used to mark it
      with the XID of the backend. When the XID was no longer active according
      to the proc array, the entry was implicitly considered as not locked
      anymore. However, when preparing a transaction, the backend's proc array
      entry was cleared before transfering the locks (and some other state) to
      the prepared transaction's dummy PGPROC entry, so there was a window where
      another backend could finish the transaction before it was in fact fully
      prepared.
      
      To fix, rewrite the locking mechanism of global transaction entries. Instead
      of an XID, just have simple locked-or-not flag in each entry (we store the
      locking backend's backend id rather than a simple boolean, but that's just
      for debugging purposes). The backend is responsible for explicitly unlocking
      the entry, and to make sure that that happens, install a callback to unlock
      it on abort or process exit.
      
      Backpatch to all supported versions.
      bb38fb0d
    • Heikki Linnakangas's avatar
      Misc message style and doc fixes. · ff810b49
      Heikki Linnakangas authored
      Euler Taveira
      ff810b49
    • Heikki Linnakangas's avatar
      Silence warnings about redefining popen on Mingw-w64. · a82a1747
      Heikki Linnakangas authored
      Mingw-w64 headers map popen/pclose to _popen and _pclose, but we want to use
      our popen wrapper rather than the Mingw-w64. #undef the Mingw's version.
      a82a1747
    • Peter Eisentraut's avatar
    • Peter Eisentraut's avatar
      pg_ctl: Write error messages to stderr · c424c049
      Peter Eisentraut authored
      c424c049
    • Tom Lane's avatar
      In initdb, ensure stdout/stderr buffering behavior is what we expect. · 2dc4f011
      Tom Lane authored
      Since this program may print to either stdout or stderr, the relative
      ordering of its messages depends on the buffering behavior of those files.
      Force stdout to be line-buffered and stderr to be unbuffered, ensuring
      that the behavior will match standard Unix interactive behavior, even
      when stdout and stderr are rerouted to a file.
      
      Per complaint from Tomas Vondra.  The particular case he pointed out is
      new in HEAD, but issues of the same sort could arise in any branch with
      other error messages, so back-patch to all branches.
      
      I'm unsure whether we might not want to do this in other client programs
      as well.  For the moment, just fix initdb.
      2dc4f011
    • Bruce Momjian's avatar
      pg_update: slight major version adjustment · 2e6602df
      Bruce Momjian authored
      2e6602df
    • Tom Lane's avatar
      Fix version check for pg_upgrade line type crosscheck. · 4456763c
      Tom Lane authored
      Per buildfarm.
      4456763c
  3. 14 May, 2014 7 commits
    • Bruce Momjian's avatar
      pg_upgrade: error out on 'line' data type usage · bb797b64
      Bruce Momjian authored
      The data type internal format changed in 9.4.  Also mention this in the
      9.4 release notes.
      bb797b64
    • Tom Lane's avatar
      Code review for recent changes in relcache.c. · b23b0f55
      Tom Lane authored
      rd_replidindex should be managed the same as rd_oidindex, and rd_keyattr
      and rd_idattr should be managed like rd_indexattr.  Omissions in this area
      meant that the bitmapsets computed for rd_keyattr and rd_idattr would be
      leaked during any relcache flush, resulting in a slow but permanent leak in
      CacheMemoryContext.  There was also a tiny probability of relcache entry
      corruption if we ran out of memory at just the wrong point in
      RelationGetIndexAttrBitmap.  Otherwise, the fields were not zeroed where
      expected, which would not bother the code any AFAICS but could greatly
      confuse anyone examining the relcache entry while debugging.
      
      Also, create an API function RelationGetReplicaIndex rather than letting
      non-relcache code be intimate with the mechanisms underlying caching of
      that value (we won't even mention the memory leak there).
      
      Also, fix a relcache flush hazard identified by Andres Freund:
      RelationGetIndexAttrBitmap must not assume that rd_replidindex stays valid
      across index_open.
      
      The aspects of this involving rd_keyattr date back to 9.3, so back-patch
      those changes.
      b23b0f55
    • Bruce Momjian's avatar
      doc: fix 9.4 release notes typo · ac53295d
      Bruce Momjian authored
      Report by Dean Rasheed
      ac53295d
    • Bruce Momjian's avatar
      doc: fix typo in 9.4 release note comments · eefd90c4
      Bruce Momjian authored
      Patch by Sergey Muraviov
      eefd90c4
    • Tom Lane's avatar
      Make initdb throw error for bad locale values. · 31a26323
      Tom Lane authored
      Historically we've printed a complaint for a bad locale setting, but then
      fallen back to the environment default.  Per discussion, this is not such
      a great idea, because rectifying an erroneous locale choice post-initdb
      (perhaps long after data has been loaded) could be enormously expensive.
      Better to complain and give the user a chance to double-check things.
      
      The behavior was particularly bad if the bad setting came from environment
      variables rather than a bogus command-line switch: in that case not only
      was there a fallback to C/SQL_ASCII, but the printed complaint was quite
      unhelpful.  It's hard to be entirely sure what variables setlocale looked
      at, but we can at least give a hint where the problem might be.
      
      Per a complaint from Tomas Vondra.
      31a26323
    • Bruce Momjian's avatar
      docs: mention windows quoting change in 9.4 release notes · eb6144bb
      Bruce Momjian authored
      Report by Heikki Linnakangas
      eb6144bb
    • Bruce Momjian's avatar
      doc: auto-updatable view adjustments for 9.4 release notes · e513087f
      Bruce Momjian authored
      Report by Dean Rasheed
      e513087f
  4. 13 May, 2014 7 commits
    • Bruce Momjian's avatar
      docs: 9.4 release notes adjustments · 062f5351
      Bruce Momjian authored
      Patch by Andres Freund, slight adjustments by me
      062f5351
    • Heikki Linnakangas's avatar
      Fix harmless access to uninitialized memory. · f35aef41
      Heikki Linnakangas authored
      When cache invalidations arrive while ri_LoadConstraintInfo() is busy
      filling a new cache entry, InvalidateConstraintCacheCallBack() compares
      the - not yet initialized - oidHashValue field with the to-be-invalidated
      hash value. To fix, check whether the entry is already marked as invalid.
      
      Andres Freund
      f35aef41
    • Heikki Linnakangas's avatar
      Initialize padding bytes in btree_gist varbit support. · 540ac7ce
      Heikki Linnakangas authored
      The code expands a varbit gist leaf key to a node key by copying the bit
      data twice in a varlen datum, as both the lower and upper key. The lower key
      was expanded to INTALIGN size, but the padding bytes were not initialized.
      That's a problem because when the lower/upper keys are compared, the padding
      bytes are used compared too, when the values are otherwise equal. That could
      lead to incorrect query results.
      
      REINDEX is advised for any btree_gist indexes on bit or bit varying data
      type, to fix any garbage padding bytes on disk.
      
      Per Valgrind, reported by Andres Freund. Backpatch to all supported
      versions.
      540ac7ce
    • Noah Misch's avatar
      Add Valgrind suppression for reorderbuffer padding bytes. · 5a90ac29
      Noah Misch authored
      Andres Freund
      5a90ac29
    • Bruce Momjian's avatar
      docs: use structfield instead of structname in 9.4 release notes · 9af8bd51
      Bruce Momjian authored
      Where appropriate
      9af8bd51
    • Bruce Momjian's avatar
      doc: 9.4 release note adjustments · 6de9a6c0
      Bruce Momjian authored
      Report by Nicolas Barbier, Tatsuo Ishii, MauMau
      6de9a6c0
    • Tom Lane's avatar
      Be more wary in choice of timezone names to test make_timestamptz with. · 66b737cd
      Tom Lane authored
      America/Metlakatla hasn't been in the IANA database all that long, so
      some installations might not have it.  It does seem worthwhile to test
      with a fractional-minute GMT offset, but we can get that from almost
      any pre-1900 date; I chose Europe/Paris, whose LMT offset from Greenwich
      should be pretty darn well established.
      
      Also, assuming that Mars/Mons_Olympus will never be in the IANA database
      seems less than future-proof, so let's use a more fanciful location for
      the bad-zone-name check.
      
      Per complaint from Christoph Berg.
      66b737cd
  5. 12 May, 2014 3 commits
  6. 11 May, 2014 3 commits
    • Tom Lane's avatar
      Stamp 9.4beta1. · e6df2e1b
      Tom Lane authored
      e6df2e1b
    • Tom Lane's avatar
      Find postgresql.auto.conf in PGDATA even when postgresql.conf is elsewhere. · 195e81af
      Tom Lane authored
      The original coding for ALTER SYSTEM made a fundamentally bogus assumption
      that postgresql.auto.conf could be sought relative to the main config file
      if we hadn't yet determined the value of data_directory.  This fails for
      common arrangements with the config file elsewhere, as reported by
      Christoph Berg.
      
      The simplest fix is to not try to read postgresql.auto.conf until after
      SelectConfigFiles has chosen (and locked down) the data_directory setting.
      
      Because of the logic in ProcessConfigFile for handling resetting of GUCs
      that've been removed from the config file, we cannot easily read the main
      and auto config files separately; so this patch adopts a brute force
      approach of reading the main config file twice during postmaster startup.
      That's a tad ugly, but the actual time cost is likely to be negligible,
      and there's no time for a more invasive redesign before beta.
      
      With this patch, any attempt to set data_directory via ALTER SYSTEM
      will be silently ignored.  It would probably be better to throw an
      error, but that can be dealt with later.  This bug, however, would
      prevent any testing of ALTER SYSTEM by a significant fraction of the
      userbase, so it seems important to get it fixed before beta.
      195e81af
    • Tom Lane's avatar
      Rename jsonb_hash_ops to jsonb_path_ops. · 12e611d4
      Tom Lane authored
      There's no longer much pressure to switch the default GIN opclass for
      jsonb, but there was still some unhappiness with the name "jsonb_hash_ops",
      since hashing is no longer a distinguishing property of that opclass,
      and anyway it seems like a relatively minor detail.  At the suggestion of
      Heikki Linnakangas, we'll use "jsonb_path_ops" instead; that captures the
      important characteristic that each index entry depends on the entire path
      from the document root to the indexed value.
      
      Also add a user-facing explanation of the implementation properties of
      these two opclasses.
      12e611d4