1
2
3
4
5
6 #include "ppc_asm.h"
7 #include "../include/asm/opal-api.h"
8
9 .text
10
11 .globl opal_kentry
12 opal_kentry:
13
14 mtctr r4
15 li r4, 0
16 li r5, 0
17 li r6, 0
18 li r7, 0
19 ld r11,opal@got(r2)
20 ld r8,0(r11)
21 ld r9,8(r11)
22 bctr
23
24 #define OPAL_CALL(name, token) \
25 .globl name; \
26 name: \
27 li r0, token; \
28 b opal_call;
29
30 opal_call:
31 mflr r11
32 std r11,16(r1)
33 mfcr r12
34 stw r12,8(r1)
35 mr r13,r2
36
37
38 ld r11,opal_return@got(r2)
39 mtlr r11
40 mfmsr r12
41
42
43 li r11,MSR_LE
44 andc r12,r12,r11
45 mtspr SPRN_HSRR1,r12
46
47
48 ld r11,opal@got(r2)
49 ld r12,8(r11)
50 ld r2,0(r11)
51 mtspr SPRN_HSRR0,r12
52 hrfid
53
54 opal_return:
55 FIXUP_ENDIAN
56 mr r2,r13;
57 lwz r11,8(r1);
58 ld r12,16(r1)
59 mtcr r11;
60 mtlr r12
61 blr
62
63 OPAL_CALL(opal_console_write, OPAL_CONSOLE_WRITE);
64 OPAL_CALL(opal_console_read, OPAL_CONSOLE_READ);
65 OPAL_CALL(opal_console_write_buffer_space, OPAL_CONSOLE_WRITE_BUFFER_SPACE);
66 OPAL_CALL(opal_poll_events, OPAL_POLL_EVENTS);
67 OPAL_CALL(opal_console_flush, OPAL_CONSOLE_FLUSH);