]>
Commit | Line | Data |
---|---|---|
61952351 | 1 | Frequently Asked Questions about the GNU C Library |
f8cac037 | 2 | |
f12944ec UD |
3 | This document tries to answer questions a user might have when installing |
4 | and using glibc. Please make sure you read this before sending questions or | |
5 | bug reports to the maintainers. | |
f8cac037 | 6 | |
f12944ec | 7 | The GNU C library is very complex. The installation process has not been |
fdacb17d | 8 | completely automated; there are too many variables. You can do substantial |
f12944ec UD |
9 | damage to your system by installing the library incorrectly. Make sure you |
10 | understand what you are undertaking before you begin. | |
f8cac037 | 11 | |
41f27456 RM |
12 | If you have any questions you think should be answered in this document, |
13 | please let me know. | |
f8cac037 | 14 | |
934b77ac | 15 | --drepper@redhat.com |
f8cac037 | 16 | \f |
61952351 UD |
17 | ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ |
18 | ||
19 | 1. Compiling glibc | |
20 | ||
21 | 1.1. What systems does the GNU C Library run on? | |
22 | 1.2. What compiler do I need to build GNU libc? | |
23 | 1.3. When I try to compile glibc I get only error messages. | |
24 | What's wrong? | |
5edb9387 | 25 | 1.4. Do I need a special linker or assembler? |
8619129f | 26 | 1.5. Which compiler should I use for powerpc? |
348ed515 UD |
27 | 1.6. Which tools should I use for ARM? |
28 | 1.7. Do I need some more things to compile the GNU C Library? | |
29 | 1.8. What version of the Linux kernel headers should be used? | |
30 | 1.9. The compiler hangs while building iconvdata modules. What's | |
f12944ec | 31 | wrong? |
348ed515 | 32 | 1.10. When I run `nm -u libc.so' on the produced library I still |
61952351 | 33 | find unresolved symbols. Can this be ok? |
348ed515 UD |
34 | 1.11. What are these `add-ons'? |
35 | 1.12. My XXX kernel emulates a floating-point coprocessor for me. | |
61952351 | 36 | Should I enable --with-fp? |
348ed515 | 37 | 1.13. When compiling GNU libc I get lots of errors saying functions |
61952351 | 38 | in glibc are duplicated in libgcc. |
348ed515 | 39 | 1.14. Why do I get messages about missing thread functions when I use |
a35cb74d | 40 | librt? I don't even use threads. |
348ed515 | 41 | 1.15. What's the problem with configure --enable-omitfp? |
b1418d8f | 42 | 1.16. I get failures during `make check'. What should I do? |
348ed515 | 43 | 1.17. What is symbol versioning good for? Do I need it? |
c7f7281e UD |
44 | 1.18. How can I compile on my fast ix86 machine a working libc for my slow |
45 | i386? After installing libc, programs abort with "Illegal | |
46 | Instruction". | |
150ae521 UD |
47 | 1.19. `make' complains about a missing dlfcn/libdl.so when building |
48 | malloc/libmemprof.so. How can I fix this? | |
2c88f872 | 49 | 1.20. Which tools should I use for MIPS? |
dfc89273 | 50 | 1.21. Which compiler should I use for powerpc64? |
9cb97cd4 RM |
51 | 1.22. `make' fails when running rpcgen the first time, |
52 | what is going on? How do I fix this? | |
268dbf25 AJ |
53 | 1.23. Why do I get: |
54 | `#error "glibc cannot be compiled without optimization"', | |
55 | when trying to compile GNU libc with GNU CC? | |
61952351 UD |
56 | |
57 | 2. Installation and configuration issues | |
58 | ||
59 | 2.1. Can I replace the libc on my Linux system with GNU libc? | |
60 | 2.2. How do I configure GNU libc so that the essential libraries | |
61 | like libc.so go into /lib and the other into /usr/lib? | |
62 | 2.3. How should I avoid damaging my system when I install GNU libc? | |
63 | 2.4. Do I need to use GNU CC to compile programs that will use the | |
64 | GNU C Library? | |
65 | 2.5. When linking with the new libc I get unresolved symbols | |
66 | `crypt' and `setkey'. Why aren't these functions in the | |
67 | libc anymore? | |
68 | 2.6. When I use GNU libc on my Linux system by linking against | |
69 | the libc.so which comes with glibc all I get is a core dump. | |
70 | 2.7. Looking through the shared libc file I haven't found the | |
71 | functions `stat', `lstat', `fstat', and `mknod' and while | |
72 | linking on my Linux system I get error messages. How is | |
73 | this supposed to work? | |
5edb9387 UD |
74 | 2.8. When I run an executable on one system which I compiled on |
75 | another, I get dynamic linker errors. Both systems have the same | |
76 | version of glibc installed. What's wrong? | |
77 | 2.9. How can I compile gcc 2.7.2.1 from the gcc source code using | |
61952351 | 78 | glibc 2.x? |
5edb9387 | 79 | 2.10. The `gencat' utility cannot process the catalog sources which |
61952351 | 80 | were used on my Linux libc5 based system. Why? |
5edb9387 | 81 | 2.11. Programs using libc have their messages translated, but other |
a35cb74d | 82 | behavior is not localized (e.g. collating order); why? |
5edb9387 | 83 | 2.12. I have set up /etc/nis.conf, and the Linux libc 5 with NYS |
61952351 | 84 | works great. But the glibc NIS+ doesn't seem to work. |
5edb9387 | 85 | 2.13. I have killed ypbind to stop using NIS, but glibc |
3dcf8ea6 | 86 | continues using NIS. |
5edb9387 | 87 | 2.14. Under Linux/Alpha, I always get "do_ypcall: clnt_call: |
3dcf8ea6 | 88 | RPC: Unable to receive; errno = Connection refused" when using NIS. |
5edb9387 UD |
89 | 2.15. After installing glibc name resolving doesn't work properly. |
90 | 2.16. How do I create the databases for NSS? | |
91 | 2.17. I have /usr/include/net and /usr/include/scsi as symlinks | |
61952351 | 92 | into my Linux source tree. Is that wrong? |
5edb9387 | 93 | 2.18. Programs like `logname', `top', `uptime' `users', `w' and |
61952351 UD |
94 | `who', show incorrect information about the (number of) |
95 | users on my system. Why? | |
5edb9387 | 96 | 2.19. After upgrading to glibc 2.1 with symbol versioning I get |
61952351 | 97 | errors about undefined symbols. What went wrong? |
5edb9387 | 98 | 2.20. When I start the program XXX after upgrading the library |
61952351 UD |
99 | I get |
100 | XXX: Symbol `_sys_errlist' has different size in shared | |
101 | object, consider re-linking | |
102 | Why? What should I do? | |
5edb9387 UD |
103 | 2.21. What do I need for C++ development? |
104 | 2.22. Even statically linked programs need some shared libraries | |
ff44f2a5 | 105 | which is not acceptable for me. What can I do? |
5edb9387 | 106 | 2.23. I just upgraded my Linux system to glibc and now I get |
fdacb17d | 107 | errors whenever I try to link any program. |
5edb9387 | 108 | 2.24. When I use nscd the machine freezes. |
0155a773 | 109 | 2.25. I need lots of open files. What do I have to do? |
7db169c9 UD |
110 | 2.26. How do I get the same behavior on parsing /etc/passwd and |
111 | /etc/group as I have with libc5 ? | |
b710a6e2 UD |
112 | 2.27. What needs to be recompiled when upgrading from glibc 2.0 to glibc |
113 | 2.1? | |
b7398be5 | 114 | 2.28. Why is extracting files via tar so slow? |
2ee511d9 UD |
115 | 2.29. Compiling programs I get parse errors in libio.h (e.g. "parse error |
116 | before `_IO_seekoff'"). How should I fix this? | |
4f7ea427 UD |
117 | 2.30. After upgrading to glibc 2.1, libraries that were compiled against |
118 | glibc 2.0.x don't work anymore. | |
9de4e203 UD |
119 | 2.31. What happened to the Berkeley DB libraries? Can I still use db |
120 | in /etc/nsswitch.conf? | |
2c88f872 | 121 | 2.32. What has do be done when upgrading to glibc 2.2? |
4442d7e8 | 122 | 2.33. The makefiles want to do a CVS commit. |
1324affa UD |
123 | 2.34. When compiling C++ programs, I get a compilation error in streambuf.h. |
124 | 2.35. When recompiling GCC, I get compilation errors in libio. | |
934b77ac UD |
125 | 2.36. Why shall glibc never get installed on GNU/Linux systems in |
126 | /usr/local? | |
4011dc70 | 127 | 2.37. When recompiling GCC, I get compilation errors in libstdc++. |
61952351 UD |
128 | |
129 | 3. Source and binary incompatibilities, and what to do about them | |
130 | ||
131 | 3.1. I expect GNU libc to be 100% source code compatible with | |
132 | the old Linux based GNU libc. Why isn't it like this? | |
133 | 3.2. Why does getlogin() always return NULL on my Linux box? | |
134 | 3.3. Where are the DST_* constants found in <sys/time.h> on many | |
135 | systems? | |
136 | 3.4. The prototypes for `connect', `accept', `getsockopt', | |
137 | `setsockopt', `getsockname', `getpeername', `send', | |
138 | `sendto', and `recvfrom' are different in GNU libc from | |
139 | any other system I saw. This is a bug, isn't it? | |
140 | 3.5. On Linux I've got problems with the declarations in Linux | |
141 | kernel headers. | |
142 | 3.6. I don't include any kernel headers myself but the compiler | |
143 | still complains about redeclarations of types in the kernel | |
144 | headers. | |
145 | 3.7. Why don't signals interrupt system calls anymore? | |
146 | 3.8. I've got errors compiling code that uses certain string | |
147 | functions. Why? | |
4775243a UD |
148 | 3.9. I get compiler messages "Initializer element not constant" with |
149 | stdin/stdout/stderr. Why? | |
150 | 3.10. I can't compile with gcc -traditional (or | |
151 | -traditional-cpp). Why? | |
152 | 3.11. I get some errors with `gcc -ansi'. Isn't glibc ANSI compatible? | |
a35cb74d UD |
153 | 3.12. I can't access some functions anymore. nm shows that they do |
154 | exist but linking fails nevertheless. | |
a5f4e34a UD |
155 | 3.13. When using the db-2 library which comes with glibc is used in |
156 | the Perl db modules the testsuite is not passed. This did not | |
157 | happen with db-1, gdbm, or ndbm. | |
5148d49f UD |
158 | 3.14. The pow() inline function I get when including <math.h> is broken. |
159 | I get segmentation faults when I run the program. | |
05f732b3 | 160 | 3.15. The sys/sem.h file lacks the definition of `union semun'. |
33127459 | 161 | 3.16. Why has <netinet/ip_fw.h> disappeared? |
28ab8526 UD |
162 | 3.17. I get floods of warnings when I use -Wconversion and include |
163 | <string.h> or <math.h>. | |
5ff1a70a UD |
164 | 3.18. After upgrading to glibc 2.1, I receive errors about |
165 | unresolved symbols, like `_dl_initial_searchlist' and can not | |
166 | execute any binaries. What went wrong? | |
7d1de115 UD |
167 | 3.19. bonnie reports that char i/o with glibc 2 is much slower than with |
168 | libc5. What can be done? | |
b93492aa UD |
169 | 3.20. Programs compiled with glibc 2.1 can't read db files made with glibc |
170 | 2.0. What has changed that programs like rpm break? | |
b5a9efcd UD |
171 | 3.21. Autoconf's AC_CHECK_FUNC macro reports that a function exists, but |
172 | when I try to use it, it always returns -1 and sets errno to ENOSYS. | |
173 | 3.22. My program segfaults when I call fclose() on the FILE* returned | |
174 | from setmntent(). Is this a glibc bug? | |
c891b2df | 175 | 3.23. I get "undefined reference to `atexit'" |
61952351 | 176 | |
7d1de115 | 177 | 4. Miscellaneous |
61952351 | 178 | |
7d1de115 | 179 | 4.1. After I changed configure.in I get `Autoconf version X.Y. |
61952351 | 180 | or higher is required for this script'. What can I do? |
7d1de115 | 181 | 4.2. When I try to compile code which uses IPv6 headers and |
61952351 UD |
182 | definitions on my Linux 2.x.y system I am in trouble. |
183 | Nothing seems to work. | |
7d1de115 | 184 | 4.3. When I set the timezone by setting the TZ environment variable |
ff44f2a5 UD |
185 | to EST5EDT things go wrong since glibc computes the wrong time |
186 | from this information. | |
7d1de115 UD |
187 | 4.4. What other sources of documentation about glibc are available? |
188 | 4.5. The timezone string for Sydney/Australia is wrong since even when | |
348ed515 | 189 | daylight saving time is in effect the timezone string is EST. |
7d1de115 | 190 | 4.6. I've build make 3.77 against glibc 2.1 and now make gets |
eeabe877 | 191 | segmentation faults. |
c63598bf | 192 | 4.7. Why do so many programs using math functions fail on my AlphaStation? |
8892c471 UD |
193 | 4.8. The conversion table for character set XX does not match with |
194 | what I expect. | |
be76803a | 195 | 4.9. How can I find out which version of glibc I am using in the moment? |
5e014387 UD |
196 | 4.10. Context switching with setcontext() does not work from within |
197 | signal handlers. | |
f8cac037 | 198 | |
61952351 UD |
199 | \f |
200 | ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ | |
f4017d20 | 201 | |
61952351 | 202 | 1. Compiling glibc |
04be94a8 | 203 | |
61952351 | 204 | 1.1. What systems does the GNU C Library run on? |
613a76ff | 205 | |
f12944ec UD |
206 | {UD} This is difficult to answer. The file `README' lists the architectures |
207 | GNU libc was known to run on *at some time*. This does not mean that it | |
208 | still can be compiled and run on them now. | |
f8cac037 | 209 | |
f12944ec UD |
210 | The systems glibc is known to work on as of this release, and most probably |
211 | in the future, are: | |
f8cac037 RM |
212 | |
213 | *-*-gnu GNU Hurd | |
4775243a UD |
214 | i[3456]86-*-linux-gnu Linux-2.x on Intel |
215 | m68k-*-linux-gnu Linux-2.x on Motorola 680x0 | |
2bbc70d5 | 216 | alpha*-*-linux-gnu Linux-2.x on DEC Alpha |
9a0a462c | 217 | powerpc-*-linux-gnu Linux and MkLinux on PowerPC systems |
dfc89273 | 218 | powerpc64-*-linux-gnu Linux-2.4+ on 64-bit PowerPC systems |
4775243a UD |
219 | sparc-*-linux-gnu Linux-2.x on SPARC |
220 | sparc64-*-linux-gnu Linux-2.x on UltraSPARC | |
ff44f2a5 | 221 | arm-*-none ARM standalone systems |
348ed515 | 222 | arm-*-linux Linux-2.x on ARM |
ff44f2a5 | 223 | arm-*-linuxaout Linux-2.x on ARM using a.out binaries |
2bbc70d5 AJ |
224 | mips*-*-linux-gnu Linux-2.x on MIPS |
225 | ia64-*-linux-gnu Linux-2.x on ia64 | |
2c88f872 | 226 | s390-*-linux-gnu Linux-2.x on IBM S/390 |
4a5b72ff | 227 | s390x-*-linux-gnu Linux-2.x on IBM S/390 64-bit |
eacde9d0 | 228 | cris-*-linux-gnu Linux-2.4+ on CRIS |
f8cac037 | 229 | |
f12944ec UD |
230 | Ports to other Linux platforms are in development, and may in fact work |
231 | already, but no one has sent us success reports for them. Currently no | |
232 | ports to other operating systems are underway, although a few people have | |
233 | expressed interest. | |
f8cac037 | 234 | |
f12944ec | 235 | If you have a system not listed above (or in the `README' file) and you are |
65903cc5 RM |
236 | really interested in porting it, see the GNU C Library web pages to learn |
237 | how to start contributing: | |
f8cac037 | 238 | |
65903cc5 | 239 | http://www.gnu.org/software/libc/resources.html |
f8cac037 RM |
240 | |
241 | ||
61952351 | 242 | 1.2. What compiler do I need to build GNU libc? |
f8cac037 | 243 | |
f12944ec UD |
244 | {UD} You must use GNU CC to compile GNU libc. A lot of extensions of GNU CC |
245 | are used to increase portability and speed. | |
f8cac037 | 246 | |
61952351 | 247 | GNU CC is found, like all other GNU packages, on |
f12944ec | 248 | |
a35cb74d | 249 | ftp://ftp.gnu.org/pub/gnu |
f12944ec | 250 | |
a35cb74d | 251 | and the many mirror sites. ftp.gnu.org is always overloaded, so try to find |
61952351 | 252 | a local mirror first. |
f8cac037 | 253 | |
b0610668 | 254 | You should always try to use the latest official release. Older versions |
f12944ec | 255 | may not have all the features GNU libc requires. The current releases of |
4011dc70 | 256 | gcc (3.2 or newer) should work with the GNU C library (for MIPS see question 1.20). |
f8cac037 | 257 | |
6e8afc1c | 258 | Please note that gcc 2.95 and 2.95.x cannot compile glibc on Alpha due to |
bd952512 UD |
259 | problems in the complex float support. |
260 | ||
f8cac037 | 261 | |
61952351 UD |
262 | 1.3. When I try to compile glibc I get only error messages. |
263 | What's wrong? | |
f8cac037 | 264 | |
b1418d8f | 265 | {UD} You definitely need GNU make to build GNU libc. No other make |
f12944ec | 266 | program has the needed functionality. |
f8cac037 | 267 | |
2bbc70d5 AJ |
268 | We recommend version GNU make version 3.79 or newer. Older versions have |
269 | bugs and/or are missing features. | |
f8cac037 | 270 | |
f8cac037 | 271 | |
5edb9387 | 272 | 1.4. Do I need a special linker or assembler? |
f8cac037 | 273 | |
5edb9387 UD |
274 | {ZW} If you want a shared library, you need a linker and assembler that |
275 | understand all the features of ELF, including weak and versioned symbols. | |
276 | The static library can be compiled with less featureful tools, but lacks key | |
277 | features such as NSS. | |
41f27456 | 278 | |
1e2fb683 | 279 | For Linux or Hurd, you want binutils 2.13 or higher. These are the only |
b0ed91ae AJ |
280 | versions we've tested and found reliable. Other versions may work but we |
281 | don't recommend them, especially not when C++ is involved. | |
a379e56a | 282 | |
5edb9387 UD |
283 | Other operating systems may come with system tools that have all the |
284 | necessary features, but this is moot because glibc hasn't been ported to | |
285 | them. | |
f8cac037 | 286 | |
f8cac037 | 287 | |
8619129f | 288 | 1.5. Which compiler should I use for powerpc? |
4775243a | 289 | |
4011dc70 | 290 | {} Removed. Does not apply anymore. |
4775243a UD |
291 | |
292 | ||
348ed515 UD |
293 | 1.6. Which tools should I use for ARM? |
294 | ||
4011dc70 | 295 | {} Removed. Does not apply anymore. |
348ed515 UD |
296 | |
297 | ||
298 | 1.7. Do I need some more things to compile the GNU C Library? | |
f8cac037 | 299 | |
61952351 | 300 | {UD} Yes, there are some more :-). |
78b5ba3e | 301 | |
61952351 UD |
302 | * GNU gettext. This package contains the tools needed to construct |
303 | `message catalog' files containing translated versions of system | |
a35cb74d | 304 | messages. See ftp://ftp.gnu.org/pub/gnu or better any mirror |
61952351 | 305 | site. (We distribute compiled message catalogs, but they may not be |
c26b4f64 | 306 | updated in patches.) |
f8cac037 | 307 | |
5edb9387 UD |
308 | * Some files are built with special tools. E.g., files ending in .gperf |
309 | need a `gperf' program. The GNU version (now available in a separate | |
310 | package, formerly only as part of libg++) is known to work while some | |
311 | vendor versions do not. | |
f8cac037 | 312 | |
61952351 | 313 | You should not need these tools unless you change the source files. |
1f205a47 | 314 | |
5edb9387 UD |
315 | * Perl 5 is needed if you wish to test an installation of GNU libc |
316 | as the primary C library. | |
4775243a | 317 | |
61952351 UD |
318 | * When compiling for Linux, the header files of the Linux kernel must |
319 | be available to the compiler as <linux/*.h> and <asm/*.h>. | |
f8cac037 | 320 | |
02228370 | 321 | * lots of disk space (~400MB for i?86-linux; more for RISC platforms). |
af6f3906 | 322 | |
61952351 | 323 | * plenty of time. Compiling just the shared and static libraries for |
bb2fc850 UD |
324 | 35mins on a 2xPIII@550Mhz w/ 512MB RAM. On a 2xUltraSPARC-II@360Mhz |
325 | w/ 1GB RAM it takes about 14 minutes. Multiply this by 1.5 or 2.0 | |
326 | if you build profiling and/or the highly optimized version as well. | |
327 | For Hurd systems times are much higher. | |
f8cac037 | 328 | |
61952351 UD |
329 | You should avoid compiling in a NFS mounted filesystem. This is |
330 | very slow. | |
0200214b | 331 | |
bb2fc850 UD |
332 | James Troup <J.J.Troup@comp.brad.ac.uk> reports a compile time for |
333 | an earlier (and smaller!) version of glibc of 45h34m for a full build | |
334 | (shared, static, and profiled) on Atari Falcon (Motorola 68030 @ 16 Mhz, | |
335 | 14 Mb memory) and Jan Barte <yann@plato.uni-paderborn.de> reports | |
336 | 22h48m on Atari TT030 (Motorola 68030 @ 32 Mhz, 34 Mb memory) | |
0200214b | 337 | |
83f6a990 | 338 | A full build of the PowerPC library took 1h on a PowerPC 750@400Mhz w/ |
6e8afc1c | 339 | 64MB of RAM, and about 9h on a 601@60Mhz w/ 72Mb. |
83f6a990 | 340 | |
ba1ffaa1 | 341 | |
348ed515 | 342 | 1.8. What version of the Linux kernel headers should be used? |
a35cb74d | 343 | |
f12944ec UD |
344 | {AJ,UD} The headers from the most recent Linux kernel should be used. The |
345 | headers used while compiling the GNU C library and the kernel binary used | |
346 | when using the library do not need to match. The GNU C library runs without | |
347 | problems on kernels that are older than the kernel headers used. The other | |
348 | way round (compiling the GNU C library with old kernel headers and running | |
349 | on a recent kernel) does not necessarily work. For example you can't use | |
b1418d8f | 350 | new kernel features if you used old kernel headers to compile the GNU C |
f12944ec UD |
351 | library. |
352 | ||
b0610668 | 353 | {ZW} Even if you are using a 2.0 kernel on your machine, we recommend you |
b710a6e2 UD |
354 | compile GNU libc with 2.2 kernel headers. That way you won't have to |
355 | recompile libc if you ever upgrade to kernel 2.2. To tell libc which | |
b0610668 | 356 | headers to use, give configure the --with-headers switch |
b710a6e2 | 357 | (e.g. --with-headers=/usr/src/linux-2.2.0/include). |
b0610668 | 358 | |
b710a6e2 | 359 | Note that you must configure the 2.2 kernel if you do this, otherwise libc |
62595351 | 360 | will be unable to find <linux/version.h>. Just change the current directory |
b710a6e2 | 361 | to the root of the 2.2 tree and do `make include/linux/version.h'. |
b0610668 | 362 | |
f12944ec | 363 | |
348ed515 | 364 | 1.9. The compiler hangs while building iconvdata modules. What's |
f12944ec UD |
365 | wrong? |
366 | ||
bb2fc850 | 367 | {} Removed. Does not apply anymore. |
a35cb74d | 368 | |
f12944ec | 369 | |
348ed515 | 370 | 1.10. When I run `nm -u libc.so' on the produced library I still |
61952351 | 371 | find unresolved symbols. Can this be ok? |
f8cac037 | 372 | |
f12944ec | 373 | {UD} Yes, this is ok. There can be several kinds of unresolved symbols: |
f8cac037 | 374 | |
61952351 UD |
375 | * magic symbols automatically generated by the linker. These have names |
376 | like __start_* and __stop_* | |
f8cac037 | 377 | |
78b5ba3e RM |
378 | * symbols starting with _dl_* come from the dynamic linker |
379 | ||
61952351 | 380 | * weak symbols, which need not be resolved at all (fabs for example) |
f8cac037 RM |
381 | |
382 | Generally, you should make sure you find a real program which produces | |
41f27456 | 383 | errors while linking before deciding there is a problem. |
f8cac037 RM |
384 | |
385 | ||
348ed515 | 386 | 1.11. What are these `add-ons'? |
999493cb | 387 | |
f12944ec | 388 | {UD} To avoid complications with export rules or external source code some |
b669ab02 UD |
389 | optional parts of the libc are distributed as separate packages, e.g., the |
390 | linuxthreads package. | |
999493cb | 391 | |
f12944ec UD |
392 | To use these packages as part of GNU libc, just unpack the tarfiles in the |
393 | libc source directory and tell the configuration script about them using the | |
394 | --enable-add-ons option. If you give just --enable-add-ons configure tries | |
395 | to find all the add-on packages in your source tree. This may not work. If | |
396 | it doesn't, or if you want to select only a subset of the add-ons, give a | |
397 | comma-separated list of the add-ons to enable: | |
613a76ff | 398 | |
b669ab02 | 399 | configure --enable-add-ons=linuxthreads |
41f27456 | 400 | |
61952351 | 401 | for example. |
0200214b | 402 | |
f12944ec UD |
403 | Add-ons can add features (including entirely new shared libraries), override |
404 | files, provide support for additional architectures, and just about anything | |
405 | else. The existing makefiles do most of the work; only some few stub rules | |
406 | must be written to get everything running. | |
613a76ff | 407 | |
bd952512 | 408 | Most add-ons are tightly coupled to a specific GNU libc version. Please |
b669ab02 UD |
409 | check that the add-ons work with the GNU libc. For example the linuxthreads |
410 | add-on has the same numbering scheme as the libc and will in general only | |
411 | work with the corresponding libc. | |
412 | ||
413 | {AJ} With glibc 2.2 the crypt add-on and with glibc 2.1 the localedata | |
414 | add-on have been integrated into the normal glibc distribution, crypt and | |
415 | localedata are therefore not anymore add-ons. | |
bd952512 | 416 | |
613a76ff | 417 | |
348ed515 | 418 | 1.12. My XXX kernel emulates a floating-point coprocessor for me. |
61952351 | 419 | Should I enable --with-fp? |
613a76ff | 420 | |
f12944ec UD |
421 | {ZW} An emulated FPU is just as good as a real one, as far as the C library |
422 | is concerned. You only need to say --without-fp if your machine has no way | |
423 | to execute floating-point instructions. | |
f8cac037 | 424 | |
61952351 UD |
425 | People who are interested in squeezing the last drop of performance |
426 | out of their machine may wish to avoid the trap overhead, but this is | |
427 | far more trouble than it's worth: you then have to compile | |
428 | *everything* this way, including the compiler's internal libraries | |
429 | (libgcc.a for GNU C), because the calling conventions change. | |
a1470b6f | 430 | |
999493cb | 431 | |
348ed515 | 432 | 1.13. When compiling GNU libc I get lots of errors saying functions |
61952351 | 433 | in glibc are duplicated in libgcc. |
5290baf0 | 434 | |
f12944ec UD |
435 | {EY} This is *exactly* the same problem that I was having. The problem was |
436 | due to the fact that configure didn't correctly detect that the linker flag | |
437 | --no-whole-archive was supported in my linker. In my case it was because I | |
438 | had run ./configure with bogus CFLAGS, and the test failed. | |
78b5ba3e | 439 | |
f12944ec UD |
440 | One thing that is particularly annoying about this problem is that once this |
441 | is misdetected, running configure again won't fix it unless you first delete | |
442 | config.cache. | |
78b5ba3e | 443 | |
f12944ec UD |
444 | {UD} Starting with glibc-2.0.3 there should be a better test to avoid some |
445 | problems of this kind. The setting of CFLAGS is checked at the very | |
446 | beginning and if it is not usable `configure' will bark. | |
78b5ba3e | 447 | |
af6f3906 | 448 | |
348ed515 | 449 | 1.14. Why do I get messages about missing thread functions when I use |
a35cb74d | 450 | librt? I don't even use threads. |
4775243a | 451 | |
a35cb74d UD |
452 | {UD} In this case you probably mixed up your installation. librt uses |
453 | threads internally and has implicit references to the thread library. | |
f12944ec UD |
454 | Normally these references are satisfied automatically but if the thread |
455 | library is not in the expected place you must tell the linker where it is. | |
456 | When using GNU ld it works like this: | |
4775243a UD |
457 | |
458 | gcc -o foo foo.c -Wl,-rpath-link=/some/other/dir -lrt | |
459 | ||
f12944ec UD |
460 | The `/some/other/dir' should contain the thread library. `ld' will use the |
461 | given path to find the implicitly referenced library while not disturbing | |
462 | any other link path. | |
4775243a UD |
463 | |
464 | ||
348ed515 | 465 | 1.15. What's the problem with configure --enable-omitfp? |
78b5ba3e | 466 | |
61952351 | 467 | {AJ} When --enable-omitfp is set the libraries are built without frame |
fdacb17d | 468 | pointers. Some compilers produce buggy code for this model and therefore we |
f12944ec | 469 | don't advise using it at the moment. |
66219c07 | 470 | |
fdacb17d | 471 | If you use --enable-omitfp, you're on your own. If you encounter problems |
f12944ec UD |
472 | with a library that was build this way, we advise you to rebuild the library |
473 | without --enable-omitfp. If the problem vanishes consider tracking the | |
474 | problem down and report it as compiler failure. | |
66219c07 | 475 | |
b1418d8f UD |
476 | Since a library built with --enable-omitfp is undebuggable on most systems, |
477 | debuggable libraries are also built - you can use them by appending "_g" to | |
f12944ec | 478 | the library names. |
66219c07 | 479 | |
f12944ec UD |
480 | The compilation of these extra libraries and the compiler optimizations slow |
481 | down the build process and need more disk space. | |
66219c07 | 482 | |
b0610668 | 483 | |
b1418d8f | 484 | 1.16. I get failures during `make check'. What should I do? |
b0610668 | 485 | |
b1418d8f UD |
486 | {AJ} The testsuite should compile and run cleanly on your system; every |
487 | failure should be looked into. Depending on the failures, you probably | |
488 | should not install the library at all. | |
b0610668 | 489 | |
268dbf25 AJ |
490 | You should consider reporting it in bugzilla |
491 | <http://sourceware.org/bugzilla/> providing as much detail as possible. | |
492 | If you run a test directly, please remember to set up the environment | |
493 | correctly. You want to test the compiled library - and not your installed | |
494 | one. The best way is to copy the exact command line which failed and run | |
495 | the test from the subdirectory for this test in the sources. | |
b0610668 UD |
496 | |
497 | There are some failures which are not directly related to the GNU libc: | |
b1418d8f | 498 | - Some compilers produce buggy code. No compiler gets single precision |
4011dc70 | 499 | complex numbers correct on Alpha. Otherwise, gcc-3.2 should be ok. |
b0610668 UD |
500 | - The kernel might have bugs. For example on Linux/Alpha 2.0.34 the |
501 | floating point handling has quite a number of bugs and therefore most of | |
b710a6e2 | 502 | the test cases in the math subdirectory will fail. Linux 2.2 has |
b1418d8f UD |
503 | fixes for the floating point support on Alpha. The Linux/SPARC kernel has |
504 | also some bugs in the FPU emulation code (as of Linux 2.2.0). | |
d32a4020 UD |
505 | - Other tools might have problems. For example bash 2.03 gives a |
506 | segmentation fault running the tst-rpmatch.sh test script. | |
b0610668 | 507 | |
a379e56a | 508 | |
348ed515 | 509 | 1.17. What is symbol versioning good for? Do I need it? |
a379e56a UD |
510 | |
511 | {AJ} Symbol versioning solves problems that are related to interface | |
512 | changes. One version of an interface might have been introduced in a | |
513 | previous version of the GNU C library but the interface or the semantics of | |
514 | the function has been changed in the meantime. For binary compatibility | |
515 | with the old library, a newer library needs to still have the old interface | |
b1418d8f | 516 | for old programs. On the other hand, new programs should use the new |
a379e56a | 517 | interface. Symbol versioning is the solution for this problem. The GNU |
b1418d8f UD |
518 | libc version 2.1 uses symbol versioning by default if the installed binutils |
519 | supports it. | |
a379e56a | 520 | |
b1418d8f UD |
521 | We don't advise building without symbol versioning, since you lose binary |
522 | compatibility - forever! The binary compatibility you lose is not only | |
523 | against the previous version of the GNU libc (version 2.0) but also against | |
524 | all future versions. | |
a379e56a | 525 | |
c7f7281e UD |
526 | |
527 | 1.18. How can I compile on my fast ix86 machine a working libc for my slow | |
528 | i386? After installing libc, programs abort with "Illegal | |
529 | Instruction". | |
530 | ||
531 | {AJ} glibc and gcc might generate some instructions on your machine that | |
532 | aren't available on i386. You've got to tell glibc that you're configuring | |
533 | for i386 with adding i386 as your machine, for example: | |
534 | ||
535 | ../configure --prefix=/usr i386-pc-linux-gnu | |
536 | ||
537 | And you need to tell gcc to only generate i386 code, just add `-mcpu=i386' | |
538 | (just -m386 doesn't work) to your CFLAGS. | |
539 | ||
540 | {UD} This applies not only to the i386. Compiling on a i686 for any older | |
541 | model will also fail if the above methods are not used. | |
542 | ||
150ae521 UD |
543 | |
544 | 1.19. `make' complains about a missing dlfcn/libdl.so when building | |
545 | malloc/libmemprof.so. How can I fix this? | |
546 | ||
547 | {AJ} Older make version (<= 3.78.90) have a bug which was hidden by a bug in | |
2bbc70d5 | 548 | glibc (<= 2.1.2). You need to upgrade make to a newer or fixed version. |
150ae521 UD |
549 | |
550 | After upgrading make, you should remove the file sysd-sorted in your build | |
551 | directory. The problem is that the broken make creates a wrong order for | |
552 | one list in that file. The list has to be recreated with the new make - | |
553 | which happens if you remove the file. | |
554 | ||
555 | You might encounter this bug also in other situations where make scans | |
2bbc70d5 AJ |
556 | directories. I strongly advise to upgrade your make version to 3.79 or |
557 | newer. | |
150ae521 | 558 | |
2c88f872 AJ |
559 | |
560 | 1.20. Which tools should I use for MIPS? | |
561 | ||
4011dc70 UD |
562 | {AJ} You should use the current development version of gcc 3.2 or newer from |
563 | CVS. | |
2c88f872 | 564 | |
02eca23b AJ |
565 | You need also recent binutils, anything before and including 2.11 will not |
566 | work correctly. Either try the Linux binutils 2.11.90.0.5 from HJ Lu or the | |
7e5fc672 AJ |
567 | current development version of binutils from CVS. |
568 | ||
569 | Please note that `make check' might fail for a number of the math tests | |
570 | because of problems of the FPU emulation in the Linux kernel (the MIPS FPU | |
571 | doesn't handle all cases and needs help from the kernel). | |
2c88f872 | 572 | |
dfc89273 UD |
573 | |
574 | 1.21. Which compiler should I use for powerpc64? | |
575 | ||
576 | {SM} You want to use at least gcc 3.2 (together with the right versions | |
577 | of all the other tools, of course). | |
578 | ||
9cb97cd4 RM |
579 | |
580 | 1.22. `make' fails when running rpcgen the first time, | |
581 | what is going on? How do I fix this? | |
582 | ||
583 | {CO} The first invocation of rpcgen is also the first use of the recently | |
584 | compiled dynamic loader. If there is any problem with the dynamic loader | |
585 | it will more than likely fail to run rpcgen properly. This could be due to | |
586 | any number of problems. | |
587 | ||
588 | The only real solution is to debug the loader and determine the problem | |
589 | yourself. Please remember that for each architecture there may be various | |
590 | patches required to get glibc HEAD into a runnable state. The best course | |
591 | of action is to determine if you have all the required patches. | |
592 | ||
268dbf25 AJ |
593 | |
594 | 1.23. Why do I get: | |
595 | `#error "glibc cannot be compiled without optimization"', | |
596 | when trying to compile GNU libc with GNU CC? | |
597 | ||
598 | {AJ,CO} There are a couple of reasons why the GNU C library will not work | |
599 | correctly if it is not complied with optimzation. | |
600 | ||
601 | In the early startup of the dynamic loader (_dl_start), before | |
602 | relocation of the PLT, you cannot make function calls. You must inline | |
603 | the functions you will use during early startup, or call compiler | |
604 | builtins (__builtin_*). | |
605 | ||
606 | Without optimizations enabled GNU CC will not inline functions. The | |
607 | early startup of the dynamic loader will make function calls via an | |
608 | unrelocated PLT and crash. | |
609 | ||
610 | Without auditing the dynamic linker code it would be difficult to remove | |
611 | this requirement. | |
612 | ||
613 | Another reason is that nested functions must be inlined in many cases to | |
614 | avoid executable stacks. | |
615 | ||
616 | In practice there is no reason to compile without optimizations, therefore | |
617 | we require that GNU libc be compiled with optimizations enabled. | |
618 | ||
61952351 UD |
619 | \f |
620 | . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . | |
e6c9a67a | 621 | |
61952351 | 622 | 2. Installation and configuration issues |
e6c9a67a | 623 | |
61952351 | 624 | 2.1. Can I replace the libc on my Linux system with GNU libc? |
e6c9a67a | 625 | |
f12944ec UD |
626 | {UD} You cannot replace any existing libc for Linux with GNU libc. It is |
627 | binary incompatible and therefore has a different major version. You can, | |
628 | however, install it alongside your existing libc. | |
e6c9a67a | 629 | |
61952351 UD |
630 | For Linux there are three major libc versions: |
631 | libc-4 a.out libc | |
632 | libc-5 original ELF libc | |
633 | libc-6 GNU libc | |
e6c9a67a | 634 | |
f12944ec UD |
635 | You can have any combination of these three installed. For more information |
636 | consult documentation for shared library handling. The Makefiles of GNU | |
637 | libc will automatically generate the needed symbolic links which the linker | |
638 | will use. | |
e6c9a67a RM |
639 | |
640 | ||
61952351 UD |
641 | 2.2. How do I configure GNU libc so that the essential libraries |
642 | like libc.so go into /lib and the other into /usr/lib? | |
ec42724d | 643 | |
61952351 UD |
644 | {UD,AJ} Like all other GNU packages GNU libc is designed to use a base |
645 | directory and install all files relative to this. The default is | |
f12944ec UD |
646 | /usr/local, because this is safe (it will not damage the system if installed |
647 | there). If you wish to install GNU libc as the primary C library on your | |
648 | system, set the base directory to /usr (i.e. run configure --prefix=/usr | |
649 | <other_options>). Note that this can damage your system; see question 2.3 for | |
650 | details. | |
651 | ||
652 | Some systems like Linux have a filesystem standard which makes a difference | |
653 | between essential libraries and others. Essential libraries are placed in | |
654 | /lib because this directory is required to be located on the same disk | |
655 | partition as /. The /usr subtree might be found on another | |
656 | partition/disk. If you configure for Linux with --prefix=/usr, then this | |
657 | will be done automatically. | |
ec42724d | 658 | |
61952351 | 659 | To install the essential libraries which come with GNU libc in /lib on |
f12944ec UD |
660 | systems other than Linux one must explicitly request it. Autoconf has no |
661 | option for this so you have to use a `configparms' file (see the `INSTALL' | |
662 | file for details). It should contain: | |
ec42724d RM |
663 | |
664 | slibdir=/lib | |
665 | sysconfdir=/etc | |
666 | ||
f12944ec UD |
667 | The first line specifies the directory for the essential libraries, the |
668 | second line the directory for system configuration files. | |
ec42724d | 669 | |
5290baf0 | 670 | |
61952351 | 671 | 2.3. How should I avoid damaging my system when I install GNU libc? |
ec42724d | 672 | |
f12944ec UD |
673 | {ZW} If you wish to be cautious, do not configure with --prefix=/usr. If |
674 | you don't specify a prefix, glibc will be installed in /usr/local, where it | |
675 | will probably not break anything. (If you wish to be certain, set the | |
676 | prefix to something like /usr/local/glibc2 which is not used for anything.) | |
845dcb57 | 677 | |
61952351 | 678 | The dangers when installing glibc in /usr are twofold: |
845dcb57 | 679 | |
61952351 | 680 | * glibc will overwrite the headers in /usr/include. Other C libraries |
27e309c1 UD |
681 | install a different but overlapping set of headers there, so the effect |
682 | will probably be that you can't compile anything. You need to rename | |
683 | /usr/include out of the way before running `make install'. (Do not throw | |
684 | it away; you will then lose the ability to compile programs against your | |
685 | old libc.) | |
845dcb57 | 686 | |
61952351 UD |
687 | * None of your old libraries, static or shared, can be used with a |
688 | different C library major version. For shared libraries this is not a | |
689 | problem, because the filenames are different and the dynamic linker | |
690 | will enforce the restriction. But static libraries have no version | |
691 | information. You have to evacuate all the static libraries in | |
692 | /usr/lib to a safe location. | |
845dcb57 | 693 | |
61952351 UD |
694 | The situation is rather similar to the move from a.out to ELF which |
695 | long-time Linux users will remember. | |
845dcb57 | 696 | |
845dcb57 | 697 | |
61952351 UD |
698 | 2.4. Do I need to use GNU CC to compile programs that will use the |
699 | GNU C Library? | |
845dcb57 | 700 | |
f12944ec UD |
701 | {ZW} In theory, no; the linker does not care, and the headers are supposed |
702 | to check for GNU CC before using its extensions to the C language. | |
845dcb57 | 703 | |
f12944ec UD |
704 | However, there are currently no ports of glibc to systems where another |
705 | compiler is the default, so no one has tested the headers extensively | |
706 | against another compiler. You may therefore encounter difficulties. If you | |
707 | do, please report them as bugs. | |
845dcb57 | 708 | |
61952351 UD |
709 | Also, in several places GNU extensions provide large benefits in code |
710 | quality. For example, the library has hand-optimized, inline assembly | |
f12944ec UD |
711 | versions of some string functions. These can only be used with GCC. See |
712 | question 3.8 for details. | |
845dcb57 | 713 | |
845dcb57 | 714 | |
61952351 UD |
715 | 2.5. When linking with the new libc I get unresolved symbols |
716 | `crypt' and `setkey'. Why aren't these functions in the | |
717 | libc anymore? | |
845dcb57 | 718 | |
037f8020 | 719 | {} Removed. Does not apply anymore. |
c4029823 | 720 | |
c4029823 | 721 | |
61952351 UD |
722 | 2.6. When I use GNU libc on my Linux system by linking against |
723 | the libc.so which comes with glibc all I get is a core dump. | |
c4029823 | 724 | |
f12944ec | 725 | {UD} On Linux, gcc sets the dynamic linker to /lib/ld-linux.so.1 unless the |
a582750d | 726 | user specifies a --dynamic-linker argument. This is the name of the libc5 |
f12944ec | 727 | dynamic linker, which does not work with glibc. |
61952351 | 728 | |
a379e56a UD |
729 | For casual use of GNU libc you can just specify to the linker |
730 | --dynamic-linker=/lib/ld-linux.so.2 | |
61952351 | 731 | |
f12944ec | 732 | which is the glibc dynamic linker, on Linux systems. On other systems the |
a379e56a UD |
733 | name is /lib/ld.so.1. When linking via gcc, you've got to add |
734 | -Wl,--dynamic-linker=/lib/ld-linux.so.2 | |
735 | ||
736 | to the gcc command line. | |
c4029823 | 737 | |
f12944ec UD |
738 | To change your environment to use GNU libc for compiling you need to change |
739 | the `specs' file of your gcc. This file is normally found at | |
c4029823 UD |
740 | |
741 | /usr/lib/gcc-lib/<arch>/<version>/specs | |
742 | ||
743 | In this file you have to change a few things: | |
744 | ||
61952351 | 745 | - change `ld-linux.so.1' to `ld-linux.so.2' |
c4029823 UD |
746 | |
747 | - remove all expression `%{...:-lgmon}'; there is no libgmon in glibc | |
748 | ||
f4017d20 UD |
749 | - fix a minor bug by changing %{pipe:-} to %| |
750 | ||
f12944ec UD |
751 | Here is what the gcc-2.7.2 specs file should look like when GNU libc is |
752 | installed at /usr: | |
c4029823 UD |
753 | |
754 | ----------------------------------------------------------------------- | |
755 | *asm: | |
756 | %{V} %{v:%{!V:-V}} %{Qy:} %{!Qn:-Qy} %{n} %{T} %{Ym,*} %{Yd,*} %{Wa,*:%*} | |
757 | ||
758 | *asm_final: | |
f4017d20 | 759 | %| |
c4029823 UD |
760 | |
761 | *cpp: | |
68dbb3a6 | 762 | %{fPIC:-D__PIC__ -D__pic__} %{fpic:-D__PIC__ -D__pic__} %{!m386:-D__i486__} %{posix:-D_POSIX_SOURCE} %{pthread:-D_REENTRANT} |
c4029823 UD |
763 | |
764 | *cc1: | |
68dbb3a6 | 765 | %{profile:-p} |
c4029823 UD |
766 | |
767 | *cc1plus: | |
768 | ||
769 | ||
770 | *endfile: | |
68dbb3a6 | 771 | %{!shared:crtend.o%s} %{shared:crtendS.o%s} crtn.o%s |
c4029823 UD |
772 | |
773 | *link: | |
68dbb3a6 | 774 | -m elf_i386 %{shared:-shared} %{!shared: %{!ibcs: %{!static: %{rdynamic:-export-dynamic} %{!dynamic-linker:-dynamic-linker /lib/ld-linux.so.2}} %{static:-static}}} |
c4029823 UD |
775 | |
776 | *lib: | |
68dbb3a6 | 777 | %{!shared: %{pthread:-lpthread} %{profile:-lc_p} %{!profile: -lc}} |
c4029823 UD |
778 | |
779 | *libgcc: | |
68dbb3a6 | 780 | -lgcc |
c4029823 UD |
781 | |
782 | *startfile: | |
61952351 | 783 | %{!shared: %{pg:gcrt1.o%s} %{!pg:%{p:gcrt1.o%s} %{!p:%{profile:gcrt1.o%s} %{!profile:crt1.o%s}}}} crti.o%s %{!shared:crtbegin.o%s} %{shared:crtbeginS.o%s} |
c4029823 UD |
784 | |
785 | *switches_need_spaces: | |
786 | ||
787 | ||
788 | *signed_char: | |
789 | %{funsigned-char:-D__CHAR_UNSIGNED__} | |
790 | ||
791 | *predefines: | |
792 | -D__ELF__ -Dunix -Di386 -Dlinux -Asystem(unix) -Asystem(posix) -Acpu(i386) -Amachine(i386) | |
793 | ||
794 | *cross_compile: | |
795 | 0 | |
796 | ||
797 | *multilib: | |
798 | . ; | |
799 | ||
800 | ----------------------------------------------------------------------- | |
801 | ||
f12944ec UD |
802 | Things get a bit more complicated if you have GNU libc installed in some |
803 | other place than /usr, i.e., if you do not want to use it instead of the old | |
804 | libc. In this case the needed startup files and libraries are not found in | |
805 | the regular places. So the specs file must tell the compiler and linker | |
806 | exactly what to use. | |
0d204b0a | 807 | |
f41c8091 | 808 | Version 2.7.2.3 does and future versions of GCC will automatically |
0d8733c4 | 809 | provide the correct specs. |
c4029823 UD |
810 | |
811 | ||
61952351 UD |
812 | 2.7. Looking through the shared libc file I haven't found the |
813 | functions `stat', `lstat', `fstat', and `mknod' and while | |
814 | linking on my Linux system I get error messages. How is | |
815 | this supposed to work? | |
c4029823 | 816 | |
f12944ec UD |
817 | {RM} Believe it or not, stat and lstat (and fstat, and mknod) are supposed |
818 | to be undefined references in libc.so.6! Your problem is probably a missing | |
819 | or incorrect /usr/lib/libc.so file; note that this is a small text file now, | |
820 | not a symlink to libc.so.6. It should look something like this: | |
c4029823 | 821 | |
ff44f2a5 | 822 | GROUP ( libc.so.6 libc_nonshared.a ) |
1f205a47 | 823 | |
c4029823 | 824 | |
5edb9387 UD |
825 | 2.8. When I run an executable on one system which I compiled on |
826 | another, I get dynamic linker errors. Both systems have the same | |
827 | version of glibc installed. What's wrong? | |
828 | ||
829 | {ZW} Glibc on one of these systems was compiled with gcc 2.7 or 2.8, the | |
830 | other with egcs (any version). Egcs has functions in its internal | |
831 | `libgcc.a' to support exception handling with C++. They are linked into | |
832 | any program or dynamic library compiled with egcs, whether it needs them or | |
833 | not. Dynamic libraries then turn around and export those functions again | |
834 | unless special steps are taken to prevent them. | |
835 | ||
836 | When you link your program, it resolves its references to the exception | |
837 | functions to the ones exported accidentally by libc.so. That works fine as | |
838 | long as libc has those functions. On the other system, libc doesn't have | |
839 | those functions because it was compiled by gcc 2.8, and you get undefined | |
840 | symbol errors. The symbols in question are named things like | |
841 | `__register_frame_info'. | |
842 | ||
843 | For glibc 2.0, the workaround is to not compile libc with egcs. We've also | |
844 | incorporated a patch which should prevent the EH functions sneaking into | |
845 | libc. It doesn't matter what compiler you use to compile your program. | |
846 | ||
847 | For glibc 2.1, we've chosen to do it the other way around: libc.so | |
848 | explicitly provides the EH functions. This is to prevent other shared | |
95f7cecb UD |
849 | libraries from doing it. |
850 | ||
851 | {UD} Starting with glibc 2.1.1 you can compile glibc with gcc 2.8.1 or | |
852 | newer since we have explicitly add references to the functions causing the | |
853 | problem. But you nevertheless should use EGCS for other reasons | |
854 | (see question 1.2). | |
5edb9387 | 855 | |
83f6a990 UD |
856 | {GK} On some Linux distributions for PowerPC, you can see this when you have |
857 | built gcc or egcs from the Web sources (gcc versions 2.95 or earlier), then | |
858 | re-built glibc. This happens because in these versions of gcc, exception | |
859 | handling is implemented using an older method; the people making the | |
860 | distributions are a little ahead of their time. | |
861 | ||
862 | A quick solution to this is to find the libgcc.a file that came with the | |
6e8afc1c | 863 | distribution (it would have been installed under /usr/lib/gcc-lib), do |
83f6a990 UD |
864 | `ar x libgcc.a frame.o' to get the frame.o file out, and add a line saying |
865 | `LDLIBS-c.so += frame.o' to the file `configparms' in the directory you're | |
866 | building in. You can check you've got the right `frame.o' file by running | |
867 | `nm frame.o' and checking that it has the symbols defined that you're | |
868 | missing. | |
869 | ||
870 | This will let you build glibc with the C compiler. The C++ compiler | |
871 | will still be binary incompatible with any C++ shared libraries that | |
872 | you got with your distribution. | |
873 | ||
5edb9387 UD |
874 | |
875 | 2.9. How can I compile gcc 2.7.2.1 from the gcc source code using | |
61952351 | 876 | glibc 2.x? |
ba1ffaa1 | 877 | |
f12944ec | 878 | {AJ} There's only correct support for glibc 2.0.x in gcc 2.7.2.3 or later. |
4011dc70 | 879 | But you should get at least gcc 2.95.3 (or later versions) anyway |
ba1ffaa1 UD |
880 | |
881 | ||
5edb9387 | 882 | 2.10. The `gencat' utility cannot process the catalog sources which |
61952351 | 883 | were used on my Linux libc5 based system. Why? |
47707456 | 884 | |
f12944ec UD |
885 | {UD} The `gencat' utility provided with glibc complies to the XPG standard. |
886 | The older Linux version did not obey the standard, so they are not | |
887 | compatible. | |
47707456 | 888 | |
61952351 | 889 | To ease the transition from the Linux version some of the non-standard |
f12944ec UD |
890 | features are also present in the `gencat' program of GNU libc. This mainly |
891 | includes the use of symbols for the message number and the automatic | |
61952351 UD |
892 | generation of header files which contain the needed #defines to map the |
893 | symbols to integers. | |
47707456 | 894 | |
f12944ec UD |
895 | Here is a simple SED script to convert at least some Linux specific catalog |
896 | files to the XPG4 form: | |
68dbb3a6 | 897 | |
61952351 UD |
898 | ----------------------------------------------------------------------- |
899 | # Change catalog source in Linux specific format to standard XPG format. | |
934b77ac | 900 | # Ulrich Drepper <drepper@redhat.com>, 1996. |
61952351 UD |
901 | # |
902 | /^\$ #/ { | |
903 | h | |
904 | s/\$ #\([^ ]*\).*/\1/ | |
905 | x | |
906 | s/\$ #[^ ]* *\(.*\)/\$ \1/ | |
907 | } | |
68dbb3a6 | 908 | |
61952351 UD |
909 | /^# / { |
910 | s/^# \(.*\)/\1/ | |
911 | G | |
912 | s/\(.*\)\n\(.*\)/\2 \1/ | |
913 | } | |
914 | ----------------------------------------------------------------------- | |
19361cb7 | 915 | |
19361cb7 | 916 | |
5edb9387 | 917 | 2.11. Programs using libc have their messages translated, but other |
a35cb74d UD |
918 | behavior is not localized (e.g. collating order); why? |
919 | ||
920 | {ZW} Translated messages are automatically installed, but the locale | |
f12944ec UD |
921 | database that controls other behaviors is not. You need to run localedef to |
922 | install this database, after you have run `make install'. For example, to | |
923 | set up the French Canadian locale, simply issue the command | |
a35cb74d UD |
924 | |
925 | localedef -i fr_CA -f ISO-8859-1 fr_CA | |
926 | ||
927 | Please see localedata/README in the source tree for further details. | |
928 | ||
929 | ||
5edb9387 | 930 | 2.12. I have set up /etc/nis.conf, and the Linux libc 5 with NYS |
61952351 | 931 | works great. But the glibc NIS+ doesn't seem to work. |
19361cb7 | 932 | |
f12944ec UD |
933 | {TK} The glibc NIS+ implementation uses a /var/nis/NIS_COLD_START file for |
934 | storing information about the NIS+ server and their public keys, because the | |
935 | nis.conf file does not contain all the necessary information. You have to | |
936 | copy a NIS_COLD_START file from a Solaris client (the NIS_COLD_START file is | |
937 | byte order independent) or generate it with nisinit from the nis-tools | |
938 | package; available at | |
939 | ||
612fdf25 | 940 | http://www.suse.de/~kukuk/linux/nisplus.html |
19361cb7 | 941 | |
68dbb3a6 | 942 | |
5edb9387 | 943 | 2.13. I have killed ypbind to stop using NIS, but glibc |
3dcf8ea6 | 944 | continues using NIS. |
4d06461a | 945 | |
f12944ec UD |
946 | {TK} For faster NIS lookups, glibc uses the /var/yp/binding/ files from |
947 | ypbind. ypbind 3.3 and older versions don't always remove these files, so | |
948 | glibc will continue to use them. Other BSD versions seem to work correctly. | |
949 | Until ypbind 3.4 is released, you can find a patch at | |
950 | ||
66f6a52b | 951 | <ftp://ftp.kernel.org/pub/linux/utils/net/NIS/ypbind-3.3-glibc4.diff.gz> |
a35cb74d | 952 | |
4d06461a | 953 | |
5edb9387 | 954 | 2.14. Under Linux/Alpha, I always get "do_ypcall: clnt_call: |
3dcf8ea6 | 955 | RPC: Unable to receive; errno = Connection refused" when using NIS. |
4d06461a | 956 | |
f12944ec UD |
957 | {TK} You need a ypbind version which is 64bit clean. Some versions are not |
958 | 64bit clean. A 64bit clean implementation is ypbind-mt. For ypbind 3.3, | |
959 | you need the patch from ftp.kernel.org (See the previous question). I don't | |
960 | know about other versions. | |
a35cb74d UD |
961 | |
962 | ||
5edb9387 | 963 | 2.15. After installing glibc name resolving doesn't work properly. |
68dbb3a6 | 964 | |
f12944ec UD |
965 | {AJ} You probably should read the manual section describing nsswitch.conf |
966 | (just type `info libc "NSS Configuration File"'). The NSS configuration | |
967 | file is usually the culprit. | |
22d57dd3 | 968 | |
22d57dd3 | 969 | |
5edb9387 | 970 | 2.16. How do I create the databases for NSS? |
3dcf8ea6 UD |
971 | |
972 | {AJ} If you have an entry "db" in /etc/nsswitch.conf you should also create | |
973 | the database files. The glibc sources contain a Makefile which does the | |
a379e56a | 974 | necessary conversion and calls to create those files. The file is |
3dcf8ea6 UD |
975 | `db-Makefile' in the subdirectory `nss' and you can call it with `make -f |
976 | db-Makefile'. Please note that not all services are capable of using a | |
977 | database. Currently passwd, group, ethers, protocol, rpc, services shadow | |
199745d1 | 978 | and netgroup are implemented. See also question 2.31. |
3dcf8ea6 UD |
979 | |
980 | ||
5edb9387 | 981 | 2.17. I have /usr/include/net and /usr/include/scsi as symlinks |
61952351 | 982 | into my Linux source tree. Is that wrong? |
22d57dd3 | 983 | |
f12944ec UD |
984 | {PB} This was necessary for libc5, but is not correct when using glibc. |
985 | Including the kernel header files directly in user programs usually does not | |
986 | work (see question 3.5). glibc provides its own <net/*> and <scsi/*> header | |
987 | files to replace them, and you may have to remove any symlink that you have | |
988 | in place before you install glibc. However, /usr/include/asm and | |
989 | /usr/include/linux should remain as they were. | |
22d57dd3 | 990 | |
22d57dd3 | 991 | |
5edb9387 | 992 | 2.18. Programs like `logname', `top', `uptime' `users', `w' and |
61952351 UD |
993 | `who', show incorrect information about the (number of) |
994 | users on my system. Why? | |
22d57dd3 | 995 | |
61952351 | 996 | {MK} See question 3.2. |
22d57dd3 | 997 | |
22d57dd3 | 998 | |
5edb9387 | 999 | 2.19. After upgrading to glibc 2.1 with symbol versioning I get |
61952351 | 1000 | errors about undefined symbols. What went wrong? |
26dee9c4 | 1001 | |
f12944ec UD |
1002 | {AJ} The problem is caused either by wrong program code or tools. In the |
1003 | versioned libc a lot of symbols are now local that were global symbols in | |
1004 | previous versions. It seems that programs linked against older versions | |
1005 | often accidentally used libc global variables -- something that should not | |
1006 | happen. | |
26dee9c4 | 1007 | |
f12944ec UD |
1008 | The only way to fix this is to recompile your program. Sorry, that's the |
1009 | price you might have to pay once for quite a number of advantages with | |
1010 | symbol versioning. | |
26dee9c4 | 1011 | |
26dee9c4 | 1012 | |
5edb9387 | 1013 | 2.20. When I start the program XXX after upgrading the library |
61952351 UD |
1014 | I get |
1015 | XXX: Symbol `_sys_errlist' has different size in shared | |
1016 | object, consider re-linking | |
1017 | Why? What should I do? | |
26dee9c4 | 1018 | |
f12944ec UD |
1019 | {UD} As the message says, relink the binary. The problem is that a few |
1020 | symbols from the library can change in size and there is no way to avoid | |
1021 | this. _sys_errlist is a good example. Occasionally there are new error | |
1022 | numbers added to the kernel and this must be reflected at user level, | |
1023 | breaking programs that refer to them directly. | |
a2b08ee5 | 1024 | |
f12944ec UD |
1025 | Such symbols should normally not be used at all. There are mechanisms to |
1026 | avoid using them. In the case of _sys_errlist, there is the strerror() | |
1027 | function which should _always_ be used instead. So the correct fix is to | |
1028 | rewrite that part of the application. | |
a2b08ee5 | 1029 | |
f12944ec UD |
1030 | In some situations (especially when testing a new library release) it might |
1031 | be possible that a symbol changed size when that should not have happened. | |
1032 | So in case of doubt report such a warning message as a problem. | |
a2b08ee5 | 1033 | |
a35cb74d | 1034 | |
5edb9387 UD |
1035 | 2.21. What do I need for C++ development? |
1036 | ||
1037 | {HJ,AJ} You need either egcs 1.1 which comes directly with libstdc++ or | |
1038 | gcc-2.8.1 together with libstdc++ 2.8.1.1. egcs 1.1 has the better C++ | |
1039 | support and works directly with glibc 2.1. If you use gcc-2.8.1 with | |
1040 | libstdc++ 2.8.1.1, you need to modify libstdc++ a bit. A patch is available | |
1041 | as: | |
66f6a52b | 1042 | <ftp://alpha.gnu.org/gnu/libstdc++-2.8.1.1-glibc2.1-diff.gz> |
a35cb74d | 1043 | |
5edb9387 UD |
1044 | Please note that libg++ 2.7.2 (and the Linux Versions 2.7.2.x) doesn't work |
1045 | very well with the GNU C library due to vtable thunks. If you're upgrading | |
1046 | from glibc 2.0.x to 2.1 you have to recompile libstdc++ since the library | |
1047 | compiled for 2.0 is not compatible due to the new Large File Support (LFS) | |
1048 | in version 2.1. | |
fb98e2bf UD |
1049 | |
1050 | {UD} But since in the case of a shared libstdc++ the version numbers should | |
1051 | be different existing programs will continue to work. | |
a35cb74d | 1052 | |
ff44f2a5 | 1053 | |
5edb9387 | 1054 | 2.22. Even statically linked programs need some shared libraries |
ff44f2a5 UD |
1055 | which is not acceptable for me. What can I do? |
1056 | ||
f12944ec UD |
1057 | {AJ} NSS (for details just type `info libc "Name Service Switch"') won't |
1058 | work properly without shared libraries. NSS allows using different services | |
1059 | (e.g. NIS, files, db, hesiod) by just changing one configuration file | |
1060 | (/etc/nsswitch.conf) without relinking any programs. The only disadvantage | |
1061 | is that now static libraries need to access shared libraries. This is | |
1062 | handled transparently by the GNU C library. | |
ff44f2a5 | 1063 | |
f12944ec UD |
1064 | A solution is to configure glibc with --enable-static-nss. In this case you |
1065 | can create a static binary that will use only the services dns and files | |
1066 | (change /etc/nsswitch.conf for this). You need to link explicitly against | |
1067 | all these services. For example: | |
ff44f2a5 | 1068 | |
2c88f872 AJ |
1069 | gcc -static test-netdb.c -o test-netdb \ |
1070 | -Wl,--start-group -lc -lnss_files -lnss_dns -lresolv -Wl,--end-group | |
ff44f2a5 UD |
1071 | |
1072 | The problem with this approach is that you've got to link every static | |
1073 | program that uses NSS routines with all those libraries. | |
1074 | ||
1075 | {UD} In fact, one cannot say anymore that a libc compiled with this | |
1076 | option is using NSS. There is no switch anymore. Therefore it is | |
1077 | *highly* recommended *not* to use --enable-static-nss since this makes | |
1078 | the behaviour of the programs on the system inconsistent. | |
1079 | ||
fdacb17d | 1080 | |
5edb9387 | 1081 | 2.23. I just upgraded my Linux system to glibc and now I get |
fdacb17d UD |
1082 | errors whenever I try to link any program. |
1083 | ||
1084 | {ZW} This happens when you have installed glibc as the primary C library but | |
1085 | have stray symbolic links pointing at your old C library. If the first | |
1086 | `libc.so' the linker finds is libc 5, it will use that. Your program | |
1087 | expects to be linked with glibc, so the link fails. | |
1088 | ||
1089 | The most common case is that glibc put its `libc.so' in /usr/lib, but there | |
1090 | was a `libc.so' from libc 5 in /lib, which gets searched first. To fix the | |
1091 | problem, just delete /lib/libc.so. You may also need to delete other | |
1092 | symbolic links in /lib, such as /lib/libm.so if it points to libm.so.5. | |
1093 | ||
1094 | {AJ} The perl script test-installation.pl which is run as last step during | |
1095 | an installation of glibc that is configured with --prefix=/usr should help | |
1096 | detect these situations. If the script reports problems, something is | |
1097 | really screwed up. | |
1098 | ||
48244d09 | 1099 | |
5edb9387 | 1100 | 2.24. When I use nscd the machine freezes. |
48244d09 | 1101 | |
5edb9387 UD |
1102 | {UD} You cannot use nscd with Linux 2.0.*. There is functionality missing |
1103 | in the kernel and work-arounds are not suitable. Besides, some parts of the | |
1104 | kernel are too buggy when it comes to using threads. | |
48244d09 | 1105 | |
b710a6e2 | 1106 | If you need nscd, you have to use at least a 2.1 kernel. |
48244d09 UD |
1107 | |
1108 | Note that I have at this point no information about any other platform. | |
1109 | ||
0155a773 UD |
1110 | |
1111 | 2.25. I need lots of open files. What do I have to do? | |
1112 | ||
1113 | {AJ} This is at first a kernel issue. The kernel defines limits with | |
1114 | OPEN_MAX the number of simultaneous open files and with FD_SETSIZE the | |
1115 | number of used file descriptors. You need to change these values in your | |
c0389ee4 | 1116 | kernel and recompile the kernel so that the kernel allows more open |
0155a773 UD |
1117 | files. You don't necessarily need to recompile the GNU C library since the |
1118 | only place where OPEN_MAX and FD_SETSIZE is really needed in the library | |
1119 | itself is the size of fd_set which is used by select. | |
1120 | ||
249fd241 UD |
1121 | The GNU C library is now select free. This means it internally has no |
1122 | limits imposed by the `fd_set' type. Instead all places where the | |
0155a773 UD |
1123 | functionality is needed the `poll' function is used. |
1124 | ||
1125 | If you increase the number of file descriptors in the kernel you don't need | |
6e8afc1c | 1126 | to recompile the C library. |
0155a773 UD |
1127 | |
1128 | {UD} You can always get the maximum number of file descriptors a process is | |
1129 | allowed to have open at any time using | |
1130 | ||
1131 | number = sysconf (_SC_OPEN_MAX); | |
1132 | ||
1133 | This will work even if the kernel limits change. | |
1134 | ||
7db169c9 UD |
1135 | |
1136 | 2.26. How do I get the same behavior on parsing /etc/passwd and | |
1137 | /etc/group as I have with libc5 ? | |
1138 | ||
1139 | {TK} The name switch setup in /etc/nsswitch.conf selected by most Linux | |
1140 | distributions does not support +/- and netgroup entries in the files like | |
1141 | /etc/passwd. Though this is the preferred setup some people might have | |
1142 | setups coming over from the libc5 days where it was the default to recognize | |
1143 | lines like this. To get back to the old behaviour one simply has to change | |
1144 | the rules for passwd, group, and shadow in the nsswitch.conf file as | |
1145 | follows: | |
1146 | ||
1147 | passwd: compat | |
1148 | group: compat | |
1149 | shadow: compat | |
1150 | ||
1151 | passwd_compat: nis | |
1152 | group_compat: nis | |
1153 | shadow_compat: nis | |
1154 | ||
b710a6e2 UD |
1155 | |
1156 | 2.27. What needs to be recompiled when upgrading from glibc 2.0 to glibc | |
1157 | 2.1? | |
1158 | ||
1159 | {AJ,CG} If you just upgrade the glibc from 2.0.x (x <= 7) to 2.1, binaries | |
1160 | that have been linked against glibc 2.0 will continue to work. | |
1161 | ||
1162 | If you compile your own binaries against glibc 2.1, you also need to | |
c19559b0 UD |
1163 | recompile some other libraries. The problem is that libio had to be changed |
1164 | and therefore libraries that are based or depend on the libio of glibc, | |
1165 | e.g. ncurses, slang and most C++ libraries, need to be recompiled. If you | |
1166 | experience strange segmentation faults in your programs linked against glibc | |
1167 | 2.1, you might need to recompile your libraries. | |
b710a6e2 UD |
1168 | |
1169 | Another problem is that older binaries that were linked statically against | |
1170 | glibc 2.0 will reference the older nss modules (libnss_files.so.1 instead of | |
1171 | libnss_files.so.2), so don't remove them. Also, the old glibc-2.0 compiled | |
1172 | static libraries (libfoo.a) which happen to depend on the older libio | |
1173 | behavior will be broken by the glibc 2.1 upgrade. We plan to produce a | |
1174 | compatibility library that people will be able to link in if they want | |
1175 | to compile a static library generated against glibc 2.0 into a program | |
1176 | on a glibc 2.1 system. You just add -lcompat and you should be fine. | |
1177 | ||
1178 | The glibc-compat add-on will provide the libcompat.a library, the older | |
1179 | nss modules, and a few other files. Together, they should make it | |
1180 | possible to do development with old static libraries on a glibc 2.1 | |
8d8c6efa | 1181 | system. This add-on is still in development. You can get it from |
df08cc56 | 1182 | <ftp://alpha.gnu.org/gnu/glibc/glibc-compat-2.1.tar.gz> |
b710a6e2 UD |
1183 | but please keep in mind that it is experimental. |
1184 | ||
b7398be5 UD |
1185 | |
1186 | 2.28. Why is extracting files via tar so slow? | |
1187 | ||
1188 | {AJ} Extracting of tar archives might be quite slow since tar has to look up | |
1189 | userid and groupids and doesn't cache negative results. If you have nis or | |
1190 | nisplus in your /etc/nsswitch.conf for the passwd and/or group database, | |
1191 | each file extractions needs a network connection. There are two possible | |
1192 | solutions: | |
1193 | ||
1194 | - do you really need NIS/NIS+ (some Linux distributions add by default | |
1195 | nis/nisplus even if it's not needed)? If not, just remove the entries. | |
1196 | ||
1197 | - if you need NIS/NIS+, use the Name Service Cache Daemon nscd that comes | |
1198 | with glibc 2.1. | |
1199 | ||
2ee511d9 UD |
1200 | |
1201 | 2.29. Compiling programs I get parse errors in libio.h (e.g. "parse error | |
1202 | before `_IO_seekoff'"). How should I fix this? | |
1203 | ||
1204 | {AJ} You might get the following errors when upgrading to glibc 2.1: | |
1205 | ||
1206 | In file included from /usr/include/stdio.h:57, | |
1207 | from ... | |
1208 | /usr/include/libio.h:335: parse error before `_IO_seekoff' | |
1209 | /usr/include/libio.h:335: parse error before `_G_off64_t' | |
1210 | /usr/include/libio.h:336: parse error before `_IO_seekpos' | |
1211 | /usr/include/libio.h:336: parse error before `_G_fpos64_t' | |
1212 | ||
1213 | The problem is a wrong _G_config.h file in your include path. The | |
1214 | _G_config.h file that comes with glibc 2.1 should be used and not one from | |
1215 | libc5 or from a compiler directory. To check which _G_config.h file the | |
1216 | compiler uses, compile your program with `gcc -E ...|grep G_config.h' and | |
1217 | remove that file. Your compiler should pick up the file that has been | |
1218 | installed by glibc 2.1 in your include directory. | |
1219 | ||
4f7ea427 UD |
1220 | |
1221 | 2.30. After upgrading to glibc 2.1, libraries that were compiled against | |
1222 | glibc 2.0.x don't work anymore. | |
1223 | ||
1224 | {AJ} See question 2.27. | |
1225 | ||
9de4e203 UD |
1226 | |
1227 | 2.31. What happened to the Berkeley DB libraries? Can I still use db | |
1228 | in /etc/nsswitch.conf? | |
1229 | ||
1230 | {AJ} Due to too many incompatible changes in disk layout and API of Berkeley | |
1231 | DB and a too tight coupling of libc and libdb, the db library has been | |
1232 | removed completely from glibc 2.2. The only place that really used the | |
1233 | Berkeley DB was the NSS db module. | |
1234 | ||
1235 | The NSS db module has been rewritten to support a number of different | |
1236 | versions of Berkeley DB for the NSS db module. Currently the releases 2.x | |
1237 | and 3.x of Berkeley DB are supported. The older db 1.85 library is not | |
1238 | supported. You can use the version from glibc 2.1.x or download a version | |
1239 | from Sleepycat Software (http://www.sleepycat.com). The library has to be | |
1240 | compiled as shared library and installed in the system lib directory | |
1241 | (normally /lib). The library needs to have a special soname to be found by | |
1242 | the NSS module. | |
1243 | ||
1244 | If public structures change in a new Berkeley db release, this needs to be | |
1245 | reflected in glibc. | |
1246 | ||
1247 | Currently the code searches for libraries with a soname of "libdb.so.3" | |
1248 | (that's the name from db 2.4.14 which comes with glibc 2.1.x) and | |
1249 | "libdb-3.0.so" (the name used by db 3.0.55 as default). | |
1250 | ||
2c88f872 AJ |
1251 | The nss_db module is now in a separate package since it requires a database |
1252 | library being available. | |
1253 | ||
1254 | ||
1255 | 2.32. What has do be done when upgrading to glibc 2.2? | |
1256 | ||
1257 | {AJ} The upgrade to glibc 2.2 should run smoothly, there's in general no | |
1258 | need to recompile programs or libraries. Nevertheless, some changes might | |
1259 | be needed after upgrading: | |
1260 | - The utmp daemon has been removed and is not supported by glibc anymore. | |
1261 | If it has been in use, it should be switched off. | |
1262 | - Programs using IPv6 have to be recompiled due to incompatible changes in | |
1263 | sockaddr_in6 by the IPv6 working group. | |
467cc99e | 1264 | - The Berkeley db libraries have been removed (for details see question 2.31). |
2c88f872 AJ |
1265 | - The format of the locale files has changed, all locales should be |
1266 | regenerated with localedef. All statically linked applications which use | |
1267 | i18n should be recompiled, otherwise they'll not be localized. | |
1268 | - glibc comes with a number of new applications. For example ldconfig has | |
1269 | been implemented for glibc, the libc5 version of ldconfig is not needed | |
1270 | anymore. | |
1271 | - There's no more K&R compatibility in the glibc headers. The GNU C library | |
1272 | requires a C compiler that handles especially prototypes correctly. | |
e0272133 | 1273 | Especially gcc -traditional will not work with glibc headers. |
2c88f872 AJ |
1274 | |
1275 | Please read also the NEWS file which is the authoritative source for this | |
1276 | and gives more details for some topics. | |
1277 | ||
4442d7e8 UD |
1278 | |
1279 | 2.33. The makefiles want to do a CVS commit. | |
1280 | ||
1281 | {UD} Only if you are not specifying the --without-cvs flag at configure | |
1282 | time. This is what you always have to use if you are checking sources | |
1283 | directly out of the public CVS repository or you have your own private | |
1284 | repository. | |
1285 | ||
1324affa UD |
1286 | |
1287 | 2.34. When compiling C++ programs, I get a compilation error in streambuf.h. | |
1288 | ||
1289 | {BH} You are using g++ 2.95.2? After upgrading to glibc 2.2, you need to | |
1290 | apply a patch to the include files in /usr/include/g++, because the fpos_t | |
1291 | type has changed in glibc 2.2. The patch is at | |
4011dc70 UD |
1292 | |
1293 | http://www.haible.de/bruno/gccinclude-glibc-2.2-compat.diff | |
1324affa UD |
1294 | |
1295 | ||
1296 | 2.35. When recompiling GCC, I get compilation errors in libio. | |
1297 | ||
4a5b72ff | 1298 | {BH} You are trying to recompile gcc 2.95.2? Use gcc 2.95.3 instead. |
5ef50d00 | 1299 | This version is needed because the fpos_t type and a few libio internals |
4a5b72ff | 1300 | have changed in glibc 2.2, and gcc 2.95.3 contains a corresponding patch. |
1324affa | 1301 | |
934b77ac UD |
1302 | |
1303 | 2.36. Why shall glibc never get installed on GNU/Linux systems in | |
1304 | /usr/local? | |
1305 | ||
1306 | {AJ} The GNU C compiler treats /usr/local/include and /usr/local/lib in a | |
1307 | special way, these directories will be searched before the system | |
1308 | directories. Since on GNU/Linux the system directories /usr/include and | |
1309 | /usr/lib contain a --- possibly different --- version of glibc and mixing | |
1310 | certain files from different glibc installations is not supported and will | |
1311 | break, you risk breaking your complete system. If you want to test a glibc | |
1312 | installation, use another directory as argument to --prefix. If you like to | |
1313 | install this glibc version as default version, overriding the existing one, | |
1314 | use --prefix=/usr and everything will go in the right places. | |
1315 | ||
4011dc70 UD |
1316 | |
1317 | 2.37. When recompiling GCC, I get compilation errors in libstdc++. | |
1318 | ||
1319 | {BH} You are trying to recompile gcc 3.2? You need to patch gcc 3.2, | |
1320 | because some last minute changes were made in glibc 2.3 which were not | |
1321 | known when gcc 3.2 was released. The patch is at | |
1322 | ||
1323 | http://www.haible.de/bruno/gcc-3.2-glibc-2.3-compat.diff | |
1324 | ||
61952351 UD |
1325 | \f |
1326 | . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . | |
a5a0310d | 1327 | |
61952351 | 1328 | 3. Source and binary incompatibilities, and what to do about them |
a5a0310d | 1329 | |
61952351 UD |
1330 | 3.1. I expect GNU libc to be 100% source code compatible with |
1331 | the old Linux based GNU libc. Why isn't it like this? | |
a5a0310d | 1332 | |
f12944ec UD |
1333 | {DMT,UD} Not every extension in Linux libc's history was well thought-out. |
1334 | In fact it had a lot of problems with standards compliance and with | |
1335 | cleanliness. With the introduction of a new version number these errors can | |
1336 | now be corrected. Here is a list of the known source code | |
61952351 | 1337 | incompatibilities: |
af6f3906 | 1338 | |
61952351 UD |
1339 | * _GNU_SOURCE: glibc does not make the GNU extensions available |
1340 | automatically. If a program depends on GNU extensions or some | |
1341 | other non-standard functionality, it is necessary to compile it | |
1342 | with the C compiler option -D_GNU_SOURCE, or better, to put | |
1343 | `#define _GNU_SOURCE' at the beginning of your source files, before | |
1344 | any C library header files are included. This difference normally | |
1345 | manifests itself in the form of missing prototypes and/or data type | |
1346 | definitions. Thus, if you get such errors, the first thing you | |
1347 | should do is try defining _GNU_SOURCE and see if that makes the | |
1348 | problem go away. | |
af6f3906 | 1349 | |
61952351 UD |
1350 | For more information consult the file `NOTES' in the GNU C library |
1351 | sources. | |
af6f3906 | 1352 | |
61952351 UD |
1353 | * reboot(): GNU libc sanitizes the interface of reboot() to be more |
1354 | compatible with the interface used on other OSes. reboot() as | |
1355 | implemented in glibc takes just one argument. This argument | |
1356 | corresponds to the third argument of the Linux reboot system call. | |
1357 | That is, a call of the form reboot(a, b, c) needs to be changed into | |
1358 | reboot(c). Beside this the header <sys/reboot.h> defines the needed | |
1359 | constants for the argument. These RB_* constants should be used | |
1360 | instead of the cryptic magic numbers. | |
1361 | ||
1362 | * swapon(): the interface of this function didn't change, but the | |
1363 | prototype is in a separate header file <sys/swap.h>. This header | |
1364 | file also provides the SWAP_* constants defined by <linux/swap.h>; | |
1365 | you should use them for the second argument to swapon(). | |
1366 | ||
1367 | * errno: If a program uses the variable "errno", then it _must_ | |
1368 | include <errno.h>. The old libc often (erroneously) declared this | |
1369 | variable implicitly as a side-effect of including other libc header | |
1370 | files. glibc is careful to avoid such namespace pollution, which, | |
1371 | in turn, means that you really need to include the header files that | |
1372 | you depend on. This difference normally manifests itself in the | |
1373 | form of the compiler complaining about references to an undeclared | |
1374 | symbol "errno". | |
dd7d45e8 | 1375 | |
61952351 UD |
1376 | * Linux-specific syscalls: All Linux system calls now have appropriate |
1377 | library wrappers and corresponding declarations in various header files. | |
1378 | This is because the syscall() macro that was traditionally used to | |
1379 | work around missing syscall wrappers are inherently non-portable and | |
1380 | error-prone. The following table lists all the new syscall stubs, | |
1381 | the header-file declaring their interface and the system call name. | |
dd7d45e8 | 1382 | |
61952351 UD |
1383 | syscall name: wrapper name: declaring header file: |
1384 | ------------- ------------- ---------------------- | |
1385 | bdflush bdflush <sys/kdaemon.h> | |
1386 | syslog ksyslog_ctl <sys/klog.h> | |
dd7d45e8 | 1387 | |
61952351 UD |
1388 | * lpd: Older versions of lpd depend on a routine called _validuser(). |
1389 | The library does not provide this function, but instead provides | |
1390 | __ivaliduser() which has a slightly different interface. Simply | |
1391 | upgrading to a newer lpd should fix this problem (e.g., the 4.4BSD | |
1392 | lpd is known to be working). | |
dd7d45e8 | 1393 | |
61952351 UD |
1394 | * resolver functions/BIND: like on many other systems the functions of |
1395 | the resolver library are not included in libc itself. There is a | |
1396 | separate library libresolv. If you get undefined symbol errors for | |
1397 | symbols starting with `res_*' simply add -lresolv to your linker | |
1398 | command line. | |
dd7d45e8 | 1399 | |
61952351 UD |
1400 | * the `signal' function's behavior corresponds to the BSD semantic and |
1401 | not the SysV semantic as it was in libc-5. The interface on all GNU | |
1402 | systems shall be the same and BSD is the semantic of choice. To use | |
1403 | the SysV behavior simply use `sysv_signal', or define _XOPEN_SOURCE. | |
1404 | See question 3.7 for details. | |
1cab5444 | 1405 | |
1cab5444 | 1406 | |
61952351 UD |
1407 | 3.2. Why does getlogin() always return NULL on my Linux box? |
1408 | ||
f12944ec UD |
1409 | {UD} The GNU C library has a format for the UTMP and WTMP file which differs |
1410 | from what your system currently has. It was extended to fulfill the needs | |
1411 | of the next years when IPv6 is introduced. The record size is different and | |
1412 | some fields have different positions. The files written by functions from | |
1413 | the one library cannot be read by functions from the other library. Sorry, | |
1414 | but this is what a major release is for. It's better to have a cut now than | |
1415 | having no means to support the new techniques later. | |
1cab5444 | 1416 | |
6973fc01 | 1417 | |
61952351 UD |
1418 | 3.3. Where are the DST_* constants found in <sys/time.h> on many |
1419 | systems? | |
6973fc01 | 1420 | |
f12944ec UD |
1421 | {UD} These constants come from the old BSD days and are not used anymore |
1422 | (libc5 does not actually implement the handling although the constants are | |
1423 | defined). | |
6973fc01 | 1424 | |
f12944ec | 1425 | Instead GNU libc contains zone database support and compatibility code for |
8b4a4715 | 1426 | POSIX TZ environment variable handling. For former is very much preferred |
7d1de115 | 1427 | (see question 4.3). |
6973fc01 UD |
1428 | |
1429 | ||
61952351 UD |
1430 | 3.4. The prototypes for `connect', `accept', `getsockopt', |
1431 | `setsockopt', `getsockname', `getpeername', `send', | |
1432 | `sendto', and `recvfrom' are different in GNU libc from | |
1433 | any other system I saw. This is a bug, isn't it? | |
f4017d20 | 1434 | |
f12944ec UD |
1435 | {UD} No, this is no bug. This version of GNU libc already follows the new |
1436 | Single Unix specifications (and I think the POSIX.1g draft which adopted the | |
1437 | solution). The type for a parameter describing a size is now `socklen_t', a | |
1438 | new type. | |
f4017d20 | 1439 | |
f4017d20 | 1440 | |
61952351 UD |
1441 | 3.5. On Linux I've got problems with the declarations in Linux |
1442 | kernel headers. | |
f4017d20 | 1443 | |
f12944ec UD |
1444 | {UD,AJ} On Linux, the use of kernel headers is reduced to the minimum. This |
1445 | gives Linus the ability to change the headers more freely. Also, user | |
8f1c9b09 | 1446 | programs are now insulated from changes in the size of kernel data |
f12944ec | 1447 | structures. |
f4017d20 | 1448 | |
f12944ec UD |
1449 | For example, the sigset_t type is 32 or 64 bits wide in the kernel. In |
1450 | glibc it is 1024 bits wide. This guarantees that when the kernel gets a | |
1451 | bigger sigset_t (for POSIX.1e realtime support, say) user programs will not | |
1452 | have to be recompiled. Consult the header files for more information about | |
1453 | the changes. | |
61952351 | 1454 | |
f12944ec UD |
1455 | Therefore you shouldn't include Linux kernel header files directly if glibc |
1456 | has defined a replacement. Otherwise you might get undefined results because | |
1457 | of type conflicts. | |
f4017d20 | 1458 | |
f4017d20 | 1459 | |
61952351 UD |
1460 | 3.6. I don't include any kernel headers myself but the compiler |
1461 | still complains about redeclarations of types in the kernel | |
1462 | headers. | |
1463 | ||
f12944ec UD |
1464 | {UD} The kernel headers before Linux 2.1.61 and 2.0.32 don't work correctly |
1465 | with glibc. Compiling C programs is possible in most cases but C++ programs | |
1466 | have (due to the change of the name lookups for `struct's) problems. One | |
1467 | prominent example is `struct fd_set'. | |
61952351 | 1468 | |
f12944ec UD |
1469 | There might be some problems left but 2.1.61/2.0.32 fix most of the known |
1470 | ones. See the BUGS file for other known problems. | |
61952351 UD |
1471 | |
1472 | ||
1473 | 3.7. Why don't signals interrupt system calls anymore? | |
1474 | ||
f12944ec UD |
1475 | {ZW} By default GNU libc uses the BSD semantics for signal(), unlike Linux |
1476 | libc 5 which used System V semantics. This is partially for compatibility | |
1477 | with other systems and partially because the BSD semantics tend to make | |
1478 | programming with signals easier. | |
f4017d20 UD |
1479 | |
1480 | There are three differences: | |
1481 | ||
1482 | * BSD-style signals that occur in the middle of a system call do not | |
1483 | affect the system call; System V signals cause the system call to | |
1484 | fail and set errno to EINTR. | |
1485 | ||
1486 | * BSD signal handlers remain installed once triggered. System V signal | |
1487 | handlers work only once, so one must reinstall them each time. | |
1488 | ||
1489 | * A BSD signal is blocked during the execution of its handler. In other | |
1490 | words, a handler for SIGCHLD (for example) does not need to worry about | |
61952351 | 1491 | being interrupted by another SIGCHLD. It may, however, be interrupted |
f4017d20 UD |
1492 | by other signals. |
1493 | ||
1494 | There is general consensus that for `casual' programming with signals, the | |
1495 | BSD semantics are preferable. You don't need to worry about system calls | |
1496 | returning EINTR, and you don't need to worry about the race conditions | |
1497 | associated with one-shot signal handlers. | |
1498 | ||
1499 | If you are porting an old program that relies on the old semantics, you can | |
1500 | quickly fix the problem by changing signal() to sysv_signal() throughout. | |
1501 | Alternatively, define _XOPEN_SOURCE before including <signal.h>. | |
1502 | ||
1503 | For new programs, the sigaction() function allows you to specify precisely | |
1504 | how you want your signals to behave. All three differences listed above are | |
1505 | individually switchable on a per-signal basis with this function. | |
1506 | ||
f12944ec UD |
1507 | If all you want is for one specific signal to cause system calls to fail and |
1508 | return EINTR (for example, to implement a timeout) you can do this with | |
f4017d20 UD |
1509 | siginterrupt(). |
1510 | ||
1511 | ||
61952351 UD |
1512 | 3.8. I've got errors compiling code that uses certain string |
1513 | functions. Why? | |
1514 | ||
f12944ec | 1515 | {AJ} glibc 2.1 has special string functions that are faster than the normal |
fdacb17d | 1516 | library functions. Some of the functions are additionally implemented as |
a25f2023 UD |
1517 | inline functions and others as macros. This might lead to problems with |
1518 | existing codes but it is explicitly allowed by ISO C. | |
04be94a8 | 1519 | |
04be94a8 | 1520 | The optimized string functions are only used when compiling with |
fdacb17d | 1521 | optimizations (-O1 or higher). The behavior can be changed with two feature |
f12944ec | 1522 | macros: |
61952351 UD |
1523 | |
1524 | * __NO_STRING_INLINES: Don't do any string optimizations. | |
1525 | * __USE_STRING_INLINES: Use assembly language inline functions (might | |
1526 | increase code size dramatically). | |
04be94a8 | 1527 | |
f12944ec UD |
1528 | Since some of these string functions are now additionally defined as macros, |
1529 | code like "char *strncpy();" doesn't work anymore (and is unnecessary, since | |
fdacb17d | 1530 | <string.h> has the necessary declarations). Either change your code or |
f12944ec | 1531 | define __NO_STRING_INLINES. |
04be94a8 | 1532 | |
f12944ec UD |
1533 | {UD} Another problem in this area is that gcc still has problems on machines |
1534 | with very few registers (e.g., ix86). The inline assembler code can require | |
1535 | almost all the registers and the register allocator cannot always handle | |
1536 | this situation. | |
04be94a8 | 1537 | |
61952351 | 1538 | One can disable the string optimizations selectively. Instead of writing |
04be94a8 UD |
1539 | |
1540 | cp = strcpy (foo, "lkj"); | |
1541 | ||
1542 | one can write | |
1543 | ||
1544 | cp = (strcpy) (foo, "lkj"); | |
1545 | ||
61952351 UD |
1546 | This disables the optimization for that specific call. |
1547 | ||
4775243a UD |
1548 | |
1549 | 3.9. I get compiler messages "Initializer element not constant" with | |
1550 | stdin/stdout/stderr. Why? | |
1551 | ||
1552 | {RM,AJ} Constructs like: | |
66f6a52b | 1553 | static FILE *InPtr = stdin; |
4775243a | 1554 | |
fdacb17d UD |
1555 | lead to this message. This is correct behaviour with glibc since stdin is |
1556 | not a constant expression. Please note that a strict reading of ISO C does | |
f12944ec | 1557 | not allow above constructs. |
4775243a | 1558 | |
f12944ec UD |
1559 | One of the advantages of this is that you can assign to stdin, stdout, and |
1560 | stderr just like any other global variable (e.g. `stdout = my_stream;'), | |
1561 | which can be very useful with custom streams that you can write with libio | |
fdacb17d | 1562 | (but beware this is not necessarily portable). The reason to implement it |
f12944ec | 1563 | this way were versioning problems with the size of the FILE structure. |
4775243a | 1564 | |
fdacb17d UD |
1565 | To fix those programs you've got to initialize the variable at run time. |
1566 | This can be done, e.g. in main, like: | |
1567 | ||
66f6a52b UD |
1568 | static FILE *InPtr; |
1569 | int main(void) | |
1570 | { | |
1571 | InPtr = stdin; | |
1572 | } | |
fdacb17d UD |
1573 | |
1574 | or by constructors (beware this is gcc specific): | |
1575 | ||
66f6a52b UD |
1576 | static FILE *InPtr; |
1577 | static void inPtr_construct (void) __attribute__((constructor)); | |
1578 | static void inPtr_construct (void) { InPtr = stdin; } | |
fdacb17d | 1579 | |
4775243a UD |
1580 | |
1581 | 3.10. I can't compile with gcc -traditional (or | |
1582 | -traditional-cpp). Why? | |
1583 | ||
1584 | {AJ} glibc2 does break -traditional and -traditonal-cpp - and will continue | |
fdacb17d | 1585 | to do so. For example constructs of the form: |
f12944ec | 1586 | |
66f6a52b UD |
1587 | enum {foo |
1588 | #define foo foo | |
1589 | } | |
f12944ec UD |
1590 | |
1591 | are useful for debugging purposes (you can use foo with your debugger that's | |
1592 | why we need the enum) and for compatibility (other systems use defines and | |
1593 | check with #ifdef). | |
4775243a UD |
1594 | |
1595 | ||
1596 | 3.11. I get some errors with `gcc -ansi'. Isn't glibc ANSI compatible? | |
1597 | ||
1598 | {AJ} The GNU C library is compatible with the ANSI/ISO C standard. If | |
f12944ec | 1599 | you're using `gcc -ansi', the glibc includes which are specified in the |
fdacb17d | 1600 | standard follow the standard. The ANSI/ISO C standard defines what has to be |
f12944ec UD |
1601 | in the include files - and also states that nothing else should be in the |
1602 | include files (btw. you can still enable additional standards with feature | |
1603 | flags). | |
4775243a | 1604 | |
f12944ec UD |
1605 | The GNU C library is conforming to ANSI/ISO C - if and only if you're only |
1606 | using the headers and library functions defined in the standard. | |
4775243a | 1607 | |
a35cb74d UD |
1608 | |
1609 | 3.12. I can't access some functions anymore. nm shows that they do | |
1610 | exist but linking fails nevertheless. | |
1611 | ||
f12944ec UD |
1612 | {AJ} With the introduction of versioning in glibc 2.1 it is possible to |
1613 | export only those identifiers (functions, variables) that are really needed | |
1614 | by application programs and by other parts of glibc. This way a lot of | |
1615 | internal interfaces are now hidden. nm will still show those identifiers | |
1616 | but marking them as internal. ISO C states that identifiers beginning with | |
1617 | an underscore are internal to the libc. An application program normally | |
1618 | shouldn't use those internal interfaces (there are exceptions, | |
1619 | e.g. __ivaliduser). If a program uses these interfaces, it's broken. These | |
1620 | internal interfaces might change between glibc releases or dropped | |
1621 | completely. | |
a35cb74d | 1622 | |
a5f4e34a UD |
1623 | |
1624 | 3.13. When using the db-2 library which comes with glibc is used in | |
1625 | the Perl db modules the testsuite is not passed. This did not | |
1626 | happen with db-1, gdbm, or ndbm. | |
1627 | ||
037f8020 | 1628 | {} Removed. Does not apply anymore. |
a5f4e34a | 1629 | |
5148d49f UD |
1630 | |
1631 | 3.14. The pow() inline function I get when including <math.h> is broken. | |
1632 | I get segmentation faults when I run the program. | |
1633 | ||
1634 | {UD} Nope, the implementation is correct. The problem is with egcs version | |
1635 | prior to 1.1. I.e., egcs 1.0 to 1.0.3 are all broken (at least on Intel). | |
1636 | If you have to use this compiler you must define __NO_MATH_INLINES before | |
1637 | including <math.h> to prevent the inline functions from being used. egcs 1.1 | |
1638 | fixes the problem. I don't know about gcc 2.8 and 2.8.1. | |
1639 | ||
05f732b3 UD |
1640 | |
1641 | 3.15. The sys/sem.h file lacks the definition of `union semun'. | |
1642 | ||
1643 | {UD} Nope. This union has to be provided by the user program. Former glibc | |
1644 | versions defined this but it was an error since it does not make much sense | |
1645 | when thinking about it. The standards describing the System V IPC functions | |
1646 | define it this way and therefore programs must be adopted. | |
1647 | ||
33127459 UD |
1648 | |
1649 | 3.16. Why has <netinet/ip_fw.h> disappeared? | |
1650 | ||
1651 | {AJ} The corresponding Linux kernel data structures and constants are | |
b710a6e2 | 1652 | totally different in Linux 2.0 and Linux 2.2. This situation has to be |
33127459 UD |
1653 | taken care in user programs using the firewall structures and therefore |
1654 | those programs (ipfw is AFAIK the only one) should deal with this problem | |
1655 | themselves. | |
1656 | ||
28ab8526 UD |
1657 | |
1658 | 3.17. I get floods of warnings when I use -Wconversion and include | |
1659 | <string.h> or <math.h>. | |
1660 | ||
1661 | {ZW} <string.h> and <math.h> intentionally use prototypes to override | |
1662 | argument promotion. -Wconversion warns about all these. You can safely | |
1663 | ignore the warnings. | |
1664 | ||
1665 | -Wconversion isn't really intended for production use, only for shakedown | |
1666 | compiles after converting an old program to standard C. | |
1667 | ||
5ff1a70a UD |
1668 | |
1669 | 3.18. After upgrading to glibc 2.1, I receive errors about | |
1670 | unresolved symbols, like `_dl_initial_searchlist' and can not | |
1671 | execute any binaries. What went wrong? | |
1672 | ||
1673 | {AJ} This normally happens if your libc and ld (dynamic linker) are from | |
1674 | different releases of glibc. For example, the dynamic linker | |
1675 | /lib/ld-linux.so.2 comes from glibc 2.0.x, but the version of libc.so.6 is | |
1676 | from glibc 2.1. | |
1677 | ||
1678 | The path /lib/ld-linux.so.2 is hardcoded in every glibc2 binary but | |
1679 | libc.so.6 is searched via /etc/ld.so.cache and in some special directories | |
1680 | like /lib and /usr/lib. If you run configure with another prefix than /usr | |
1681 | and put this prefix before /lib in /etc/ld.so.conf, your system will break. | |
1682 | ||
1683 | So what can you do? Either of the following should work: | |
1684 | ||
1685 | * Run `configure' with the same prefix argument you've used for glibc 2.0.x | |
1686 | so that the same paths are used. | |
1687 | * Replace /lib/ld-linux.so.2 with a link to the dynamic linker from glibc | |
1688 | 2.1. | |
1689 | ||
1690 | You can even call the dynamic linker by hand if everything fails. You've | |
1691 | got to set LD_LIBRARY_PATH so that the corresponding libc is found and also | |
1692 | need to provide an absolute path to your binary: | |
1693 | ||
1694 | LD_LIBRARY_PATH=<path-where-libc.so.6-lives> \ | |
1695 | <path-where-corresponding-dynamic-linker-lives>/ld-linux.so.2 \ | |
1696 | <path-to-binary>/binary | |
1697 | ||
1698 | For example `LD_LIBRARY_PATH=/libold /libold/ld-linux.so.2 /bin/mv ...' | |
1699 | might be useful in fixing a broken system (if /libold contains dynamic | |
1700 | linker and corresponding libc). | |
1701 | ||
1702 | With that command line no path is used. To further debug problems with the | |
1703 | dynamic linker, use the LD_DEBUG environment variable, e.g. | |
1704 | `LD_DEBUG=help echo' for the help text. | |
1705 | ||
1706 | If you just want to test this release, don't put the lib directory in | |
1707 | /etc/ld.so.conf. You can call programs directly with full paths (as above). | |
1708 | When compiling new programs against glibc 2.1, you've got to specify the | |
1709 | correct paths to the compiler (option -I with gcc) and linker (options | |
1710 | --dynamic-linker, -L and --rpath). | |
1711 | ||
61952351 | 1712 | |
7d1de115 UD |
1713 | 3.19. bonnie reports that char i/o with glibc 2 is much slower than with |
1714 | libc5. What can be done? | |
1715 | ||
1716 | {AJ} The GNU C library uses thread safe functions by default and libc5 used | |
1717 | non thread safe versions. The non thread safe functions have in glibc the | |
1718 | suffix `_unlocked', for details check <stdio.h>. Using `putc_unlocked' etc. | |
1719 | instead of `putc' should give nearly the same speed with bonnie (bonnie is a | |
1720 | benchmark program for measuring disk access). | |
9f6b6d8d | 1721 | |
b93492aa UD |
1722 | |
1723 | 3.20. Programs compiled with glibc 2.1 can't read db files made with glibc | |
1724 | 2.0. What has changed that programs like rpm break? | |
1725 | ||
037f8020 | 1726 | {} Removed. Does not apply anymore. |
b93492aa | 1727 | |
b5a9efcd UD |
1728 | |
1729 | 3.21. Autoconf's AC_CHECK_FUNC macro reports that a function exists, but | |
1730 | when I try to use it, it always returns -1 and sets errno to ENOSYS. | |
1731 | ||
1732 | {ZW} You are using a 2.0 Linux kernel, and the function you are trying to | |
1733 | use is only implemented in 2.1/2.2. Libc considers this to be a function | |
1734 | which exists, because if you upgrade to a 2.2 kernel, it will work. One | |
1735 | such function is sigaltstack. | |
1736 | ||
1737 | Your program should check at runtime whether the function works, and | |
1738 | implement a fallback. Note that Autoconf cannot detect unimplemented | |
1739 | functions in other systems' C libraries, so you need to do this anyway. | |
1740 | ||
1741 | ||
1742 | 3.22. My program segfaults when I call fclose() on the FILE* returned | |
1743 | from setmntent(). Is this a glibc bug? | |
1744 | ||
1745 | {GK} No. Don't do this. Use endmntent(), that's what it's for. | |
1746 | ||
1747 | In general, you should use the correct deallocation routine. For instance, | |
1748 | if you open a file using fopen(), you should deallocate the FILE * using | |
1749 | fclose(), not free(), even though the FILE * is also a pointer. | |
1750 | ||
1751 | In the case of setmntent(), it may appear to work in most cases, but it | |
1752 | won't always work. Unfortunately, for compatibility reasons, we can't | |
1753 | change the return type of setmntent() to something other than FILE *. | |
1754 | ||
c891b2df UD |
1755 | |
1756 | 3.23. I get "undefined reference to `atexit'" | |
1757 | ||
1758 | {UD} This means that your installation is somehow broken. The situation is | |
1759 | the same as for 'stat', 'fstat', etc (see question 2.7). Investigate why the | |
1760 | linker does not pick up libc_nonshared.a. | |
1761 | ||
1762 | If a similar message is issued at runtime this means that the application or | |
1763 | DSO is not linked against libc. This can cause problems since 'atexit' is | |
1764 | not exported anymore. | |
1765 | ||
9f6b6d8d UD |
1766 | \f |
1767 | . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . | |
1768 | ||
7d1de115 | 1769 | 4. Miscellaneous |
61952351 | 1770 | |
7d1de115 | 1771 | 4.1. After I changed configure.in I get `Autoconf version X.Y. |
61952351 UD |
1772 | or higher is required for this script'. What can I do? |
1773 | ||
1774 | {UD} You have to get the specified autoconf version (or a later one) | |
a35cb74d | 1775 | from your favorite mirror of ftp.gnu.org. |
61952351 | 1776 | |
04be94a8 | 1777 | |
7d1de115 | 1778 | 4.2. When I try to compile code which uses IPv6 headers and |
61952351 UD |
1779 | definitions on my Linux 2.x.y system I am in trouble. |
1780 | Nothing seems to work. | |
1781 | ||
f12944ec UD |
1782 | {UD} The problem is that IPv6 development still has not reached a point |
1783 | where the headers are stable. There are still lots of incompatible changes | |
1784 | made and the libc headers have to follow. | |
61952351 | 1785 | |
348ed515 UD |
1786 | {PB} The 2.1 release of GNU libc aims to comply with the current versions of |
1787 | all the relevant standards. The IPv6 support libraries for older Linux | |
1788 | systems used a different naming convention and so code written to work with | |
1789 | them may need to be modified. If the standards make incompatible changes in | |
1790 | the future then the libc may need to change again. | |
1791 | ||
1792 | IPv6 will not work with a 2.0.x kernel. When kernel 2.2 is released it | |
1793 | should contain all the necessary support; until then you should use the | |
1794 | latest 2.1.x release you can find. As of 98/11/26 the currently recommended | |
1795 | kernel for IPv6 is 2.1.129. | |
1796 | ||
1797 | Also, as of the 2.1 release the IPv6 API provided by GNU libc is not | |
b669ab02 | 1798 | 100% complete. |
04be94a8 | 1799 | |
ff44f2a5 | 1800 | |
7d1de115 | 1801 | 4.3. When I set the timezone by setting the TZ environment variable |
ff44f2a5 UD |
1802 | to EST5EDT things go wrong since glibc computes the wrong time |
1803 | from this information. | |
1804 | ||
f12944ec UD |
1805 | {UD} The problem is that people still use the braindamaged POSIX method to |
1806 | select the timezone using the TZ environment variable with a format EST5EDT | |
8b4a4715 UD |
1807 | or whatever. People, if you insist on using TZ instead of the timezone |
1808 | database (see below), read the POSIX standard, the implemented behaviour is | |
f12944ec UD |
1809 | correct! What you see is in fact the result of the decisions made while |
1810 | POSIX.1 was created. We've only implemented the handling of TZ this way to | |
1811 | be POSIX compliant. It is not really meant to be used. | |
1812 | ||
1813 | The alternative approach to handle timezones which is implemented is the | |
1814 | correct one to use: use the timezone database. This avoids all the problems | |
1815 | the POSIX method has plus it is much easier to use. Simply run the tzselect | |
1816 | shell script, answer the question and use the name printed in the end by | |
8b4a4715 UD |
1817 | making a symlink /etc/localtime pointing to /usr/share/zoneinfo/NAME (NAME |
1818 | is the returned value from tzselect). That's all. You never again have to | |
1819 | worry. | |
f12944ec UD |
1820 | |
1821 | So, please avoid sending bug reports about time related problems if you use | |
1822 | the POSIX method and you have not verified something is really broken by | |
1823 | reading the POSIX standards. | |
ff44f2a5 | 1824 | |
fdacb17d | 1825 | |
7d1de115 | 1826 | 4.4. What other sources of documentation about glibc are available? |
fdacb17d UD |
1827 | |
1828 | {AJ} The FSF has a page about the GNU C library at | |
1829 | <http://www.gnu.org/software/libc/>. The problem data base of open and | |
1830 | solved bugs in GNU libc is available at | |
1831 | <http://www-gnats.gnu.org:8080/cgi-bin/wwwgnats.pl>. Eric Green has written | |
9de4e203 | 1832 | a HowTo for converting from Linux libc5 to glibc2. The HowTo is accessible |
fdacb17d UD |
1833 | via the FSF page and at <http://www.imaxx.net/~thrytis/glibc>. Frodo |
1834 | Looijaard describes a different way installing glibc2 as secondary libc at | |
1835 | <http://huizen.dds.nl/~frodol/glibc>. | |
1836 | ||
1837 | Please note that this is not a complete list. | |
1838 | ||
348ed515 | 1839 | |
7d1de115 | 1840 | 4.5. The timezone string for Sydney/Australia is wrong since even when |
348ed515 UD |
1841 | daylight saving time is in effect the timezone string is EST. |
1842 | ||
1843 | {UD} The problem for some timezones is that the local authorities decided | |
1844 | to use the term "summer time" instead of "daylight saving time". In this | |
1845 | case the abbreviation character `S' is the same as the standard one. So, | |
1846 | for Sydney we have | |
1847 | ||
1848 | Eastern Standard Time = EST | |
1849 | Eastern Summer Time = EST | |
1850 | ||
1851 | Great! To get this bug fixed convince the authorities to change the laws | |
1852 | and regulations of the country this effects. glibc behaves correctly. | |
1853 | ||
eeabe877 | 1854 | |
7d1de115 | 1855 | 4.6. I've build make 3.77 against glibc 2.1 and now make gets |
eeabe877 UD |
1856 | segmentation faults. |
1857 | ||
037f8020 | 1858 | {} Removed. Does not apply anymore, use make 3.79 or newer. |
eeabe877 | 1859 | |
c63598bf UD |
1860 | |
1861 | 4.7. Why do so many programs using math functions fail on my AlphaStation? | |
1862 | ||
1863 | {AO} The functions floor() and floorf() use an instruction that is not | |
1864 | implemented in some old PALcodes of AlphaStations. This may cause | |
1865 | `Illegal Instruction' core dumps or endless loops in programs that | |
1866 | catch these signals. Updating the firmware to a 1999 release has | |
1867 | fixed the problem on an AlphaStation 200 4/166. | |
1868 | ||
8892c471 UD |
1869 | |
1870 | 4.8. The conversion table for character set XX does not match with | |
1871 | what I expect. | |
1872 | ||
1873 | {UD} I don't doubt for a minute that some of the conversion tables contain | |
1874 | errors. We tried the best we can and relied on automatic generation of the | |
1875 | data to prevent human-introduced errors but this still is no guarantee. If | |
1876 | you think you found a problem please send a bug report describing it and | |
1877 | give an authoritive reference. The latter is important since otherwise | |
1878 | the current behaviour is as good as the proposed one. | |
1879 | ||
1880 | Before doing this look through the list of known problem first: | |
1881 | ||
1882 | - the GBK (simplified Chinese) encoding is based on Unicode tables. This | |
1883 | is good. These tables, however, differ slightly from the tables used | |
1884 | by the M$ people. The differences are these [+ Unicode, - M$]: | |
1885 | ||
1886 | +0xA1AA 0x2015 | |
1887 | +0xA844 0x2014 | |
1888 | -0xA1AA 0x2014 | |
1889 | -0xA844 0x2015 | |
1890 | ||
1891 | In addition the Unicode tables contain mappings for the GBK characters | |
1892 | 0xA8BC, 0xA8BF, 0xA989 to 0xA995, and 0xFE50 to 0xFEA0. | |
1893 | ||
ffa156af UD |
1894 | - when mapping from EUC-CN to GBK and vice versa we ignore the fact that |
1895 | the coded character at position 0xA1A4 maps to different Unicode | |
1896 | characters. Since the iconv() implementation can do whatever it wants | |
1897 | if it cannot directly map a character this is a perfectly good solution | |
1898 | since the semantics and appearance of the character does not change. | |
1899 | ||
be76803a UD |
1900 | |
1901 | 4.9. How can I find out which version of glibc I am using in the moment? | |
1902 | ||
1903 | {UD} If you want to find out about the version from the command line simply | |
1904 | run the libc binary. This is probably not possible on all platforms but | |
1905 | where it is simply locate the libc DSO and start it as an application. On | |
1906 | Linux like | |
1907 | ||
1908 | /lib/libc.so.6 | |
1909 | ||
1910 | This will produce all the information you need. | |
1911 | ||
1912 | What always will work is to use the API glibc provides. Compile and run the | |
1913 | following little program to get the version information: | |
1914 | ||
1915 | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | |
1916 | #include <stdio.h> | |
1917 | #include <gnu/libc-version.h> | |
1918 | int main (void) { puts (gnu_get_libc_version ()); return 0; } | |
1919 | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | |
1920 | ||
1921 | This interface can also obviously be used to perform tests at runtime if | |
1922 | this should be necessary. | |
1923 | ||
5e014387 UD |
1924 | |
1925 | 4.10. Context switching with setcontext() does not work from within | |
1926 | signal handlers. | |
1927 | ||
1928 | {DMT} The Linux implementations (IA-64, S390 so far) of setcontext() | |
1929 | supports synchronous context switches only. There are several reasons for | |
1930 | this: | |
1931 | ||
02eca23b AJ |
1932 | - UNIX provides no other (portable) way of effecting a synchronous |
1933 | context switch (also known as co-routine switch). Some versions | |
1934 | support this via setjmp()/longjmp() but this does not work | |
1935 | universally. | |
1936 | ||
1937 | - As defined by the UNIX '98 standard, the only way setcontext() | |
1938 | could trigger an asychronous context switch is if this function | |
1939 | were invoked on the ucontext_t pointer passed as the third argument | |
1940 | to a signal handler. But according to draft 5, XPG6, XBD 2.4.3, | |
1941 | setcontext() is not among the set of routines that may be called | |
1942 | from a signal handler. | |
1943 | ||
1944 | - If setcontext() were to be used for asynchronous context switches, | |
1945 | all kinds of synchronization and re-entrancy issues could arise and | |
1946 | these problems have already been solved by real multi-threading | |
1947 | libraries (e.g., POSIX threads or Linux threads). | |
1948 | ||
1949 | - Synchronous context switching can be implemented entirely in | |
1950 | user-level and less state needs to be saved/restored than for an | |
1951 | asynchronous context switch. It is therefore useful to distinguish | |
1952 | between the two types of context switches. Indeed, some | |
1953 | application vendors are known to use setcontext() to implement | |
1954 | co-routines on top of normal (heavier-weight) pre-emptable threads. | |
5e014387 UD |
1955 | |
1956 | It should be noted that if someone was dead-bent on using setcontext() | |
1957 | on the third arg of a signal handler, then IA-64 Linux could support | |
1958 | this via a special version of sigaction() which arranges that all | |
1959 | signal handlers start executing in a shim function which takes care of | |
1960 | saving the preserved registers before calling the real signal handler | |
1961 | and restoring them afterwards. In other words, we could provide a | |
1962 | compatibility layer which would support setcontext() for asynchronous | |
1963 | context switches. However, given the arguments above, I don't think | |
1964 | that makes sense. setcontext() provides a decent co-routine interface | |
1965 | and we should just discourage any asynchronous use (which just calls | |
1966 | for trouble at any rate). | |
1967 | ||
f8cac037 | 1968 | \f |
61952351 UD |
1969 | ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ |
1970 | ||
f8cac037 | 1971 | Answers were given by: |
5e014387 UD |
1972 | {UD} Ulrich Drepper, <drepper@redhat.com> |
1973 | {DMT} David Mosberger-Tang, <davidm@hpl.hp.com> | |
dd7d45e8 | 1974 | {RM} Roland McGrath, <roland@gnu.org> |
9de4e203 | 1975 | {AJ} Andreas Jaeger, <aj@suse.de> |
22d57dd3 | 1976 | {EY} Eric Youngdale, <eric@andante.jic.com> |
a5a0310d | 1977 | {PB} Phil Blundell, <Philip.Blundell@pobox.com> |
af6f3906 | 1978 | {MK} Mark Kettenis, <kettenis@phys.uva.nl> |
f4017d20 | 1979 | {ZW} Zack Weinberg, <zack@rabi.phys.columbia.edu> |
612fdf25 | 1980 | {TK} Thorsten Kukuk, <kukuk@suse.de> |
5e014387 | 1981 | {GK} Geoffrey Keating, <geoffk@redhat.com> |
a35cb74d | 1982 | {HJ} H.J. Lu, <hjl@gnu.org> |
b710a6e2 | 1983 | {CG} Cristian Gafton, <gafton@redhat.com> |
5e014387 | 1984 | {AO} Alexandre Oliva, <aoliva@redhat.com> |
1324affa | 1985 | {BH} Bruno Haible, <haible@clisp.cons.org> |
dfc89273 | 1986 | {SM} Steven Munroe, <sjmunroe@us.ibm.com> |
268dbf25 | 1987 | {CO} Carlos O'Donell, <carlos@systemhalted.org> |
f8cac037 RM |
1988 | \f |
1989 | Local Variables: | |
61952351 UD |
1990 | mode:outline |
1991 | outline-regexp:"\\?" | |
f12944ec | 1992 | fill-column:76 |
f8cac037 | 1993 | End: |