wiki:Getting-Started/iPhone

Version 47 (modified by ismangil, 12 years ago) (diff)

--

Getting Started: Building for Apple iPhone, iPad and iPod Touch

  1. Features
  2. Requirements
  3. Build Preparation
  4. Building PJSIP
  5. Simulator
  6. OpenSSL Suport
  7. Common problems
    1. Unable to accept incoming call in background mode (iOS4)
    2. Supporting multiple architectures (armv6 and armv7)
    3. Unable to support Bluetooth input
    4. Problem with interruption (by a phone call or an alarm), headset plug/unplug, or Bluetooth input
    5. Problem with deprecated CPU_SUBTYPE_ARM_ALL subtype
    6. Sound not working in the simulator
    7. List of Issues
  8. Other iPhone Projects

Apple iPhone target is supported by PJSIP version 1.7 and later.

Features

Some of the features of the iPhone port:

  • it has a native CoreAudio based audio device, which supports the following features:
    • the built-in/device's echo canceller
    • output volume setting
    • change input route to bluetooth input
    • change output route
    • input latency setting
    • output latency setting
  • supports for the built-in iLBC codec
  • Note: video (from 2.x) is not yet supported on iOS.

Requirements

You'll need an iPhone SDK, part of Xcode. Apple iPad is supported starting with iPhone SDK 3.2 onwards.

Make sure Command Line Tools in Xcode Preferences is installed:

Xcode Command Line Tools

Build Preparation

  1. Get the source code, if you haven't already.
  2. Set your config_site.h to the following:
    #define PJ_CONFIG_IPHONE 1
    #include <pj/config_site_sample.h>
    
    This will activate iPhone specific settings in the config_site_sample.h.

Building PJSIP

Just run:

$ cd /path/to/your/pjsip/dir
$ ./configure-iphone
$ make dep && make clean && make

Open ipjsua.xcodeproj using Xcode in pjproject/pjsip-apps/src/ipjsua and build the project.

Notes:

  • the ./configure-iphone is a wrapper that calls the standard ./configure script with settings suitable for iPhone target.
  • the latest iPhone SDK version will be selected by default. You may change this by setting IPHONESDK environment variable to the desired SDK path. For ipjsua, select Project-Edit Project Settings-Base SDK and Targets-ipjsua-Get Info-Base SDK to change the SDK version.
  • you may pass standard ./configure options to this script too.
  • for more info, run ./configure-iphone --help
  • other customizations are similar to what is explained in Building with GNU page.

Simulator

To configure the build system for the iPhone simulator:

export DEVPATH=/Developer/Platforms/iPhoneSimulator.platform/Developer
export CC=/Developer/Platforms/iPhoneSimulator.platform/Developer/usr/bin/gcc-4.0
CFLAGS="-O2 -m32 -miphoneos-version-min=4.0" LDFLAGS="-O2 -m32" ./configure-iphone
make dep && make clean && make

Note that the exact paths may vary according to your SDK version.

OpenSSL Suport

Follow the instructions below to enable TLS transport by using OpenSSL:

  1. Build and install OpenSSL-1.0.0 for iPhone by following these instructions or OpenSSL-0.9.8o with these instructions.
  2. Specify OpenSSL location when running configure-iphone, for example (with Bash):
    export OPENSSL=${HOME}/openssl/openssl_arm
    export CFLAGS="-O2 -Wno-unused-label -I${OPENSSL}/include"
    export LDFLAGS="-L${OPENSSL}/lib"
    ./configure-iphone
    
    And check that OpenSSL is detected by the configure script:
    ...
    checking for OpenSSL installations..
    checking openssl/ssl.h usability... yes
    checking openssl/ssl.h presence... no
    aconfigure: WARNING: openssl/ssl.h: accepted by the compiler, rejected by the preprocessor!
    aconfigure: WARNING: openssl/ssl.h: proceeding with the compiler's result
    checking for openssl/ssl.h... yes
    checking for ERR_load_BIO_strings in -lcrypto... yes
    checking for SSL_library_init in -lssl... yes
    OpenSSL library found, SSL support enabled
    ...
    
  3. Build the libraries:
    make dep && make
    
  4. In XCode project setting of your application (for example, ipjsua), add libssl.a and libcrypto.a from OpenSSL ARM directory to the project's Libraries:
    1. In Group & Files pane, expand ipjsua, then right click Libraries, and select Add -> Existing Files....
    2. Find libssl.a and libcrypto.a from OpenSSL ARM directory (for example, ${HOME}/openssl/openssl_arm) and add them to the project.
  5. Build the app

Common problems

Unable to accept incoming call in background mode (iOS4)

If while in the background, ipjsua (or your application) is unable to detect if there is an incoming call and display the local notification:

  1. Note that background feature only works with TCP.
  2. Make sure that voip is included in the required background modes (UIBackgroundModes) in the application’s Info.plist file.
  3. Make sure that the TCP socket is successfully wrapped with CFReadStreamRef (check if there is a message: "Failed to configure TCP transport for VoIP usage").
  4. Check whether you can accept the incoming call by bringing the app to the foreground. If yes, make sure that the incoming call request comes from the wrapped TCP socket (check the log for the INVITE request).

