]> git.saurik.com Git - apple/xnu.git/blame - libkern/kxld/kxld_sect.h
xnu-7195.101.1.tar.gz
[apple/xnu.git] / libkern / kxld / kxld_sect.h
CommitLineData
b0d623f7
A
1/*
2 * Copyright (c) 2008 Apple Inc. All rights reserved.
3 *
4 * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
0a7de745 5 *
b0d623f7
A
6 * This file contains Original Code and/or Modifications of Original Code
7 * as defined in and that are subject to the Apple Public Source License
8 * Version 2.0 (the 'License'). You may not use this file except in
9 * compliance with the License. The rights granted to you under the License
10 * may not be used to create, or enable the creation or redistribution of,
11 * unlawful or unlicensed copies of an Apple operating system, or to
12 * circumvent, violate, or enable the circumvention or violation of, any
13 * terms of an Apple operating system software license agreement.
0a7de745 14 *
b0d623f7
A
15 * Please obtain a copy of the License at
16 * http://www.opensource.apple.com/apsl/ and read it before using this file.
0a7de745 17 *
b0d623f7
A
18 * The Original Code and all software distributed under the License are
19 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
20 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
21 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
22 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
23 * Please see the License for the specific language governing rights and
24 * limitations under the License.
0a7de745 25 *
b0d623f7
A
26 * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
27 */
28#ifndef _KXLD_SECT_H_
29#define _KXLD_SECT_H_
30
b0d623f7
A
31#include <sys/types.h>
32#if KERNEL
33 #include <libkern/kxld_types.h>
34#else
35 #include "kxld_types.h"
36#endif
37
38#include "kxld_array.h"
39
40struct kxld_array;
41struct kxld_relocator;
42struct kxld_reloc;
43struct kxld_seg;
44struct kxld_symtab;
45struct relocation_info;
46struct section;
47struct section_64;
48typedef struct kxld_sect KXLDSect;
49
50struct kxld_sect {
0a7de745
A
51 char sectname[16]; // The name of the section
52 char segname[16]; // The segment to which the section belongs
53 u_char *data; // The start of the section in memory
54 KXLDArray relocs; // The section's relocation entries
55 kxld_addr_t base_addr; // The base address of the section
56 kxld_addr_t link_addr; // The relocated address of the section
57 kxld_size_t size; // The size of the section
58 u_int sectnum; // The number of the section (for relocation)
59 u_int flags; // Flags describing the section
60 u_int align; // The section's alignment as a power of 2
61 u_int reserved1; // Dependent on the section type
62 u_int reserved2; // Dependent on the section type
63 boolean_t allocated; // This section's data is allocated internally
b0d623f7
A
64};
65
66/*******************************************************************************
67* Constructors and destructors
68*******************************************************************************/
69
70#if KXLD_USER_OR_ILP32
71/* Initializes a section object from a Mach-O section header and modifies the
72 * section offset to point to the next section header.
73 */
74kern_return_t kxld_sect_init_from_macho_32(KXLDSect *sect, u_char *macho,
0a7de745
A
75 u_long *sect_offset, u_int sectnum, const struct kxld_relocator *relocator)
76__attribute__((nonnull, visibility("hidden")));
b0d623f7
A
77#endif /* KXLD_USER_OR_ILP32 */
78
79#if KXLD_USER_OR_LP64
80/* Initializes a section object from a Mach-O64 section header and modifies the
81 * section offset to point to the next section header.
82 */
83kern_return_t kxld_sect_init_from_macho_64(KXLDSect *sect, u_char *macho,
0a7de745
A
84 u_long *sect_offset, u_int sectnum, const struct kxld_relocator *relocator)
85__attribute__((nonnull, visibility("hidden")));
b0d623f7
A
86#endif /* KXLD_USER_OR_LP64 */
87
88#if KXLD_USER_OR_GOT
89/* Initializes a GOT section from the number of entries that the section should
90 * have.
91 */
92kern_return_t kxld_sect_init_got(KXLDSect *sect, u_int ngots)
0a7de745 93__attribute__((nonnull, visibility("hidden")));
b0d623f7
A
94#endif /* KXLD_USER_OR_GOT */
95
96#if KXLD_USER_OR_COMMON
97/* Initializes a zerofill section of the specified size and alignment */
0a7de745 98void kxld_sect_init_zerofill(KXLDSect *sect, const char *segname,
b0d623f7 99 const char *sectname, kxld_size_t size, u_int align)
0a7de745 100__attribute__((nonnull, visibility("hidden")));
b0d623f7 101#endif /* KXLD_USER_OR_COMMON */
0a7de745 102
b0d623f7
A
103/* Clears the section object */
104void kxld_sect_clear(KXLDSect *sect)
0a7de745 105__attribute__((nonnull, visibility("hidden")));
b0d623f7
A
106
107/* Denitializes the section object and frees its array of relocs */
108void kxld_sect_deinit(KXLDSect *sect)
0a7de745 109__attribute__((nonnull, visibility("hidden")));
b0d623f7
A
110
111/*******************************************************************************
112* Accessors
113*******************************************************************************/
114
115/* Gets the number of relocation entries in the section */
116u_int kxld_sect_get_num_relocs(const KXLDSect *sect)
0a7de745 117__attribute__((pure, nonnull, visibility("hidden")));
b0d623f7
A
118
119/* Returns the address parameter adjusted to the minimum alignment required by
120 * the section.
121 */
122kxld_addr_t kxld_sect_align_address(const KXLDSect *sect, kxld_addr_t address)
0a7de745 123__attribute__((pure, nonnull, visibility("hidden")));
b0d623f7
A
124
125/* Returns the space required by the exported Mach-O header */
126u_long kxld_sect_get_macho_header_size(boolean_t is_32_bit)
0a7de745 127__attribute__((const, visibility("hidden")));
b0d623f7
A
128
129/* Returns the space required by the exported Mach-O data */
130u_long kxld_sect_get_macho_data_size(const KXLDSect *sect)
0a7de745 131__attribute__((pure, nonnull, visibility("hidden")));
b0d623f7
A
132
133#if KXLD_USER_OR_LP64
134/* Returns the number of GOT entries required by relocation entries in the
135 * given section.
136 */
0a7de745 137u_int kxld_sect_get_ngots(const KXLDSect *sect,
b0d623f7 138 const struct kxld_relocator *relocator, const struct kxld_symtab *symtab)
0a7de745 139__attribute__((pure, nonnull, visibility("hidden")));
b0d623f7
A
140#endif /* KXLD_USER_OR_LP64 */
141
142kern_return_t kxld_sect_export_macho_to_file_buffer(const KXLDSect *sect, u_char *buf,
0a7de745 143 u_long *header_offset, u_long header_size, u_long *data_offset,
b0d623f7 144 u_long data_size, boolean_t is_32_bit)
0a7de745 145__attribute__((nonnull, visibility("hidden")));
b0d623f7 146
39037602 147kern_return_t kxld_sect_export_macho_to_vm(const KXLDSect *sect, u_char *buf,
0a7de745
A
148 u_long *header_offset,
149 u_long header_size,
150 kxld_addr_t link_addr,
151 u_long data_size,
152 boolean_t is_32_bit)
39037602 153__attribute__((nonnull, visibility("hidden")));
b0d623f7
A
154
155/*******************************************************************************
156* Mutators
157*******************************************************************************/
158
159/* Relocates the section to the given link address */
160void kxld_sect_relocate(KXLDSect *sect, kxld_addr_t link_addr)
0a7de745 161__attribute__((nonnull, visibility("hidden")));
b0d623f7
A
162
163#if KXLD_USER_OR_COMMON
164/* Adds a number of bytes to the section's size. Returns the size of the
165 * section before it was grown.
166 */
167kxld_size_t kxld_sect_grow(KXLDSect *sect, kxld_size_t nbytes, u_int align)
0a7de745 168__attribute__((nonnull, visibility("hidden")));
b0d623f7
A
169#endif /* KXLD_USER_OR_COMMON */
170
171#if KXLD_USER_OR_GOT
172/* Popluates the entries of a GOT section */
173kern_return_t kxld_sect_populate_got(KXLDSect *sect, struct kxld_symtab *symtab,
174 boolean_t swap)
0a7de745 175__attribute__((nonnull, visibility("hidden")));
b0d623f7
A
176#endif /* KXLD_USER_OR_GOT */
177
178/* Processes all of a section's relocation entries */
0a7de745 179kern_return_t kxld_sect_process_relocs(KXLDSect *sect,
6d2010ae 180 struct kxld_relocator *relocator)
0a7de745 181__attribute__((nonnull, visibility("hidden")));
b0d623f7
A
182
183#endif /* _KXLD_SECT_H_ */