OK, thanks for this :)

On Fri, Jan 27, 2023 at 12:40 AM Andreas Schwab via Gcc-patches <
gcc-patches@gcc.gnu.org> wrote:

> This follows the example of aarch64.
>
> gcc/:
>         * common/config/riscv/riscv-common.cc
>         (riscv_option_optimization_table)
>         [TARGET_DEFAULT_ASYNC_UNWIND_TABLES]: Enable
>         -fasynchronous_unwind_tables and -funwind-tables.
>         * config.gcc (riscv*-*-linux*): Define
>         TARGET_DEFAULT_ASYNC_UNWIND_TABLES.
> ---
>  gcc/common/config/riscv/riscv-common.cc | 4 ++++
>  gcc/config.gcc                          | 1 +
>  2 files changed, 5 insertions(+)
>
> diff --git a/gcc/common/config/riscv/riscv-common.cc
> b/gcc/common/config/riscv/riscv-common.cc
> index 2e3116e7673..616e2f897b9 100644
> --- a/gcc/common/config/riscv/riscv-common.cc
> +++ b/gcc/common/config/riscv/riscv-common.cc
> @@ -1756,6 +1756,10 @@ static const struct default_options
> riscv_option_optimization_table[] =
>    {
>      { OPT_LEVELS_1_PLUS, OPT_fsection_anchors, NULL, 1 },
>      { OPT_LEVELS_2_PLUS, OPT_free, NULL, 1 },
> +#if TARGET_DEFAULT_ASYNC_UNWIND_TABLES == 1
> +    { OPT_LEVELS_ALL, OPT_fasynchronous_unwind_tables, NULL, 1 },
> +    { OPT_LEVELS_ALL, OPT_funwind_tables, NULL, 1},
> +#endif
>      { OPT_LEVELS_NONE, 0, NULL, 0 }
>    };
>
> diff --git a/gcc/config.gcc b/gcc/config.gcc
> index 89f56047cfe..744b46fb3b0 100644
> --- a/gcc/config.gcc
> +++ b/gcc/config.gcc
> @@ -2417,6 +2417,7 @@ riscv*-*-linux*)
>         *) echo "Unknown value for enable_multilib"; exit 1
>         esac
>         tmake_file="${tmake_file} riscv/t-riscv riscv/t-linux"
> +       tm_defines="${tm_defines} TARGET_DEFAULT_ASYNC_UNWIND_TABLES=1"
>         gnu_ld=yes
>         gas=yes
>         case $target in
> --
> 2.39.1
>
>
> --
> Andreas Schwab, SUSE Labs, sch...@suse.de
> GPG Key fingerprint = 0196 BAD8 1CE9 1970 F4BE  1748 E4D4 88E3 0EEA B9D7
> "And now for something completely different."
>

Reply via email to