gcc-plugins: arm_ssp_per_task_plugin: Fix for older GCC < 6
authorChris Packham <chris.packham@alliedtelesis.co.nz>
Fri, 10 May 2019 09:00:25 +0000 (21:00 +1200)
committerKees Cook <keescook@chromium.org>
Fri, 10 May 2019 22:35:01 +0000 (15:35 -0700)
Use gen_rtx_set instead of gen_rtx_SET. The former is a wrapper macro
that handles the difference between GCC versions implementing
the latter.

This fixes the following error on my system with g++ 5.4.0 as the host
compiler

   HOSTCXX -fPIC scripts/gcc-plugins/arm_ssp_per_task_plugin.o
 scripts/gcc-plugins/arm_ssp_per_task_plugin.c:42:14: error: macro "gen_rtx_SET" requires 3 arguments, but only 2 given
          mask)),
               ^
 scripts/gcc-plugins/arm_ssp_per_task_plugin.c: In function ‘unsigned int arm_pertask_ssp_rtl_execute()’:
 scripts/gcc-plugins/arm_ssp_per_task_plugin.c:39:20: error: ‘gen_rtx_SET’ was not declared in this scope
    emit_insn_before(gen_rtx_SET

Signed-off-by: Chris Packham <chris.packham@alliedtelesis.co.nz>
Fixes: 189af4657186 ("ARM: smp: add support for per-task stack canaries")
Cc: stable@vger.kernel.org
Tested-by: Douglas Anderson <dianders@chromium.org>
Signed-off-by: Kees Cook <keescook@chromium.org>
scripts/gcc-plugins/arm_ssp_per_task_plugin.c

index 89c47f57d1ce14476ca7c2638e89e31926c3d7fb..8c1af9bdcb1bbaadb419e876717cded98ae9c408 100644 (file)
@@ -36,7 +36,7 @@ static unsigned int arm_pertask_ssp_rtl_execute(void)
                mask = GEN_INT(sext_hwi(sp_mask, GET_MODE_PRECISION(Pmode)));
                masked_sp = gen_reg_rtx(Pmode);
 
-               emit_insn_before(gen_rtx_SET(masked_sp,
+               emit_insn_before(gen_rtx_set(masked_sp,
                                             gen_rtx_AND(Pmode,
                                                         stack_pointer_rtx,
                                                         mask)),