Overview
Comment: | Merge trunk into branch "tagged-pointers" |
---|---|
Downloads: | Tarball | ZIP archive | SQL archive |
Timelines: | family | ancestors | descendants | both | tagged-pointers |
Files: | files | file ages | folders |
SHA3-256: |
f5be211a1b76fb7b0ab816d1897367b3 |
User & Date: | js on 2020-06-29 23:17:15 |
Other Links: | branch diff | manifest | tags |
Context
2020-06-29
| ||
23:24 | lookup-asm-x86_64-elf.S: Support tagged pointers check-in: 577564693c user: js tags: tagged-pointers | |
23:17 | Merge trunk into branch "tagged-pointers" check-in: f5be211a1b user: js tags: tagged-pointers | |
23:14 | Convert all x86/ELF ASM files to Intel syntax check-in: 2073a345ba user: js tags: trunk | |
20:30 | Add support for tagged pointers in object_getClass check-in: 8707dd73c4 user: js tags: tagged-pointers | |
Changes
Modified configure.ac from [91f2d79380] to [ffd0b1674a].
︙ | ︙ | |||
248 249 250 251 252 253 254 255 256 257 258 259 260 261 | dnl accept everything used in ObjFW's assembly files. dnl Therefore, use the integrated assembler for ObjC dnl files, but not for assembly files. mips*-*-*) flag="-integrated-as" OBJCFLAGS="$OBJCFLAGS $flag" OBJFW_OBJCFLAGS="$OBJFW_OBJCFLAGS $flag" ;; dnl Clang's assembler on Windows is not complete yet dnl and cannot compile all .S files. *-*-mingw*) ASFLAGS="$ASFLAGS -no-integrated-as" ;; dnl Clang generates assembly output on SPARC64 that | > > > > | 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 | dnl accept everything used in ObjFW's assembly files. dnl Therefore, use the integrated assembler for ObjC dnl files, but not for assembly files. mips*-*-*) flag="-integrated-as" OBJCFLAGS="$OBJCFLAGS $flag" OBJFW_OBJCFLAGS="$OBJFW_OBJCFLAGS $flag" ;; dnl Many older Clang versions don't support jmp short. i?86-*-* | x86_64-*-*) ASFLAGS="$ASFLAGS -no-integrated-as" ;; dnl Clang's assembler on Windows is not complete yet dnl and cannot compile all .S files. *-*-mingw*) ASFLAGS="$ASFLAGS -no-integrated-as" ;; dnl Clang generates assembly output on SPARC64 that |
︙ | ︙ |
Modified src/forwarding/forwarding-x86-elf.S from [9bcb5fc324] to [2e098aafbd].
︙ | ︙ | |||
15 16 17 18 19 20 21 22 23 24 25 26 | * file. */ #include "config.h" #include "platform.h" .globl of_forward .globl of_forward_stret .section .text of_forward: | > > | | | | | | | | | | | | | | | | | | | | | | > > | < < | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | > > | < < | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 | * file. */ #include "config.h" #include "platform.h" .intel_syntax noprefix .globl of_forward .globl of_forward_stret .section .text of_forward: push ebp mov ebp, esp push ebx sub esp, 20 call get_eip 0: add ebx, offset _GLOBAL_OFFSET_TABLE_ mov eax, [ebp+8] mov [esp], eax mov eax, [ebx+object_getClass@GOT] call eax mov [esp], eax lea eax, [ebx+sel_forwardingTargetForSelector_@GOTOFF] mov [esp+4], eax mov eax, [ebx+class_respondsToSelector@GOT] call eax test eax, eax jz short 1f mov eax, [ebp+8] mov [esp], eax lea eax, [ebx+sel_forwardingTargetForSelector_@GOTOFF] mov [esp+4], eax mov eax, [ebx+objc_msg_lookup@GOT] call eax mov edx, [ebp+8] mov [esp], edx lea edx, [ebx+sel_forwardingTargetForSelector_@GOTOFF] mov [esp+4], edx mov edx, [ebp+12] mov [esp+8], edx call eax test eax, eax jz short 1f cmp eax, [ebp+8] je short 1f mov [ebp+8], eax mov [esp], eax mov eax, [ebp+12] mov [esp+4], eax mov eax, [ebx+objc_msg_lookup@GOT] call eax add esp, 20 pop ebx pop ebp jmp eax 1: mov eax, [ebx+of_method_not_found@GOT] add esp, 20 pop ebx pop ebp jmp eax .type of_forward, %function .size of_forward, .-of_forward of_forward_stret: push ebp mov ebp, esp push ebx sub esp, 20 call get_eip 0: add ebx, offset _GLOBAL_OFFSET_TABLE_ mov eax, [ebp+12] mov [esp], eax mov eax, [ebx+object_getClass@GOT] call eax mov [esp], eax lea eax, [ebx+sel_forwardingTargetForSelector_@GOTOFF] mov [esp+4], eax mov eax, [ebx+class_respondsToSelector@GOT] call eax test eax, eax jz short 1f mov eax, [ebp+12] mov [esp], eax lea eax, [ebx+sel_forwardingTargetForSelector_@GOTOFF] mov [esp+4], eax mov eax, [ebx+objc_msg_lookup@GOT] call eax mov edx, [ebp+12] mov [esp], edx lea edx, [ebx+sel_forwardingTargetForSelector_@GOTOFF] mov [esp+4], edx mov edx, [ebp+16] mov [esp+8], edx call eax test eax, eax jz short 1f cmp eax, [ebp+12] je short 1f mov [ebp+12], eax mov [esp], eax mov eax, [ebp+16] mov [esp+4], eax mov eax, [ebx+objc_msg_lookup_stret@GOT] call eax add esp, 20 pop ebx pop ebp jmp eax 1: mov eax, [ebx+of_method_not_found_stret@GOT] add esp, 20 pop ebx pop ebp jmp eax .type of_forward_stret, %function .size of_forward_stret, .-of_forward_stret init: push ebp mov ebp, esp push ebx sub esp, 4 call get_eip 0: add ebx, offset _GLOBAL_OFFSET_TABLE_ lea eax, [ebx+module@GOTOFF] mov [esp], eax mov eax, [ebx+__objc_exec_class@GOT] call eax add esp, 4 pop ebx pop ebp ret get_eip: mov ebx, [esp] ret #ifdef OF_SOLARIS .section .init_array, "aw" #else .section .ctors, "aw", %progbits #endif |
︙ | ︙ |
Modified src/forwarding/forwarding-x86_64-elf.S from [d6c82663f6] to [1d1fc641cf].
︙ | ︙ | |||
15 16 17 18 19 20 21 22 23 24 25 26 | * file. */ #include "config.h" #include "platform.h" .globl of_forward .globl of_forward_stret .section .text of_forward: | > > | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 | * file. */ #include "config.h" #include "platform.h" .intel_syntax noprefix .globl of_forward .globl of_forward_stret .section .text of_forward: push rbp mov rbp, rsp /* Save all arguments */ sub rsp, 0xC0 /* 16-byte alignment */ mov [rbp-0x08], rax mov [rbp-0x10], rdi mov [rbp-0x18], rsi mov [rbp-0x20], rdx mov [rbp-0x28], rcx mov [rbp-0x30], r8 mov [rbp-0x38], r9 movaps [rbp-0x50], xmm0 movaps [rbp-0x60], xmm1 movaps [rbp-0x70], xmm2 movaps [rbp-0x80], xmm3 movaps [rbp-0x90], xmm4 movaps [rbp-0xA0], xmm5 movaps [rbp-0xB0], xmm6 movaps [rbp-0xC0], xmm7 call object_getClass@PLT mov rdi, rax lea rsi, [rip+sel_forwardingTargetForSelector_] call class_respondsToSelector@PLT test rax, rax jz short 0f mov rdi, [rbp-0x10] lea rsi, [rip+sel_forwardingTargetForSelector_] call objc_msg_lookup@PLT mov rdi, [rbp-0x10] lea rsi, [rip+sel_forwardingTargetForSelector_] mov rdx, [rbp-0x18] call rax test rax, rax jz short 0f cmp rax, [rbp-0x10] je short 0f mov [rbp-0x10], rax mov rdi, rax mov rsi, [rbp-0x18] call objc_msg_lookup@PLT mov r11, rax /* Restore all arguments */ movaps xmm7, [rbp-0xC0] movaps xmm6, [rbp-0xB0] movaps xmm5, [rbp-0xA0] movaps xmm4, [rbp-0x90] movaps xmm3, [rbp-0x80] movaps xmm2, [rbp-0x70] movaps xmm1, [rbp-0x60] movaps xmm0, [rbp-0x50] mov r9, [rbp-0x38] mov r8, [rbp-0x30] mov rcx, [rbp-0x28] mov rdx, [rbp-0x20] mov rsi, [rbp-0x18] mov rdi, [rbp-0x10] mov rax, [rbp-0x08] mov rsp, rbp pop rbp jmp r11 0: mov rdi, [rbp-0x10] mov rsi, [rbp-0x18] mov rsp, rbp pop rbp jmp of_method_not_found@PLT .type of_forward, %function .size of_forward, .-of_forward of_forward_stret: push rbp mov rbp, rsp /* Save all arguments */ sub rsp, 0xC0 /* 16-byte alignment */ mov [rbp-0x08], rax mov [rbp-0x10], rdi mov [rbp-0x18], rsi mov [rbp-0x20], rdx mov [rbp-0x28], rcx mov [rbp-0x30], r8 mov [rbp-0x38], r9 movaps [rbp-0x50], xmm0 movaps [rbp-0x60], xmm1 movaps [rbp-0x70], xmm2 movaps [rbp-0x80], xmm3 movaps [rbp-0x90], xmm4 movaps [rbp-0xA0], xmm5 movaps [rbp-0xB0], xmm6 movaps [rbp-0xC0], xmm7 mov rdi, rsi call object_getClass@PLT mov rdi, rax lea rsi, [rip+sel_forwardingTargetForSelector_] call class_respondsToSelector@PLT test rax, rax jz short 0f mov rdi, [rbp-0x18] lea rsi, [rip+sel_forwardingTargetForSelector_] call objc_msg_lookup@PLT mov rdi, [rbp-0x18] lea rsi, [rip+sel_forwardingTargetForSelector_] mov rdx, [rbp-0x20] call rax test rax, rax jz short 0f cmp rax, [rbp-0x18] je short 0f mov [rbp-0x18], rax mov rdi, rax mov rsi, [rbp-0x20] call objc_msg_lookup_stret@PLT mov r11, rax /* Restore all arguments */ movaps xmm7, [rbp-0xC0] movaps xmm6, [rbp-0xB0] movaps xmm5, [rbp-0xA0] movaps xmm4, [rbp-0x90] movaps xmm3, [rbp-0x80] movaps xmm2, [rbp-0x70] movaps xmm1, [rbp-0x60] movaps xmm0, [rbp-0x50] mov r9, [rbp-0x38] mov r8, [rbp-0x30] mov rcx, [rbp-0x28] mov rdx, [rbp-0x20] mov rsi, [rbp-0x18] mov rdi, [rbp-0x10] mov rax, [rbp-0x08] mov rsp, rbp pop rbp jmp r11 0: mov rdi, [rbp-0x10] mov rsi, [rbp-0x18] mov rdx, [rbp-0x20] mov rsp, rbp pop rbp jmp of_method_not_found_stret@PLT .type of_forward_stret, %function .size of_forward_stret, .-of_forward_stret init: lea rdi, [rip+module] jmp __objc_exec_class@PLT #ifdef OF_SOLARIS .section .init_array, "aw" #else .section .ctors, "aw", %progbits #endif |
︙ | ︙ |
Modified src/runtime/lookup-asm/lookup-asm-x86-elf.S from [6c4a8f6d7c] to [65ed1dc5ee].
︙ | ︙ | |||
15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 | * file. */ #include "config.h" #include "platform.h" .globl objc_msg_lookup .globl objc_msg_lookup_stret .globl objc_msg_lookup_super .globl objc_msg_lookup_super_stret .section .text .macro generate_lookup name not_found \name: | > > | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 | * file. */ #include "config.h" #include "platform.h" .intel_syntax noprefix .globl objc_msg_lookup .globl objc_msg_lookup_stret .globl objc_msg_lookup_super .globl objc_msg_lookup_super_stret .section .text .macro generate_lookup name not_found \name: mov edx, [esp+4] test edx, edx jz short ret_nil mov edx, [edx] mov edx, [edx+32] .Lmain_\name: mov eax, [esp+8] #ifdef OF_SELUID24 movzx ecx, byte ptr [eax+2] mov edx, [edx+ecx*4] #endif movzx ecx, byte ptr [eax+1] mov edx, [edx+ecx*4] movzx ecx, byte ptr [eax] mov eax, [edx+ecx*4] test eax, eax jz short 0f ret 0: call get_eip 1: add eax, offset _GLOBAL_OFFSET_TABLE_ mov eax, [eax+\not_found@GOT] jmp eax .type \name, %function .size \name, .-\name .endm .macro generate_lookup_super name lookup \name: mov edx, [esp+4] mov eax, [edx] test eax, eax jz short ret_nil mov [esp+4], eax mov edx, [edx+4] mov edx, [edx+32] jmp short .Lmain_\lookup .type \name, %function .size \name, .-\name .endm generate_lookup objc_msg_lookup objc_method_not_found generate_lookup objc_msg_lookup_stret objc_method_not_found_stret generate_lookup_super objc_msg_lookup_super objc_msg_lookup generate_lookup_super objc_msg_lookup_super_stret objc_msg_lookup_stret ret_nil: call get_eip 0: add eax, nil_method-0b ret nil_method: xor eax, eax ret get_eip: mov eax, [esp] ret #ifdef OF_LINUX .section .note.GNU-stack, "", %progbits #endif |
Modified src/runtime/lookup-asm/lookup-asm-x86_64-elf.S from [16edfd651f] to [edf654aa73].
︙ | ︙ | |||
15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 | * file. */ #include "config.h" #include "platform.h" .globl objc_msg_lookup .globl objc_msg_lookup_stret .globl objc_msg_lookup_super .globl objc_msg_lookup_super_stret .section .text .macro generate_lookup name not_found \name: | > > | | | | | | | | | | | | | | | | | | | | | 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 | * file. */ #include "config.h" #include "platform.h" .intel_syntax noprefix .globl objc_msg_lookup .globl objc_msg_lookup_stret .globl objc_msg_lookup_super .globl objc_msg_lookup_super_stret .section .text .macro generate_lookup name not_found \name: test rdi, rdi jz short ret_nil mov r8, [rdi] mov r8, [r8+64] .Lmain_\name: mov rax, [rsi] movzx ecx, ah movzx edx, al #ifdef OF_SELUID24 shr eax, 16 mov r8, [r8+rax*8] #endif mov r8, [r8+rcx*8] mov rax, [r8+rdx*8] test rax, rax jz short \not_found@PLT ret .type \name, %function .size \name, .-\name .endm .macro generate_lookup_super name lookup \name: mov r8, rdi mov rdi, [rdi] test rdi, rdi jz ret_nil mov r8, [r8+8] mov r8, [r8+64] jmp .Lmain_\lookup .type \name, %function .size \name, .-\name .endm generate_lookup objc_msg_lookup objc_method_not_found generate_lookup objc_msg_lookup_stret objc_method_not_found_stret generate_lookup_super objc_msg_lookup_super objc_msg_lookup generate_lookup_super objc_msg_lookup_super_stret objc_msg_lookup_stret ret_nil: lea rax, [rip+nil_method] ret nil_method: xor rax, rax ret #ifdef OF_LINUX .section .note.GNU-stack, "", %progbits #endif |