Liblinphone is a high level library integrating all the SIP video calls feature into a single easy to use API. Usually telecommunications is made of two things: media (transport of voice or video, encoding and decoding...), and signaling (routing calls, ringing, accepting a call etc...).

Liblinphone aims at combining the two things together and doing most things automatically. This makes it easier to the programmer to implement video calls in any application, without being an expert in VoIP and telecommunications. Liblinphone is an open source library based on Mediastreamer2 for voice/video streaming, and belle-sip for SIP signaling.

Liblinphone in Linphone architecture

Linphone and linphonec are directly based on Liblinphone.


Signaling features

  • SIP user agent compliant with RFC 3261
  • IPv6 dual stack or v6-only mode
  • Digest authentication
  • Supports multiple calls simultaneously with call management features: hold on with music, resume, transfer...
  • Multiple SIP proxy support: registrar, proxies, outbound proxies
  • Text instant messaging with delivery and "is typing" notification
  • Presence using list subscription to presence server, or in peer to peer mode
  • DTMF (telephone tones) support using SIP INFO or RFC 2833

Media features

Liblinphone leverages on mediastreamer2 engine for rendering audio & video streams, and as such takes advantages of all features implemented in mediastreamer2.


Liblinphone is available on the following platforms:

  • GNU/Linux: x86, x86-64, ARM v5, v7, arm64 ; Debian 7/8, Centos 6/7
  • Windows Desktop: x86 (works also on x86_64)   Vista and later
  • Mac OS X: x86_64 ; 10.7 and later.
  • GNU/Linux embedded: Linphonec or liblinphone are good candidates to provide the software stack of an hardware phone or hardware communication system.
  • Apple iOS 9 to 11 (ARM v7, ARM 64)
  • Google Android 4.1 to 8.1 (ARM v7-v8, x86)
  • BlackBerry OS10 (ARM v7)
  • Windows 10 (mobile and desktop) (ARM v7)

Implemented standards

Registration, calls, CORE FUNCTIONS

  • Session Initiation Protocol, RFC 3261
    • 8. General User Agent behaviour
    • 9. Cancelling a request
    • 10. Registrations
    • 12. Dialogs
    • 13. Initiating a session
    • 14. Modifying an existing session
    • 15. Terminating a session
    • 17. Transactions
    • 18. Transports
    • 22.4 The Digest Authentication Scheme
  • Session Description Protocol, RFC 4566
  • An Offer/Answer Model with the Session Description Protocol (SDP), RFC 3264
  • An Extension to the Session Initiation Protocol (SIP), RFC 3581 (use of rport parameter)
  • Session Initiation Protocol (SIP) INFO Method and Package Framework, RFC 6086
    • 4. The INFO Method
  • The Session Initiation Protocol (SIP) Refer Method, RFC 3515
    • 2. The REFER Method
  • Session Description Protocol (SDP) Security Descriptions for Media Streams, RFC 4568
  • Managing Client-Initiated Connections in the Session Initiation Protocol (+sip.instance parameter), RFC 5626
  • Connection reuse in the Session Initiation Protocol (alias parameter), RFC 5923
  • Correct Transaction Handling for 2xx Response to Session Initiation Protocol (SIP) INVITE Requests, RFC 6026
  • A privacy mechanism for the Session Initiation Protocol, RFC 3323
  • Private Extensions to the Session Initiation Protocol (SIP) for Asserted Identity within Trusted Networks, RFC 3325
  • Interactive Connectivity Establishment (ICE), RFC 5245
  • Re-INVITE and Target-Refresh Request Handling, RFC 6141, chpt. 5 only


  • A Presence Event Package for the Session Initiation Protocol (SIP), RFC 3856
  • Session Initiation Protocol (SIP) Extension for Event State Publication, RFC 3903 (Creation of PUBLISH requests)
  • A Data Model for Presence, RFC 4479
  • RPID: Rich Presence Extensions to the Presence Information Data Format (PIDF), RFC 4480
  • Subscriptions to Request-Contained Resource Lists in the Session Initiation Protocol (SIP), RFC 5367
  • Session Initiation Protocol (SIP) - Specific Event Notification, RFC 6665
  • SIP body compression, RFC 1951
  • Message Body Handling in the Session Initiation Protocol, RFC 5621


  • Session Initiation Protocol, RFC 3261
  • The Session Initiation Protocol (SIP) Refer Method, RFC 3515
    • 2. The REFER Method
  • Indication of message composition in instant messaging, RFC 3994
  • Session Initiation Protocol (SIP) Extension for Instant Messaging, RFC 3428 (only text/plain messages)
  • Subscriptions to Request-Contained Resource Lists in the Session Initiation Protocol (SIP), RFC 5367
  • Session Initiation Protocol (SIP) - Specific Event Notification, RFC 6665
  • SIP body compression, RFC 1951
  • Message Body Handling in the Session Initiation Protocol, RFC 5621
  • SIP Call Control - Conferencing for User Agents, RFC 4579
  • Conference Establishment Using Request-Contained Lists in SIP, RFC 5366
  • Obtaining and Using Globally Routable User Agent URIs (GRUUs) in SIP, RFC 5627
  • SIP Event Package for Conference State, RFC 4575
  • File transfer also possible via HTTP POST/GET - RCS vnd.gsma.rcs-ft-http+xml
  • Common Presence and Instant Messaging (CPIM): Message Format, RFC 3862
  • Instant Message Disposition Notification, RFC 5438





Liblinphone is dual licensed. It can be licensed and distributed:

  • under GNU GPLv2 license - for free (open source)
  • under proprietary and commercial license to be used in closed source applications. Contact Belledonne Communications for costs and other service information.


Liblinphone Android version:

Liblinphone IOS version:

Liblinphone Blackberry:

Liblinphone win32 SDK version:

Liblinphone macos SDK version:

Source code

Please see Linphone Source code section.



The Liblinphone wiki gives good hints to start programming with liblinphone.

The API reference documentations are available in various formats depending on the target programming language:

Liblinphone C API documentation (used for Linux, Windows, Mac and iOS) documented with Doxygen.

Liblinphone's Java wrapper for Android applications.

Python wrapper documentation