Fix pg_upgrade's handling of TOAST tables
(Bruce Momjian)
The pg_class.relfrozenxid value for
TOAST tables was not correctly copied into the new installation
during pg_upgrade. This could later result in
pg_clog files being discarded while they were still
needed to validate tuples in the TOAST tables, leading to
"could not access status of transaction" failures.
This error poses a significant risk of data loss for installations
that have been upgraded with pg_upgrade. This patch
corrects the problem for future uses of pg_upgrade,
but does not in itself cure the issue in installations that have been
processed with a buggy version of pg_upgrade.
Suppress incorrect "PD_ALL_VISIBLE flag was incorrectly set"
warning (Heikki Linnakangas)
VACUUM would sometimes issue this warning in cases that
are actually valid.
Use better SQLSTATE error codes for hot standby conflict cases
(Tatsuo Ishii and Simon Riggs)
All retryable conflict errors now have an error code that indicates
that a retry is possible. Also, session closure due to the database
being dropped on the master is now reported as
ERRCODE_DATABASE_DROPPED, rather than
ERRCODE_ADMIN_SHUTDOWN, so that connection poolers can
handle the situation correctly.
Prevent intermittent hang in interactions of startup process with
bgwriter process (Simon Riggs)
This affected recovery in non-hot-standby cases.
Disallow including a composite type in itself (Tom Lane)
This prevents scenarios wherein the server could recurse infinitely
while processing the composite type. While there are some possible
uses for such a structure, they don't seem compelling enough to
justify the effort required to make sure it always works safely.
Avoid potential deadlock during catalog cache initialization
(Nikhil Sontakke)
In some cases the cache loading code would acquire share lock on a
system index before locking the index's catalog. This could deadlock
against processes trying to acquire exclusive locks in the other,
more standard order.
Fix dangling-pointer problem in BEFORE ROW UPDATE trigger
handling when there was a concurrent update to the target tuple
(Tom Lane)
This bug has been observed to result in intermittent "cannot
extract system attribute from virtual tuple" failures while trying to
do UPDATE RETURNING ctid. There is a very small probability
of more serious errors, such as generating incorrect index entries for
the updated tuple.
Disallow DROP TABLE when there are pending deferred trigger
events for the table (Tom Lane)
Formerly the DROP would go through, leading to
"could not open relation with OID nnn" errors when the
triggers were eventually fired.
Allow "replication" as a user name in
pg_hba.conf (Andrew Dunstan)
"replication" is special in the database name column, but it
was mistakenly also treated as special in the user name column.
Prevent crash triggered by constant-false WHERE conditions during
GEQO optimization (Tom Lane)
Improve planner's handling of semi-join and anti-join cases
(Tom Lane)
Fix handling of SELECT FOR UPDATE in a sub-SELECT
(Tom Lane)
This bug typically led to "cannot extract system attribute from
virtual tuple" errors.
Fix selectivity estimation for text search to account for NULLs
(Jesper Krogh)
Fix get_actual_variable_range() to support hypothetical indexes
injected by an index adviser plugin (Gurjeet Singh)
Fix PL/Python memory leak involving array slices (Daniel Popowich)
Allow libpq's SSL initialization to succeed when
user's home directory is unavailable (Tom Lane)
If the SSL mode is such that a root certificate file is not required,
there is no need to fail. This change restores the behavior to what
it was in pre-9.0 releases.
Fix libpq to return a useful error message for errors
detected in conninfo_array_parse
(Joseph Adams)
A typo caused the library to return NULL, rather than the
PGconn structure containing the error message, to the
application.
Fix ecpg preprocessor's handling of float constants
(Heikki Linnakangas)
Fix parallel pg_restore to handle comments on
POST_DATA items correctly (Arnd Hannemann)
Fix pg_restore to cope with long lines (over 1KB) in
TOC files (Tom Lane)
Put in more safeguards against crashing due to division-by-zero
with overly enthusiastic compiler optimization (Aurelien Jarno)
Support use of dlopen() in FreeBSD and OpenBSD on MIPS (Tom Lane)
There was a hard-wired assumption that this system function was not
available on MIPS hardware on these systems. Use a compile-time test
instead, since more recent versions have it.
Fix compilation failures on HP-UX (Heikki Linnakangas)
Avoid crash when trying to write to the Windows console very early
in process startup (Rushabh Lathia)
Support building with MinGW 64 bit compiler for Windows
(Andrew Dunstan)
Fix version-incompatibility problem with libintl on
Windows (Hiroshi Inoue)
Fix usage of xcopy in Windows build scripts to
work correctly under Windows 7 (Andrew Dunstan)
This affects the build scripts only, not installation or usage.
Fix path separator used by pg_regress on Cygwin
(Andrew Dunstan)
Update time zone data files to tzdata release 2011f
for DST law changes in Chile, Cuba, Falkland Islands, Morocco, Samoa,
and Turkey; also historical corrections for South Australia, Alaska,
and Hawaii.