From: Aldy Hernandez Date: Wed, 4 Jan 2012 14:53:30 +0000 (+0000) Subject: re PR middle-end/51212 (ICE: verify_flow_info failed: BB 3 can not throw but has... X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=7ba6572377d8cc69471fc77f37c1880e808c449c;p=gcc.git re PR middle-end/51212 (ICE: verify_flow_info failed: BB 3 can not throw but has an EH edge with -fgnu-tm -fnon-call-exceptions and transaction_callable) 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. From-SVN: r182877 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index fc644564971..d01b88deeb4 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,10 @@ +2012-01-04 Aldy Hernandez + + 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 PR middle-end/51696 diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi index bb05d88b55f..1e45b616f48 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 2ed556030eb..121cf69304b 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;