treewide: remove redundant IS_ERR() before error code check
[linux/fpc-iii.git] / arch / sparc / prom / cif.S
blobdd06bb1fb90c4088648225da3d0989e17e719890
1 /* SPDX-License-Identifier: GPL-2.0 */
2 /* cif.S: PROM entry/exit assembler trampolines.
3  *
4  * Copyright (C) 1996, 1997 Jakub Jelinek (jj@sunsite.mff.cuni.cz)
5  * Copyright (C) 2005, 2006 David S. Miller <davem@davemloft.net>
6  */
8 #include <asm/pstate.h>
9 #include <asm/cpudata.h>
10 #include <asm/thread_info.h>
12         .text
13         .globl  prom_cif_direct
14 prom_cif_direct:
15         save    %sp, -192, %sp
16         sethi   %hi(p1275buf), %o1
17         or      %o1, %lo(p1275buf), %o1
18         ldx     [%o1 + 0x0008], %l2     ! prom_cif_handler
19         mov     %g4, %l0
20         mov     %g5, %l1
21         mov     %g6, %l3
22         call    %l2
23          mov    %i0, %o0                ! prom_args
24         mov     %l0, %g4
25         mov     %l1, %g5
26         mov     %l3, %g6
27         ret
28          restore
30         .globl  prom_cif_callback
31 prom_cif_callback:
32         sethi   %hi(p1275buf), %o1
33         or      %o1, %lo(p1275buf), %o1
34         save    %sp, -192, %sp
35         TRAP_LOAD_THREAD_REG(%g6, %g1)
36         LOAD_PER_CPU_BASE(%g5, %g6, %g4, %g3, %o0)
37         ldx     [%g6 + TI_TASK], %g4
38         call    prom_world
39          mov    0, %o0
40         ldx     [%i1 + 0x000], %l2
41         call    %l2
42          mov    %i0, %o0
43         mov     %o0, %l1
44         call    prom_world
45          mov    1, %o0
46         ret
47          restore %l1, 0, %o0