# Core Linux V4L2 API for Rust (core) [![github](https://img.shields.io/badge/github-katyo/linux--video--rs-8da0cb.svg?style=for-the-badge&logo=github)](https://github.com/katyo/linux-video-rs) [![crate](https://img.shields.io/crates/v/linux-video-core.svg?style=for-the-badge&color=fc8d62&logo=rust)](https://crates.io/crates/linux-video-core) [![docs](https://img.shields.io/badge/docs.rs-linux--video--core-66c2a5?style=for-the-badge&logo=)](https://docs.rs/linux-video-core) [![MIT](https://img.shields.io/badge/License-MIT-brightgreen.svg?style=for-the-badge)](https://opensource.org/licenses/MIT) [![CI](https://img.shields.io/github/actions/workflow/status/katyo/linux-video-rs/ci.yml?branch=master&style=for-the-badge&logo=github-actions&logoColor=white)](https://github.com/katyo/linux-video-rs/actions?query=workflow%3ARust) This crates intended to provide access to Linux V4L2 APIs without any limitations. The primary design goal is an optimal balance between safety and overhead. The implementation much closer to system calls than v4l. Interface types wraps kernel types to avoid unnecessary copying. At end this is my demure attempt to do things right. ## Crates - **[linux-video-core](https://crates.io/crates/linux-video-core)** - core abstractions and low level interface (not for end users) - [linux-video](https://crates.io/crates/linux-video) - sync interface which supports synchronous operation only - [tokio-linux-video](https://crates.io/crates/tokio-linux-video) - async interface for [tokio](https://tokio.rs/) users - [async-std-linux-video](https://crates.io/crates/async-std-linux-video) - async interface for [async-std](https://async.rs/) users This crate provides low-level bindings and does not intended to end-users.