#input-output #linux #iio #analog #unsafe-bindings

sys libiio-sys

Native, unsafe, bindings to the Linux libiio library. Used by industrial-io.

5 releases (3 breaking)

0.4.0 Dec 10, 2024
0.3.1 Jan 28, 2022
0.3.0 May 26, 2021
0.2.0 Dec 29, 2019
0.1.0 Nov 22, 2018

#461 in Embedded development

Download history 1044/week @ 2024-09-24 896/week @ 2024-10-01 898/week @ 2024-10-08 797/week @ 2024-10-15 810/week @ 2024-10-22 1021/week @ 2024-10-29 615/week @ 2024-11-05 723/week @ 2024-11-12 1075/week @ 2024-11-19 681/week @ 2024-11-26 813/week @ 2024-12-03 943/week @ 2024-12-10 689/week @ 2024-12-17 440/week @ 2024-12-24 583/week @ 2024-12-31 680/week @ 2025-01-07

2,522 downloads per month
Used in 2 crates (via industrial-io)

MIT license

2MB
44K SLoC

Rust wrapper for Linux Industrial I/O library, libiio

Crates.io

Rust wrapper for the Linux Industrial I/O user-space library, libiio. This provides high-performance analog input and output on Linux systems.

Currently this defaults to bindings for libiio v0.25.

To use in an application, add this to Cargo.toml:

[dependencies]
libiio-sys = "0.4"

Generating Bindings

Bindings for different versions of the C library can be generated using the bindgen command-line tools.

Run bindgen over the iio.h header from the desired version of the library, outputting the results to a file,

bindings-<version>_<size>.rs

where <version> is the libiio version and <size> is the target CPU word size (typically 32 or 64).

So, for example, this is how we generated them v0.25, on a 64-bit system:

First we cloned the repo and checked out the proper version:

$ git clone https://github.com/analogdevicesinc/libiio.git
$ cd libiio
$ git checkout v0.25

Then into the directory for this repo, we ran bindgen on the header saving the result in the bindings directory:

$ cd industrial-io/libiio-sys/
$ bindgen ~/libiio/iio.h -o bindings/bindings-0.25_64.rs

Dependencies