Skip to main content

fidl_cf_sc_internal_drivermanagerconfig__common/
fidl_cf_sc_internal_drivermanagerconfig__common.rs

1// WARNING: This file is machine generated by fidlgen.
2
3#![warn(clippy::all)]
4#![allow(unused_parens, unused_mut, unused_imports, nonstandard_style)]
5
6use bitflags::bitflags;
7use fidl::encoding::{MessageBufFor, ProxyChannelBox, ResourceDialect};
8use futures::future::{self, MaybeDone, TryFutureExt};
9use zx_status;
10
11#[derive(Clone, Debug, Eq, Hash, Ord, PartialEq, PartialOrd)]
12pub struct Config {
13    pub delay_fallback_until_base_drivers_indexed: bool,
14    pub enable_test_shutdown_delays: bool,
15    pub power_inject_offer: bool,
16    pub power_suspend_enabled: bool,
17    pub root_driver: String,
18    pub set_root_driver_host_critical: bool,
19    pub suspend_timeout_fallback: bool,
20    pub wait_for_suspending_token: bool,
21}
22
23impl fidl::Persistable for Config {}
24
25mod internal {
26    use super::*;
27
28    impl fidl::encoding::ValueTypeMarker for Config {
29        type Borrowed<'a> = &'a Self;
30        fn borrow(value: &<Self as fidl::encoding::TypeMarker>::Owned) -> Self::Borrowed<'_> {
31            value
32        }
33    }
34
35    unsafe impl fidl::encoding::TypeMarker for Config {
36        type Owned = Self;
37
38        #[inline(always)]
39        fn inline_align(_context: fidl::encoding::Context) -> usize {
40            8
41        }
42
43        #[inline(always)]
44        fn inline_size(_context: fidl::encoding::Context) -> usize {
45            32
46        }
47    }
48
49    unsafe impl<D: fidl::encoding::ResourceDialect> fidl::encoding::Encode<Config, D> for &Config {
50        #[inline]
51        unsafe fn encode(
52            self,
53            encoder: &mut fidl::encoding::Encoder<'_, D>,
54            offset: usize,
55            _depth: fidl::encoding::Depth,
56        ) -> fidl::Result<()> {
57            encoder.debug_check_bounds::<Config>(offset);
58            // Delegate to tuple encoding.
59            fidl::encoding::Encode::<Config, D>::encode(
60                (
61                    <bool as fidl::encoding::ValueTypeMarker>::borrow(
62                        &self.delay_fallback_until_base_drivers_indexed,
63                    ),
64                    <bool as fidl::encoding::ValueTypeMarker>::borrow(
65                        &self.enable_test_shutdown_delays,
66                    ),
67                    <bool as fidl::encoding::ValueTypeMarker>::borrow(&self.power_inject_offer),
68                    <bool as fidl::encoding::ValueTypeMarker>::borrow(&self.power_suspend_enabled),
69                    <fidl::encoding::BoundedString<100> as fidl::encoding::ValueTypeMarker>::borrow(
70                        &self.root_driver,
71                    ),
72                    <bool as fidl::encoding::ValueTypeMarker>::borrow(
73                        &self.set_root_driver_host_critical,
74                    ),
75                    <bool as fidl::encoding::ValueTypeMarker>::borrow(
76                        &self.suspend_timeout_fallback,
77                    ),
78                    <bool as fidl::encoding::ValueTypeMarker>::borrow(
79                        &self.wait_for_suspending_token,
80                    ),
81                ),
82                encoder,
83                offset,
84                _depth,
85            )
86        }
87    }
88    unsafe impl<
89        D: fidl::encoding::ResourceDialect,
90        T0: fidl::encoding::Encode<bool, D>,
91        T1: fidl::encoding::Encode<bool, D>,
92        T2: fidl::encoding::Encode<bool, D>,
93        T3: fidl::encoding::Encode<bool, D>,
94        T4: fidl::encoding::Encode<fidl::encoding::BoundedString<100>, D>,
95        T5: fidl::encoding::Encode<bool, D>,
96        T6: fidl::encoding::Encode<bool, D>,
97        T7: fidl::encoding::Encode<bool, D>,
98    > fidl::encoding::Encode<Config, D> for (T0, T1, T2, T3, T4, T5, T6, T7)
99    {
100        #[inline]
101        unsafe fn encode(
102            self,
103            encoder: &mut fidl::encoding::Encoder<'_, D>,
104            offset: usize,
105            depth: fidl::encoding::Depth,
106        ) -> fidl::Result<()> {
107            encoder.debug_check_bounds::<Config>(offset);
108            // Zero out padding regions. There's no need to apply masks
109            // because the unmasked parts will be overwritten by fields.
110            unsafe {
111                let ptr = encoder.buf.as_mut_ptr().add(offset).offset(0);
112                (ptr as *mut u64).write_unaligned(0);
113            }
114            unsafe {
115                let ptr = encoder.buf.as_mut_ptr().add(offset).offset(24);
116                (ptr as *mut u64).write_unaligned(0);
117            }
118            // Write the fields.
119            self.0.encode(encoder, offset + 0, depth)?;
120            self.1.encode(encoder, offset + 1, depth)?;
121            self.2.encode(encoder, offset + 2, depth)?;
122            self.3.encode(encoder, offset + 3, depth)?;
123            self.4.encode(encoder, offset + 8, depth)?;
124            self.5.encode(encoder, offset + 24, depth)?;
125            self.6.encode(encoder, offset + 25, depth)?;
126            self.7.encode(encoder, offset + 26, depth)?;
127            Ok(())
128        }
129    }
130
131    impl<D: fidl::encoding::ResourceDialect> fidl::encoding::Decode<Self, D> for Config {
132        #[inline(always)]
133        fn new_empty() -> Self {
134            Self {
135                delay_fallback_until_base_drivers_indexed: fidl::new_empty!(bool, D),
136                enable_test_shutdown_delays: fidl::new_empty!(bool, D),
137                power_inject_offer: fidl::new_empty!(bool, D),
138                power_suspend_enabled: fidl::new_empty!(bool, D),
139                root_driver: fidl::new_empty!(fidl::encoding::BoundedString<100>, D),
140                set_root_driver_host_critical: fidl::new_empty!(bool, D),
141                suspend_timeout_fallback: fidl::new_empty!(bool, D),
142                wait_for_suspending_token: fidl::new_empty!(bool, D),
143            }
144        }
145
146        #[inline]
147        unsafe fn decode(
148            &mut self,
149            decoder: &mut fidl::encoding::Decoder<'_, D>,
150            offset: usize,
151            _depth: fidl::encoding::Depth,
152        ) -> fidl::Result<()> {
153            decoder.debug_check_bounds::<Self>(offset);
154            // Verify that padding bytes are zero.
155            let ptr = unsafe { decoder.buf.as_ptr().add(offset).offset(0) };
156            let padval = unsafe { (ptr as *const u64).read_unaligned() };
157            let mask = 0xffffffff00000000u64;
158            let maskedval = padval & mask;
159            if maskedval != 0 {
160                return Err(fidl::Error::NonZeroPadding {
161                    padding_start: offset + 0 + ((mask as u64).trailing_zeros() / 8) as usize,
162                });
163            }
164            let ptr = unsafe { decoder.buf.as_ptr().add(offset).offset(24) };
165            let padval = unsafe { (ptr as *const u64).read_unaligned() };
166            let mask = 0xffffffffff000000u64;
167            let maskedval = padval & mask;
168            if maskedval != 0 {
169                return Err(fidl::Error::NonZeroPadding {
170                    padding_start: offset + 24 + ((mask as u64).trailing_zeros() / 8) as usize,
171                });
172            }
173            fidl::decode!(
174                bool,
175                D,
176                &mut self.delay_fallback_until_base_drivers_indexed,
177                decoder,
178                offset + 0,
179                _depth
180            )?;
181            fidl::decode!(
182                bool,
183                D,
184                &mut self.enable_test_shutdown_delays,
185                decoder,
186                offset + 1,
187                _depth
188            )?;
189            fidl::decode!(bool, D, &mut self.power_inject_offer, decoder, offset + 2, _depth)?;
190            fidl::decode!(bool, D, &mut self.power_suspend_enabled, decoder, offset + 3, _depth)?;
191            fidl::decode!(
192                fidl::encoding::BoundedString<100>,
193                D,
194                &mut self.root_driver,
195                decoder,
196                offset + 8,
197                _depth
198            )?;
199            fidl::decode!(
200                bool,
201                D,
202                &mut self.set_root_driver_host_critical,
203                decoder,
204                offset + 24,
205                _depth
206            )?;
207            fidl::decode!(
208                bool,
209                D,
210                &mut self.suspend_timeout_fallback,
211                decoder,
212                offset + 25,
213                _depth
214            )?;
215            fidl::decode!(
216                bool,
217                D,
218                &mut self.wait_for_suspending_token,
219                decoder,
220                offset + 26,
221                _depth
222            )?;
223            Ok(())
224        }
225    }
226}