fidl_cf_sc_internal_sagconfig_common/
fidl_cf_sc_internal_sagconfig_common.rs1#![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 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 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 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 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}