Skip to main content

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