summaryrefslogtreecommitdiff
path: root/rust-src/bch_bindgen/src/opts.rs
diff options
context:
space:
mode:
authorTruongSinh Tran-Nguyen <i@truongsinh.pro>2023-04-27 11:02:00 -0700
committerKent Overstreet <kent.overstreet@linux.dev>2023-04-27 19:23:17 -0400
commitc1a8e27a3fad202750a1b66a1fd1fa82a8a5bd92 (patch)
tree1bb2e1fbe3ceee13ae4b8a4257ef31e1c924a4a8 /rust-src/bch_bindgen/src/opts.rs
parent9ee211eacad51bce6858ca9b9755b6c9eb253f2e (diff)
chore(rust): add opt_get! and expose some FMODE_* as Rust const
In an effort to rewrite `bch2_read_super` from C to Rust, it is neccessary to have `opt_get!` macro defined, and some FMODE_* consts (defined as macro in `include/linux/blkdev.h`) defined as Rust const. Bindgen is currently unable to exapnd C functional macro [1], this this commit use the workaround as introduced in [2]. [1] https://github.com/rust-lang/rust-bindgen/issues/753 [2] https://github.com/rust-lang/rust-bindgen/issues/753#issuecomment-608546390 Signed-off-by: TruongSinh Tran-Nguyen <i@truongsinh.pro>
Diffstat (limited to 'rust-src/bch_bindgen/src/opts.rs')
-rw-r--r--rust-src/bch_bindgen/src/opts.rs30
1 files changed, 28 insertions, 2 deletions
diff --git a/rust-src/bch_bindgen/src/opts.rs b/rust-src/bch_bindgen/src/opts.rs
index e2261993..d38d469c 100644
--- a/rust-src/bch_bindgen/src/opts.rs
+++ b/rust-src/bch_bindgen/src/opts.rs
@@ -3,7 +3,33 @@ macro_rules! opt_set {
($opts:ident, $n:ident, $v:expr) => {
bch_bindgen::paste! {
$opts.$n = $v;
- $opts.[<set_ $n _defined>](1);
+ $opts.[<set_ $n _defined>](1)
}
- }
+ };
+}
+
+#[macro_export]
+macro_rules! opt_defined {
+ ($opts:ident, $n:ident) => {
+ bch_bindgen::paste! {
+ $opts.[< $n _defined>]()
+ }
+ };
+}
+
+#[macro_export]
+macro_rules! opt_get {
+ ($opts:ident, $n:ident) => {
+ if bch_bindgen::opt_defined!($opts, $n) == 0 {
+ bch_bindgen::paste! {
+ unsafe {
+ bch_bindgen::bcachefs::bch2_opts_default.$n
+ }
+ }
+ } else {
+ bch_bindgen::paste! {
+ $opts.$n
+ }
+ }
+ };
}