postgresql/contrib
Tom Lane 82bbb60c30 Fix valgrind warning for btree_gist indexes on macaddr.
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.
2014-05-16 15:11:51 -04:00
..
adminpack Create function prototype as part of PG_FUNCTION_INFO_V1 macro 2014-04-18 00:03:19 -04:00
auth_delay
auto_explain pgindent run for 9.4 2014-05-06 12:12:18 -04:00
btree_gin Create function prototype as part of PG_FUNCTION_INFO_V1 macro 2014-04-18 00:03:19 -04:00
btree_gist Fix valgrind warning for btree_gist indexes on macaddr. 2014-05-16 15:11:51 -04:00
chkpass Create function prototype as part of PG_FUNCTION_INFO_V1 macro 2014-04-18 00:03:19 -04:00
citext Create function prototype as part of PG_FUNCTION_INFO_V1 macro 2014-04-18 00:03:19 -04:00
cube pgindent run for 9.4 2014-05-06 12:12:18 -04:00
dblink pgindent run for 9.4 2014-05-06 12:12:18 -04:00
dict_int Create function prototype as part of PG_FUNCTION_INFO_V1 macro 2014-04-18 00:03:19 -04:00
dict_xsyn Create function prototype as part of PG_FUNCTION_INFO_V1 macro 2014-04-18 00:03:19 -04:00
dummy_seclabel Update copyright for 2014 2014-01-07 16:05:30 -05:00
earthdistance pgindent run for 9.4 2014-05-06 12:12:18 -04:00
file_fdw pgindent run for 9.4 2014-05-06 12:12:18 -04:00
fuzzystrmatch pgindent run for 9.4 2014-05-06 12:12:18 -04:00
hstore Avoid some pnstrdup()s when constructing jsonb 2014-05-09 12:46:21 +03:00
intagg
intarray pgindent run for 9.4 2014-05-06 12:12:18 -04:00
isn Fix calculation of ISMN check digit. 2014-01-13 15:43:29 +02:00
lo Create function prototype as part of PG_FUNCTION_INFO_V1 macro 2014-04-18 00:03:19 -04:00
ltree pgindent run for 9.4 2014-05-06 12:12:18 -04:00
oid2name pgindent run for 9.4 2014-05-06 12:12:18 -04:00
pageinspect pgindent run for 9.4 2014-05-06 12:12:18 -04:00
passwordcheck Update copyright for 2014 2014-01-07 16:05:30 -05:00
pg_archivecleanup pgindent run for 9.4 2014-05-06 12:12:18 -04:00
pg_buffercache Create function prototype as part of PG_FUNCTION_INFO_V1 macro 2014-04-18 00:03:19 -04:00
pg_freespacemap Create function prototype as part of PG_FUNCTION_INFO_V1 macro 2014-04-18 00:03:19 -04:00
pg_prewarm pgindent run for 9.4 2014-05-06 12:12:18 -04:00
pg_standby Remove MinGW readdir/errno bug workaround fixed on 2003-10-10 2014-03-21 13:47:37 -04:00
pg_stat_statements pgindent run for 9.4 2014-05-06 12:12:18 -04:00
pg_test_fsync pgindent run for 9.4 2014-05-06 12:12:18 -04:00
pg_test_timing Remove undocumented -h (help) option 2013-07-01 12:40:33 -04:00
pg_trgm pgindent run for 9.4 2014-05-06 12:12:18 -04:00
pg_upgrade Fix whitespace 2014-05-15 13:23:31 -04:00
pg_upgrade_support Create function prototype as part of PG_FUNCTION_INFO_V1 macro 2014-04-18 00:03:19 -04:00
pg_xlogdump pgindent run for 9.4 2014-05-06 12:12:18 -04:00
pgbench pgindent run for 9.4 2014-05-06 12:12:18 -04:00
pgcrypto pgindent run for 9.4 2014-05-06 12:12:18 -04:00
pgrowlocks Create function prototype as part of PG_FUNCTION_INFO_V1 macro 2014-04-18 00:03:19 -04:00
pgstattuple pgindent run for 9.4 2014-05-06 12:12:18 -04:00
postgres_fdw pgindent run for 9.4 2014-05-06 12:12:18 -04:00
seg Create function prototype as part of PG_FUNCTION_INFO_V1 macro 2014-04-18 00:03:19 -04:00
sepgsql pgindent run for 9.4 2014-05-06 12:12:18 -04:00
spi pgindent run for 9.4 2014-05-06 12:12:18 -04:00
sslinfo pgindent run for 9.4 2014-05-06 12:12:18 -04:00
start-scripts Remove dead URL mention in OSX startup script 2013-09-04 17:04:33 -04:00
tablefunc Update copyright for 2014 2014-01-07 16:05:30 -05:00
tcn pgindent run for 9.4 2014-05-06 12:12:18 -04:00
test_decoding Add test case for logical decoding of prepared transactions. 2014-05-16 11:34:50 +03:00
test_parser Create function prototype as part of PG_FUNCTION_INFO_V1 macro 2014-04-18 00:03:19 -04:00
test_shm_mq pgindent run for 9.4 2014-05-06 12:12:18 -04:00
tsearch2 Create function prototype as part of PG_FUNCTION_INFO_V1 macro 2014-04-18 00:03:19 -04:00
unaccent Create function prototype as part of PG_FUNCTION_INFO_V1 macro 2014-04-18 00:03:19 -04:00
uuid-ossp Create function prototype as part of PG_FUNCTION_INFO_V1 macro 2014-04-18 00:03:19 -04:00
vacuumlo Centralize getopt-related declarations in a new header file pg_getopt.h. 2014-02-15 14:31:30 -05:00
worker_spi pgindent run for 9.4 2014-05-06 12:12:18 -04:00
xml2 pgindent run for 9.4 2014-05-06 12:12:18 -04:00
contrib-global.mk
Makefile Introduce logical decoding. 2014-03-03 16:32:18 -05:00
README Rename 'gmake' to 'make' in docs and recommended commands 2014-02-12 17:29:19 -05:00

The PostgreSQL contrib tree
---------------------------

This subtree contains porting tools, analysis utilities, and plug-in
features that are not part of the core PostgreSQL system, mainly
because they address a limited audience or are too experimental to be
part of the main source tree.  This does not preclude their
usefulness.

User documentation for each module appears in the main SGML
documentation.

When building from the source distribution, these modules are not
built automatically, unless you build the "world" target.  You can
also build and install them all by running "make all" and "make
install" in this directory; or to build and install just one selected
module, do the same in that module's subdirectory.

Some directories supply new user-defined functions, operators, or
types.  To make use of one of these modules, after you have installed
the code you need to register the new SQL objects in the database
system by executing a CREATE EXTENSION command.  In a fresh database,
you can simply do

    CREATE EXTENSION module_name;

See the PostgreSQL documentation for more information about this
procedure.