nix::kmod

Function init_module

Source
pub fn init_module(module_image: &[u8], param_values: &CStr) -> Result<()>
Expand description

Loads a kernel module from a buffer.

It loads an ELF image into kernel space, performs any necessary symbol relocations, initializes module parameters to values provided by the caller, and then runs the module’s init function.

This function requires CAP_SYS_MODULE privilege.

The module_image argument points to a buffer containing the binary image to be loaded. The buffer should contain a valid ELF image built for the running kernel.

The param_values argument is a string containing space-delimited specifications of the values for module parameters. Each of the parameter specifications has the form:

name[=value[,value...]]

§Example

use std::fs::File;
use std::io::Read;
use std::ffi::CString;
use nix::kmod::init_module;

let mut f = File::open("mykernel.ko").unwrap();
let mut contents: Vec<u8> = Vec::new();
f.read_to_end(&mut contents).unwrap();
init_module(&mut contents, &CString::new("who=Rust when=Now,12").unwrap()).unwrap();

See man init_module(2) for more information.