1. 14 Mar, 2017 8 commits
  2. 13 Mar, 2017 14 commits
  3. 12 Mar, 2017 8 commits
    • Noah Misch's avatar
      Use wrappers of PG_DETOAST_DATUM_PACKED() more. · 3a0d4731
      Noah Misch authored
      This makes almost all core code follow the policy introduced in the
      previous commit.  Specific decisions:
      
      - Text search support functions with char* and length arguments, such as
        prsstart and lexize, may receive unaligned strings.  I doubt
        maintainers of non-core text search code will notice.
      
      - Use plain VARDATA() on values detoasted or synthesized earlier in the
        same function.  Use VARDATA_ANY() on varlenas sourced outside the
        function, even if they happen to always have four-byte headers.  As an
        exception, retain the universal practice of using VARDATA() on return
        values of SendFunctionCall().
      
      - Retain PG_GETARG_BYTEA_P() in pageinspect.  (Page images are too large
        for a one-byte header, so this misses no optimization.)  Sites that do
        not call get_page_from_raw() typically need the four-byte alignment.
      
      - For now, do not change btree_gist.  Its use of four-byte headers in
        memory is partly entangled with storage of 4-byte headers inside
        GBT_VARKEY, on disk.
      
      - For now, do not change gtrgm_consistent() or gtrgm_distance().  They
        incorporate the varlena header into a cache, and there are multiple
        credible implementation strategies to consider.
      3a0d4731
    • Noah Misch's avatar
      Recommend wrappers of PG_DETOAST_DATUM_PACKED(). · 9d7726c2
      Noah Misch authored
      When commit 3e23b68d introduced
      single-byte varlena headers, its fmgr.h changes presented
      PG_GETARG_TEXT_PP() and PG_GETARG_TEXT_P() as equals.  Its postgres.h
      changes presented PG_DETOAST_DATUM_PACKED() and VARDATA_ANY() as the
      exceptional case.  Now, instead, firmly recommend PG_GETARG_TEXT_PP()
      over PG_GETARG_TEXT_P(); likewise for other ...PP() macros.  This shaves
      cycles and invites consistency of style.
      9d7726c2
    • Noah Misch's avatar
      Fix pg_file_write() error handling. · 944a026b
      Noah Misch authored
      Detect fclose() failures; given "ln -s /dev/full $PGDATA/devfull",
      "pg_file_write('devfull', 'x', true)" now fails as it should.  Don't
      leak a stream when fwrite() fails.  Remove a born-ineffective test that
      aimed to skip zero-length writes.  Back-patch to 9.2 (all supported
      versions).
      944a026b
    • Noah Misch's avatar
      Assume deconstruct_array() outputs are untoasted. · 2fd26b23
      Noah Misch authored
      In functions that issue a deconstruct_array() call, consistently use
      plain VARSIZE()/VARDATA() on the array elements.  Prior practice was
      divided between those and VARSIZE_ANY_EXHDR()/VARDATA_ANY().
      2fd26b23
    • Noah Misch's avatar
      Fix comment about length of text, bytea, etc. · 9e092646
      Noah Misch authored
      When commit 3e23b68d introduced
      single-byte varlena headers, it rendered this comment incomplete.
      9e092646
    • Tom Lane's avatar
      Add "break"s to make it clearer what will happen in a nested switch. · 766f7fd6
      Tom Lane authored
      This could only matter if the guessed_type variable had a value that wasn't
      a member of the PasswordType enum; but just in case, let's be sure that
      control falls out to reach the elog(ERROR) at the end of the function.
      Per gripe from Coverity.
      766f7fd6
    • Tom Lane's avatar
      Fix typo in initdb's SCRAM password processing. · 835cc113
      Tom Lane authored
      Noted by Coverity (a rather impressive catch).
      
      Michael Paquier
      835cc113
    • Tom Lane's avatar
      Remove dead code in nodeGatherMerge.c. · 5d3f7c57
      Tom Lane authored
      Coverity noted that the last line of gather_merge_getnext() was
      unreachable, since each arm of the preceding "if" ends in a "return".
      Drop it as an oversight.  In passing, improve some nearby comments.
      5d3f7c57
  4. 11 Mar, 2017 3 commits
  5. 10 Mar, 2017 7 commits
    • Tom Lane's avatar
      Improve postmaster's logging of listen socket creation. · f9dfa5c9
      Tom Lane authored
      When one of the kernel calls in the socket()/bind()/listen() sequence
      fails, include the specific address we're trying to bind to in the log
      message.  This greatly eases debugging of network misconfigurations.
      
      Also, after successfully setting up a listen socket, report its address
      in the log, to ease verification that the expected addresses were bound.
      There was some debate about whether to print this message at LOG level or
      only DEBUG1, but the majority of votes were for the former.
      
      Discussion: https://postgr.es/m/9564.1489091245@sss.pgh.pa.us
      f9dfa5c9
    • Peter Eisentraut's avatar
      pg_dump: Fix dumping of publications · de752816
      Peter Eisentraut authored
      Dumping a publication with more than one table crashed pg_dump.
      
      patch by Amit Langote <Langote_Amit_f8@lab.ntt.co.jp>, test by me
      de752816
    • Tom Lane's avatar
      Reduce log verbosity of startup/shutdown for launcher subprocesses. · 6ec4c858
      Tom Lane authored
      There's no really good reason why the autovacuum launcher and logical
      replication launcher should announce themselves at startup and shutdown
      by default.  Users don't care that those processes exist, and it's
      inconsistent that those background processes announce themselves while
      others don't.  So, reduce those messages from LOG to DEBUG1 level.
      
      I was sorely tempted to reduce the "starting logical replication worker
      for subscription ..." message to DEBUG1 as well, but forebore for now.
      Those processes might possibly be of direct interest to users, at least
      until logical replication is a lot better shaken out than it is today.
      
      Discussion: https://postgr.es/m/19479.1489121003@sss.pgh.pa.us
      6ec4c858
    • Robert Haas's avatar
      Revert "Use group updates when setting transaction status in clog." · 39081175
      Robert Haas authored
      This reverts commit ccce90b3.  This
      optimization is unsafe, at least, of rollbacks and rollbacks to
      savepoints, but I'm concerned there may be other problematic cases as
      well.  Therefore, I've decided to revert this pending further
      investigation.
      39081175
    • Andres Freund's avatar
      Enable 64 bit atomics on ARM64. · f8f1430a
      Andres Freund authored
      Previously they were disabled due to performance concerns on 32bit
      arm, where 64bit atomics are often implemented via kernel traps.
      
      Author: Roman Shaposhnik
      Discussion: http://postgr.es/m/CA+ULb+uErkFuXUCCXWHYvnV5KnAyjGUzzRcPA-M0cgO+Hm4RSA@mail.gmail.com
      f8f1430a
    • Tom Lane's avatar
      Sanitize newlines in object names in "pg_restore -l" output. · f39ddd84
      Tom Lane authored
      Commits 89e0bac8 et al replaced newlines with spaces in object names
      printed in SQL comments, but we neglected to consider that the same
      names are also printed by "pg_restore -l", and a newline would render
      the output unparseable by "pg_restore -L".  Apply the same replacement
      in "-l" output.  Since "pg_restore -L" doesn't actually examine any
      object names, only the dump ID field that starts each line, this is
      enough to fix things for its purposes.
      
      The previous fix was treated as a security issue, and we might have
      done that here as well, except that the issue was reported publicly
      to start with.  Anyway it's hard to see how this could be exploited
      for SQL injection; "pg_restore -L" doesn't do much with the file
      except parse it for leading integers.
      
      Per bug #14587 from Milos Urbanek.  Back-patch to all supported versions.
      
      Discussion: https://postgr.es/m/20170310155318.1425.30483@wrigleys.postgresql.org
      f39ddd84
    • Tom Lane's avatar
      Change the relkind for partitioned tables from 'P' to 'p'. · 8b358b42
      Tom Lane authored
      Seven of the eight other relkind codes are lower-case, so it wasn't
      consistent for this one to be upper-case.  Fix it while we still can.
      
      Historical notes: the reason for the lone exception, i.e. sequences being
      'S', is that 's' was once used for "special" relations.  Also, at one time
      the partitioned-tables patch used both 'P' and 'p', but that got changed,
      leaving only a surprising choice behind.
      
      This also fixes a couple little bits of technical debt, such as
      type_sanity.sql not knowing that 'm' is a legal value for relkind.
      
      Discussion: https://postgr.es/m/27899.1488909319@sss.pgh.pa.us
      8b358b42