xref: /aosp_15_r20/system/nfc/src/rust/test/main.rs (revision 7eba2f3b06c51ae21384f6a4f14577b668a869b3)
1*7eba2f3bSAndroid Build Coastguard Worker // Copyright 2021, The Android Open Source Project
2*7eba2f3bSAndroid Build Coastguard Worker //
3*7eba2f3bSAndroid Build Coastguard Worker // Licensed under the Apache License, Version 2.0 (the "License");
4*7eba2f3bSAndroid Build Coastguard Worker // you may not use this file except in compliance with the License.
5*7eba2f3bSAndroid Build Coastguard Worker // You may obtain a copy of the License at
6*7eba2f3bSAndroid Build Coastguard Worker //
7*7eba2f3bSAndroid Build Coastguard Worker //     http://www.apache.org/licenses/LICENSE-2.0
8*7eba2f3bSAndroid Build Coastguard Worker //
9*7eba2f3bSAndroid Build Coastguard Worker // Unless required by applicable law or agreed to in writing, software
10*7eba2f3bSAndroid Build Coastguard Worker // distributed under the License is distributed on an "AS IS" BASIS,
11*7eba2f3bSAndroid Build Coastguard Worker // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12*7eba2f3bSAndroid Build Coastguard Worker // See the License for the specific language governing permissions and
13*7eba2f3bSAndroid Build Coastguard Worker // limitations under the License.
14*7eba2f3bSAndroid Build Coastguard Worker 
15*7eba2f3bSAndroid Build Coastguard Worker //! Rootcanal HAL
16*7eba2f3bSAndroid Build Coastguard Worker //! This connects to "rootcanal" which provides a simulated
17*7eba2f3bSAndroid Build Coastguard Worker //! Nfc chip as well as a simulated environment.
18*7eba2f3bSAndroid Build Coastguard Worker 
19*7eba2f3bSAndroid Build Coastguard Worker use log::{debug, LevelFilter};
20*7eba2f3bSAndroid Build Coastguard Worker use logger::{self, Config};
21*7eba2f3bSAndroid Build Coastguard Worker use nfc_rnci::api::NciApi;
22*7eba2f3bSAndroid Build Coastguard Worker 
23*7eba2f3bSAndroid Build Coastguard Worker /// Result type
24*7eba2f3bSAndroid Build Coastguard Worker type Result<T> = std::result::Result<T, Box<dyn std::error::Error + Send + Sync>>;
25*7eba2f3bSAndroid Build Coastguard Worker 
26*7eba2f3bSAndroid Build Coastguard Worker /// The NFC response callback
nfc_callback(kind: u16, val: &[u8])27*7eba2f3bSAndroid Build Coastguard Worker pub fn nfc_callback(kind: u16, val: &[u8]) {
28*7eba2f3bSAndroid Build Coastguard Worker     debug!("Callback#{} -> {:?}", kind, val);
29*7eba2f3bSAndroid Build Coastguard Worker }
30*7eba2f3bSAndroid Build Coastguard Worker 
31*7eba2f3bSAndroid Build Coastguard Worker #[tokio::main]
main() -> Result<()>32*7eba2f3bSAndroid Build Coastguard Worker async fn main() -> Result<()> {
33*7eba2f3bSAndroid Build Coastguard Worker     let set_tlvs: [u8; 10] = [3, 0xa1, 1, 0x1e, 0xa2, 1, 0x19, 0x80, 1, 0x01];
34*7eba2f3bSAndroid Build Coastguard Worker     let get_tlvs: [u8; 3] = [2, 0x52, 0x80];
35*7eba2f3bSAndroid Build Coastguard Worker     logger::init(Config::default().with_tag_on_device("lnfc").with_max_level(LevelFilter::Trace));
36*7eba2f3bSAndroid Build Coastguard Worker 
37*7eba2f3bSAndroid Build Coastguard Worker     let mut nci = NciApi::new();
38*7eba2f3bSAndroid Build Coastguard Worker     nci.nfc_enable(nfc_callback).await;
39*7eba2f3bSAndroid Build Coastguard Worker     nci.nfc_init().await?;
40*7eba2f3bSAndroid Build Coastguard Worker     let lmrts = nci.nfc_get_lmrt_size().await;
41*7eba2f3bSAndroid Build Coastguard Worker     debug!("LMRT size:{}", lmrts);
42*7eba2f3bSAndroid Build Coastguard Worker     let status = nci.nfc_set_config(&set_tlvs).await?;
43*7eba2f3bSAndroid Build Coastguard Worker     debug!("SET_CONFIG status:{}", status);
44*7eba2f3bSAndroid Build Coastguard Worker     let status = nci.nfc_get_config(&get_tlvs).await?;
45*7eba2f3bSAndroid Build Coastguard Worker     debug!("GET_CONFIG status:{}", status);
46*7eba2f3bSAndroid Build Coastguard Worker     nci.nfc_disable().await;
47*7eba2f3bSAndroid Build Coastguard Worker     nci.nfc_enable(nfc_callback).await;
48*7eba2f3bSAndroid Build Coastguard Worker     nci.nfc_init().await?;
49*7eba2f3bSAndroid Build Coastguard Worker     let status = nci.nfc_get_config(&get_tlvs).await?;
50*7eba2f3bSAndroid Build Coastguard Worker     debug!("GET_CONFIG status:{}", status);
51*7eba2f3bSAndroid Build Coastguard Worker     nci.nfc_disable().await;
52*7eba2f3bSAndroid Build Coastguard Worker     Ok(())
53*7eba2f3bSAndroid Build Coastguard Worker }
54