From: Jeffrey A Law Date: Thu, 17 May 2001 17:53:52 +0000 (+0000) Subject: except.c (sjlj_emit_function_enter): Call assemble_external_libcall for eh_personalit... X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=8979edec07977e922f0534a4a29e720a5b983fa6;p=gcc.git except.c (sjlj_emit_function_enter): Call assemble_external_libcall for eh_personality_libfunc. * except.c (sjlj_emit_function_enter): Call assemble_external_libcall for eh_personality_libfunc. From-SVN: r42216 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index f021be5cd4d..a50be8d99eb 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +Thu May 17 11:54:50 2001 Jeffrey A Law (law@cygnus.com) + + * except.c (sjlj_emit_function_enter): Call assemble_external_libcall + for eh_personality_libfunc. + Thu May 17 19:48:00 CEST 2001 Jan Hubicka * recog.c (validate_replace_rtx_1): Use "TO" mode if not VOIDmode diff --git a/gcc/except.c b/gcc/except.c index b7771367149..35d76cb8a82 100644 --- a/gcc/except.c +++ b/gcc/except.c @@ -2139,6 +2139,10 @@ sjlj_emit_function_enter (dispatch_label) start_sequence (); + /* We're storing this libcall's address into memory instead of + calling it directly. Thus, we must call assemble_external_libcall + here, as we can not depend on emit_library_call to do it for us. */ + assemble_external_libcall (eh_personality_libfunc); mem = change_address (fc, Pmode, plus_constant (XEXP (fc, 0), sjlj_fc_personality_ofs)); emit_move_insn (mem, eh_personality_libfunc);