diff --git a/gcc/ChangeLog b/gcc/ChangeLog index fc64456497162bd042a25363de1833fee7a51ef8..d01b88deeb425c5aaf9a409b75aede488757d2be 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,10 @@ +2012-01-04 Aldy Hernandez <aldyh@redhat.com> + + PR middle-end/51212 + * opts.c (finish_options): Sorry out when using transactional + memory and non-call exceptions. + * doc/invoke.texi (C Dialect Options): Document it. + 2012-01-04 Aldy Hernandez <aldyh@redhat.com> PR middle-end/51696 diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi index bb05d88b55f5c3c3385bd64776e34f8083cdfb2e..1e45b616f48d427e2046d4de891a8c268d239d52 100644 --- a/gcc/doc/invoke.texi +++ b/gcc/doc/invoke.texi @@ -1742,6 +1742,9 @@ For more information on GCC's support for transactional memory, @xref{Enabling libitm,,The GNU Transactional Memory Library,libitm,GNU Transactional Memory Library}. +Note that the transactional memory feature is not supported with +non-call exceptions (@option{-fnon-call-exceptions}). + @item -fms-extensions @opindex fms-extensions Accept some non-standard constructs used in Microsoft header files. diff --git a/gcc/opts.c b/gcc/opts.c index 2ed556030eb26f4fffca3324f9e2d97ed1898cb0..121cf69304b06a0d03df8cc3debb7a6a1353f3d5 100644 --- a/gcc/opts.c +++ b/gcc/opts.c @@ -666,6 +666,9 @@ finish_options (struct gcc_options *opts, struct gcc_options *opts_set, if (opts->x_flag_tm && opts->x_flag_non_call_exceptions) sorry ("transactional memory is not supported with non-call exceptions"); + if (opts->x_flag_tm && opts->x_flag_non_call_exceptions) + sorry ("transactional memory is not supported with non-call exceptions"); + /* -Wmissing-noreturn is alias for -Wsuggest-attribute=noreturn. */ if (opts->x_warn_missing_noreturn) opts->x_warn_suggest_attribute_noreturn = true;