]>
Commit | Line | Data |
---|---|---|
1da177e4 LT |
1 | config BINFMT_ELF |
2 | bool "Kernel support for ELF binaries" | |
2919b510 | 3 | depends on MMU && (BROKEN || !FRV) |
1da177e4 LT |
4 | default y |
5 | ---help--- | |
6 | ELF (Executable and Linkable Format) is a format for libraries and | |
7 | executables used across different architectures and operating | |
8 | systems. Saying Y here will enable your kernel to run ELF binaries | |
9 | and enlarge it by about 13 KB. ELF support under Linux has now all | |
10 | but replaced the traditional Linux a.out formats (QMAGIC and ZMAGIC) | |
11 | because it is portable (this does *not* mean that you will be able | |
12 | to run executables from different architectures or operating systems | |
13 | however) and makes building run-time libraries very easy. Many new | |
14 | executables are distributed solely in ELF format. You definitely | |
15 | want to say Y here. | |
16 | ||
17 | Information about ELF is contained in the ELF HOWTO available from | |
18 | <http://www.tldp.org/docs.html#howto>. | |
19 | ||
20 | If you find that after upgrading from Linux kernel 1.2 and saying Y | |
21 | here, you still can't run any ELF binaries (they just crash), then | |
22 | you'll have to install the newest ELF runtime libraries, including | |
23 | ld.so (check the file <file:Documentation/Changes> for location and | |
24 | latest version). | |
25 | ||
b9d36d5d RM |
26 | config COMPAT_BINFMT_ELF |
27 | bool | |
4cea5ceb | 28 | depends on COMPAT && BINFMT_ELF |
b9d36d5d | 29 | |
e39f5602 DD |
30 | config ARCH_BINFMT_ELF_RANDOMIZE_PIE |
31 | bool | |
32 | ||
1da177e4 LT |
33 | config BINFMT_ELF_FDPIC |
34 | bool "Kernel support for FDPIC ELF binaries" | |
35 | default y | |
3bc24a1a | 36 | depends on (FRV || BLACKFIN || (SUPERH32 && !MMU)) |
1da177e4 LT |
37 | help |
38 | ELF FDPIC binaries are based on ELF, but allow the individual load | |
39 | segments of a binary to be located in memory independently of each | |
40 | other. This makes this format ideal for use in environments where no | |
41 | MMU is available as it still permits text segments to be shared, | |
42 | even if data segments are not. | |
43 | ||
44 | It is also possible to run FDPIC ELF binaries on MMU linux also. | |
45 | ||
656eb2cd RM |
46 | config CORE_DUMP_DEFAULT_ELF_HEADERS |
47 | bool "Write ELF core dumps with partial segments" | |
89502155 | 48 | default y |
2d96d105 | 49 | depends on BINFMT_ELF && ELF_CORE |
656eb2cd RM |
50 | help |
51 | ELF core dump files describe each memory mapping of the crashed | |
52 | process, and can contain or omit the memory contents of each one. | |
53 | The contents of an unmodified text mapping are omitted by default. | |
54 | ||
55 | For an unmodified text mapping of an ELF object, including just | |
56 | the first page of the file in a core dump makes it possible to | |
57 | identify the build ID bits in the file, without paying the i/o | |
58 | cost and disk space to dump all the text. However, versions of | |
59 | GDB before 6.7 are confused by ELF core dump files in this format. | |
60 | ||
61 | The core dump behavior can be controlled per process using | |
62 | the /proc/PID/coredump_filter pseudo-file; this setting is | |
63 | inherited. See Documentation/filesystems/proc.txt for details. | |
64 | ||
65 | This config option changes the default setting of coredump_filter | |
89502155 | 66 | seen at boot time. If unsure, say Y. |
656eb2cd | 67 | |
1da177e4 | 68 | config BINFMT_FLAT |
3202e181 | 69 | bool "Kernel support for flat binaries" |
b8c141e8 | 70 | depends on !MMU && (!FRV || BROKEN) |
1da177e4 LT |
71 | help |
72 | Support uClinux FLAT format binaries. | |
73 | ||
74 | config BINFMT_ZFLAT | |
75 | bool "Enable ZFLAT support" | |
76 | depends on BINFMT_FLAT | |
77 | select ZLIB_INFLATE | |
78 | help | |
79 | Support FLAT format compressed binaries | |
80 | ||
81 | config BINFMT_SHARED_FLAT | |
82 | bool "Enable shared FLAT support" | |
83 | depends on BINFMT_FLAT | |
84 | help | |
85 | Support FLAT shared libraries | |
86 | ||
e17c6d56 DW |
87 | config HAVE_AOUT |
88 | def_bool n | |
89 | ||
1da177e4 LT |
90 | config BINFMT_AOUT |
91 | tristate "Kernel support for a.out and ECOFF binaries" | |
e17c6d56 | 92 | depends on HAVE_AOUT |
1da177e4 LT |
93 | ---help--- |
94 | A.out (Assembler.OUTput) is a set of formats for libraries and | |
95 | executables used in the earliest versions of UNIX. Linux used | |
96 | the a.out formats QMAGIC and ZMAGIC until they were replaced | |
97 | with the ELF format. | |
98 | ||
99 | The conversion to ELF started in 1995. This option is primarily | |
100 | provided for historical interest and for the benefit of those | |
101 | who need to run binaries from that era. | |
102 | ||
103 | Most people should answer N here. If you think you may have | |
104 | occasional use for this format, enable module support above | |
105 | and answer M here to compile this support as a module called | |
106 | binfmt_aout. | |
107 | ||
108 | If any crucial components of your system (such as /sbin/init | |
109 | or /lib/ld.so) are still in a.out format, you will have to | |
110 | say Y here. | |
111 | ||
112 | config OSF4_COMPAT | |
113 | bool "OSF/1 v4 readv/writev compatibility" | |
114 | depends on ALPHA && BINFMT_AOUT | |
115 | help | |
116 | Say Y if you are using OSF/1 binaries (like Netscape and Acrobat) | |
117 | with v4 shared libraries freely available from Compaq. If you're | |
118 | going to use shared libraries from Tru64 version 5.0 or later, say N. | |
119 | ||
120 | config BINFMT_EM86 | |
121 | tristate "Kernel support for Linux/Intel ELF binaries" | |
122 | depends on ALPHA | |
123 | ---help--- | |
124 | Say Y here if you want to be able to execute Linux/Intel ELF | |
125 | binaries just like native Alpha binaries on your Alpha machine. For | |
126 | this to work, you need to have the emulator /usr/bin/em86 in place. | |
127 | ||
128 | You can get the same functionality by saying N here and saying Y to | |
129 | "Kernel support for MISC binaries". | |
130 | ||
131 | You may answer M to compile the emulation support as a module and | |
132 | later load the module when you want to use a Linux/Intel binary. The | |
133 | module will be called binfmt_em86. If unsure, say Y. | |
134 | ||
135 | config BINFMT_SOM | |
136 | tristate "Kernel support for SOM binaries" | |
137 | depends on PARISC && HPUX | |
138 | help | |
139 | SOM is a binary executable format inherited from HP/UX. Say | |
140 | Y here to be able to load and execute SOM binaries directly. | |
141 | ||
142 | config BINFMT_MISC | |
143 | tristate "Kernel support for MISC binaries" | |
144 | ---help--- | |
145 | If you say Y here, it will be possible to plug wrapper-driven binary | |
146 | formats into the kernel. You will like this especially when you use | |
147 | programs that need an interpreter to run like Java, Python, .NET or | |
148 | Emacs-Lisp. It's also useful if you often run DOS executables under | |
149 | the Linux DOS emulator DOSEMU (read the DOSEMU-HOWTO, available from | |
150 | <http://www.tldp.org/docs.html#howto>). Once you have | |
151 | registered such a binary class with the kernel, you can start one of | |
152 | those programs simply by typing in its name at a shell prompt; Linux | |
153 | will automatically feed it to the correct interpreter. | |
154 | ||
155 | You can do other nice things, too. Read the file | |
156 | <file:Documentation/binfmt_misc.txt> to learn how to use this | |
157 | feature, <file:Documentation/java.txt> for information about how | |
158 | to include Java support. and <file:Documentation/mono.txt> for | |
159 | information about how to include Mono-based .NET support. | |
160 | ||
161 | To use binfmt_misc, you will need to mount it: | |
162 | mount binfmt_misc -t binfmt_misc /proc/sys/fs/binfmt_misc | |
163 | ||
164 | You may say M here for module support and later load the module when | |
165 | you have use for it; the module is called binfmt_misc. If you | |
166 | don't know what to answer at this point, say Y. |