You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			|  | 5 years ago | |
|---|---|---|
| .. | ||
| examples | 5 years ago | |
| src | 5 years ago | |
| .gitignore | 5 years ago | |
| Cargo.toml | 5 years ago | |
| README.md | 5 years ago | |
| bindgen.sh | 5 years ago | |
| cbindgen.toml | 5 years ago | |
| memflow_win32.h | 5 years ago | |
| memflow_win32_cpp.h | 5 years ago | |
		
			
				
				README.md
			
		
		
			
			
		
	
	memflow-win32-ffi
The memflow win32 FFI crate provides an interface to the memflow-win32 API for C/C++. Currently a single memflow_win32.h file is generated aside from the dynamic library that can be used to interact with memflow.
This FFI library is intended to be used in combination with the memflow-ffi library.
A simple example that initializes the memflow-ffi and memflow-win32-ffi:
#include "memflow_win32.h"
#include <stdio.h>
int main(int argc, char *argv[]) {
	log_init(1);
	ConnectorInventory *inv = inventory_try_new();
	printf("inv: %p\n", inv);
	const char *conn_name = argc > 1? argv[1]: "kvm";
	const char *conn_arg = argc > 2? argv[2]: "";
	CloneablePhysicalMemoryObj *conn =
        inventory_create_connector(inv, conn_name, conn_arg);
	printf("conn: %p\n", conn);
	if (conn) {
		Kernel *kernel = kernel_build(conn);
		printf("Kernel: %p\n", kernel);
		Win32Version ver = kernel_winver(kernel);
		printf("major: %d\n", ver.nt_major_version);
		printf("minor: %d\n", ver.nt_minor_version);
		printf("build: %d\n", ver.nt_build_number);
		kernel_free(kernel);
	}
	inventory_free(inv);
	return 0;
}
Additional examples can be found in the examples folder as well as in the memflow-ffi crate.