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
|
# IBM_PROLOG_BEGIN_TAG
# This is an automatically generated prolog.
#
# $Source: src/runtime/rt_start.S $
#
# OpenPOWER HostBoot Project
#
# Contributors Listed Below - COPYRIGHT 2013,2019
# [+] International Business Machines Corp.
# [+] Joel Stanley
#
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
# implied. See the License for the specific language governing
# permissions and limitations under the License.
#
# IBM_PROLOG_END_TAG
.include "kernel/ppcconsts.S"
#define __HOSTBOOT_RUNTIME_INTERFACE_VERSION_ONLY 1
#include <runtime/interface.h>
.section .text.intvects
.org 0x0;
hbrt_desired_interface_version:
.quad 0x4842525456455253 # 'HBRTVERS' eyecatch.
.quad HOSTBOOT_RUNTIME_INTERFACE_VERSION
.org 0x100;
_init:
mflr r10 # Save LR
bl 1f # Get current address by branch-with-link.
1:
mflr r4 # Extract current address.
mtlr r10 # Restore LR.
clrrdi r4, r4, 12 # Align address to 4k.
addi r10, r4, 0x2000 # Find VFS_LAST_ADDRESS symbol.
ld r10, 0(r10) # Read start of relocation table.
add r10, r10, r4
ld r8, 0(r10) # Get count of relocations.
cmpwi cr0, r8, 0 # Perform relocations (if any).
beq 2f
# TLS workaround
# Load ASCII 'T','L','S' + 0x00 into bits 32:63 of r6, which will be used
# to compare against bits 0-31 of each relocation entry. A match signifies
# that this and the next relocation entry are the TLS module and offset
# relocations respectively. Skip both relocations before continuing the
# processing. These first two directives create the reference pattern to
# compare against. Also skip a relocation entry if its value is 0.
rldicl r6,r6,0,63 # Clear r6 to zero
addis r6, 0, 0x544C # Load ASCII "TL" into bits 32:47 of r6
ori r6, r6, 0x5300 # Load ASCII "S" + 0x00 into bits 48:63 of r6
mtctr r8
1:
ldu r8, 8(r10) # Get relocation destination
add r8, r8, r4
ld r7, 0(r8) # Get relocation address
# TLS workaround (continued for next 8 instructions)
rldicl r5,r5,0,63 # Clear r5 to zero
cmp cr0, 0, r5, r7 # Compare the relocation address (r7) to zero (r5)
beq cr0, 3f # If the relocation address is zero, do
# not adjust it and instead jump to the loop
# decrement/branch instruction
rldicl r5,r7,32,32 # Rotate bits 0-31 of the relocation address
# into 32-63 and clear bits 0-31, saving result
# to r5, to set up the next comparison
cmp cr0, 0, r6, r5 # Compare bits 32-63, which should both contain
# ASCII TLS+0x00 if this is a TLS module
bne cr0, 4f # If not a TLS module relocation, keep going;
ldu r8, 8(r10) # otherwise, skip the TLS module relocation
bdnz 3f # and decrement the loop counter to match. Jump
# to a 2nd skip/decrement pair to effectively skip
# the next TLS module relocation as well
4:
add r7, r7, r4
std r7, 0(r8) # Update relocation address.
3:
bdnz 1b # Decrement CTR and continue loop.
2:
addi r10, r4, 0x2008 # Find pointer to main TOC.
ld r10, 0(r10) # Dereference pointer to get TOC entry.
ld r2, 8(r10)
ld r10, 0(r10)
mtctr r10
bctr
.section .text.kernelasm # @2000
.global VFS_LAST_ADDRESS
VFS_LAST_ADDRESS:
.space 8
main_toc_ptr:
.quad _main
.section .data
.global hbi_ImageId
hbi_ImageId:
.space 128
|