Tom Rini | 10e4779 | 2018-05-06 17:58:06 -0400 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0+ */ |
Rafal Jaworowski | a19be78 | 2008-01-09 19:39:36 +0100 | [diff] [blame] | 2 | /* |
| 3 | * (C) Copyright 2007 Semihalf |
| 4 | * |
| 5 | * Written by: Rafal Jaworowski <raj@semihalf.com> |
Rafal Jaworowski | a19be78 | 2008-01-09 19:39:36 +0100 | [diff] [blame] | 6 | */ |
| 7 | |
| 8 | #if defined(CONFIG_PPC) |
| 9 | |
| 10 | .text |
Rafal Jaworowski | a19be78 | 2008-01-09 19:39:36 +0100 | [diff] [blame] | 11 | .globl _start |
| 12 | _start: |
Rafal Jaworowski | 3d25ba5 | 2009-01-23 13:27:15 +0100 | [diff] [blame] | 13 | lis %r11, search_hint@ha |
| 14 | addi %r11, %r11, search_hint@l |
| 15 | stw %r1, 0(%r11) |
Rafal Jaworowski | a19be78 | 2008-01-09 19:39:36 +0100 | [diff] [blame] | 16 | b main |
| 17 | |
| 18 | |
| 19 | .globl syscall |
| 20 | syscall: |
| 21 | lis %r11, syscall_ptr@ha |
| 22 | addi %r11, %r11, syscall_ptr@l |
| 23 | lwz %r11, 0(%r11) |
| 24 | mtctr %r11 |
| 25 | bctr |
Rafal Jaworowski | 9d9689f | 2009-01-23 13:27:16 +0100 | [diff] [blame] | 26 | |
Heinrich Schuchardt | 3d2e2f8 | 2024-11-03 06:35:49 +0100 | [diff] [blame] | 27 | #elif defined(CONFIG_ARM) && !defined(CONFIG_ARM64) |
Rafal Jaworowski | 9d9689f | 2009-01-23 13:27:16 +0100 | [diff] [blame] | 28 | |
| 29 | .text |
| 30 | .globl _start |
| 31 | _start: |
Liya Huang | 9ed7dec | 2025-01-28 09:13:16 +0800 | [diff] [blame] | 32 | ldr r4, =search_hint |
| 33 | mov r5, sp |
| 34 | str r5, [r4] |
Rafal Jaworowski | 9d9689f | 2009-01-23 13:27:16 +0100 | [diff] [blame] | 35 | b main |
| 36 | |
Brunham, Kalen | ba4dc55 | 2024-05-17 19:13:48 +0000 | [diff] [blame] | 37 | |
Heinrich Schuchardt | 3d2e2f8 | 2024-11-03 06:35:49 +0100 | [diff] [blame] | 38 | .globl syscall |
Brunham, Kalen | ba4dc55 | 2024-05-17 19:13:48 +0000 | [diff] [blame] | 39 | syscall: |
Liya Huang | 9ed7dec | 2025-01-28 09:13:16 +0800 | [diff] [blame] | 40 | ldr r4, =syscall_ptr |
| 41 | ldr r4, [r4] |
| 42 | bx r4 |
Brunham, Kalen | ba4dc55 | 2024-05-17 19:13:48 +0000 | [diff] [blame] | 43 | |
Heinrich Schuchardt | 3d2e2f8 | 2024-11-03 06:35:49 +0100 | [diff] [blame] | 44 | #elif defined(CONFIG_ARM64) |
| 45 | |
| 46 | .text |
| 47 | .globl _start |
| 48 | _start: |
| 49 | ldr x17, =search_hint |
| 50 | mov x16, sp |
| 51 | str x16, [x17] |
| 52 | b main |
Rafal Jaworowski | 9d9689f | 2009-01-23 13:27:16 +0100 | [diff] [blame] | 53 | |
| 54 | .globl syscall |
| 55 | syscall: |
Heinrich Schuchardt | 3d2e2f8 | 2024-11-03 06:35:49 +0100 | [diff] [blame] | 56 | ldr x16, =syscall_ptr |
| 57 | ldr x16, [x16] |
| 58 | br x16 |
Rafal Jaworowski | 9d9689f | 2009-01-23 13:27:16 +0100 | [diff] [blame] | 59 | |
Stanislav Galabov | 35d35e8 | 2016-02-04 12:13:44 +0200 | [diff] [blame] | 60 | #elif defined(CONFIG_MIPS) |
Stanislav Galabov | 10c7a57 | 2016-02-17 15:23:31 +0200 | [diff] [blame] | 61 | #include <asm/asm.h> |
Stanislav Galabov | 35d35e8 | 2016-02-04 12:13:44 +0200 | [diff] [blame] | 62 | .text |
| 63 | .globl __start |
| 64 | .ent __start |
| 65 | __start: |
Stanislav Galabov | 10c7a57 | 2016-02-17 15:23:31 +0200 | [diff] [blame] | 66 | PTR_S $sp, search_hint |
Stanislav Galabov | 35d35e8 | 2016-02-04 12:13:44 +0200 | [diff] [blame] | 67 | b main |
| 68 | .end __start |
| 69 | |
| 70 | .globl syscall |
| 71 | .ent syscall |
| 72 | syscall: |
Stanislav Galabov | 10c7a57 | 2016-02-17 15:23:31 +0200 | [diff] [blame] | 73 | PTR_S $ra, return_addr |
| 74 | PTR_L $t9, syscall_ptr |
Stanislav Galabov | 35d35e8 | 2016-02-04 12:13:44 +0200 | [diff] [blame] | 75 | jalr $t9 |
| 76 | nop |
Stanislav Galabov | 10c7a57 | 2016-02-17 15:23:31 +0200 | [diff] [blame] | 77 | PTR_L $ra, return_addr |
Stanislav Galabov | 35d35e8 | 2016-02-04 12:13:44 +0200 | [diff] [blame] | 78 | jr $ra |
| 79 | nop |
| 80 | .end syscall |
| 81 | |
| 82 | return_addr: |
Stanislav Galabov | 10c7a57 | 2016-02-17 15:23:31 +0200 | [diff] [blame] | 83 | .align 8 |
Stanislav Galabov | 35d35e8 | 2016-02-04 12:13:44 +0200 | [diff] [blame] | 84 | .long 0 |
Heinrich Schuchardt | 974cad5 | 2024-11-23 09:47:52 +0100 | [diff] [blame] | 85 | #elif defined(CONFIG_ARCH_RV32I) |
| 86 | |
| 87 | .text |
| 88 | .globl _start |
| 89 | _start: |
| 90 | la t0, search_hint |
| 91 | sw sp, 0(t0) |
| 92 | la t0, main |
| 93 | jalr x0, t0 |
| 94 | |
| 95 | .globl syscall |
| 96 | syscall: |
| 97 | la t0, syscall_ptr |
| 98 | lw t0, 0(t0) |
| 99 | jalr x0, t0 |
| 100 | |
| 101 | #elif defined(CONFIG_ARCH_RV64I) |
| 102 | |
| 103 | .text |
| 104 | .globl _start |
| 105 | _start: |
| 106 | la t0, search_hint |
| 107 | sd sp, 0(t0) |
| 108 | la t0, main |
| 109 | jalr x0, t0 |
| 110 | |
| 111 | .globl syscall |
| 112 | syscall: |
| 113 | la t0, syscall_ptr |
| 114 | ld t0, 0(t0) |
| 115 | jalr x0, t0 |
| 116 | |
Rafal Jaworowski | 3d25ba5 | 2009-01-23 13:27:15 +0100 | [diff] [blame] | 117 | #else |
| 118 | #error No support for this arch! |
| 119 | #endif |
Rafal Jaworowski | a19be78 | 2008-01-09 19:39:36 +0100 | [diff] [blame] | 120 | |
Heinrich Schuchardt | 3d2e2f8 | 2024-11-03 06:35:49 +0100 | [diff] [blame] | 121 | .section .data |
| 122 | |
Rafal Jaworowski | a19be78 | 2008-01-09 19:39:36 +0100 | [diff] [blame] | 123 | .globl syscall_ptr |
| 124 | syscall_ptr: |
Stanislav Galabov | 10c7a57 | 2016-02-17 15:23:31 +0200 | [diff] [blame] | 125 | .align 8 |
Rafal Jaworowski | a19be78 | 2008-01-09 19:39:36 +0100 | [diff] [blame] | 126 | .long 0 |
Rafal Jaworowski | 3d25ba5 | 2009-01-23 13:27:15 +0100 | [diff] [blame] | 127 | |
| 128 | .globl search_hint |
| 129 | search_hint: |
Heinrich Schuchardt | 3d2e2f8 | 2024-11-03 06:35:49 +0100 | [diff] [blame] | 130 | .long 0 |