Note: these steps do not troubleshoot audio problems.

Supporting multiple architectures (armv6 and armv7)

You need to compile separately for each architecture. If your iPhone SDK has llvm-gcc compiler (which is the supported compiler starting iOS SDK 5), then you need to set ARCH environment variable to the desired architecture before running configure-iphone, for example:

export ARCH = "-arch armv6"

For traditional gcc, you need to use these compilation flags (for armv7):

export CFLAGS += -march=armv7 -mcpu=arm1176jzf-s -mcpu=cortex-a8
export LDFLAGS += -march=armv7 -mcpu=arm1176jzf-s -mcpu=cortex-a8

For armv6, you need to compile using the flags:

export CFLAGS += -march=armv6 -mcpu=arm1176jzf-s
export LDFLAGS += -march=armv6 -mcpu=arm1176jzf-s

Then you need to combine the resulting libraries using the lipo command. For example:

lipo -arch armv6 lib/armv6/libpjlib.a -arch armv7 lib/armv7/libpjlib.a -create -output lib/libpjlib.a

Unable to support Bluetooth input

Since Bluetooth input support is only available for iOS 3.1 or later, you need to specifically specify that your deployment target is iOS 3.1 or above. You can do this either in user.mak:

export CFLAGS += -D__IPHONE_OS_VERSION_MIN_REQUIRED=30100

or in config_site.h:

#define __IPHONE_OS_VERSION_MIN_REQUIRED 30100

You need to recompile PJSIP after this.

Problem with interruption (by a phone call or an alarm), headset plug/unplug, or Bluetooth input

For devices running iOS 4.0 or later, you need to enable your application to respond to remote-control events. This allows PJSIP to properly receive and process the above events. You can do this by adding the following code in your application:

[[UIApplication sharedApplication] beginReceivingRemoteControlEvents];

For more details, please refer to Apple's doc on Remote Control of Multimedia.

Problem with deprecated CPU_SUBTYPE_ARM_ALL subtype

If you get this warning during compilation:

CPU_SUBTYPE_ARM_ALL subtype is deprecated
warning: -force_cpusubtype_ALL will become unsupported for ARM architectures

Modify your user.mak (this requires at least gcc 4.2.1 so please use r3462 or later (see ticket #1218)):

export CFLAGS += -march=armv7 -mcpu=arm1176jzf-s -mcpu=cortex-a8
export LDFLAGS += -march=armv7 -mcpu=arm1176jzf-s -mcpu=cortex-a8

Then rebuild PJSIP. Next, change your XCode setting, go to Targets-ipjsua(or your application name)-Get Info-Build, select Architectures-armv7 and tick Build Active Architecture Only-Yes.

If you need to support another architecture and/or cpu subtype, you can visit Wikipedia doc on ARM architecture.

Sound not working in the simulator

Go to System Preferences > Sound > Sound Effects and then uncheck and recheck "Play user interface sound effects". If it still doesn't work, you can try some other suggestions here.

List of Issues

#1113
iPhone: Echo cancellation may not work on iOS using SDK 4.x
#1115
iPhone: Long delay when calling AudioConverterNew() causing timeout in acquiring pjsua lock (thanks Bogdan Krakowski the report)
#1130
Incoming TCP connection on iPhone iOS4 BG mode would fail over and over with EAGAIN error (thanks Bogdan Krakowski for the report)
#1172
Crash in coreaudio_dev (iPhone OS) when there is no call during a GSM interruption
#1174
Fix crash in coreaudio_dev's interruptionListener (iPhone OS) and support for multiple interrupted streams (thanks to Seth Hinze for the patch)
#1194
iPhone: Fix problems with echo cancellation and Bluetooth input (SDK 4.x)
#1225
iPhone: UDP socket send error after waking up from background mode (thanks Joe Meade for the report)
#1226
iPhone (info only): No audio in calls if app is woken up from background mode without network connectivity (thanks Joe Meade for the report)
#1228
Long delay in iPhone initialization (thanks Guy Zelkha for the report)
#1231
Crash in iPhone iOS when trying to make a call after the application is left running for days (thanks Alejandro Orellana for the report)
#1245
Assertion may be raised if iPhone app woken up to perform registration and the server is down (thanks Alejandro Orellana for the report)
#1246
Use CFHost API for pj_getaddrinfo() on iPhone OS
#1324
Build correctness on non-video platforms (Symbian, iPhone, Windows Mobile)
#1335
Fixes assertion when interruptionListener is called from an unregistered thread on iPhone OS (thanks to Ilya Kalinin for the patch)
#1342
Disable local host resolution on iPhone OS
#1482
iPhone: Solution for application getting killed by iOS 5 due to too many wakeups
#1597
Handle socket failure in STUN resolution when coming back from iPhone/iOS background mode

Other iPhone Projects

Also have a look at these PJSIP iPhone ports by pjsip users:

Attachments (1)

Download all attachments as: .zip