Overview
Comment: | Add lookup-asm-mips64-elf.S |
---|---|
Downloads: | Tarball | ZIP archive | SQL archive |
Timelines: | family | ancestors | descendants | both | trunk |
Files: | files | file ages | folders |
SHA3-256: |
68d4a17534e08aa2cbe7b6389d68b0ea |
User & Date: | js on 2016-02-07 20:34:36 |
Other Links: | manifest | tags |
Context
2016-02-10
| ||
22:25 | Add -[OFRunLoop runUntilDate:] check-in: 0f44c12d9f user: js tags: trunk | |
2016-02-07
| ||
20:34 | Add lookup-asm-mips64-elf.S check-in: 68d4a17534 user: js tags: trunk | |
14:09 | Fix a typo that broke big endian MIPS check-in: 84aa6556f9 user: js tags: trunk | |
Changes
Modified src/platform.h from [a0a7522d63] to [b2820cb66e].
︙ | ︙ | |||
45 46 47 48 49 50 51 | # endif # if defined(OF_ARMV7) || defined(__ARM_ARCH_6__) || \ defined(__ARM_ARCH_6J__) || defined(__ARM_ARCH_6K__) || \ defined(__ARM_ARCH_6Z__) || defined(__ARM_ARCH_6ZK__) || \ defined(__ARM_ARCH_6T2__) # define OF_ARMV6 # endif | | > > > > > > > | | > | 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 | # endif # if defined(OF_ARMV7) || defined(__ARM_ARCH_6__) || \ defined(__ARM_ARCH_6J__) || defined(__ARM_ARCH_6K__) || \ defined(__ARM_ARCH_6Z__) || defined(__ARM_ARCH_6ZK__) || \ defined(__ARM_ARCH_6T2__) # define OF_ARMV6 # endif #elif defined(_MIPS_SIM) # if _MIPS_SIM == _ABI64 # define OF_MIPS64 # define OF_MIPS64_N64 # elif _MIPS_SIM == _ABIN32 # define OF_MIPS64 # define OF_MIPS64_N32 # elif _MIPS_SIM == _ABIO32 # define OF_MIPS # define OF_MIPS_O32 # endif #elif defined(__mips_eabi) && _MIPS_SZPTR == 32 # define OF_MIPS # define OF_MIPS_EABI #elif defined(__sparc64__) || (defined(__sparc__) && defined(__arch64__)) # define OF_SPARC64 #elif defined(__sparc__) && !defined(__arch64__) # define OF_SPARC |
︙ | ︙ |
Added src/runtime/lookup-asm/lookup-asm-mips64-elf.S version [2bfd1071b2].
> > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 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 | /* * Copyright (c) 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015, 2016 * Jonathan Schleifer <js@heap.zone> * * All rights reserved. * * This file is part of ObjFW. It may be distributed under the terms of the * Q Public License 1.0, which can be found in the file LICENSE.QPL included in * the packaging of this file. * * Alternatively, it may be distributed under the terms of the GNU General * Public License, either version 2 or 3, which can be found in the file * LICENSE.GPLv2 or LICENSE.GPLv3 respectively included in the packaging of this * 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: beqz $a0, 0f ld $t0, 0($a0) ld $t0, 64($t0) .Lmain_\name: #ifdef OF_BIG_ENDIAN # ifdef OF_SELUID24 lbu $t1, 5($a1) # endif lbu $t2, 6($a1) lbu $t3, 7($a1) #else # ifdef OF_SELUID24 lbu $t1, 2($a1) # endif lbu $t2, 1($a1) lbu $t3, 0($a1) #endif #ifdef OF_SELUID24 sll $t1, $t1, 3 #endif sll $t2, $t2, 3 sll $t3, $t3, 3 #ifdef OF_SELUID24 daddu $t0, $t0, $t1 ld $t0, 0($t0) #endif daddu $t0, $t0, $t2 ld $t0, 0($t0) daddu $t0, $t0, $t3 ld $t0, 0($t0) beqz $t0, 1f move $v0, $t0 j $ra 0: lui $v0, %hi(%neg(%gp_rel(\name))) daddu $v0, $v0, $t9 daddiu $v0, $v0, %lo(%neg(%gp_rel(\name))) ld $v0, %got_disp(nil_method)($v0) j $ra 1: daddiu $sp, $sp, -32 sd $gp, 16($sp) lui $gp, %hi(%neg(%gp_rel(\name))) daddu $gp, $gp, $t9 daddiu $gp, $gp, %lo(%neg(%gp_rel(\name))) sd $ra, 24($sp) jal \not_found ld $ra, 24($sp) ld $gp, 16($sp) daddiu $sp, $sp, 32 j $ra .type \name, %function .size \name, .-\name .endm .macro generate_lookup_super name lookup \name: ld $t0, 0($a0) beqz $t0, 0f ld $t0, 8($a0) ld $t0, 64($t0) b .Lmain_\lookup 0: lui $v0, %hi(%neg(%gp_rel(\name))) daddu $v0, $v0, $t9 daddiu $v0, $v0, %lo(%neg(%gp_rel(\name))) ld $v0, %got_disp(nil_method)($v0) j $ra .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 nil_method: move $v0, $zero j $ra #ifdef OF_LINUX .section .note.GNU-stack, "", %progbits #endif |
Modified src/runtime/lookup-asm/lookup-asm.S from [b638ae745b] to [b95917777c].
︙ | ︙ | |||
25 26 27 28 29 30 31 32 33 34 35 36 37 38 | # include "lookup-asm-x86-elf.S" # elif defined(OF_ARM64) # include "lookup-asm-arm64-elf.S" # elif defined(OF_ARM) # include "lookup-asm-arm-elf.S" # elif defined(OF_POWERPC) # include "lookup-asm-ppc-elf.S" # elif defined(OF_MIPS) # include "lookup-asm-mips-elf.S" # elif defined(OF_SPARC64) # include "lookup-asm-sparc64-elf.S" # elif defined(OF_SPARC) # include "lookup-asm-sparc-elf.S" # endif | > > | 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 | # include "lookup-asm-x86-elf.S" # elif defined(OF_ARM64) # include "lookup-asm-arm64-elf.S" # elif defined(OF_ARM) # include "lookup-asm-arm-elf.S" # elif defined(OF_POWERPC) # include "lookup-asm-ppc-elf.S" # elif defined(OF_MIPS64_N64) # include "lookup-asm-mips64-elf.S" # elif defined(OF_MIPS) # include "lookup-asm-mips-elf.S" # elif defined(OF_SPARC64) # include "lookup-asm-sparc64-elf.S" # elif defined(OF_SPARC) # include "lookup-asm-sparc-elf.S" # endif |
︙ | ︙ |
Modified src/runtime/runtime-private.h from [bae86bc27a] to [c0ea96e247].
︙ | ︙ | |||
182 183 184 185 186 187 188 | return dtable->buckets[i]->buckets[j]; #endif } #if defined(OF_ELF) # if defined(OF_X86_64) || defined(OF_X86) || defined(OF_POWERPC) || \ | | > | 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 | return dtable->buckets[i]->buckets[j]; #endif } #if defined(OF_ELF) # if defined(OF_X86_64) || defined(OF_X86) || defined(OF_POWERPC) || \ defined(OF_ARM64) || defined(OF_ARM) || \ defined(OF_MIPS64_N64) || defined(OF_MIPS) || \ defined(OF_SPARC64) || defined(OF_SPARC) # define OF_ASM_LOOKUP # endif #elif defined(OF_MACH_O) # if defined(OF_X86_64) || defined(OF_POWERPC) # define OF_ASM_LOOKUP # endif |
︙ | ︙ |