GitXplorerGitXplorer
a

azbuse

public
7 stars
0 forks
11 issues

Commits

List of commits on branch master.
Unverified
628c349d819d42640554b992b2dacd5965d92f94

Use Ubuntu 24.04

aakiradeveloper committed 8 months ago
Unverified
18ebb64c02bba242e8bf7be75cc6bc2349872c53

Print kernel version

aakiradeveloper committed 8 months ago
Unverified
2eb6badbaa792027c09a6a74dc533b3d9a08faec

Update README

aakiradeveloper committed 8 months ago
Unverified
3220d7e920097f15988dc62d24be1d37c50d679a

Use __s32 as error type

aakiradeveloper committed 8 months ago
Unverified
5d1ef4743158e6c9c5d3cf4049525ec235530ef4

fix: Pass PAGE_SHIFT from kernel

aakiradeveloper committed 8 months ago
Unverified
bff771fb7af8767cc870869fa59f626ffd301e97

Modify CI

aakiradeveloper committed 8 months ago

README

The README file for this repository.

AZBUSE

MIT licensed

Block device in userspace.

Motivation

Developing a kernel module is hard. It's hard because you need to understand the kernel internal which is very complicated therefore very hard to understand.

You sometimes want to develop a storage driver, either filesystem or block device, but implemention is very hard. Besides, in-kernel implementation may not be the best choice for the realization of your idea when it wants libraries that are found only in userland. For these reasons, it would be nice if you can develop a storage driver in userland. Language like Rust will be the optimal language choice for this purpose because it often involves system-level programming.

Filesystem in userspace (FUSE) is an well-established solution for this problem and there are libraries in many languages including Rust. However, it only supports filesystem not block device.

Block device in userspace has been pursued by many developers and there are existing projects that implement this. However, none of them are best for the following two reasons.

Firstly, most of them use Network Block Device (NBD) for interacting with the kernel. Using NBD is not the best option for these two reasons: 1) It is sub-optimal in performance because it involves network stack and 2) It drops information about the request (e.g. request flags) because NBD rounds it up. The best starred project named BUSE is of this category.

Secondly, none of them allow users to implement block device application in Rust. All I found are in either C or Go.

This project azbuse aims to be the best solution for block device in userspace by implementing special kernel module for interacting with kernel and providing Rust library for implementing block device applications.

Architecture

The diagram below illustrates the architecture of azbuse.

After loading the azbuse kernel module, you can see a /dev/azbusectl device. You also need to install azbusectl command to add or remove a block device. sudo azbusectl add 1 will create /dev/azbuse1 and this will be the interface for I/O submission from clients.

All you need to do is implement StorageEngine trait and you can connect your implementation to kernel to get I/O requests from /dev/azbuse1 through the in-kernel queue. The kernel interactions are done through ioctl and kernel pages are mmaped for efficient data transfer.

スクリーンショット 2024-05-17 17 45 27

Goal "Everything in Rust."

Since I am a Rust enthusiast, I want to implement everything in Rust.

  • [x] Implement block device in userspace in Rust.
  • [ ] Implementing kernel module in Rust using Rust for Linux.