fdf_component/
macros.rs

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
// Copyright 2024 The Fuchsia Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

//! Implementation of the [`driver_register`] macro for registering driver implementations
//! with the driver host.

use crate::server::DriverServer;
use crate::Driver;

/// These re-exports are for the use of the macro and so should not be surfaced in documentation.
#[doc(hidden)]
pub use fdf_sys::{
    fdf_dispatcher_get_current_dispatcher, DriverRegistration,
    DriverRegistration_driver_registration_v1, DRIVER_REGISTRATION_VERSION_1,
};

/// Called by the macro [`driver_register`] to create the driver registration struct
/// without exposing any of the internal implementation as a public API.
#[doc(hidden)]
pub const fn make_driver_registration<T: Driver>() -> DriverRegistration {
    DriverRegistration {
        version: DRIVER_REGISTRATION_VERSION_1 as u64,
        v1: DriverRegistration_driver_registration_v1 {
            initialize: Some(DriverServer::<T>::initialize),
            destroy: Some(DriverServer::<T>::destroy),
        },
    }
}

/// Macro for declaring a driver's implementation of the [`Driver`] trait.
///
/// # Example
///
/// ```
/// use fdf_server::{driver_register, Driver, DriverContext};
/// use log::info;
/// use zx::Status;
///
/// #[derive(Default)]
/// struct TestDriver;
///
/// impl Driver for TestDriver {
///     async fn start(context: DriverContext) -> Result<Self, Status> {
///         info!("driver starting!");
///         // implement binding the node client, creating children, etc. here.
///         Ok(Self)
///     }
///     async fn stop(&self) {
///         info!("driver stop message");
///     }
/// }
///
/// driver_register!(TestDriver);
/// ```
#[macro_export]
macro_rules! driver_register {
    ($ty:ty) => {
        #[no_mangle]
        #[link_section = ".driver_registration"]
        #[allow(non_upper_case_globals)]
        pub static __fuchsia_driver_registration__: $crate::macros::DriverRegistration =
            $crate::macros::make_driver_registration::<$ty>();
    };
}