From 170337a2e5dad781c35dbe77f15f5b07d3f988c1 Mon Sep 17 00:00:00 2001 From: Theo de Raadt Date: Tue, 10 Jul 2018 16:01:27 +0000 Subject: In asm.h ensure NENTRY uses the old-school nop-sled align, but change standard ENTRY is a trapsled. Fix a few functions which fall-through into an ENTRY macro. amd64 binaries now are free of double+-nop sequences (except for one assember nit in aes-586.pl). Previous changes by guenther got us here. ok mortimer kettenis --- sys/arch/amd64/amd64/locore.S | 4 +--- sys/arch/amd64/amd64/locore0.S | 4 +--- sys/arch/amd64/amd64/spl.S | 4 +--- sys/arch/amd64/amd64/vector.S | 4 +--- sys/arch/amd64/include/asm.h | 8 +++++--- 5 files changed, 9 insertions(+), 15 deletions(-) (limited to 'sys/arch') diff --git a/sys/arch/amd64/amd64/locore.S b/sys/arch/amd64/amd64/locore.S index b1f85ab6137..05ec5fb2d37 100644 --- a/sys/arch/amd64/amd64/locore.S +++ b/sys/arch/amd64/amd64/locore.S @@ -1,4 +1,4 @@ -/* $OpenBSD: locore.S,v 1.103 2018/07/03 23:21:15 mortimer Exp $ */ +/* $OpenBSD: locore.S,v 1.104 2018/07/10 16:01:26 deraadt Exp $ */ /* $NetBSD: locore.S,v 1.13 2004/03/25 18:33:17 drochner Exp $ */ /* @@ -128,8 +128,6 @@ * override user-land alignment before including asm.h */ #define ALIGN_DATA .align 8,0xcc -#define ALIGN_TEXT .align 16,0x90 -#define _ALIGN_TEXT ALIGN_TEXT #include diff --git a/sys/arch/amd64/amd64/locore0.S b/sys/arch/amd64/amd64/locore0.S index 662b58fb5bc..67f6f75ea99 100644 --- a/sys/arch/amd64/amd64/locore0.S +++ b/sys/arch/amd64/amd64/locore0.S @@ -1,4 +1,4 @@ -/* $OpenBSD: locore0.S,v 1.8 2018/05/22 15:55:30 guenther Exp $ */ +/* $OpenBSD: locore0.S,v 1.9 2018/07/10 16:01:26 deraadt Exp $ */ /* $NetBSD: locore.S,v 1.13 2004/03/25 18:33:17 drochner Exp $ */ /* @@ -116,8 +116,6 @@ * override user-land alignment before including asm.h */ #define ALIGN_DATA .align 8,0xcc -#define ALIGN_TEXT .align 16,0x90 -#define _ALIGN_TEXT ALIGN_TEXT #include diff --git a/sys/arch/amd64/amd64/spl.S b/sys/arch/amd64/amd64/spl.S index 063dbe7db81..c4782552d5c 100644 --- a/sys/arch/amd64/amd64/spl.S +++ b/sys/arch/amd64/amd64/spl.S @@ -1,4 +1,4 @@ -/* $OpenBSD: spl.S,v 1.16 2018/07/03 23:21:15 mortimer Exp $ */ +/* $OpenBSD: spl.S,v 1.17 2018/07/10 16:01:26 deraadt Exp $ */ /* $NetBSD: spl.S,v 1.3 2004/06/28 09:13:11 fvdl Exp $ */ /* @@ -65,8 +65,6 @@ * POSSIBILITY OF SUCH DAMAGE. */ -#define ALIGN_TEXT .align 16,0x90 - #include #include #include diff --git a/sys/arch/amd64/amd64/vector.S b/sys/arch/amd64/amd64/vector.S index d9c42d5b03c..0dc7f2e5dd7 100644 --- a/sys/arch/amd64/amd64/vector.S +++ b/sys/arch/amd64/amd64/vector.S @@ -1,4 +1,4 @@ -/* $OpenBSD: vector.S,v 1.70 2018/07/10 08:57:44 guenther Exp $ */ +/* $OpenBSD: vector.S,v 1.71 2018/07/10 16:01:26 deraadt Exp $ */ /* $NetBSD: vector.S,v 1.5 2004/06/28 09:13:11 fvdl Exp $ */ /* @@ -65,8 +65,6 @@ * POSSIBILITY OF SUCH DAMAGE. */ -#define ALIGN_TEXT .align 16,0x90 - #include #include #include diff --git a/sys/arch/amd64/include/asm.h b/sys/arch/amd64/include/asm.h index 110beb7c5c3..0ef11752c02 100644 --- a/sys/arch/amd64/include/asm.h +++ b/sys/arch/amd64/include/asm.h @@ -1,4 +1,4 @@ -/* $OpenBSD: asm.h,v 1.13 2018/07/01 16:02:12 guenther Exp $ */ +/* $OpenBSD: asm.h,v 1.14 2018/07/10 16:01:26 deraadt Exp $ */ /* $NetBSD: asm.h,v 1.2 2003/05/02 18:05:47 yamt Exp $ */ /*- @@ -66,6 +66,8 @@ #define _ALIGN_TRAPS .align 16, 0xcc #define _ENTRY(x) \ + .text; _ALIGN_TRAPS; .globl x; .type x,@function; x: +#define _NENTRY(x) \ .text; _ALIGN_TEXT; .globl x; .type x,@function; x: #ifdef _KERNEL @@ -137,8 +139,8 @@ #endif #define ENTRY(y) _ENTRY(_C_LABEL(y)); _PROF_PROLOGUE -#define NENTRY(y) _ENTRY(_C_LABEL(y)) -#define ASENTRY(y) _ENTRY(_ASM_LABEL(y)); _PROF_PROLOGUE +#define NENTRY(y) _NENTRY(_C_LABEL(y)) +#define ASENTRY(y) _NENTRY(_ASM_LABEL(y)); _PROF_PROLOGUE #define END(y) .size y, . - y #define STRONG_ALIAS(alias,sym) \ -- cgit v1.2.3