2008-07-17 05:41:39 +08:00
|
|
|
;
|
|
|
|
; Smart alignment macros
|
|
|
|
;
|
|
|
|
USE: smartalign
|
|
|
|
|
|
|
|
%imacro alignmode 1-2.nolist
|
|
|
|
%ifidni %1,nop
|
2008-07-18 05:22:10 +08:00
|
|
|
%define __ALIGN_JMP_THRESHOLD__ 16
|
|
|
|
|
2008-07-17 05:41:39 +08:00
|
|
|
%define __ALIGN_16BIT_1B__ 0x90
|
|
|
|
%define __ALIGN_16BIT_2B__ 0x90,0x90
|
|
|
|
%define __ALIGN_16BIT_3B__ 0x90,0x90,0x90
|
|
|
|
%define __ALIGN_16BIT_4B__ 0x90,0x90,0x90,0x90
|
|
|
|
%define __ALIGN_16BIT_5B__ 0x90,0x90,0x90,0x90,0x90
|
|
|
|
%define __ALIGN_16BIT_6B__ 0x90,0x90,0x90,0x90,0x90,0x90
|
|
|
|
%define __ALIGN_16BIT_7B__ 0x90,0x90,0x90,0x90,0x90,0x90,0x90
|
|
|
|
%define __ALIGN_16BIT_8B__ 0x90,0x90,0x90,0x90,0x90,0x90,0x90,0x90
|
2008-10-20 07:38:28 +08:00
|
|
|
%define __ALIGN_16BIT_GROUP__ 8
|
2008-07-17 05:41:39 +08:00
|
|
|
|
|
|
|
%define __ALIGN_32BIT_1B__ 0x90
|
|
|
|
%define __ALIGN_32BIT_2B__ 0x90,0x90
|
|
|
|
%define __ALIGN_32BIT_3B__ 0x90,0x90,0x90
|
|
|
|
%define __ALIGN_32BIT_4B__ 0x90,0x90,0x90,0x90
|
|
|
|
%define __ALIGN_32BIT_5B__ 0x90,0x90,0x90,0x90,0x90
|
|
|
|
%define __ALIGN_32BIT_6B__ 0x90,0x90,0x90,0x90,0x90,0x90
|
|
|
|
%define __ALIGN_32BIT_7B__ 0x90,0x90,0x90,0x90,0x90,0x90,0x90
|
|
|
|
%define __ALIGN_32BIT_8B__ 0x90,0x90,0x90,0x90,0x90,0x90,0x90,0x90
|
2008-10-20 07:38:28 +08:00
|
|
|
%define __ALIGN_32BIT_GROUP__ 8
|
2008-07-17 05:41:39 +08:00
|
|
|
|
|
|
|
%define __ALIGN_64BIT_1B__ 0x90
|
|
|
|
%define __ALIGN_64BIT_2B__ 0x90,0x90
|
|
|
|
%define __ALIGN_64BIT_3B__ 0x90,0x90,0x90
|
|
|
|
%define __ALIGN_64BIT_4B__ 0x90,0x90,0x90,0x90
|
|
|
|
%define __ALIGN_64BIT_5B__ 0x90,0x90,0x90,0x90,0x90
|
|
|
|
%define __ALIGN_64BIT_6B__ 0x90,0x90,0x90,0x90,0x90,0x90
|
|
|
|
%define __ALIGN_64BIT_7B__ 0x90,0x90,0x90,0x90,0x90,0x90,0x90
|
|
|
|
%define __ALIGN_64BIT_8B__ 0x90,0x90,0x90,0x90,0x90,0x90,0x90,0x90
|
2008-10-20 07:38:28 +08:00
|
|
|
%define __ALIGN_64BIT_GROUP__ 8
|
2008-07-17 05:41:39 +08:00
|
|
|
%elifidni %1,generic
|
2008-07-18 05:22:10 +08:00
|
|
|
%define __ALIGN_JMP_THRESHOLD__ 8
|
|
|
|
|
2008-07-17 05:41:39 +08:00
|
|
|
%define __ALIGN_16BIT_1B__ 0x90
|
2008-07-18 05:20:06 +08:00
|
|
|
%define __ALIGN_16BIT_2B__ 0x89,0xf6
|
|
|
|
%define __ALIGN_16BIT_3B__ 0x8d,0x74,0x00
|
|
|
|
%define __ALIGN_16BIT_4B__ 0x8d,0xb4,0x00,0x00
|
|
|
|
%define __ALIGN_16BIT_5B__ 0x90,0x8d,0xb4,0x00,0x00
|
|
|
|
%define __ALIGN_16BIT_6B__ 0x89,0xf6,0x8d,0xbd,0x00,0x00
|
|
|
|
%define __ALIGN_16BIT_7B__ 0x8d,0x74,0x00,0x8d,0xbd,0x00,0x00
|
|
|
|
%define __ALIGN_16BIT_8B__ 0x8d,0xb4,0x00,0x00,0x8d,0xbd,0x00,0x00
|
2008-10-20 07:38:28 +08:00
|
|
|
%define __ALIGN_16BIT_GROUP__ 8
|
2008-07-17 05:41:39 +08:00
|
|
|
|
|
|
|
%define __ALIGN_32BIT_1B__ 0x90
|
|
|
|
%define __ALIGN_32BIT_2B__ 0x89,0xf6
|
|
|
|
%define __ALIGN_32BIT_3B__ 0x8d,0x76,0x00
|
|
|
|
%define __ALIGN_32BIT_4B__ 0x8d,0x74,0x26,0x00
|
|
|
|
%define __ALIGN_32BIT_5B__ 0x90,0x8d,0x74,0x26,0x00
|
|
|
|
%define __ALIGN_32BIT_6B__ 0x8d,0xb6,0x00,0x00,0x00,0x00
|
|
|
|
%define __ALIGN_32BIT_7B__ 0x8d,0xb4,0x26,0x00,0x00,0x00,0x00
|
|
|
|
%undef __ALIGN_32BIT_8B__
|
2008-10-20 07:38:28 +08:00
|
|
|
%define __ALIGN_32BIT_GROUP__ 7
|
2008-07-17 05:41:39 +08:00
|
|
|
|
|
|
|
%define __ALIGN_64BIT_1B__ 0x90
|
|
|
|
%define __ALIGN_64BIT_2B__ 0x66,0x90
|
|
|
|
%define __ALIGN_64BIT_3B__ 0x66,0x66,0x90
|
|
|
|
%define __ALIGN_64BIT_4B__ 0x66,0x66,0x66,0x90
|
|
|
|
%define __ALIGN_64BIT_5B__ 0x66,0x66,0x90,0x66,0x90
|
|
|
|
%define __ALIGN_64BIT_6B__ 0x66,0x66,0x90,0x66,0x66,0x90
|
|
|
|
%define __ALIGN_64BIT_7B__ 0x66,0x66,0x66,0x90,0x66,0x66,0x90
|
|
|
|
%define __ALIGN_64BIT_8B__ 0x66,0x66,0x66,0x90,0x66,0x66,0x66,0x90
|
2008-10-20 07:38:28 +08:00
|
|
|
%define __ALIGN_64BIT_GROUP__ 8
|
2008-07-17 05:41:39 +08:00
|
|
|
%elifidni %1,k8
|
2008-07-18 05:22:10 +08:00
|
|
|
%define __ALIGN_JMP_THRESHOLD__ 16
|
|
|
|
|
2008-07-17 05:41:39 +08:00
|
|
|
%define __ALIGN_16BIT_1B__ 0x90
|
|
|
|
%define __ALIGN_16BIT_2B__ 0x66,0x90
|
|
|
|
%define __ALIGN_16BIT_3B__ 0x66,0x66,0x90
|
|
|
|
%define __ALIGN_16BIT_4B__ 0x66,0x66,0x66,0x90
|
|
|
|
%define __ALIGN_16BIT_5B__ 0x66,0x66,0x90,0x66,0x90
|
|
|
|
%define __ALIGN_16BIT_6B__ 0x66,0x66,0x90,0x66,0x66,0x90
|
|
|
|
%define __ALIGN_16BIT_7B__ 0x66,0x66,0x66,0x90,0x66,0x66,0x90
|
|
|
|
%define __ALIGN_16BIT_8B__ 0x66,0x66,0x66,0x90,0x66,0x66,0x66,0x90
|
2008-10-20 07:38:28 +08:00
|
|
|
%define __ALIGN_16BIT_GROUP__ 8
|
2008-07-17 05:41:39 +08:00
|
|
|
|
|
|
|
%define __ALIGN_32BIT_1B__ 0x90
|
|
|
|
%define __ALIGN_32BIT_2B__ 0x66,0x90
|
|
|
|
%define __ALIGN_32BIT_3B__ 0x66,0x66,0x90
|
|
|
|
%define __ALIGN_32BIT_4B__ 0x66,0x66,0x66,0x90
|
|
|
|
%define __ALIGN_32BIT_5B__ 0x66,0x66,0x90,0x66,0x90
|
|
|
|
%define __ALIGN_32BIT_6B__ 0x66,0x66,0x90,0x66,0x66,0x90
|
|
|
|
%define __ALIGN_32BIT_7B__ 0x66,0x66,0x66,0x90,0x66,0x66,0x90
|
|
|
|
%define __ALIGN_32BIT_8B__ 0x66,0x66,0x66,0x90,0x66,0x66,0x66,0x90
|
2008-10-20 07:38:28 +08:00
|
|
|
%define __ALIGN_32BIT_GROUP__ 8
|
2008-07-17 05:41:39 +08:00
|
|
|
|
|
|
|
%define __ALIGN_64BIT_1B__ 0x90
|
|
|
|
%define __ALIGN_64BIT_2B__ 0x66,0x90
|
|
|
|
%define __ALIGN_64BIT_3B__ 0x66,0x66,0x90
|
|
|
|
%define __ALIGN_64BIT_4B__ 0x66,0x66,0x66,0x90
|
|
|
|
%define __ALIGN_64BIT_5B__ 0x66,0x66,0x90,0x66,0x90
|
|
|
|
%define __ALIGN_64BIT_6B__ 0x66,0x66,0x90,0x66,0x66,0x90
|
|
|
|
%define __ALIGN_64BIT_7B__ 0x66,0x66,0x66,0x90,0x66,0x66,0x90
|
|
|
|
%define __ALIGN_64BIT_8B__ 0x66,0x66,0x66,0x90,0x66,0x66,0x66,0x90
|
2008-10-20 07:38:28 +08:00
|
|
|
%define __ALIGN_64BIT_GROUP__ 8
|
2008-07-17 05:41:39 +08:00
|
|
|
%elifidni %1,k7
|
2008-07-18 05:22:10 +08:00
|
|
|
%define __ALIGN_JMP_THRESHOLD__ 16
|
|
|
|
|
2008-07-17 05:41:39 +08:00
|
|
|
%define __ALIGN_16BIT_1B__ 0x90
|
|
|
|
%define __ALIGN_16BIT_2B__ 0x66,0x90
|
|
|
|
%define __ALIGN_16BIT_3B__ 0x66,0x66,0x90
|
|
|
|
%define __ALIGN_16BIT_4B__ 0x66,0x66,0x66,0x90
|
|
|
|
%define __ALIGN_16BIT_5B__ 0x66,0x66,0x90,0x66,0x90
|
|
|
|
%define __ALIGN_16BIT_6B__ 0x66,0x66,0x90,0x66,0x66,0x90
|
|
|
|
%define __ALIGN_16BIT_7B__ 0x66,0x66,0x66,0x90,0x66,0x66,0x90
|
|
|
|
%define __ALIGN_16BIT_8B__ 0x66,0x66,0x66,0x90,0x66,0x66,0x66,0x90
|
2008-10-20 07:38:28 +08:00
|
|
|
%define __ALIGN_64BIT_GROUP__ 8
|
2008-07-17 05:41:39 +08:00
|
|
|
|
|
|
|
%define __ALIGN_32BIT_1B__ 0x90
|
|
|
|
%define __ALIGN_32BIT_2B__ 0x8b,0xc0
|
|
|
|
%define __ALIGN_32BIT_3B__ 0x8d,0x04,0x20
|
|
|
|
%define __ALIGN_32BIT_4B__ 0x8d,0x44,0x20,0x00
|
|
|
|
%define __ALIGN_32BIT_5B__ 0x8d,0x44,0x20,0x00,0x90
|
|
|
|
%define __ALIGN_32BIT_6B__ 0x8d,0x80,0x00,0x00,0x00,0x00
|
|
|
|
%define __ALIGN_32BIT_7B__ 0x8d,0x04,0x05,0x00,0x00,0x00,0x00
|
|
|
|
%undef __ALIGN_32BIT_8B__
|
2008-10-20 07:38:28 +08:00
|
|
|
%define __ALIGN_32BIT_GROUP__ 7
|
2008-07-17 05:41:39 +08:00
|
|
|
|
|
|
|
%define __ALIGN_64BIT_1B__ 0x90
|
|
|
|
%define __ALIGN_64BIT_2B__ 0x66,0x90
|
|
|
|
%define __ALIGN_64BIT_3B__ 0x66,0x66,0x90
|
|
|
|
%define __ALIGN_64BIT_4B__ 0x66,0x66,0x66,0x90
|
|
|
|
%define __ALIGN_64BIT_5B__ 0x66,0x66,0x90,0x66,0x90
|
|
|
|
%define __ALIGN_64BIT_6B__ 0x66,0x66,0x90,0x66,0x66,0x90
|
|
|
|
%define __ALIGN_64BIT_7B__ 0x66,0x66,0x66,0x90,0x66,0x66,0x90
|
|
|
|
%define __ALIGN_64BIT_8B__ 0x66,0x66,0x66,0x90,0x66,0x66,0x66,0x90
|
2008-10-20 07:38:28 +08:00
|
|
|
%define __ALIGN_64BIT_GROUP__ 8
|
2008-07-17 05:41:39 +08:00
|
|
|
%elifidni %1,p6
|
2008-07-18 05:22:10 +08:00
|
|
|
%define __ALIGN_JMP_THRESHOLD__ 16
|
|
|
|
|
2008-07-17 05:41:39 +08:00
|
|
|
%define __ALIGN_16BIT_1B__ 0x90
|
|
|
|
%define __ALIGN_16BIT_2B__ 0x66,0x90
|
2008-07-18 05:13:53 +08:00
|
|
|
%define __ALIGN_16BIT_3B__ 0x0f,0x1f,0x00
|
|
|
|
%define __ALIGN_16BIT_4B__ 0x0f,0x1f,0x40,0x00
|
|
|
|
%define __ALIGN_16BIT_5B__ 0x90,0x0f,0x1f,0x40,0x00
|
|
|
|
%define __ALIGN_16BIT_6B__ 0x0f,0x1f,0x00,0x0f,0x1f,0x00
|
|
|
|
%define __ALIGN_16BIT_7B__ 0x0f,0x1f,0x00,0x0f,0x1f,0x40,0x00
|
|
|
|
%define __ALIGN_16BIT_8B__ 0x0f,0x1f,0x40,0x00,0x0f,0x1f,0x40,0x00
|
2008-10-20 07:38:28 +08:00
|
|
|
%define __ALIGN_16BIT_GROUP__ 8
|
2008-07-17 05:41:39 +08:00
|
|
|
|
|
|
|
%define __ALIGN_32BIT_1B__ 0x90
|
|
|
|
%define __ALIGN_32BIT_2B__ 0x66,0x90
|
|
|
|
%define __ALIGN_32BIT_3B__ 0x0f,0x1f,0x00
|
|
|
|
%define __ALIGN_32BIT_4B__ 0x0f,0x1f,0x40,0x00
|
|
|
|
%define __ALIGN_32BIT_5B__ 0x0f,0x1f,0x44,0x00,0x00
|
|
|
|
%define __ALIGN_32BIT_6B__ 0x66,0x0f,0x1f,0x44,0x00,0x00
|
|
|
|
%define __ALIGN_32BIT_7B__ 0x0f,0x1f,0x80,0x00,0x00,0x00,0x00
|
|
|
|
%define __ALIGN_32BIT_8B__ 0x0f,0x1f,0x84,0x00,0x00,0x00,0x00,0x00
|
2008-10-20 07:38:28 +08:00
|
|
|
%define __ALIGN_32BIT_GROUP__ 8
|
2008-07-17 05:41:39 +08:00
|
|
|
|
|
|
|
%define __ALIGN_64BIT_1B__ 0x90
|
|
|
|
%define __ALIGN_64BIT_2B__ 0x66,0x90
|
|
|
|
%define __ALIGN_64BIT_3B__ 0x0f,0x1f,0x00
|
|
|
|
%define __ALIGN_64BIT_4B__ 0x0f,0x1f,0x40,0x00
|
|
|
|
%define __ALIGN_64BIT_5B__ 0x0f,0x1f,0x44,0x00,0x00
|
|
|
|
%define __ALIGN_64BIT_6B__ 0x66,0x0f,0x1f,0x44,0x00,0x00
|
|
|
|
%define __ALIGN_64BIT_7B__ 0x0f,0x1f,0x80,0x00,0x00,0x00,0x00
|
|
|
|
%define __ALIGN_64BIT_8B__ 0x0f,0x1f,0x84,0x00,0x00,0x00,0x00,0x00
|
2008-10-20 07:38:28 +08:00
|
|
|
%define __ALIGN_64BIT_GROUP__ 8
|
2008-07-17 05:41:39 +08:00
|
|
|
%else
|
|
|
|
%error unknown alignment mode: %1
|
|
|
|
%endif
|
2008-07-18 05:20:06 +08:00
|
|
|
%ifnempty %2
|
|
|
|
%xdefine __ALIGN_JMP_THRESHOLD__ %2
|
|
|
|
%endif
|
2008-07-17 05:41:39 +08:00
|
|
|
%xdefine __ALIGNMODE__ %1,__ALIGN_JMP_THRESHOLD__
|
|
|
|
%endmacro
|
|
|
|
|
|
|
|
%unimacro align 1-2+.nolist
|
|
|
|
%imacro align 1-2+.nolist
|
|
|
|
%ifnempty %2
|
2008-10-01 19:16:26 +08:00
|
|
|
times (((%1) - (($-$$) % (%1))) % (%1)) %2
|
2008-07-17 05:41:39 +08:00
|
|
|
%else
|
|
|
|
%push
|
2008-10-01 19:16:26 +08:00
|
|
|
%assign %$pad (((%1) - (($-$$) % (%1))) % (%1))
|
2008-07-18 05:22:10 +08:00
|
|
|
%if %$pad > __ALIGN_JMP_THRESHOLD__
|
2008-07-18 05:28:29 +08:00
|
|
|
jmp %$end
|
2008-07-17 05:41:39 +08:00
|
|
|
; We can't re-use %$pad here as $ will have changed!
|
2008-10-01 19:16:26 +08:00
|
|
|
times (((%1) - (($-$$) % (%1))) % (%1)) nop
|
2008-07-18 05:28:29 +08:00
|
|
|
%$end:
|
2008-07-17 05:41:39 +08:00
|
|
|
%else
|
2008-10-20 07:38:28 +08:00
|
|
|
%rep %$pad / __ALIGN_%[__BITS__]BIT_GROUP__
|
|
|
|
db __ALIGN_%[__BITS__]BIT_%[__ALIGN_%[__BITS__]BIT_GROUP__]B__
|
|
|
|
%endrep
|
|
|
|
%assign %$pad %$pad % __ALIGN_%[__BITS__]BIT_GROUP__
|
|
|
|
%if %$pad > 0
|
|
|
|
db __ALIGN_%[__BITS__]BIT_%[%$pad]B__
|
2008-07-17 05:41:39 +08:00
|
|
|
%endif
|
|
|
|
%endif
|
|
|
|
%pop
|
|
|
|
%endif
|
|
|
|
%endmacro
|
|
|
|
|
|
|
|
alignmode generic
|