aboutsummaryrefslogtreecommitdiffstats
path: root/contrib/libs/c-ares/INSTALL.md
blob: e8a36773e412ff62e07d54669ca9f353ac702274 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
** This file is adapted from libcurl and not yet fully rewritten for c-ares! **

``` 
                          ___       __ _ _ __ ___  ___ 
                         / __| ___ / _` | '__/ _ \/ __|
                        | (_  |___| (_| | | |  __/\__ \
                         \___|     \__,_|_|  \___||___/

                                How To Compile
``` 

Installing Binary Packages
==========================

Lots of people download binary distributions of c-ares. This document 
does not describe how to install c-ares using such a binary package. 
This document describes how to compile, build and install c-ares from 
source code. 

Building from Git 
=================

If you get your code off a Git repository rather than an official 
release tarball, see the [GIT-INFO](GIT-INFO) file in the root directory 
for specific instructions on how to proceed. 

In particular, if not using CMake you will need to run `./buildconf` (Unix) or 
`buildconf.bat` (Windows) to generate build files, and for the former 
you will need a local installation of Autotools.  If using CMake the steps are 
the same for both Git and official release tarballs. 

AutoTools Build 
=============== 

### General Information, works on most Unix Platforms (Linux, FreeBSD, etc) 

A normal Unix installation is made in three or four steps (after you've 
unpacked the source archive): 

    ./configure 
    make 
    make ahost adig acountry (optional) 
    make install 

You probably need to be root when doing the last command. 

If you have checked out the sources from the git repository, read the 
[GIT-INFO](GIT_INFO) on how to proceed. 

Get a full listing of all available configure options by invoking it like: 

    ./configure --help 

If you want to install c-ares in a different file hierarchy than /usr/local, 
you need to specify that already when running configure: 

    ./configure --prefix=/path/to/c-ares/tree 

If you happen to have write permission in that directory, you can do `make 
install` without being root. An example of this would be to make a local 
install in your own home directory: 

    ./configure --prefix=$HOME 
    make 
    make install 

### More Options 

To force configure to use the standard cc compiler if both cc and gcc are 
present, run configure like 

    CC=cc ./configure 
    # or 
    env CC=cc ./configure 

To force a static library compile, disable the shared library creation 
by running configure like: 

    ./configure --disable-shared 

If you're a c-ares developer and use gcc, you might want to enable more 
debug options with the `--enable-debug` option. 

### Special Cases 

Some versions of uClibc require configuring with `CPPFLAGS=-D_GNU_SOURCE=1` 
to get correct large file support. 

The Open Watcom C compiler on Linux requires configuring with the variables: 

    ./configure CC=owcc AR="$WATCOM/binl/wlib" AR_FLAGS=-q \ 
        RANLIB=/bin/true STRIP="$WATCOM/binl/wstrip" CFLAGS=-Wextra 


### CROSS COMPILE 

(This section was graciously brought to us by Jim Duey, with additions by 
Dan Fandrich) 

Download and unpack the c-ares package. 

`cd` to the new directory. (e.g. `cd c-ares-1.7.6`) 

Set environment variables to point to the cross-compile toolchain and call 
configure with any options you need.  Be sure and specify the `--host` and 
`--build` parameters at configuration time.  The following script is an 
example of cross-compiling for the IBM 405GP PowerPC processor using the 
toolchain from MonteVista for Hardhat Linux. 

```sh 
#! /bin/sh 

export PATH=$PATH:/opt/hardhat/devkit/ppc/405/bin 
export CPPFLAGS="-I/opt/hardhat/devkit/ppc/405/target/usr/include" 
export AR=ppc_405-ar 
export AS=ppc_405-as 
export LD=ppc_405-ld 
export RANLIB=ppc_405-ranlib 
export CC=ppc_405-gcc 
export NM=ppc_405-nm 

./configure --target=powerpc-hardhat-linux \ 
     --host=powerpc-hardhat-linux \ 
     --build=i586-pc-linux-gnu \ 
     --prefix=/opt/hardhat/devkit/ppc/405/target/usr/local \ 
     --exec-prefix=/usr/local 
``` 

You may also need to provide a parameter like `--with-random=/dev/urandom` 
to configure as it cannot detect the presence of a random number 
generating device for a target system.  The `--prefix` parameter 
specifies where c-ares will be installed.  If `configure` completes 
successfully, do `make` and `make install` as usual. 

In some cases, you may be able to simplify the above commands to as 
little as: 

    ./configure --host=ARCH-OS 


### Cygwin (Windows) 

Almost identical to the unix installation. Run the configure script in the 
c-ares root with `sh configure`. Make sure you have the sh executable in 
`/bin/` or you'll see the configure fail toward the end. 

Run `make` 


### QNX 

(This section was graciously brought to us by David Bentham) 

As QNX is targeted for resource constrained environments, the QNX headers 
set conservative limits. This includes the `FD_SETSIZE` macro, set by default 
to 32. Socket descriptors returned within the c-ares library may exceed this, 
resulting in memory faults/SIGSEGV crashes when passed into `select(..)` 
calls using `fd_set` macros. 

A good all-round solution to this is to override the default when building 
c-ares, by overriding `CFLAGS` during configure, example: 

    # configure CFLAGS='-DFD_SETSIZE=64 -g -O2' 


### RISC OS 

The library can be cross-compiled using gccsdk as follows: 

    CC=riscos-gcc AR=riscos-ar RANLIB='riscos-ar -s' ./configure \ 
         --host=arm-riscos-aof --without-random --disable-shared 
    make 

where `riscos-gcc` and `riscos-ar` are links to the gccsdk tools. 
You can then link your program with `c-ares/lib/.libs/libcares.a`. 


### Android 

Method using a configure cross-compile (tested with Android NDK r7b): 

  - prepare the toolchain of the Android NDK for standalone use; this can 
    be done by invoking the script: 

        ./tools/make-standalone-toolchain.sh 

    which creates a usual cross-compile toolchain. Lets assume that you put 
    this toolchain below `/opt` then invoke configure with something 
    like: 

    ``` 
        export PATH=/opt/arm-linux-androideabi-4.4.3/bin:$PATH 
       ./configure --host=arm-linux-androideabi [more configure options] 
        make
    ``` 
  - if you want to compile directly from our GIT repo you might run into 
    this issue with older automake stuff: 

    ``` 
        checking host system type... 
        Invalid configuration `arm-linux-androideabi': 
        system `androideabi' not recognized 
        configure: error: /bin/sh ./config.sub arm-linux-androideabi failed 
    ``` 
    this issue can be fixed with using more recent versions of `config.sub` 
    and `config.guess` which can be obtained here: 
    http://git.savannah.gnu.org/gitweb/?p=config.git;a=tree 
    you need to replace your system-own versions which usually can be 
    found in your automake folder: 
    `find /usr -name config.sub` 


CMake builds 
============ 

Current releases of c-ares introduce a CMake v3+ build system that has been 
tested on most platforms including Windows, Linux, FreeBSD, MacOS, AIX and 
Solaris. 

In the most basic form, building with CMake might look like: 

```sh 
cd /path/to/cmake/source 
mkdir build 
cd build 
cmake -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=/usr/local/cares .. 
make 
sudo make install 
``` 

Options 
------- 

Options to CMake are passed on the command line using "-D${OPTION}=${VALUE}". 
The values defined are all boolean and take values like On, Off, True, False. 

* CARES_STATIC - Build the static library (off by default) 
* CARES_SHARED - Build the shared library (on by default) 
* CARES_INSTALL - Hook in installation, useful to disable if chain building 
* CARES_STATIC_PIC - Build the static library as position-independent (off by 
   default) 


Ninja 
----- 

Ninja is the next-generation build system meant for generators like CMake that 
heavily parallize builds.  Its use is very similar to the normal build: 

```sh 
cd /path/to/cmake/source 
mkdir build 
cd build 
cmake -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=/usr/local/cares -G "Ninja" .. 
ninja 
sudo ninja install 
``` 

Windows MSVC Command Line 
------------------------- 

``` 
cd \path\to\cmake\source 
mkdir build 
cd build 
cmake -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=C:\cares -G "NMake Makefiles" .. 
nmake 
nmake install 
``` 

Windows MinGW-w64 Command Line via MSYS 
--------------------------------------- 
``` 
cd \path\to\cmake\source 
mkdir build 
cd build 
cmake -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=C:\cares -G "MSYS Makefiles" .. 
make 
make install 
``` 


Platform-specific build systems 
=============================== 

Win32 
----- 

### Building Windows DLLs and C run-time (CRT) linkage issues 

As a general rule, building a DLL with static CRT linkage is highly 
discouraged, and intermixing CRTs in the same app is something to 
avoid at any cost. 
 
Reading and comprehension of Microsoft Knowledge Base articles 
KB94248 and KB140584 is a must for any Windows developer. Especially 
important is full understanding if you are not going to follow the 
advice given above. 
 
 - [KB94248](http://support.microsoft.com/kb/94248/en-us) - How To Use the C Run-Time 
 
 - [KB140584](http://support.microsoft.com/kb/140584/en-us) - How to link with the correct C Run-Time (CRT) library 
 
 - [KB190799](http://msdn.microsoft.com/en-us/library/ms235460) - Potential Errors Passing CRT Objects Across DLL Boundaries 
 
If your app is misbehaving in some strange way, or it is suffering 
from memory corruption, before asking for further help, please try 
first to rebuild every single library your app uses as well as your 
app using the debug multithreaded dynamic C runtime. 
 
 
### MingW32 
 
Make sure that MinGW32's bin dir is in the search path, for example: 
 
    set PATH=c:\mingw32\bin;%PATH% 
 
then run 'make -f Makefile.m32' in the root dir. 
 
 
### MSVC 6 caveats 
 
If you use MSVC 6 it is required that you use the February 2003 edition PSDK: 
http://www.microsoft.com/msdownload/platformsdk/sdkupdate/psdk-full.htm 
 
 
### MSVC from command line 
 
Run the `vcvars32.bat` file to get a proper environment. The 
`vcvars32.bat` file is part of the Microsoft development environment and 
you may find it in `C:\Program Files\Microsoft Visual Studio\vc98\bin` 
provided that you installed Visual C/C++ 6 in the default directory. 
 
Further details in [README.msvc](README.msvc) 
 
 
### MSVC IDEs 
 
Details in [README.msvc](README.msvc) 
 
 
### Important static c-ares usage note 
 
When building an application that uses the static c-ares library, you must 
add `-DCARES_STATICLIB` to your `CFLAGS`.  Otherwise the linker will look for 
dynamic import symbols. 
 
 
IBM OS/2 
-------- 
 
Building under OS/2 is not much different from building under unix. 
You need: 
 
  - emx 0.9d 
  - GNU make 
  - GNU patch 
  - ksh 
  - GNU bison 
  - GNU file utilities 
  - GNU sed 
  - autoconf 2.13 
 
If during the linking you get an error about `_errno` being an undefined 
symbol referenced from the text segment, you need to add `-D__ST_MT_ERRNO__` 
in your definitions. 
 
If you're getting huge binaries, probably your makefiles have the `-g` in 
`CFLAGS`. 
 
 
NetWare 
------- 
 
To compile `libcares.a` / `libcares.lib` you need: 
 
 - either any gcc / nlmconv, or CodeWarrior 7 PDK 4 or later. 
 - gnu make and awk running on the platform you compile on; 
   native Win32 versions can be downloaded from: 
   http://www.gknw.net/development/prgtools/ 
 - recent Novell LibC SDK available from: 
   http://developer.novell.com/ndk/libc.htm 
 - or recent Novell CLib SDK available from: 
   http://developer.novell.com/ndk/clib.htm 
 
Set a search path to your compiler, linker and tools; on Linux make 
sure that the var `OSTYPE` contains the string 'linux'; set the var 
`NDKBASE` to point to the base of your Novell NDK; and then type 
`make -f Makefile.netware` from the top source directory; 
 
 
PORTS
=====

This is a probably incomplete list of known hardware and operating systems 
that c-ares has been compiled for. If you know a system c-ares compiles and 
runs on, that isn't listed, please let us know! 

     - Alpha Tru64 v5.0 5.1 
     - ARM Android 1.5, 2.1, 2.3 
     - MIPS IRIX 6.2, 6.5 
     - Power AIX 3.2.5, 4.2, 4.3.1, 4.3.2, 5.1, 5.2 
     - i386 Linux 1.3, 2.0, 2.2, 2.3, 2.4, 2.6 
     - i386 Novell NetWare 
     - i386 Windows 95, 98, ME, NT, 2000, XP, 2003 
     - x86_64 Linux 
 
 
Useful URLs
===========

 - c-ares: https://c-ares.haxx.se/ 
 - MingW: http://www.mingw.org/ 
 - MinGW-w64: http://mingw-w64.sourceforge.net/ 
 - OpenWatcom: http://www.openwatcom.org/