at v6.16-rc4 1.7 kB view raw
1// SPDX-License-Identifier: GPL-2.0 2 3//! Bindings. 4//! 5//! Imports the generated bindings by `bindgen`. 6//! 7//! This crate may not be directly used. If you need a kernel C API that is 8//! not ported or wrapped in the `kernel` crate, then do so first instead of 9//! using this crate. 10 11#![no_std] 12// See <https://github.com/rust-lang/rust-bindgen/issues/1651>. 13#![cfg_attr(test, allow(deref_nullptr))] 14#![cfg_attr(test, allow(unaligned_references))] 15#![cfg_attr(test, allow(unsafe_op_in_unsafe_fn))] 16#![allow( 17 clippy::all, 18 missing_docs, 19 non_camel_case_types, 20 non_upper_case_globals, 21 non_snake_case, 22 improper_ctypes, 23 unreachable_pub, 24 unsafe_op_in_unsafe_fn 25)] 26 27#[allow(dead_code)] 28#[allow(clippy::undocumented_unsafe_blocks)] 29#[cfg_attr(CONFIG_RUSTC_HAS_UNNECESSARY_TRANSMUTES, allow(unnecessary_transmutes))] 30mod bindings_raw { 31 // Manual definition for blocklisted types. 32 type __kernel_size_t = usize; 33 type __kernel_ssize_t = isize; 34 type __kernel_ptrdiff_t = isize; 35 36 // Use glob import here to expose all helpers. 37 // Symbols defined within the module will take precedence to the glob import. 38 pub use super::bindings_helper::*; 39 include!(concat!( 40 env!("OBJTREE"), 41 "/rust/bindings/bindings_generated.rs" 42 )); 43} 44 45// When both a directly exposed symbol and a helper exists for the same function, 46// the directly exposed symbol is preferred and the helper becomes dead code, so 47// ignore the warning here. 48#[allow(dead_code)] 49mod bindings_helper { 50 // Import the generated bindings for types. 51 use super::bindings_raw::*; 52 include!(concat!( 53 env!("OBJTREE"), 54 "/rust/bindings/bindings_helpers_generated.rs" 55 )); 56} 57 58pub use bindings_raw::*;