Since August 22th 2023, the "main" branch of libiio contains what will eventually become libiio v1.0. It features a brand new API, which is incompatible with libiio v0.25 and older. Have a look at the wiki for a description of the API changes.
The old v0.x API can still be found in the libiio-v0 branch. Libiio v0.x is now considered legacy, and as such, only important bug fixes will be accepted into this branch.
Old programs compiled against libiio v0.x will still be able to run with libiio v1.0 and newer, as it provides a compatibility layer.
Library for interfacing with Linux IIO devices
libiio is used to interface to the Linux Industrial Input/Output (IIO) Subsystem. The Linux IIO subsystem is intended to provide support for devices that in some sense are analog to digital or digital to analog converters (ADCs, DACs). This includes, but is not limited to ADCs, Accelerometers, Gyros, IMUs, Capacitance to Digital Converters (CDCs), Pressure Sensors, Color, Light and Proximity Sensors, Temperature Sensors, Magnetometers, DACs, DDS (Direct Digital Synthesis), PLLs (Phase Locked Loops), Variable/Programmable Gain Amplifiers (VGA, PGA), and RF transceivers. You can use libiio natively on an embedded Linux target (local mode), or use libiio to communicate remotely to that same target from a host Linux, Windows or MAC over USB or Ethernet or Serial.
Although libiio was primarily developed by Analog Devices Inc., it is an active open source library, which many people have contributed to. The library is released under the GNU Lesser General Public License (LGPL), version 2.1 or (at your option) any later version, this open-source license allows anyone to use the library, on any vendors processor/FPGA/SoC, which may be controlling any vendors peripheral device (ADC, DAC, etc) either locally or remotely. This includes closed or open-source, commercial or non-commercial applications (subject to the LGPL license freedoms, obligations and restrictions). The examples and test applications (sometimes referred to as the iio-utils) are released separately under the GNU General Public License (GPL) version 2.0 (at your option) any later version.
Library License : Tests/Examples License : Latest Release : Downloads :
Scans : Release docs: Issues :
Support:
If you have a question about libiio and an Analog Devices IIO kernel driver please ask on : . If you have a question about a non-ADI devices, please ask it on github.
As with many open source packages, we use GitHub to do develop and maintain the source, and Azure Pipelines for continuous integration.
- If you want to just use libiio, we suggest using the latest release.
- If you think you have found a bug in the release, or need a feature which isn't in the release, try the latest untested binaries from the main branch and check out the documentation based on the main branch. We provide builds for a few operating systems. If you need something else, we can most likely add that -- just ask.
If you use it, and like it - please let us know. If you use it, and hate it - please let us know that too. The goal of the project is to try to make Linux IIO devices easier to use on a variety of platforms. If we aren't doing that - we will try to make it better.
Feedback is appreciated (in order of preference):
- Github trackers for bugs, improvements, or feature requests
- Analog Devices web forums for general help on libiio and/or ADI Linux IIO drivers
- The IIO mailing list for questions about other Linux IIO drivers, or kernel-specific IIO questions
Weblinks:
- About IIO: https://wiki.analog.com/software/linux/docs/iio/iio
- API Documentation: http://analogdevicesinc.github.io/libiio/
- Libiio : http://wiki.analog.com/resources/tools-software/linux-software/libiio
- Libiio internals : http://wiki.analog.com/resources/tools-software/linux-software/libiio_internals
- The Ubuntu packages are known to work on their Debian counterpart releases.