7faab1209ee5170af6290109ab1a5a7de4227f27
[asterisk/asterisk.git] / channels / h323 / README
1                 Open H.323 Channel Driver for Asterisk
2                         By Jeremy McNamara  
3                         For The NuFone Network
4
5              First public release on November 10th, 2002
6
7
8         Developed using:        RedHat 7.2/7.3/8.0
9                                 Open H.323 v1.11.7              
10                                 PWLib      v1.4.11
11                                 GCC   2.96/3.1/3.2
12
13         Dependancies:           openssl-0.9.6b
14                                 openssl-devel-0.9.6b
15                                 expat-1.95
16                                 expat-dev-1.95
17
18         Warning: Older versions than listed will NOT work, while newer versions
19                  should work, but most likely have not been well tested.
20
21
22 chan_h323 has been implemented using Asterisk's RTP stack insted of trying
23 to implement a pseudo sound card driver. 
24
25 NOTICE: Whatever you do, DO NOT USE distrubution specific installs
26 of Open H.323 and PWLib. In fact you should check to make sure 
27 your distro didn't install them for you without your knowledge.
28 Check everything out of CVS. If you dont know how to deal with cvs, learn. 
29 Also, if you are not using the listed versions of Open H.323 or PWlib 
30 you are on your own, sorry. 
31
32
33
34 To compile this code:
35 You first need the latest release versions of PWLib and Open H.323 from
36 http://www.openh323.org/. Make sure you follow the build instructions EXCPLICTLY.
37
38 Once PWLib and Open H.323 have been compiled, issue a make in the asterisk/channels/h323 
39 directory, then go back to the Asterisk source top level directory and issue a make install.
40
41
42
43 Most common compile error:  
44
45 If you receive ANYTHING that says 'undefined symbol' you are experiencing
46 typical version skew.  For example:
47
48 libh323_linux_x86_r.so.1: undefined symbol: GetNumberValueAt__C14PAbstractArrayi
49
50 You need to search and destroy every version of libh323 and libpt then 
51 completely recompile everything
52
53 Example commands to make sure everything gets cleaned and then
54 rebult in proper order:
55
56 cd /path/to/pwlib
57 make clean opt
58 cd /path/to/openh323
59 make clean opt 
60 cd /path/to/asterisk/channels/h323
61 make  
62 cd /path/to/asterisk
63 make install 
64
65 (Note: Open H.323 or PWLib never get a 'make install' so don't do it)
66  
67
68 Most common run-time error:
69
70 libpt_linux_x86_r.so.1: cannot open shared object file: No such 
71 file or directory
72
73 You have not set the LD_LIBRARY_PATH environment variable.
74
75 Example environment for sh/bash:
76
77 PWLIBDIR=$HOME/pwlib
78 export PWLIBDIR
79 OPENH323DIR=$HOME/openh323
80 export OPENH323DIR
81 LD_LIBRARY_PATH=$PWLIBDIR/lib:$OPENH323DIR/lib
82 export LD_LIBRARY_PATH
83
84 We recomend puting the above directives into your /etc/profile so 
85 you do not have to remember to export those values every time you 
86 want to recompile.
87
88
89 If you still have trouble please contact 'JerJer' in #Asterisk on 
90 irc.freenode.net or send and email to jj@nufone.net
91
92 If you happen to be lucky enough to segfault this code please run a 
93 backtrace  and send me the gory details. Segmentation faults are not
94 tolerated, no matter what Distro you run!
95
96 bt example:
97
98 # /usr/sbin/asterisk -vvvgc
99 ...
100 [chan_h323.so]
101 Segmentation Fault (core dumped)
102
103 # ls core.*
104 core.1976
105
106 # gdb /usr/sbin/asterisk core.1976
107 ...lots of useless garbage here..
108 (gdb) bt
109
110 Send whatever shows up right after the 'bt'
111
112
113 Also, a full debug screen output is almost needed. Make sure you are 
114 in the full console mode (-c) and turn on 'h.323  debug'. A nice way 
115 to capture everything is with script (man script) 
116
117
118
119 Jeremy McNamara
120 The NuFone Network