en:av_calls
Differences
This shows you the differences between two versions of the page.
Next revision | Previous revision | ||
en:av_calls [2010/10/17 15:36] – external edit 127.0.0.1 | en:av_calls [2019/04/28 13:50] (current) – external edit 127.0.0.1 | ||
---|---|---|---|
Line 1: | Line 1: | ||
# | # | ||
+ | |||
#labels Phase-Deploy, | #labels Phase-Deploy, | ||
+ | |||
+ | |||
= Introduction = | = Introduction = | ||
+ | |||
+ | |||
== What is it about? == | == What is it about? == | ||
- | This is an implementation of [[http:// | + | |
+ | |||
+ | This is an implementation of [[http:// | ||
+ | |||
Together with XEP-0167, several other technologies are used. One of them is the multimedia back-end [[http:// | Together with XEP-0167, several other technologies are used. One of them is the multimedia back-end [[http:// | ||
+ | |||
+ | |||
GStreamer is considered to be one of the most powerful multimedia frameworks available. It can be easily extended and it is used by many third-party developers (It is used by almost all multimedia applications in Gnome. In KDE it can be used together with Phonon). | GStreamer is considered to be one of the most powerful multimedia frameworks available. It can be easily extended and it is used by many third-party developers (It is used by almost all multimedia applications in Gnome. In KDE it can be used together with Phonon). | ||
+ | |||
+ | |||
ICE (in this case specifically Jingle ICE-UDP) describes the process of establishing connections between clients, which ports are used, etc. (for details, look at the specification). | ICE (in this case specifically Jingle ICE-UDP) describes the process of establishing connections between clients, which ports are used, etc. (for details, look at the specification). | ||
+ | |||
+ | |||
Regarding the ports used for data transmissing, | Regarding the ports used for data transmissing, | ||
+ | |||
+ | |||
The project page is here [[http:// | The project page is here [[http:// | ||
+ | |||
+ | |||
+ | |||
== Compatibility with various operating systems == | == Compatibility with various operating systems == | ||
+ | |||
+ | |||
* MS Windows - a precompiled version can be found on [[http:// | * MS Windows - a precompiled version can be found on [[http:// | ||
+ | |||
* Gentoo Linux - emerge psimedia (rion-overlay) | * Gentoo Linux - emerge psimedia (rion-overlay) | ||
+ | |||
* Ubuntu - supports from version 9.04 | * Ubuntu - supports from version 9.04 | ||
+ | |||
* Mac OS X - a precompiled version can be found on [[http:// | * Mac OS X - a precompiled version can be found on [[http:// | ||
+ | |||
+ | |||
+ | |||
== Building on `*`nix systems == | == Building on `*`nix systems == | ||
+ | |||
+ | |||
Psimedia is used to encode/ | Psimedia is used to encode/ | ||
+ | |||
+ | |||
+ | |||
=== Requirements for building === | === Requirements for building === | ||
+ | |||
+ | |||
* [[https:// | * [[https:// | ||
+ | |||
* *gstreamer-plugins-base-0.10.22* | * *gstreamer-plugins-base-0.10.22* | ||
+ | |||
* gstreamer-plugins-good | * gstreamer-plugins-good | ||
+ | |||
* *glib-2.20* | * *glib-2.20* | ||
+ | |||
* [[http:// | * [[http:// | ||
+ | |||
* *speex-1.2rc1* | * *speex-1.2rc1* | ||
+ | |||
* *liboil0.3* | * *liboil0.3* | ||
+ | |||
* *Qt* | * *Qt* | ||
+ | |||
+ | |||
*IMPORTANT: | *IMPORTANT: | ||
+ | |||
+ | |||
Officially only glib 2.19.x is necessary (it's not clear which version psimedia requires to work without problems). | Officially only glib 2.19.x is necessary (it's not clear which version psimedia requires to work without problems). | ||
+ | |||
+ | |||
Plug-ins: speex, v4l, v4l2, theora, ogg, alsa, jpeg. | Plug-ins: speex, v4l, v4l2, theora, ogg, alsa, jpeg. | ||
+ | |||
+ | |||
+ | |||
=== Building process === | === Building process === | ||
+ | |||
+ | |||
A simple script to do the build when the requirements are installed, can be found [[http:// | A simple script to do the build when the requirements are installed, can be found [[http:// | ||
+ | |||
+ | |||
Before building, you need to specify the Psi installation path. in case no prefix (--prefix) was specified when configuring Psi (configure), | Before building, you need to specify the Psi installation path. in case no prefix (--prefix) was specified when configuring Psi (configure), | ||
+ | |||
+ | |||
< | < | ||
+ | |||
svn co https:// | svn co https:// | ||
+ | |||
cd psimedia | cd psimedia | ||
+ | |||
qconf | qconf | ||
+ | |||
./configure | ./configure | ||
+ | |||
make | make | ||
+ | |||
mkdir -p / | mkdir -p / | ||
+ | |||
cp gstprovider/ | cp gstprovider/ | ||
+ | |||
</ | </ | ||
+ | |||
+ | |||
When building fails with the following error: | When building fails with the following error: | ||
+ | |||
< | < | ||
+ | |||
cc1: warnings being treated as errors | cc1: warnings being treated as errors | ||
+ | |||
</ | </ | ||
+ | |||
you can try the following: | you can try the following: | ||
+ | |||
< | < | ||
+ | |||
sed 's/ -Werror//' | sed 's/ -Werror//' | ||
+ | |||
</ | </ | ||
+ | |||
but it should be able to work without this :-) | but it should be able to work without this :-) | ||
+ | |||
+ | |||
+ | |||
== Testing == | == Testing == | ||
+ | |||
+ | |||
To test, run demo/demo once the build is finished. In the demo program, copy-paste the codec line into the box below to get the same image there. | To test, run demo/demo once the build is finished. In the demo program, copy-paste the codec line into the box below to get the same image there. | ||
+ | |||
+ | |||
+ | |||
== Connecting over IPv4 using STUN == | == Connecting over IPv4 using STUN == | ||
+ | |||
+ | |||
If you are behind a router performing Network Address Translation (NAT), then you also need to set up a STUN server. This can be set up on the last tab in the account settings. You can use stun.ekiga.net (if it doesn' | If you are behind a router performing Network Address Translation (NAT), then you also need to set up a STUN server. This can be set up on the last tab in the account settings. You can use stun.ekiga.net (if it doesn' | ||
+ | |||
Also check your voice call settings in the Psi prefences. | Also check your voice call settings in the Psi prefences. | ||
+ | |||
+ | |||
_UPD_: *jabber.ru* is now also running a stun server: *stun.jabber.ru* port: *5249*. | _UPD_: *jabber.ru* is now also running a stun server: *stun.jabber.ru* port: *5249*. | ||
+ | |||
< | < | ||
+ | |||
{{psiplus_account_props.png< | {{psiplus_account_props.png< | ||
+ | |||
+ | |||
+ | |||
+ | |||
= Troubleshooting Voice Calls with Psi/Psi+ = | = Troubleshooting Voice Calls with Psi/Psi+ = | ||
+ | |||
+ | |||
== First step, install the latest version of Psi/Psi+ == | == First step, install the latest version of Psi/Psi+ == | ||
+ | |||
+ | |||
Psi 0.14 has several known interoperability issues with voice calls. To get voice calls to work stable, it is essential to be using a recent version of Psi/Psi+. | Psi 0.14 has several known interoperability issues with voice calls. To get voice calls to work stable, it is essential to be using a recent version of Psi/Psi+. | ||
+ | |||
+ | |||
== Second step, make sure your system is reachable over IPv6 == | == Second step, make sure your system is reachable over IPv6 == | ||
+ | |||
+ | |||
Many systems cannot be reached over IPv4, which means a direct connection is impossible. The easiest solution to this problem is enabling IPv6 support. Even when your internet service provider does not offer IPv6 connectivity, | Many systems cannot be reached over IPv4, which means a direct connection is impossible. The easiest solution to this problem is enabling IPv6 support. Even when your internet service provider does not offer IPv6 connectivity, | ||
+ | |||
+ | |||
=== Enable IPv6 connectivity === | === Enable IPv6 connectivity === | ||
+ | |||
+ | |||
On older systems, such as MS Windows XP, IPv6 connectivity is not enabled by default. On MS Windows XP, the following command enables IPv6 support: | On older systems, such as MS Windows XP, IPv6 connectivity is not enabled by default. On MS Windows XP, the following command enables IPv6 support: | ||
+ | |||
< | < | ||
+ | |||
netsh interface ipv6 install | netsh interface ipv6 install | ||
+ | |||
</ | </ | ||
+ | |||
+ | |||
If your service provider offers native IPv6 support, you may already be able to access the [[http:// | If your service provider offers native IPv6 support, you may already be able to access the [[http:// | ||
+ | |||
+ | |||
=== Set up an IPv6 tunnel using [[http:// | === Set up an IPv6 tunnel using [[http:// | ||
+ | |||
+ | |||
When your service provider does not offer native IPv6 connectivity, | When your service provider does not offer native IPv6 connectivity, | ||
+ | |||
< | < | ||
+ | |||
netsh interface ipv6 set teredo client | netsh interface ipv6 set teredo client | ||
+ | |||
</ | </ | ||
+ | |||
+ | |||
On Debian and Ubuntu a tunnel can be set up with this command: | On Debian and Ubuntu a tunnel can be set up with this command: | ||
+ | |||
< | < | ||
+ | |||
apt-get install miredo | apt-get install miredo | ||
+ | |||
</ | </ | ||
+ | |||
or when you are not root: | or when you are not root: | ||
+ | |||
< | < | ||
+ | |||
sudo apt-get install miredo | sudo apt-get install miredo | ||
+ | |||
</ | </ | ||
+ | |||
+ | |||
Other GNU/Linux distributions should also have the miredo package in their repositories. | Other GNU/Linux distributions should also have the miredo package in their repositories. | ||
+ | |||
+ | |||
Now try the [[http:// | Now try the [[http:// | ||
+ | |||
+ | |||
=== Set up an IPv6 tunnel using Freenet6 === | === Set up an IPv6 tunnel using Freenet6 === | ||
+ | |||
+ | |||
When Teredo does not work, you can also use Freenet6 to establish an IPv6 tunnel. Download one of the following for MS Windows: | When Teredo does not work, you can also use Freenet6 to establish an IPv6 tunnel. Download one of the following for MS Windows: | ||
+ | |||
+ | |||
* [[http:// | * [[http:// | ||
+ | |||
* [[http:// | * [[http:// | ||
+ | |||
+ | |||
Install and let the client connect. This should give you IPv6 connectivity. You can check this again using the [[http:// | Install and let the client connect. This should give you IPv6 connectivity. You can check this again using the [[http:// | ||
+ | |||
+ | |||
There is also a gw6c available in Debian and Ubuntu. | There is also a gw6c available in Debian and Ubuntu. | ||
+ | |||
+ | |||
+ | |||
When both parties can access the [[http:// | When both parties can access the [[http:// | ||
+ | |||
+ | |||
+ | |||
== Final step, test your speakers and microphone == | == Final step, test your speakers and microphone == | ||
+ | |||
+ | |||
Test your speakers and microphone. On GNU/Linux with ALSA a simple test can be done with this command: | Test your speakers and microphone. On GNU/Linux with ALSA a simple test can be done with this command: | ||
+ | |||
< | < | ||
+ | |||
arecord | aplay | arecord | aplay | ||
+ | |||
</ | </ | ||
+ | |||
+ | |||
On MS Windows, the sound recorder can be used to verify the microphone is working correctly. | On MS Windows, the sound recorder can be used to verify the microphone is working correctly. | ||
+ | |||
+ | |||
For testing in Psi/Psi+, try the (Collabora) echo test from [[http:// | For testing in Psi/Psi+, try the (Collabora) echo test from [[http:// | ||
+ | |||
Note that these tests do not offer IPv6 support yet. | Note that these tests do not offer IPv6 support yet. | ||
+ | |||
+ | |||
+ | |||
= Frequently Asked Questions = | = Frequently Asked Questions = | ||
+ | |||
+ | |||
== Why should I use IPv6? == | == Why should I use IPv6? == | ||
+ | |||
+ | |||
There are also several ways to get IPv4 connectivity to work fully from any situation. One option is to set a STUN server as described in the previous section. These approaches tend to be significantly more fragile however. This writer of this text really recommends both parties to enable IPv6 connectivity in the case of voice calls between two Psi instances. This has shown to give a 100% success rate so far. | There are also several ways to get IPv4 connectivity to work fully from any situation. One option is to set a STUN server as described in the previous section. These approaches tend to be significantly more fragile however. This writer of this text really recommends both parties to enable IPv6 connectivity in the case of voice calls between two Psi instances. This has shown to give a 100% success rate so far. | ||
+ | |||
+ | |||
+ | |||
== Why can't I phone a Nokia N900? Why does Psi/Psi+ only support Speex? == | == Why can't I phone a Nokia N900? Why does Psi/Psi+ only support Speex? == | ||
+ | |||
+ | |||
Right now it is not possible to establish a succesful phone call to an N900 user. In the service discovery window, you may see the error "codec mismatch" | Right now it is not possible to establish a succesful phone call to an N900 user. In the service discovery window, you may see the error "codec mismatch" | ||
+ | |||
* G729 | * G729 | ||
+ | |||
* ILBC | * ILBC | ||
+ | |||
* PCMA | * PCMA | ||
+ | |||
* PCMU | * PCMU | ||
+ | |||
+ | |||
Psi+ only supports: | Psi+ only supports: | ||
+ | |||
* Speex Wideband | * Speex Wideband | ||
+ | |||
* Speex Narrowband (only in case both Psi+ and Psimedia+, both patched with the patches from [[http:// | * Speex Narrowband (only in case both Psi+ and Psimedia+, both patched with the patches from [[http:// | ||
+ | |||
+ | |||
Since they have no codec in common. Direct voice calls will always fail between them. Both phones can however dial to Asterisk and should be able to participate on the same voice conference, in which case Asterisk would take care of the transcoding. | Since they have no codec in common. Direct voice calls will always fail between them. Both phones can however dial to Asterisk and should be able to participate on the same voice conference, in which case Asterisk would take care of the transcoding. | ||
+ | |||
+ | |||
The reason Psimedia only supports these codecs is because it currently does not contain any form of codec negotiation. In the future, codec negotiation will be added to Psimedia using the Farsight library. This will bring support for many common codecs including PCMA and PCMU which will allow phone calls to phones such as the Nokia N900 to work. | The reason Psimedia only supports these codecs is because it currently does not contain any form of codec negotiation. In the future, codec negotiation will be added to Psimedia using the Farsight library. This will bring support for many common codecs including PCMA and PCMU which will allow phone calls to phones such as the Nokia N900 to work. | ||
+ | |||
+ | |||
+ | |||
== What about video phoning? == | == What about video phoning? == | ||
+ | |||
+ | |||
There is an undocumented environment variable, which enables video call support. This support has not seen much testing however and may not work at all. In case you still want to try it, set *PSI_ENABLE_VIDEO=1* before launching Psi. | There is an undocumented environment variable, which enables video call support. This support has not seen much testing however and may not work at all. In case you still want to try it, set *PSI_ENABLE_VIDEO=1* before launching Psi. | ||
+ | |||
+ | |||
*Some notes:* | *Some notes:* | ||
+ | |||
* On Linux, always choose the V4L2 variant of your camera. V4L1 likely will not work. | * On Linux, always choose the V4L2 variant of your camera. V4L1 likely will not work. | ||
+ | |||
* On Linux, there has been success with 2 different cameras using the gspca module, a camera with the uvcvideo module did not work for unknown reasons | * On Linux, there has been success with 2 different cameras using the gspca module, a camera with the uvcvideo module did not work for unknown reasons | ||
+ | |||
* On Windows, any camera with a working driver is expected to work | * On Windows, any camera with a working driver is expected to work | ||
+ | |||
+ | |||
+ | |||
= Other = | = Other = | ||
+ | |||
+ | |||
== TODO by Justin == | == TODO by Justin == | ||
+ | |||
+ | |||
What's left to do: | What's left to do: | ||
+ | |||
* Make the calldlg prettier. | * Make the calldlg prettier. | ||
+ | |||
* Make a new sound effect for incoming calls. | * Make a new sound effect for incoming calls. | ||
+ | |||
* Reconcile with existing VoiceCallManager/ | * Reconcile with existing VoiceCallManager/ | ||
+ | |||
+ | |||
== Additional information == | == Additional information == | ||
- | [http:// | + | |
+ | [[http:// | ||
+ | [[http:// | ||
+ | [[https:// | ||
en/av_calls.1287329812.txt.gz · Last modified: 2012/04/06 06:42 (external edit)