builtins/
debuglog_resource.rs
1use anyhow::{format_err, Error};
6use fidl_fuchsia_kernel as fkernel;
7use futures::prelude::*;
8use std::sync::Arc;
9use zx::{self as zx, HandleBased, Resource};
10
11pub struct DebuglogResource {
13 resource: Resource,
14}
15
16impl DebuglogResource {
17 pub fn new(resource: Resource) -> Result<Arc<Self>, Error> {
19 let resource_info = resource.info()?;
20 if resource_info.kind != zx::sys::ZX_RSRC_KIND_SYSTEM
21 || resource_info.base != zx::sys::ZX_RSRC_SYSTEM_DEBUGLOG_BASE
22 || resource_info.size != 1
23 {
24 return Err(format_err!("Debuglog resource not available."));
25 }
26 Ok(Arc::new(Self { resource }))
27 }
28
29 pub async fn serve(
30 self: Arc<Self>,
31 mut stream: fkernel::DebuglogResourceRequestStream,
32 ) -> Result<(), Error> {
33 while let Some(fkernel::DebuglogResourceRequest::Get { responder }) =
34 stream.try_next().await?
35 {
36 responder.send(self.resource.duplicate_handle(zx::Rights::SAME_RIGHTS)?)?;
37 }
38 Ok(())
39 }
40}
41
42#[cfg(test)]
43mod tests {
44 use super::*;
45 use fuchsia_component::client::connect_to_protocol;
46 use {fidl_fuchsia_kernel as fkernel, fuchsia_async as fasync};
47
48 async fn get_debuglog_resource() -> Result<Resource, Error> {
49 let debuglog_resource_provider = connect_to_protocol::<fkernel::DebuglogResourceMarker>()?;
50 let debuglog_resource_handle = debuglog_resource_provider.get().await?;
51 Ok(Resource::from(debuglog_resource_handle))
52 }
53
54 async fn serve_debuglog_resource() -> Result<fkernel::DebuglogResourceProxy, Error> {
55 let debuglog_resource = get_debuglog_resource().await?;
56
57 let (proxy, stream) =
58 fidl::endpoints::create_proxy_and_stream::<fkernel::DebuglogResourceMarker>();
59 fasync::Task::local(
60 DebuglogResource::new(debuglog_resource)
61 .unwrap_or_else(|e| panic!("Error while creating debuglog resource service: {}", e))
62 .serve(stream)
63 .unwrap_or_else(|e| panic!("Error while serving debuglog resource service: {}", e)),
64 )
65 .detach();
66 Ok(proxy)
67 }
68
69 #[fuchsia::test]
70 async fn base_type_is_debuglog() -> Result<(), Error> {
71 let debuglog_resource_provider = serve_debuglog_resource().await?;
72 let debuglog_resource: Resource = debuglog_resource_provider.get().await?;
73 let resource_info = debuglog_resource.info()?;
74 assert_eq!(resource_info.kind, zx::sys::ZX_RSRC_KIND_SYSTEM);
75 assert_eq!(resource_info.base, zx::sys::ZX_RSRC_SYSTEM_DEBUGLOG_BASE);
76 assert_eq!(resource_info.size, 1);
77 Ok(())
78 }
79}