lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <20171210201903.GA13846@osadl.at>
Date:   Sun, 10 Dec 2017 20:19:03 +0000
From:   Nicholas Mc Guire <der.herr@...r.at>
To:     Lukas Bulwahn <lukas.bulwahn@...il.com>
Cc:     Josh Poimboeuf <jpoimboe@...hat.com>, sil2review@...ts.osadl.org,
        Jiri Slaby <jslaby@...e.cz>, Ingo Molnar <mingo@...nel.org>,
        linux-kernel@...r.kernel.org
Subject: Re: [SIL2review] [PATCH] objtool: Use value of intended enum to
 compile with clang

On Sun, Dec 10, 2017 at 07:35:00PM +0100, Lukas Bulwahn wrote:
> Just use the right value and avoid an implicit conversion between the two
> enumeration types that just happened to work in this case. It seems that
> this must have just been overlooked in the new implementation of objtool
> in commit baa41469a7b9 ("objtool: Implement stack validation 2.0").
> 
> I found this when compiling the kernel with clang-5.0, i.e., executing
> 
>   make HOSTCC=clang-5.0 CC=clang-5.0 defconfig && \
>   make HOSTCC=clang-5.0 CC=clang-5.0
> 
> fails with:
> 
> ```
> arch/x86/decode.c:141:20: error: implicit conversion from enumeration type 'enum op_src_type' to different enumeration type 'enum op_dest_type' [-Werror,-Wenum-conversion]
>                         op->dest.type = OP_SRC_REG;
>                                       ~ ^~~~~~~~~~
> 1 error generated.
> ```

given the declaration in tools/objtool/arch.h
enum op_dest_type {
        OP_DEST_REG,
        ...

enum op_src_type {
        OP_SRC_REG,
        ...

the change seems correct and it is clear why it worked with the wrong type

> 
> Fixes: baa41469a7b9 ("objtool: Implement stack validation 2.0")
> Signed-off-by: Lukas Bulwahn <lukas.bulwahn@...il.com>
Reviewed-by: Nicholas Mc Guire <der.herr@...r.at>

> ---
>  tools/objtool/arch/x86/decode.c | 2 +-
>  1 file changed, 1 insertion(+), 1 deletion(-)
> 
> diff --git a/tools/objtool/arch/x86/decode.c b/tools/objtool/arch/x86/decode.c
> index 8acfc47..540a209 100644
> --- a/tools/objtool/arch/x86/decode.c
> +++ b/tools/objtool/arch/x86/decode.c
> @@ -138,7 +138,7 @@ int arch_decode_instruction(struct elf *elf, struct section *sec,
>  			*type = INSN_STACK;
>  			op->src.type = OP_SRC_ADD;
>  			op->src.reg = op_to_cfi_reg[modrm_reg][rex_r];
> -			op->dest.type = OP_SRC_REG;
> +			op->dest.type = OP_DEST_REG;
>  			op->dest.reg = CFI_SP;
>  		}
>  		break;
> -- 
> 2.7.4
> 
> _______________________________________________
> SIL2review mailing list
> SIL2review@...ts.osadl.org
> https://lists.osadl.org/mailman/listinfo/sil2review

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