NativeNfcManager.cpp revision 8d154680537afa5242edeb98c8f414d6186558cf
1525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/* 2525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project * Copyright (C) 2012 The Android Open Source Project 3525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project * 4525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License"); 5525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project * you may not use this file except in compliance with the License. 6525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project * You may obtain a copy of the License at 7525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project * 8525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project * http://www.apache.org/licenses/LICENSE-2.0 9525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project * 10525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project * Unless required by applicable law or agreed to in writing, software 11525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS, 12525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project * See the License for the specific language governing permissions and 14525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project * limitations under the License. 15525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project */ 16525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 17525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project#include <semaphore.h> 18525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project#include <errno.h> 19525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project#include "OverrideLog.h" 20525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project#include "NfcJniUtil.h" 21525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project#include "NfcAdaptation.h" 22525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project#include "SyncEvent.h" 23525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project#include "PeerToPeer.h" 24525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project#include "SecureElement.h" 259f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen#include "RoutingManager.h" 26525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project#include "NfcTag.h" 27525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project#include "config.h" 28525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project#include "PowerSwitch.h" 29525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project#include "JavaClassConstants.h" 30525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project#include "Pn544Interop.h" 312534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes#include <ScopedLocalRef.h> 322534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes#include <ScopedUtfChars.h> 339f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen#include <ScopedPrimitiveArray.h> 34525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 35525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectextern "C" 36525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 37525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project #include "nfa_api.h" 38525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project #include "nfa_p2p_api.h" 39525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project #include "rw_api.h" 40525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project #include "nfa_ee_api.h" 41525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project #include "nfc_brcm_defs.h" 42525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project #include "ce_api.h" 43525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 44525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 45525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectextern UINT8 *p_nfa_dm_start_up_cfg; 46525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectextern const UINT8 nfca_version_string []; 47a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chuextern const UINT8 nfa_version_string []; 48a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chuextern tNFA_DM_DISC_FREQ_CFG* p_nfa_dm_rf_disc_freq_cfg; //defined in stack 49525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectnamespace android 50525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 51525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern bool gIsTagDeactivating; 52525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern bool gIsSelectingRfInterface; 53525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern void nativeNfcTag_doTransceiveStatus (uint8_t * buf, uint32_t buflen); 54a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu extern void nativeNfcTag_notifyRfTimeout (); 55525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern void nativeNfcTag_doConnectStatus (jboolean is_connect_ok); 56525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern void nativeNfcTag_doDeactivateStatus (int status); 57525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern void nativeNfcTag_doWriteStatus (jboolean is_write_ok); 58525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern void nativeNfcTag_doCheckNdefResult (tNFA_STATUS status, uint32_t max_size, uint32_t current_size, uint8_t flags); 59525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern void nativeNfcTag_doMakeReadonlyResult (tNFA_STATUS status); 60525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern void nativeNfcTag_doPresenceCheckResult (tNFA_STATUS status); 61525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern void nativeNfcTag_formatStatus (bool is_ok); 62525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern void nativeNfcTag_resetPresenceCheck (); 63525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern void nativeNfcTag_doReadCompleted (tNFA_STATUS status); 64525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern void nativeNfcTag_abortWaits (); 65525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern void nativeLlcpConnectionlessSocket_abortWait (); 66525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern void nativeNfcTag_registerNdefTypeHandler (); 67525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern void nativeLlcpConnectionlessSocket_receiveData (uint8_t* data, uint32_t len, uint32_t remote_sap); 68525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 69525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 70525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 71525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/***************************************************************************** 72525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 73525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** public variables and functions 74525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 75525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*****************************************************************************/ 76a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chubool gActivated = false; 77a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan ChuSyncEvent gDeactivatedEvent; 78525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 79525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectnamespace android 80525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 81525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project jmethodID gCachedNfcManagerNotifyNdefMessageListeners; 82525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project jmethodID gCachedNfcManagerNotifyTransactionListeners; 83525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project jmethodID gCachedNfcManagerNotifyLlcpLinkActivation; 84525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project jmethodID gCachedNfcManagerNotifyLlcpLinkDeactivated; 8557a44d07a3de327e8cdbbcd622118aa517313dbeMartijn Coenen jmethodID gCachedNfcManagerNotifyLlcpFirstPacketReceived; 86525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project jmethodID gCachedNfcManagerNotifySeFieldActivated; 87525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project jmethodID gCachedNfcManagerNotifySeFieldDeactivated; 88525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project jmethodID gCachedNfcManagerNotifySeListenActivated; 89525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project jmethodID gCachedNfcManagerNotifySeListenDeactivated; 909f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen jmethodID gCachedNfcManagerNotifyHostEmuActivated; 919f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen jmethodID gCachedNfcManagerNotifyHostEmuData; 929f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen jmethodID gCachedNfcManagerNotifyHostEmuDeactivated; 93525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project const char* gNativeP2pDeviceClassName = "com/android/nfc/dhimpl/NativeP2pDevice"; 94525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project const char* gNativeLlcpServiceSocketClassName = "com/android/nfc/dhimpl/NativeLlcpServiceSocket"; 95525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project const char* gNativeLlcpConnectionlessSocketClassName = "com/android/nfc/dhimpl/NativeLlcpConnectionlessSocket"; 96525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project const char* gNativeLlcpSocketClassName = "com/android/nfc/dhimpl/NativeLlcpSocket"; 97525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project const char* gNativeNfcTagClassName = "com/android/nfc/dhimpl/NativeNfcTag"; 98525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project const char* gNativeNfcManagerClassName = "com/android/nfc/dhimpl/NativeNfcManager"; 99525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project const char* gNativeNfcSecureElementClassName = "com/android/nfc/dhimpl/NativeNfcSecureElement"; 100525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project void doStartupConfig (); 101525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project void startStopPolling (bool isStartPolling); 102525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project void startRfDiscovery (bool isStart); 10361beae816af13f75dabb484d287739723c716deeMartijn Coenen void setUiccIdleTimeout (bool enable); 104c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen void restartPollingWithTechMask(int mask); 105525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 106525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 107525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 108525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/***************************************************************************** 109525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 110525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** private variables and functions 111525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 112525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*****************************************************************************/ 113525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectnamespace android 114525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 115525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic jint sLastError = ERROR_BUFFER_TOO_SMALL; 116525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic jmethodID sCachedNfcManagerNotifySeApduReceived; 117525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic jmethodID sCachedNfcManagerNotifySeMifareAccess; 118525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic jmethodID sCachedNfcManagerNotifySeEmvCardRemoval; 119525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic jmethodID sCachedNfcManagerNotifyTargetDeselected; 120525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic SyncEvent sNfaEnableEvent; //event for NFA_Enable() 121525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic SyncEvent sNfaDisableEvent; //event for NFA_Disable() 122525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic SyncEvent sNfaEnableDisablePollingEvent; //event for NFA_EnablePolling(), NFA_DisablePolling() 123525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic SyncEvent sNfaSetConfigEvent; // event for Set_Config.... 124f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenenstatic SyncEvent sNfaGetConfigEvent; // event for Get_Config.... 125525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool sIsNfaEnabled = false; 126525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool sDiscoveryEnabled = false; //is polling for tag? 127525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool sIsDisabling = false; 128525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool sRfEnabled = false; // whether RF discovery is enabled 129525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool sSeRfActive = false; // whether RF with SE is likely active 130c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenenstatic bool sReaderModeEnabled = false; // whether we're only reading tags, not allowing P2p/card emu 131525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool sP2pActive = false; // whether p2p was last active 132525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool sAbortConnlessWait = false; 133525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool sIsSecElemSelected = false; //has NFC service selected a sec elem 134525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project#define CONFIG_UPDATE_TECH_MASK (1 << 1) 135525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project#define DEFAULT_TECH_MASK (NFA_TECHNOLOGY_MASK_A \ 136525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project | NFA_TECHNOLOGY_MASK_B \ 137525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project | NFA_TECHNOLOGY_MASK_F \ 138525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project | NFA_TECHNOLOGY_MASK_ISO15693 \ 139525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project | NFA_TECHNOLOGY_MASK_B_PRIME \ 140525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project | NFA_TECHNOLOGY_MASK_A_ACTIVE \ 14197a71fe90493efd5947bb6f18c7b58a7e795c1ddEvan Chu | NFA_TECHNOLOGY_MASK_F_ACTIVE \ 14297a71fe90493efd5947bb6f18c7b58a7e795c1ddEvan Chu | NFA_TECHNOLOGY_MASK_KOVIO) 143c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen#define DEFAULT_DISCOVERY_DURATION 500 1448d154680537afa5242edeb98c8f414d6186558cfMartijn Coenen#define READER_MODE_DISCOVERY_DURATION 200 145525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 146525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic void nfaConnectionCallback (UINT8 event, tNFA_CONN_EVT_DATA *eventData); 147525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic void nfaDeviceManagementCallback (UINT8 event, tNFA_DM_CBACK_DATA *eventData); 148525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool isPeerToPeer (tNFA_ACTIVATED& activated); 149525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool isListenMode(tNFA_ACTIVATED& activated); 150525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 151f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenenstatic UINT16 sCurrentConfigLen; 152f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenenstatic UINT8 sConfig[256]; 153c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen 154525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project///////////////////////////////////////////////////////////// 155525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project///////////////////////////////////////////////////////////// 156525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 157525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 158525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 159525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 160525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: getNative 161525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 162525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Get native data 163525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 164525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: Native data structure. 165525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 166525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 167525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectnfc_jni_native_data *getNative (JNIEnv* e, jobject o) 168525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 169525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project static struct nfc_jni_native_data *sCachedNat = NULL; 170525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (e) 171525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 172525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sCachedNat = nfc_jni_get_nat(e, o); 173525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 174525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return sCachedNat; 175525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 176525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 177525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 178525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 179525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 180525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: handleRfDiscoveryEvent 181525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 182525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Handle RF-discovery events from the stack. 183525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** discoveredDevice: Discovered device. 184525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 185525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: None 186525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 187525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 188525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic void handleRfDiscoveryEvent (tNFC_RESULT_DEVT* discoveredDevice) 189525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 190525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (discoveredDevice->more) 191525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 192525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project //there is more discovery notification coming 193525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return; 194525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 195525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 196525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project bool isP2p = NfcTag::getInstance ().isP2pDiscovered (); 197c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen if (!sReaderModeEnabled && isP2p) 198525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 199525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project //select the peer that supports P2P 200525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcTag::getInstance ().selectP2p(); 201525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 202525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project else 203525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 204525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project //select the first of multiple tags that is discovered 205525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcTag::getInstance ().selectFirstTag(); 206525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 207525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 208525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 209525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 210525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 211525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 212525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfaConnectionCallback 213525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 214525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Receive connection-related events from stack. 215525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** connEvent: Event code. 216525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** eventData: Event data. 217525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 218525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: None 219525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 220525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 221525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic void nfaConnectionCallback (UINT8 connEvent, tNFA_CONN_EVT_DATA* eventData) 222525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 223525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tNFA_STATUS status = NFA_STATUS_FAILED; 224525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: event= %u", __FUNCTION__, connEvent); 225525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 226525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project switch (connEvent) 227525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 228525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_POLL_ENABLED_EVT: // whether polling successfully started 229525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 230525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_POLL_ENABLED_EVT: status = %u", __FUNCTION__, eventData->status); 231525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 232525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaEnableDisablePollingEvent); 233525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaEnableDisablePollingEvent.notifyOne (); 234525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 235525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 236525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 237525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_POLL_DISABLED_EVT: // Listening/Polling stopped 238525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 239525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_POLL_DISABLED_EVT: status = %u", __FUNCTION__, eventData->status); 240525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 241525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaEnableDisablePollingEvent); 242525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaEnableDisablePollingEvent.notifyOne (); 243525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 244525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 245525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 246525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_RF_DISCOVERY_STARTED_EVT: // RF Discovery started 247525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 248525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_RF_DISCOVERY_STARTED_EVT: status = %u", __FUNCTION__, eventData->status); 249525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 250525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaEnableDisablePollingEvent); 251525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaEnableDisablePollingEvent.notifyOne (); 252525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 253525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 254525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 255525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_RF_DISCOVERY_STOPPED_EVT: // RF Discovery stopped event 256525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 257525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_RF_DISCOVERY_STOPPED_EVT: status = %u", __FUNCTION__, eventData->status); 258525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 259525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaEnableDisablePollingEvent); 260525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaEnableDisablePollingEvent.notifyOne (); 261525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 262525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 263525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 264525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_DISC_RESULT_EVT: // NFC link/protocol discovery notificaiton 265525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project status = eventData->disc_result.status; 266525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_DISC_RESULT_EVT: status = %d", __FUNCTION__, status); 267525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (status != NFA_STATUS_OK) 268525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 269525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE("%s: NFA_DISC_RESULT_EVT error: status = %d", __FUNCTION__, status); 270525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 271525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project else 272525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 273525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcTag::getInstance().connectionEventHandler(connEvent, eventData); 274525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project handleRfDiscoveryEvent(&eventData->disc_result.discovery_ntf); 275525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 276525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 277525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 278525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_SELECT_RESULT_EVT: // NFC link/protocol discovery select response 279525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_SELECT_RESULT_EVT: status = %d, gIsSelectingRfInterface = %d, sIsDisabling=%d", __FUNCTION__, eventData->status, gIsSelectingRfInterface, sIsDisabling); 280525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 281525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (sIsDisabling) 282525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 283525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 284525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (eventData->status != NFA_STATUS_OK) 285525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 286525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (gIsSelectingRfInterface) 287525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 288525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_doConnectStatus(false); 289525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 290525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 291525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE("%s: NFA_SELECT_RESULT_EVT error: status = %d", __FUNCTION__, eventData->status); 292525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NFA_Deactivate (FALSE); 293525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 294525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 295525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 296525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_DEACTIVATE_FAIL_EVT: 297525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_DEACTIVATE_FAIL_EVT: status = %d", __FUNCTION__, eventData->status); 298525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 299525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 300525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_ACTIVATED_EVT: // NFC link/protocol activated 301525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_ACTIVATED_EVT: gIsSelectingRfInterface=%d, sIsDisabling=%d", __FUNCTION__, gIsSelectingRfInterface, sIsDisabling); 302a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu NfcTag::getInstance().setActive(true); 303b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen if (sIsDisabling || !sIsNfaEnabled) 304525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 305a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu gActivated = true; 306525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 307525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcTag::getInstance().setActivationState (); 308525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (gIsSelectingRfInterface) 309525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 310525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_doConnectStatus(true); 311525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 312525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 313525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 314525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_resetPresenceCheck(); 315525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (isPeerToPeer(eventData->activated)) 316525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 317f5cd84c3a7ffb66196ab3c0745569da937d7533bMartijn Coenen if (sReaderModeEnabled) 318f5cd84c3a7ffb66196ab3c0745569da937d7533bMartijn Coenen { 319f5cd84c3a7ffb66196ab3c0745569da937d7533bMartijn Coenen ALOGD("%s: ignoring peer target in reader mode.", __FUNCTION__); 320f5cd84c3a7ffb66196ab3c0745569da937d7533bMartijn Coenen NFA_Deactivate (FALSE); 321f5cd84c3a7ffb66196ab3c0745569da937d7533bMartijn Coenen break; 322f5cd84c3a7ffb66196ab3c0745569da937d7533bMartijn Coenen } 323525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sP2pActive = true; 324525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_ACTIVATED_EVT; is p2p", __FUNCTION__); 325525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // Disable RF field events in case of p2p 326525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project UINT8 nfa_disable_rf_events[] = { 0x00 }; 327525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: Disabling RF field events", __FUNCTION__); 328525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project status = NFA_SetConfig(NCI_PARAM_ID_RF_FIELD_INFO, sizeof(nfa_disable_rf_events), 329525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project &nfa_disable_rf_events[0]); 330525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (status == NFA_STATUS_OK) { 331525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: Disabled RF field events", __FUNCTION__); 332525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } else { 333525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: Failed to disable RF field events", __FUNCTION__); 334525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 33557a44d07a3de327e8cdbbcd622118aa517313dbeMartijn Coenen // For the SE, consider the field to be on while p2p is active. 33657a44d07a3de327e8cdbbcd622118aa517313dbeMartijn Coenen SecureElement::getInstance().notifyRfFieldEvent (true); 337525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 338525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project else if (pn544InteropIsBusy() == false) 339525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 340525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcTag::getInstance().connectionEventHandler (connEvent, eventData); 341525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 342525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // We know it is not activating for P2P. If it activated in 34357a44d07a3de327e8cdbbcd622118aa517313dbeMartijn Coenen // listen mode then it is likely for an SE transaction. 344525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // Send the RF Event. 345525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (isListenMode(eventData->activated)) 346525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 347525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sSeRfActive = true; 348525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SecureElement::getInstance().notifyListenModeState (true); 349525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 350525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 351525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 352525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 353525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_DEACTIVATED_EVT: // NFC link/protocol deactivated 354525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_DEACTIVATED_EVT Type: %u, gIsTagDeactivating: %d", __FUNCTION__, eventData->deactivated.type,gIsTagDeactivating); 355525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcTag::getInstance().setDeactivationState (eventData->deactivated); 356525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (eventData->deactivated.type != NFA_DEACTIVATE_TYPE_SLEEP) 357525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 358a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu { 359a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu SyncEventGuard g (gDeactivatedEvent); 360a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu gActivated = false; //guard this variable from multi-threaded access 361a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu gDeactivatedEvent.notifyOne (); 362a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu } 363525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_resetPresenceCheck(); 364525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcTag::getInstance().connectionEventHandler (connEvent, eventData); 365525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_abortWaits(); 366525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcTag::getInstance().abort (); 367525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 368525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project else if (gIsTagDeactivating) 369525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 370a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu NfcTag::getInstance().setActive(false); 371525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_doDeactivateStatus(0); 372525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 373525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 374525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // If RF is activated for what we think is a Secure Element transaction 375525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // and it is deactivated to either IDLE or DISCOVERY mode, notify w/event. 376525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if ((eventData->deactivated.type == NFA_DEACTIVATE_TYPE_IDLE) 377525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project || (eventData->deactivated.type == NFA_DEACTIVATE_TYPE_DISCOVERY)) 378525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 379525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (sSeRfActive) { 380525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sSeRfActive = false; 381b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen if (!sIsDisabling && sIsNfaEnabled) 382b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen SecureElement::getInstance().notifyListenModeState (false); 383525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } else if (sP2pActive) { 384525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sP2pActive = false; 385525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // Make sure RF field events are re-enabled 386b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen ALOGD("%s: NFA_DEACTIVATED_EVT; is p2p", __FUNCTION__); 387525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // Disable RF field events in case of p2p 388525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project UINT8 nfa_enable_rf_events[] = { 0x01 }; 389525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 390b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen if (!sIsDisabling && sIsNfaEnabled) 391b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen { 392b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen ALOGD ("%s: Enabling RF field events", __FUNCTION__); 393b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen status = NFA_SetConfig(NCI_PARAM_ID_RF_FIELD_INFO, sizeof(nfa_enable_rf_events), 394b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen &nfa_enable_rf_events[0]); 395b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen if (status == NFA_STATUS_OK) { 396b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen ALOGD ("%s: Enabled RF field events", __FUNCTION__); 397b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen } else { 398b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen ALOGE ("%s: Failed to enable RF field events", __FUNCTION__); 399b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen } 400b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen // Consider the field to be off at this point 401b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen SecureElement::getInstance().notifyRfFieldEvent (false); 402525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 403525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 404525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 405525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 406525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 407525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 408525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_TLV_DETECT_EVT: // TLV Detection complete 409525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project status = eventData->tlv_detect.status; 410525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_TLV_DETECT_EVT: status = %d, protocol = %d, num_tlvs = %d, num_bytes = %d", 411525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project __FUNCTION__, status, eventData->tlv_detect.protocol, 412525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project eventData->tlv_detect.num_tlvs, eventData->tlv_detect.num_bytes); 413525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (status != NFA_STATUS_OK) 414525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 415525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE("%s: NFA_TLV_DETECT_EVT error: status = %d", __FUNCTION__, status); 416525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 417525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 418525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 419525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_NDEF_DETECT_EVT: // NDEF Detection complete; 420525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project //if status is failure, it means the tag does not contain any or valid NDEF data; 421525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project //pass the failure status to the NFC Service; 422525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project status = eventData->ndef_detect.status; 423525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_NDEF_DETECT_EVT: status = 0x%X, protocol = %u, " 424525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project "max_size = %lu, cur_size = %lu, flags = 0x%X", __FUNCTION__, 425525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project status, 426525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project eventData->ndef_detect.protocol, eventData->ndef_detect.max_size, 427525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project eventData->ndef_detect.cur_size, eventData->ndef_detect.flags); 428525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcTag::getInstance().connectionEventHandler (connEvent, eventData); 429525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_doCheckNdefResult(status, 430525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project eventData->ndef_detect.max_size, eventData->ndef_detect.cur_size, 431525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project eventData->ndef_detect.flags); 432525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 433525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 434525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_DATA_EVT: // Data message received (for non-NDEF reads) 435525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_DATA_EVT: len = %d", __FUNCTION__, eventData->data.len); 436525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_doTransceiveStatus(eventData->data.p_data,eventData->data.len); 437525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 438a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu case NFA_RW_INTF_ERROR_EVT: 439a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu ALOGD("%s: NFC_RW_INTF_ERROR_EVT", __FUNCTION__); 440a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu nativeNfcTag_notifyRfTimeout(); 441a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu break; 442525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_SELECT_CPLT_EVT: // Select completed 443525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project status = eventData->status; 444525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_SELECT_CPLT_EVT: status = %d", __FUNCTION__, status); 445525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (status != NFA_STATUS_OK) 446525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 447525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE("%s: NFA_SELECT_CPLT_EVT error: status = %d", __FUNCTION__, status); 448525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 449525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 450525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 451525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_READ_CPLT_EVT: // NDEF-read or tag-specific-read completed 452525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_READ_CPLT_EVT: status = 0x%X", __FUNCTION__, eventData->status); 453525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_doReadCompleted (eventData->status); 454525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcTag::getInstance().connectionEventHandler (connEvent, eventData); 455525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 456525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 457525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_WRITE_CPLT_EVT: // Write completed 458525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_WRITE_CPLT_EVT: status = %d", __FUNCTION__, eventData->status); 459525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_doWriteStatus (eventData->status == NFA_STATUS_OK); 460525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 461525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 462525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_SET_TAG_RO_EVT: // Tag set as Read only 463525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_SET_TAG_RO_EVT: status = %d", __FUNCTION__, eventData->status); 464525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_doMakeReadonlyResult(eventData->status); 465525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 466525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 467525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_CE_NDEF_WRITE_START_EVT: // NDEF write started 468525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_CE_NDEF_WRITE_START_EVT: status: %d", __FUNCTION__, eventData->status); 469525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 470525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (eventData->status != NFA_STATUS_OK) 471525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE("%s: NFA_CE_NDEF_WRITE_START_EVT error: status = %d", __FUNCTION__, eventData->status); 472525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 473525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 474525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_CE_NDEF_WRITE_CPLT_EVT: // NDEF write completed 475525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: FA_CE_NDEF_WRITE_CPLT_EVT: len = %lu", __FUNCTION__, eventData->ndef_write_cplt.len); 476525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 477525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 478525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_LLCP_ACTIVATED_EVT: // LLCP link is activated 479525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_LLCP_ACTIVATED_EVT: is_initiator: %d remote_wks: %d, remote_lsc: %d, remote_link_miu: %d, local_link_miu: %d", 480525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project __FUNCTION__, 481525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project eventData->llcp_activated.is_initiator, 482525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project eventData->llcp_activated.remote_wks, 483525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project eventData->llcp_activated.remote_lsc, 484525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project eventData->llcp_activated.remote_link_miu, 485525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project eventData->llcp_activated.local_link_miu); 486525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 487525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PeerToPeer::getInstance().llcpActivatedHandler (getNative(0, 0), eventData->llcp_activated); 488525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 489525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 490525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_LLCP_DEACTIVATED_EVT: // LLCP link is deactivated 491525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_LLCP_DEACTIVATED_EVT", __FUNCTION__); 492525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PeerToPeer::getInstance().llcpDeactivatedHandler (getNative(0, 0), eventData->llcp_deactivated); 493525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 49457a44d07a3de327e8cdbbcd622118aa517313dbeMartijn Coenen case NFA_LLCP_FIRST_PACKET_RECEIVED_EVT: // Received first packet over llcp 49557a44d07a3de327e8cdbbcd622118aa517313dbeMartijn Coenen ALOGD("%s: NFA_LLCP_FIRST_PACKET_RECEIVED_EVT", __FUNCTION__); 49657a44d07a3de327e8cdbbcd622118aa517313dbeMartijn Coenen PeerToPeer::getInstance().llcpFirstPacketHandler (getNative(0, 0)); 49757a44d07a3de327e8cdbbcd622118aa517313dbeMartijn Coenen break; 498525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_PRESENCE_CHECK_EVT: 499525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_PRESENCE_CHECK_EVT", __FUNCTION__); 500525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_doPresenceCheckResult (eventData->status); 501525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 502525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_FORMAT_CPLT_EVT: 503525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_FORMAT_CPLT_EVT: status=0x%X", __FUNCTION__, eventData->status); 504525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_formatStatus (eventData->status == NFA_STATUS_OK); 505525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 506525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 507525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_I93_CMD_CPLT_EVT: 508525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_I93_CMD_CPLT_EVT: status=0x%X", __FUNCTION__, eventData->status); 509525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 510525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 511525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_CE_UICC_LISTEN_CONFIGURED_EVT : 512525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_CE_UICC_LISTEN_CONFIGURED_EVT : status=0x%X", __FUNCTION__, eventData->status); 513525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SecureElement::getInstance().connectionEventHandler (connEvent, eventData); 514525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 515525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 516525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_SET_P2P_LISTEN_TECH_EVT: 517525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_SET_P2P_LISTEN_TECH_EVT", __FUNCTION__); 518525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PeerToPeer::getInstance().connectionEventHandler (connEvent, eventData); 519525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 520525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 521525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project default: 522525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE("%s: unknown event ????", __FUNCTION__); 523525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 524525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 525525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 526525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 527525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 528525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 529525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 530525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_initNativeStruc 531525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 532525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Initialize variables. 533525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 534525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 535525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 536525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: True if ok. 537525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 538525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 539525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic jboolean nfcManager_initNativeStruc (JNIEnv* e, jobject o) 540525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 541525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: enter", __FUNCTION__); 542525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 5432534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes nfc_jni_native_data* nat = (nfc_jni_native_data*)malloc(sizeof(struct nfc_jni_native_data)); 544525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (nat == NULL) 545525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 546525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: fail allocate native data", __FUNCTION__); 547525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return JNI_FALSE; 548525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 549525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 550525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project memset (nat, 0, sizeof(*nat)); 5512534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes e->GetJavaVM(&(nat->vm)); 5522534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes nat->env_version = e->GetVersion(); 5532534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes nat->manager = e->NewGlobalRef(o); 554525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 5552534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes ScopedLocalRef<jclass> cls(e, e->GetObjectClass(o)); 5562534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes jfieldID f = e->GetFieldID(cls.get(), "mNative", "I"); 5572534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes e->SetIntField(o, f, (jint)nat); 558525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 559525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project /* Initialize native cached references */ 5602534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes gCachedNfcManagerNotifyNdefMessageListeners = e->GetMethodID(cls.get(), 561525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project "notifyNdefMessageListeners", "(Lcom/android/nfc/dhimpl/NativeNfcTag;)V"); 5622534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes gCachedNfcManagerNotifyTransactionListeners = e->GetMethodID(cls.get(), 563525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project "notifyTransactionListeners", "([B)V"); 5642534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes gCachedNfcManagerNotifyLlcpLinkActivation = e->GetMethodID(cls.get(), 565525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project "notifyLlcpLinkActivation", "(Lcom/android/nfc/dhimpl/NativeP2pDevice;)V"); 5662534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes gCachedNfcManagerNotifyLlcpLinkDeactivated = e->GetMethodID(cls.get(), 567525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project "notifyLlcpLinkDeactivated", "(Lcom/android/nfc/dhimpl/NativeP2pDevice;)V"); 56857a44d07a3de327e8cdbbcd622118aa517313dbeMartijn Coenen gCachedNfcManagerNotifyLlcpFirstPacketReceived = e->GetMethodID(cls.get(), 56957a44d07a3de327e8cdbbcd622118aa517313dbeMartijn Coenen "notifyLlcpLinkFirstPacketReceived", "(Lcom/android/nfc/dhimpl/NativeP2pDevice;)V"); 5702534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes sCachedNfcManagerNotifyTargetDeselected = e->GetMethodID(cls.get(), 571525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project "notifyTargetDeselected","()V"); 5722534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes gCachedNfcManagerNotifySeFieldActivated = e->GetMethodID(cls.get(), 573525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project "notifySeFieldActivated", "()V"); 5742534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes gCachedNfcManagerNotifySeFieldDeactivated = e->GetMethodID(cls.get(), 575525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project "notifySeFieldDeactivated", "()V"); 5762534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes gCachedNfcManagerNotifySeListenActivated = e->GetMethodID(cls.get(), 577525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project "notifySeListenActivated", "()V"); 5782534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes gCachedNfcManagerNotifySeListenDeactivated = e->GetMethodID(cls.get(), 579525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project "notifySeListenDeactivated", "()V"); 580525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 5819f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen gCachedNfcManagerNotifyHostEmuActivated = e->GetMethodID(cls.get(), 5829f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen "notifyHostEmuActivated", "()V"); 5839f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 5849f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen gCachedNfcManagerNotifyHostEmuData = e->GetMethodID(cls.get(), 5859f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen "notifyHostEmuData", "([B)V"); 5869f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 5879f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen gCachedNfcManagerNotifyHostEmuDeactivated = e->GetMethodID(cls.get(), 5889f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen "notifyHostEmuDeactivated", "()V"); 5899f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 5902534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes sCachedNfcManagerNotifySeApduReceived = e->GetMethodID(cls.get(), 591525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project "notifySeApduReceived", "([B)V"); 592525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 5932534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes sCachedNfcManagerNotifySeMifareAccess = e->GetMethodID(cls.get(), 594525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project "notifySeMifareAccess", "([B)V"); 595525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 5962534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes sCachedNfcManagerNotifySeEmvCardRemoval = e->GetMethodID(cls.get(), 597525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project "notifySeEmvCardRemoval", "()V"); 598525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 5992534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes if (nfc_jni_cache_object(e, gNativeNfcTagClassName, &(nat->cached_NfcTag)) == -1) 600525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 601525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: fail cache NativeNfcTag", __FUNCTION__); 602525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return JNI_FALSE; 603525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 604525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 6052534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes if (nfc_jni_cache_object(e, gNativeP2pDeviceClassName, &(nat->cached_P2pDevice)) == -1) 606525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 607525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: fail cache NativeP2pDevice", __FUNCTION__); 608525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return JNI_FALSE; 609525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 610525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 611525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: exit", __FUNCTION__); 612525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return JNI_TRUE; 613525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 614525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 615525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 616525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 617525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 618525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfaDeviceManagementCallback 619525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 620525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Receive device management events from stack. 621525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** dmEvent: Device-management event ID. 622525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** eventData: Data associated with event ID. 623525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 624525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: None 625525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 626525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 627525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectvoid nfaDeviceManagementCallback (UINT8 dmEvent, tNFA_DM_CBACK_DATA* eventData) 628525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 629525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: enter; event=0x%X", __FUNCTION__, dmEvent); 630525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 631525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project switch (dmEvent) 632525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 633525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_DM_ENABLE_EVT: /* Result of NFA_Enable */ 634525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 635525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaEnableEvent); 636525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: NFA_DM_ENABLE_EVT; status=0x%X", 637525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project __FUNCTION__, eventData->status); 638525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sIsNfaEnabled = eventData->status == NFA_STATUS_OK; 639525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sIsDisabling = false; 640525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaEnableEvent.notifyOne (); 641525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 642525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 643525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 644525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_DM_DISABLE_EVT: /* Result of NFA_Disable */ 645525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 646525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaDisableEvent); 647525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: NFA_DM_DISABLE_EVT", __FUNCTION__); 648525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sIsNfaEnabled = false; 649525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sIsDisabling = false; 650525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaDisableEvent.notifyOne (); 651525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 652525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 653525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 654525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_DM_SET_CONFIG_EVT: //result of NFA_SetConfig 655525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: NFA_DM_SET_CONFIG_EVT", __FUNCTION__); 656525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 657525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaSetConfigEvent); 658525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaSetConfigEvent.notifyOne(); 659525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 660525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 661525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 662525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_DM_GET_CONFIG_EVT: /* Result of NFA_GetConfig */ 663525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: NFA_DM_GET_CONFIG_EVT", __FUNCTION__); 664f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen { 665f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen SyncEventGuard guard (sNfaGetConfigEvent); 666f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen if (eventData->status == NFA_STATUS_OK && 667f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen eventData->get_config.tlv_size <= sizeof(sConfig)) 668f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen { 669f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen sCurrentConfigLen = eventData->get_config.tlv_size; 670f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen memcpy(sConfig, eventData->get_config.param_tlvs, eventData->get_config.tlv_size); 671f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen } 672f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen else 673f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen { 674f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen ALOGE("%s: NFA_DM_GET_CONFIG failed", __FUNCTION__); 675f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen sCurrentConfigLen = 0; 676f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen } 677f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen sNfaGetConfigEvent.notifyOne(); 678f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen } 679525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 680525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 681525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_DM_RF_FIELD_EVT: 682525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: NFA_DM_RF_FIELD_EVT; status=0x%X; field status=%u", __FUNCTION__, 683525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project eventData->rf_field.status, eventData->rf_field.rf_field_status); 684b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen if (sIsDisabling || !sIsNfaEnabled) 685b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen break; 686525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 687b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen if (!sP2pActive && eventData->rf_field.status == NFA_STATUS_OK) 688b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen SecureElement::getInstance().notifyRfFieldEvent ( 689b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen eventData->rf_field.rf_field_status == NFA_DM_RF_FIELD_ON); 690525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 691525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 692525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_DM_NFCC_TRANSPORT_ERR_EVT: 693525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_DM_NFCC_TIMEOUT_EVT: 694525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 695525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (dmEvent == NFA_DM_NFCC_TIMEOUT_EVT) 696a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu ALOGE ("%s: NFA_DM_NFCC_TIMEOUT_EVT; abort", __FUNCTION__); 697a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu else if (dmEvent == NFA_DM_NFCC_TRANSPORT_ERR_EVT) 698a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu ALOGE ("%s: NFA_DM_NFCC_TRANSPORT_ERR_EVT; abort", __FUNCTION__); 699525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 700525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_abortWaits(); 701525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcTag::getInstance().abort (); 702525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sAbortConnlessWait = true; 703525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeLlcpConnectionlessSocket_abortWait(); 704525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 705525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: aborting sNfaEnableDisablePollingEvent", __FUNCTION__); 706525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaEnableDisablePollingEvent); 707525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaEnableDisablePollingEvent.notifyOne(); 708525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 709525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 710525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: aborting sNfaEnableEvent", __FUNCTION__); 711525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaEnableEvent); 712525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaEnableEvent.notifyOne(); 713525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 714525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 715525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: aborting sNfaDisableEvent", __FUNCTION__); 716525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaDisableEvent); 717525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaDisableEvent.notifyOne(); 718525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 719525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sDiscoveryEnabled = false; 720525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PowerSwitch::getInstance ().abort (); 721525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 722525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (!sIsDisabling && sIsNfaEnabled) 723525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 724525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NFA_Disable(FALSE); 725525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sIsDisabling = true; 726525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 727525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project else 728525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 729525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sIsNfaEnabled = false; 730525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sIsDisabling = false; 731525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 732525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PowerSwitch::getInstance ().initialize (PowerSwitch::UNKNOWN_LEVEL); 733a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu ALOGE ("%s: crash NFC service", __FUNCTION__); 734a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu ////////////////////////////////////////////// 735a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu //crash the NFC service process so it can restart automatically 736a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu abort (); 737a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu ////////////////////////////////////////////// 738525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 739525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 740525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 741525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_DM_PWR_MODE_CHANGE_EVT: 742525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PowerSwitch::getInstance ().deviceManagementCallback (dmEvent, eventData); 743525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 744525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 745525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project default: 746525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: unhandled event", __FUNCTION__); 747525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 748525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 749525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 750525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 7519f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen/******************************************************************************* 7529f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 7539f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Function: nfcManager_sendRawFrame 7549f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 7559f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Description: Send a raw frame. 7569f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** e: JVM environment. 7579f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** o: Java object. 7589f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 7599f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Returns: True if ok. 7609f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 7619f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen*******************************************************************************/ 762c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenenstatic jboolean nfcManager_sendRawFrame (JNIEnv* e, jobject, jbyteArray data) 7639f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen{ 7649f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen ScopedByteArrayRO bytes(e, data); 7659f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen uint8_t* buf = const_cast<uint8_t*>(reinterpret_cast<const uint8_t*>(&bytes[0])); 7669f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen size_t bufLen = bytes.size(); 7679f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen tNFA_STATUS status = NFA_SendRawFrame (buf, bufLen, 0); 7689f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 7699f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen return (status == NFA_STATUS_OK); 7709f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen} 7719f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 7729f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen/******************************************************************************* 7739f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 7749f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Function: nfcManager_routeAid 7759f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 7769f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Description: Route an AID to an EE 7779f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** e: JVM environment. 7789f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** o: Java object. 7799f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 7809f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Returns: True if ok. 7819f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 7829f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen*******************************************************************************/ 783c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenenstatic jboolean nfcManager_routeAid (JNIEnv* e, jobject, jbyteArray aid, jint route) 7849f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen{ 7859f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen ScopedByteArrayRO bytes(e, aid); 7869f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen uint8_t* buf = const_cast<uint8_t*>(reinterpret_cast<const uint8_t*>(&bytes[0])); 7879f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen size_t bufLen = bytes.size(); 7889f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen bool result = RoutingManager::getInstance().addAidRouting(buf, bufLen, route); 7899f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen return result; 7909f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen} 7919f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 7929f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen/******************************************************************************* 7939f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 7949f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Function: nfcManager_unrouteAid 7959f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 7969f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Description: Remove a AID routing 7979f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** e: JVM environment. 7989f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** o: Java object. 7999f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 8009f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Returns: True if ok. 8019f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 8029f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen*******************************************************************************/ 803c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenenstatic jboolean nfcManager_unrouteAid (JNIEnv* e, jobject, jbyteArray aid) 8049f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen{ 8059f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen ScopedByteArrayRO bytes(e, aid); 8069f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen uint8_t* buf = const_cast<uint8_t*>(reinterpret_cast<const uint8_t*>(&bytes[0])); 8079f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen size_t bufLen = bytes.size(); 8089f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen bool result = RoutingManager::getInstance().removeAidRouting(buf, bufLen); 8099f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen return result; 8109f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen} 811525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 812525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 813525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 814525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doInitialize 815525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 816525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Turn on NFC. 817525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 818525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 819525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 820525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: True if ok. 821525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 822525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 823525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic jboolean nfcManager_doInitialize (JNIEnv* e, jobject o) 824525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 825a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu ALOGD ("%s: enter; ver=%s nfa=%s NCI_VERSION=0x%02X", 826a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu __FUNCTION__, nfca_version_string, nfa_version_string, NCI_VERSION); 827525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tNFA_STATUS stat = NFA_STATUS_OK; 828525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 829525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (sIsNfaEnabled) 830525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 831525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: already enabled", __FUNCTION__); 832525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project goto TheEnd; 833525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 834525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 835525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PowerSwitch::getInstance ().initialize (PowerSwitch::FULL_POWER); 836525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 837525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 838525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project unsigned long num = 0; 839525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 840525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcAdaptation& theInstance = NfcAdaptation::GetInstance(); 841525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project theInstance.Initialize(); //start GKI, NCI task, NFC task 842525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 843525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 844525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaEnableEvent); 845525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tHAL_NFC_ENTRY* halFuncEntries = theInstance.GetHalEntryFuncs (); 846525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 847525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NFA_Init (halFuncEntries); 848525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 849525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project stat = NFA_Enable (nfaDeviceManagementCallback, nfaConnectionCallback); 850525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (stat == NFA_STATUS_OK) 851525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 852525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project num = initializeGlobalAppLogLevel (); 853525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project CE_SetTraceLevel (num); 854525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project LLCP_SetTraceLevel (num); 855525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NFC_SetTraceLevel (num); 856525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project RW_SetTraceLevel (num); 857525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NFA_SetTraceLevel (num); 858525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NFA_P2pSetTraceLevel (num); 859525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaEnableEvent.wait(); //wait for NFA command to finish 860525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 861525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 862525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 863525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (stat == NFA_STATUS_OK) 864525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 865525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project //sIsNfaEnabled indicates whether stack started successfully 866525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (sIsNfaEnabled) 867525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 868525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SecureElement::getInstance().initialize (getNative(e, o)); 8699f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen RoutingManager::getInstance().initialize(getNative(e, o)); 870525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_registerNdefTypeHandler (); 871525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcTag::getInstance().initialize (getNative(e, o)); 872525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PeerToPeer::getInstance().initialize (); 873525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PeerToPeer::getInstance().handleNfcOnOff (true); 874525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 875525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ///////////////////////////////////////////////////////////////////////////////// 876525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // Add extra configuration here (work-arounds, etc.) 877525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 878525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project struct nfc_jni_native_data *nat = getNative(e, o); 879525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 880525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if ( nat ) 881525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 882525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (GetNumValue(NAME_POLLING_TECH_MASK, &num, sizeof(num))) 883525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nat->tech_mask = num; 884525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project else 885525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nat->tech_mask = DEFAULT_TECH_MASK; 886525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: tag polling tech mask=0x%X", __FUNCTION__, nat->tech_mask); 887525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 888525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 889525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // if this value exists, set polling interval. 890525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (GetNumValue(NAME_NFA_DM_DISC_DURATION_POLL, &num, sizeof(num))) 891c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen nat->discovery_duration = num; 892c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen else 893c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen nat->discovery_duration = DEFAULT_DISCOVERY_DURATION; 894c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen 895c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen NFA_SetRfDiscoveryDuration(nat->discovery_duration); 896525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 897525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // Do custom NFCA startup configuration. 898525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project doStartupConfig(); 899525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project goto TheEnd; 900525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 901525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 902525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 903525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: fail nfa enable; error=0x%X", __FUNCTION__, stat); 904525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 905525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (sIsNfaEnabled) 906525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project stat = NFA_Disable (FALSE /* ungraceful */); 907525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 908525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project theInstance.Finalize(); 909525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 910525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 911525c260303268a83da4c3413b953d13c9084e834The Android Open Source ProjectTheEnd: 912525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (sIsNfaEnabled) 913525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PowerSwitch::getInstance ().setLevel (PowerSwitch::LOW_POWER); 914525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: exit", __FUNCTION__); 915525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return sIsNfaEnabled ? JNI_TRUE : JNI_FALSE; 916525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 917525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 918525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 919525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 920525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 921525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_enableDiscovery 922525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 923525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Start polling and listening for devices. 924525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 925525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 926525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** mode: Not used. 927525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 928525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: None 929525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 930525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 931525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic void nfcManager_enableDiscovery (JNIEnv* e, jobject o) 932525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 933525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tNFA_TECHNOLOGY_MASK tech_mask = DEFAULT_TECH_MASK; 934525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project struct nfc_jni_native_data *nat = getNative(e, o); 935525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 936525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (nat) 937525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tech_mask = (tNFA_TECHNOLOGY_MASK)nat->tech_mask; 938525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 939525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: enter; tech_mask = %02x", __FUNCTION__, tech_mask); 940525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 941525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (sDiscoveryEnabled) 942525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 943525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: already polling", __FUNCTION__); 944525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return; 945525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 946525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 947525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tNFA_STATUS stat = NFA_STATUS_OK; 948525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 949525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: sIsSecElemSelected=%u", __FUNCTION__, sIsSecElemSelected); 950525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 951525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PowerSwitch::getInstance ().setLevel (PowerSwitch::FULL_POWER); 952525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 953525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (sRfEnabled) { 954525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // Stop RF discovery to reconfigure 955525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project startRfDiscovery(false); 956525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 957525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 958525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 959525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaEnableDisablePollingEvent); 960525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project stat = NFA_EnablePolling (tech_mask); 961525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (stat == NFA_STATUS_OK) 962525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 963525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: wait for enable event", __FUNCTION__); 964525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sDiscoveryEnabled = true; 965525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaEnableDisablePollingEvent.wait (); //wait for NFA_POLL_ENABLED_EVT 966525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: got enabled event", __FUNCTION__); 967525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 968525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project else 969525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 970525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: fail enable discovery; error=0x%X", __FUNCTION__, stat); 971525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 972525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 973525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 974525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // Start P2P listening if tag polling was enabled or the mask was 0. 975525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (sDiscoveryEnabled || (tech_mask == 0)) 976525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 977525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: Enable p2pListening", __FUNCTION__); 978525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PeerToPeer::getInstance().enableP2pListening (true); 979525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 980525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 981525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // Actually start discovery. 982525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project startRfDiscovery (true); 983525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 984525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PowerSwitch::getInstance ().setModeOn (PowerSwitch::DISCOVERY); 985525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 986525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: exit", __FUNCTION__); 987525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 988525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 989525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 990525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 991525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 992525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_disableDiscovery 993525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 994525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Stop polling and listening for devices. 995525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 996525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 997525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 998525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: None 999525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1000525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 10012534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesvoid nfcManager_disableDiscovery (JNIEnv*, jobject) 1002525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1003525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tNFA_STATUS status = NFA_STATUS_OK; 1004525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: enter;", __FUNCTION__); 1005525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1006525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project pn544InteropAbortNow (); 1007525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (sDiscoveryEnabled == false) 1008525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1009525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: already disabled", __FUNCTION__); 1010525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project goto TheEnd; 1011525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1012525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1013525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // Stop RF Discovery. 1014525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project startRfDiscovery (false); 1015525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1016525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (sDiscoveryEnabled) 1017525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1018525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaEnableDisablePollingEvent); 1019525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project status = NFA_DisablePolling (); 1020525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (status == NFA_STATUS_OK) 1021525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1022525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sDiscoveryEnabled = false; 1023525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaEnableDisablePollingEvent.wait (); //wait for NFA_POLL_DISABLED_EVT 1024525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1025525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project else 1026525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: Failed to disable polling; error=0x%X", __FUNCTION__, status); 1027525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1028525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1029525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PeerToPeer::getInstance().enableP2pListening (false); 1030525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1031525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project //if nothing is active after this, then tell the controller to power down 1032525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (! PowerSwitch::getInstance ().setModeOff (PowerSwitch::DISCOVERY)) 1033525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PowerSwitch::getInstance ().setLevel (PowerSwitch::LOW_POWER); 1034525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1035b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen // We may have had RF field notifications that did not cause 1036b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen // any activate/deactive events. For example, caused by wireless 1037b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen // charging orbs. Those may cause us to go to sleep while the last 1038b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen // field event was indicating a field. To prevent sticking in that 1039b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen // state, always reset the rf field status when we disable discovery. 1040b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen SecureElement::getInstance().resetRfFieldStatus(); 1041525c260303268a83da4c3413b953d13c9084e834The Android Open Source ProjectTheEnd: 1042525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: exit", __FUNCTION__); 1043525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1044525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1045d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenenvoid enableDisableLptd (bool enable) 1046d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen{ 1047d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen // This method is *NOT* thread-safe. Right now 1048d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen // it is only called from the same thread so it's 1049d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen // not an issue. 1050d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen static bool sCheckedLptd = false; 1051d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen static bool sHasLptd = false; 1052d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen 1053d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen tNFA_STATUS stat = NFA_STATUS_OK; 1054d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen if (!sCheckedLptd) 1055d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen { 1056d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen sCheckedLptd = true; 1057d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen SyncEventGuard guard (sNfaGetConfigEvent); 1058d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen tNFA_PMID configParam[1] = {NCI_PARAM_ID_TAGSNIFF_CFG}; 1059d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen stat = NFA_GetConfig(1, configParam); 1060d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen if (stat != NFA_STATUS_OK) 1061d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen { 1062d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen ALOGE("%s: NFA_GetConfig failed", __FUNCTION__); 1063d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen return; 1064d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen } 1065d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen sNfaGetConfigEvent.wait (); 1066d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen if (sCurrentConfigLen < 4 || sConfig[1] != NCI_PARAM_ID_TAGSNIFF_CFG) { 1067d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen ALOGE("%s: Config TLV length %d returned is too short", __FUNCTION__, 1068d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen sCurrentConfigLen); 1069d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen return; 1070d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen } 1071d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen sHasLptd = true; 1072d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen } 1073d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen // Bail if we checked and didn't find any LPTD config before 1074d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen if (!sHasLptd) return; 107533aeb7c13f8fd9d9bd301f31680836b8ec912d51Martijn Coenen UINT8 enable_byte = enable ? 0x01 : 0x00; 1076d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen 1077d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen SyncEventGuard guard(sNfaSetConfigEvent); 1078d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen 107933aeb7c13f8fd9d9bd301f31680836b8ec912d51Martijn Coenen stat = NFA_SetConfig(NCI_PARAM_ID_TAGSNIFF_CFG, 1, &enable_byte); 1080d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen if (stat == NFA_STATUS_OK) 1081d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen sNfaSetConfigEvent.wait (); 1082d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen else 1083d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen ALOGE("%s: Could not configure LPTD feature", __FUNCTION__); 1084d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen return; 1085d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen} 1086d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen 108761beae816af13f75dabb484d287739723c716deeMartijn Coenenvoid setUiccIdleTimeout (bool enable) 108861beae816af13f75dabb484d287739723c716deeMartijn Coenen{ 1089f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen // This method is *NOT* thread-safe. Right now 1090f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen // it is only called from the same thread so it's 1091f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen // not an issue. 109261beae816af13f75dabb484d287739723c716deeMartijn Coenen tNFA_STATUS stat = NFA_STATUS_OK; 1093f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen UINT8 swp_cfg_byte0 = 0x00; 109461beae816af13f75dabb484d287739723c716deeMartijn Coenen { 1095f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen SyncEventGuard guard (sNfaGetConfigEvent); 1096c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen tNFA_PMID configParam[1] = {0xC2}; 1097c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen stat = NFA_GetConfig(1, configParam); 1098f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen if (stat != NFA_STATUS_OK) 1099f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen { 1100f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen ALOGE("%s: NFA_GetConfig failed", __FUNCTION__); 1101f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen return; 1102f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen } 1103f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen sNfaGetConfigEvent.wait (); 1104f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen if (sCurrentConfigLen < 4 || sConfig[1] != 0xC2) { 1105f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen ALOGE("%s: Config TLV length %d returned is too short", __FUNCTION__, 1106f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen sCurrentConfigLen); 1107f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen return; 1108f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen } 1109f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen swp_cfg_byte0 = sConfig[3]; 111061beae816af13f75dabb484d287739723c716deeMartijn Coenen } 1111f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen SyncEventGuard guard(sNfaSetConfigEvent); 1112f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen if (enable) 1113f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen swp_cfg_byte0 |= 0x01; 111461beae816af13f75dabb484d287739723c716deeMartijn Coenen else 1115f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen swp_cfg_byte0 &= ~0x01; 1116f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen 1117f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen stat = NFA_SetConfig(0xC2, 1, &swp_cfg_byte0); 1118f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen if (stat == NFA_STATUS_OK) 1119f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen sNfaSetConfigEvent.wait (); 1120f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen else 1121f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen ALOGE("%s: Could not configure UICC idle timeout feature", __FUNCTION__); 1122f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen return; 112361beae816af13f75dabb484d287739723c716deeMartijn Coenen} 1124525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1125525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1126525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function nfc_jni_cache_object_local 1127525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1128525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description Allocates a java object and calls it's constructor 1129525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1130525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns -1 on failure, 0 on success 1131525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1132525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 11332534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic int nfc_jni_cache_object_local (JNIEnv *e, const char *className, jobject *cachedObj) 1134525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 11352534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes ScopedLocalRef<jclass> cls(e, e->FindClass(className)); 11362534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes if(cls.get() == NULL) { 1137525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: find class error", __FUNCTION__); 1138525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return -1; 1139525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1140525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 11412534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes jmethodID ctor = e->GetMethodID(cls.get(), "<init>", "()V"); 11422534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes jobject obj = e->NewObject(cls.get(), ctor); 11432534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes if (obj == NULL) { 1144525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: create object error", __FUNCTION__); 1145525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return -1; 1146525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1147525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 11482534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes *cachedObj = obj; 11492534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes if (*cachedObj == NULL) { 1150525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: global ref error", __FUNCTION__); 1151525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return -1; 1152525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1153525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return 0; 1154525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1155525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1156525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1157525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1158525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1159525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doCreateLlcpServiceSocket 1160525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1161525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Create a new LLCP server socket. 1162525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 1163525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 1164525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** nSap: Service access point. 1165525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** sn: Service name 1166525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** miu: Maximum information unit. 1167525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** rw: Receive window size. 1168525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** linearBufferLength: Max buffer size. 1169525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1170525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: NativeLlcpServiceSocket Java object. 1171525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1172525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 11732534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jobject nfcManager_doCreateLlcpServiceSocket (JNIEnv* e, jobject, jint nSap, jstring sn, jint miu, jint rw, jint linearBufferLength) 1174525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1175525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PeerToPeer::tJNI_HANDLE jniHandle = PeerToPeer::getInstance().getNewJniHandle (); 1176525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 11772534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes ScopedUtfChars serviceName(e, sn); 11782534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes 11792534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes ALOGD ("%s: enter: sap=%i; name=%s; miu=%i; rw=%i; buffLen=%i", __FUNCTION__, nSap, serviceName.c_str(), miu, rw, linearBufferLength); 1180525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1181525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project /* Create new NativeLlcpServiceSocket object */ 11822534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes jobject serviceSocket = NULL; 1183525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (nfc_jni_cache_object(e, gNativeLlcpServiceSocketClassName, &(serviceSocket)) == -1) 1184525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1185525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: Llcp socket object creation error", __FUNCTION__); 1186525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return NULL; 1187525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1188525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1189525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project /* Get NativeLlcpServiceSocket class object */ 11902534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes ScopedLocalRef<jclass> clsNativeLlcpServiceSocket(e, e->GetObjectClass(serviceSocket)); 1191525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (e->ExceptionCheck()) 1192525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1193525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project e->ExceptionClear(); 1194525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE("%s: Llcp Socket get object class error", __FUNCTION__); 1195525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return NULL; 1196525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1197525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 11982534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes if (!PeerToPeer::getInstance().registerServer (jniHandle, serviceName.c_str())) 1199525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1200525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE("%s: RegisterServer error", __FUNCTION__); 1201525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return NULL; 1202525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1203525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 12042534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes jfieldID f; 12052534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes 1206525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project /* Set socket handle to be the same as the NfaHandle*/ 12072534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes f = e->GetFieldID(clsNativeLlcpServiceSocket.get(), "mHandle", "I"); 12082534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes e->SetIntField(serviceSocket, f, (jint) jniHandle); 1209525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: socket Handle = 0x%X", __FUNCTION__, jniHandle); 1210525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1211525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project /* Set socket linear buffer length */ 12122534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes f = e->GetFieldID(clsNativeLlcpServiceSocket.get(), "mLocalLinearBufferLength", "I"); 12132534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes e->SetIntField(serviceSocket, f,(jint)linearBufferLength); 1214525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: buffer length = %d", __FUNCTION__, linearBufferLength); 1215525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1216525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project /* Set socket MIU */ 12172534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes f = e->GetFieldID(clsNativeLlcpServiceSocket.get(), "mLocalMiu", "I"); 12182534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes e->SetIntField(serviceSocket, f,(jint)miu); 1219525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: MIU = %d", __FUNCTION__, miu); 1220525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1221525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project /* Set socket RW */ 12222534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes f = e->GetFieldID(clsNativeLlcpServiceSocket.get(), "mLocalRw", "I"); 12232534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes e->SetIntField(serviceSocket, f,(jint)rw); 1224525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: RW = %d", __FUNCTION__, rw); 1225525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1226525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sLastError = 0; 1227525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: exit", __FUNCTION__); 1228525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return serviceSocket; 1229525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1230525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1231525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1232525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1233525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1234525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doGetLastError 1235525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1236525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Get the last error code. 1237525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 1238525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 1239525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1240525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: Last error code. 1241525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1242525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 12432534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jint nfcManager_doGetLastError(JNIEnv*, jobject) 1244525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1245525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: last error=%i", __FUNCTION__, sLastError); 1246525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return sLastError; 1247525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1248525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1249525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1250525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1251525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1252525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doDeinitialize 1253525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1254525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Turn off NFC. 1255525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 1256525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 1257525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1258525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: True if ok. 1259525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1260525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 12612534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jboolean nfcManager_doDeinitialize (JNIEnv*, jobject) 1262525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1263525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: enter", __FUNCTION__); 1264525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1265525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sIsDisabling = true; 1266525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project pn544InteropAbortNow (); 1267525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SecureElement::getInstance().finalize (); 1268a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu PowerSwitch::getInstance ().initialize (PowerSwitch::UNKNOWN_LEVEL); 1269525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1270525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (sIsNfaEnabled) 1271525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1272525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaDisableEvent); 1273525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tNFA_STATUS stat = NFA_Disable (TRUE /* graceful */); 1274525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (stat == NFA_STATUS_OK) 1275525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1276525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: wait for completion", __FUNCTION__); 1277525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaDisableEvent.wait (); //wait for NFA command to finish 1278525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PeerToPeer::getInstance ().handleNfcOnOff (false); 1279525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1280525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project else 1281525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1282525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: fail disable; error=0x%X", __FUNCTION__, stat); 1283525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1284525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1285525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_abortWaits(); 1286525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcTag::getInstance().abort (); 1287525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sAbortConnlessWait = true; 1288525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeLlcpConnectionlessSocket_abortWait(); 1289525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sIsNfaEnabled = false; 1290525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sDiscoveryEnabled = false; 1291525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sIsDisabling = false; 1292525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sIsSecElemSelected = false; 12938d154680537afa5242edeb98c8f414d6186558cfMartijn Coenen gActivated = false; 1294525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1295525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1296525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project //unblock NFA_EnablePolling() and NFA_DisablePolling() 1297525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaEnableDisablePollingEvent); 1298525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaEnableDisablePollingEvent.notifyOne (); 1299525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1300525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1301525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcAdaptation& theInstance = NfcAdaptation::GetInstance(); 1302525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project theInstance.Finalize(); 1303525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1304525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: exit", __FUNCTION__); 1305525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return JNI_TRUE; 1306525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1307525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1308525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1309525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1310525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1311525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doCreateLlcpSocket 1312525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1313525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Create a LLCP connection-oriented socket. 1314525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 1315525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 1316525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** nSap: Service access point. 1317525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** miu: Maximum information unit. 1318525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** rw: Receive window size. 1319525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** linearBufferLength: Max buffer size. 1320525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1321525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: NativeLlcpSocket Java object. 1322525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1323525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 13242534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jobject nfcManager_doCreateLlcpSocket (JNIEnv* e, jobject, jint nSap, jint miu, jint rw, jint linearBufferLength) 1325525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1326525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: enter; sap=%d; miu=%d; rw=%d; buffer len=%d", __FUNCTION__, nSap, miu, rw, linearBufferLength); 1327525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 13282534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes PeerToPeer::tJNI_HANDLE jniHandle = PeerToPeer::getInstance().getNewJniHandle (); 1329a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu PeerToPeer::getInstance().createClient (jniHandle, miu, rw); 1330525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1331525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project /* Create new NativeLlcpSocket object */ 13322534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes jobject clientSocket = NULL; 1333525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (nfc_jni_cache_object_local(e, gNativeLlcpSocketClassName, &(clientSocket)) == -1) 1334525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1335525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: fail Llcp socket creation", __FUNCTION__); 13362534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes return clientSocket; 1337525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1338525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1339525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project /* Get NativeConnectionless class object */ 13402534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes ScopedLocalRef<jclass> clsNativeLlcpSocket(e, e->GetObjectClass(clientSocket)); 1341525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (e->ExceptionCheck()) 1342525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1343525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project e->ExceptionClear(); 1344525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: fail get class object", __FUNCTION__); 13452534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes return clientSocket; 1346525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1347525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 13482534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes jfieldID f; 13492534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes 1350525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project /* Set socket SAP */ 13512534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes f = e->GetFieldID (clsNativeLlcpSocket.get(), "mSap", "I"); 1352525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project e->SetIntField (clientSocket, f, (jint) nSap); 1353525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1354525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project /* Set socket handle */ 13552534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes f = e->GetFieldID (clsNativeLlcpSocket.get(), "mHandle", "I"); 1356525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project e->SetIntField (clientSocket, f, (jint) jniHandle); 1357525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1358525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project /* Set socket MIU */ 13592534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes f = e->GetFieldID (clsNativeLlcpSocket.get(), "mLocalMiu", "I"); 1360525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project e->SetIntField (clientSocket, f, (jint) miu); 1361525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1362525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project /* Set socket RW */ 13632534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes f = e->GetFieldID (clsNativeLlcpSocket.get(), "mLocalRw", "I"); 1364525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project e->SetIntField (clientSocket, f, (jint) rw); 1365525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1366525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: exit", __FUNCTION__); 1367525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return clientSocket; 1368525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1369525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1370525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1371525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1372525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1373525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doCreateLlcpConnectionlessSocket 1374525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1375525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Create a connection-less socket. 1376525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 1377525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 1378525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** nSap: Service access point. 1379525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** sn: Service name. 1380525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1381525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: NativeLlcpConnectionlessSocket Java object. 1382525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1383525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 13842534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jobject nfcManager_doCreateLlcpConnectionlessSocket (JNIEnv *, jobject, jint nSap, jstring /*sn*/) 1385525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1386525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: nSap=0x%X", __FUNCTION__, nSap); 1387525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return NULL; 1388525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1389525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1390525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1391525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1392525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1393525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doGetSecureElementList 1394525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1395525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Get a list of secure element handles. 1396525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 1397525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 1398525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1399525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: List of secure element handles. 1400525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1401525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 14022534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jintArray nfcManager_doGetSecureElementList(JNIEnv* e, jobject) 1403525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1404525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s", __FUNCTION__); 1405a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu return SecureElement::getInstance().getSecureElementIdList (e); 1406525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1407525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 14089f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen/******************************************************************************* 14099f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 14109f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Function: nfcManager_enableRoutingToHost 14119f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 1412d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen** Description: NFC controller starts routing data to host. 14139f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** e: JVM environment. 14149f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** o: Java object. 14159f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 14169f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Returns: None 14179f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 14189f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen*******************************************************************************/ 14199f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenenstatic void nfcManager_enableRoutingToHost(JNIEnv*, jobject) 14209f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen{ 14219f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen ALOGD ("%s: enter", __FUNCTION__); 14229f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen PowerSwitch::getInstance ().setLevel (PowerSwitch::FULL_POWER); 14239f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen PowerSwitch::getInstance ().setModeOn (PowerSwitch::HOST_ROUTING); 14249f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen if (sRfEnabled) { 14259f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen // Stop RF discovery to reconfigure 14269f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen startRfDiscovery(false); 14279f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen } 14289f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen RoutingManager::getInstance().commitRouting(); 14299f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen startRfDiscovery(true); 14309f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen ALOGD ("%s: exit", __FUNCTION__); 14319f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen} 14329f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 14339f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen/******************************************************************************* 14349f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 14359f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Function: nfcManager_disableRoutingToHost 14369f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 1437d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen** Description: NFC controller stops routing data to host. 14389f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** e: JVM environment. 14399f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** o: Java object. 14409f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 14419f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Returns: None 14429f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 14439f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen*******************************************************************************/ 14449f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenenstatic void nfcManager_disableRoutingToHost(JNIEnv*, jobject) 14459f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen{ 14469f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen ALOGD ("%s: enter", __FUNCTION__); 1447d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen bool rfWasEnabled = false; 14489f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 1449d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen if (PowerSwitch::getInstance ().getLevel() == PowerSwitch::LOW_POWER) 1450d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen { 1451d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen ALOGD ("%s: no need to disable routing while power is OFF", __FUNCTION__); 1452d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen goto TheEnd; 1453d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen } 1454d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen 1455d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen if (sRfEnabled) { 1456d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen rfWasEnabled = true; 1457d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen // Stop RF discovery to reconfigure 1458d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen startRfDiscovery(false); 1459d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen } 1460d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen RoutingManager::getInstance().commitRouting(); 1461d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen if (rfWasEnabled) 1462d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen { 1463d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen startRfDiscovery(true); 1464d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen } 14659f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen if (! PowerSwitch::getInstance ().setModeOff (PowerSwitch::HOST_ROUTING)) 14669f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen PowerSwitch::getInstance ().setLevel (PowerSwitch::LOW_POWER); 14679f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn CoenenTheEnd: 14689f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen ALOGD ("%s: exit", __FUNCTION__); 14699f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen} 1470525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1471525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1472525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1473525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doSelectSecureElement 1474525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1475525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: NFC controller starts routing data in listen mode. 1476525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 1477525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 1478525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1479525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: None 1480525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1481525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 14822534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic void nfcManager_doSelectSecureElement(JNIEnv*, jobject) 1483525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1484525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: enter", __FUNCTION__); 1485525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project bool stat = true; 1486525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1487aafca6482d0b65b1ecab990659c07e4a82582db8Martijn Coenen if (sIsSecElemSelected) 1488aafca6482d0b65b1ecab990659c07e4a82582db8Martijn Coenen { 1489aafca6482d0b65b1ecab990659c07e4a82582db8Martijn Coenen ALOGD ("%s: already selected", __FUNCTION__); 1490aafca6482d0b65b1ecab990659c07e4a82582db8Martijn Coenen goto TheEnd; 1491aafca6482d0b65b1ecab990659c07e4a82582db8Martijn Coenen } 1492aafca6482d0b65b1ecab990659c07e4a82582db8Martijn Coenen 1493525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PowerSwitch::getInstance ().setLevel (PowerSwitch::FULL_POWER); 1494525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1495525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (sRfEnabled) { 1496525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // Stop RF Discovery if we were polling 1497525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project startRfDiscovery (false); 1498525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1499525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 15009f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 1501525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project stat = SecureElement::getInstance().activate (0xABCDEF); 1502525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sIsSecElemSelected = true; 1503525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1504525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project startRfDiscovery (true); 1505525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PowerSwitch::getInstance ().setModeOn (PowerSwitch::SE_ROUTING); 1506aafca6482d0b65b1ecab990659c07e4a82582db8Martijn CoenenTheEnd: 1507525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: exit", __FUNCTION__); 1508525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1509525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1510525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1511525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1512525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1513525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doDeselectSecureElement 1514525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1515525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: NFC controller stops routing data in listen mode. 1516525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 1517525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 1518525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1519525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: None 1520525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1521525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 15222534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic void nfcManager_doDeselectSecureElement(JNIEnv*, jobject) 1523525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1524525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: enter", __FUNCTION__); 1525be1939b4b6003ac7a65fcb95a3912f5e1ce8e75fThe Android Open Source Project bool bRestartDiscovery = false; 1526525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1527525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (! sIsSecElemSelected) 1528525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1529525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: already deselected", __FUNCTION__); 1530a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu goto TheEnd2; 1531525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1532525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1533525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (PowerSwitch::getInstance ().getLevel() == PowerSwitch::LOW_POWER) 1534525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1535525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: do not deselect while power is OFF", __FUNCTION__); 1536525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sIsSecElemSelected = false; 1537525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project goto TheEnd; 1538525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1539525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1540be1939b4b6003ac7a65fcb95a3912f5e1ce8e75fThe Android Open Source Project if (sRfEnabled) { 1541be1939b4b6003ac7a65fcb95a3912f5e1ce8e75fThe Android Open Source Project // Stop RF Discovery if we were polling 1542be1939b4b6003ac7a65fcb95a3912f5e1ce8e75fThe Android Open Source Project startRfDiscovery (false); 1543be1939b4b6003ac7a65fcb95a3912f5e1ce8e75fThe Android Open Source Project bRestartDiscovery = true; 1544be1939b4b6003ac7a65fcb95a3912f5e1ce8e75fThe Android Open Source Project } 1545be1939b4b6003ac7a65fcb95a3912f5e1ce8e75fThe Android Open Source Project 1546525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project //if controller is not routing to sec elems AND there is no pipe connected, 1547525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project //then turn off the sec elems 1548525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (SecureElement::getInstance().isBusy() == false) 1549525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SecureElement::getInstance().deactivate (0xABCDEF); 1550525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 15519f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen sIsSecElemSelected = false; 1552525c260303268a83da4c3413b953d13c9084e834The Android Open Source ProjectTheEnd: 1553be1939b4b6003ac7a65fcb95a3912f5e1ce8e75fThe Android Open Source Project if (bRestartDiscovery) 1554be1939b4b6003ac7a65fcb95a3912f5e1ce8e75fThe Android Open Source Project startRfDiscovery (true); 1555be1939b4b6003ac7a65fcb95a3912f5e1ce8e75fThe Android Open Source Project 1556525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project //if nothing is active after this, then tell the controller to power down 1557525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (! PowerSwitch::getInstance ().setModeOff (PowerSwitch::SE_ROUTING)) 1558525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PowerSwitch::getInstance ().setLevel (PowerSwitch::LOW_POWER); 1559525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1560a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan ChuTheEnd2: 1561525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: exit", __FUNCTION__); 1562525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1563525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1564525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1565525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1566525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1567525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: isPeerToPeer 1568525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1569525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Whether the activation data indicates the peer supports NFC-DEP. 1570525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** activated: Activation data. 1571525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1572525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: True if the peer supports NFC-DEP. 1573525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1574525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 1575525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool isPeerToPeer (tNFA_ACTIVATED& activated) 1576525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1577525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return activated.activate_ntf.protocol == NFA_PROTOCOL_NFC_DEP; 1578525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1579525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1580525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1581525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1582525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: isListenMode 1583525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1584525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Indicates whether the activation data indicates it is 1585525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** listen mode. 1586525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1587525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: True if this listen mode. 1588525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1589525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 1590525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool isListenMode(tNFA_ACTIVATED& activated) 1591525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1592525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return ((NFC_DISCOVERY_TYPE_LISTEN_A == activated.activate_ntf.rf_tech_param.mode) 1593525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project || (NFC_DISCOVERY_TYPE_LISTEN_B == activated.activate_ntf.rf_tech_param.mode) 1594525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project || (NFC_DISCOVERY_TYPE_LISTEN_F == activated.activate_ntf.rf_tech_param.mode) 1595525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project || (NFC_DISCOVERY_TYPE_LISTEN_A_ACTIVE == activated.activate_ntf.rf_tech_param.mode) 1596525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project || (NFC_DISCOVERY_TYPE_LISTEN_F_ACTIVE == activated.activate_ntf.rf_tech_param.mode) 1597525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project || (NFC_DISCOVERY_TYPE_LISTEN_ISO15693 == activated.activate_ntf.rf_tech_param.mode) 1598525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project || (NFC_DISCOVERY_TYPE_LISTEN_B_PRIME == activated.activate_ntf.rf_tech_param.mode)); 1599525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1600525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1601525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1602525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1603525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doCheckLlcp 1604525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1605525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Not used. 1606525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1607525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: True 1608525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1609525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 16102534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jboolean nfcManager_doCheckLlcp(JNIEnv*, jobject) 1611525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1612525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s", __FUNCTION__); 1613525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return JNI_TRUE; 1614525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1615525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1616525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1617525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1618525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1619525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doActivateLlcp 1620525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1621525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Not used. 1622525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1623525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: True 1624525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1625525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 16262534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jboolean nfcManager_doActivateLlcp(JNIEnv*, jobject) 1627525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1628525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s", __FUNCTION__); 1629525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return JNI_TRUE; 1630525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1631525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1632525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1633525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1634525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1635525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doAbort 1636525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1637525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Not used. 1638525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1639525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: None 1640525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1641525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 16422534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic void nfcManager_doAbort(JNIEnv*, jobject) 1643525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1644525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE("%s: abort()", __FUNCTION__); 1645525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project abort(); 1646525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1647525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1648525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1649525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1650525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1651525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doDownload 1652525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1653a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu** Description: Download firmware patch files. Do not turn on NFC. 1654525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1655a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu** Returns: True if ok. 1656525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1657525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 16582534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jboolean nfcManager_doDownload(JNIEnv*, jobject) 1659525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1660a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu ALOGD ("%s: enter", __FUNCTION__); 1661a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu NfcAdaptation& theInstance = NfcAdaptation::GetInstance(); 1662a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu 1663a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu theInstance.Initialize(); //start GKI, NCI task, NFC task 1664a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu theInstance.DownloadFirmware (); 1665a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu theInstance.Finalize(); 1666a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu ALOGD ("%s: exit", __FUNCTION__); 1667525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return JNI_TRUE; 1668525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1669525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1670525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1671525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1672525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1673525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doResetTimeouts 1674525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1675525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Not used. 1676525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1677525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: None 1678525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1679525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 16802534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic void nfcManager_doResetTimeouts(JNIEnv*, jobject) 1681525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1682a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu ALOGD ("%s", __FUNCTION__); 1683a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu NfcTag::getInstance().resetAllTransceiveTimeouts (); 1684525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1685525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1686525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1687525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1688525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1689525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doSetTimeout 1690525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1691525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Set timeout value. 1692525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 1693525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 1694a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu** tech: technology ID. 1695525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** timeout: Timeout value. 1696525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1697525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: True if ok. 1698525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1699525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 1700a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chustatic bool nfcManager_doSetTimeout(JNIEnv*, jobject, jint tech, jint timeout) 1701525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1702525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (timeout <= 0) 1703525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1704525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE("%s: Timeout must be positive.",__FUNCTION__); 1705525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return false; 1706525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1707a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu ALOGD ("%s: tech=%d, timeout=%d", __FUNCTION__, tech, timeout); 1708a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu NfcTag::getInstance().setTransceiveTimeout (tech, timeout); 1709525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return true; 1710525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1711525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1712525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1713525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1714525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1715525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doGetTimeout 1716525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1717525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Get timeout value. 1718525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 1719525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 1720a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu** tech: technology ID. 1721525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1722525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: Timeout value. 1723525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1724525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 1725a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chustatic jint nfcManager_doGetTimeout(JNIEnv*, jobject, jint tech) 1726525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1727a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu int timeout = NfcTag::getInstance().getTransceiveTimeout (tech); 1728a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu ALOGD ("%s: tech=%d, timeout=%d", __FUNCTION__, tech, timeout); 1729a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu return timeout; 1730525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1731525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1732525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1733525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1734525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1735525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doDump 1736525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1737525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Not used. 1738525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 1739525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 1740525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1741525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: Text dump. 1742525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1743525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 17442534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jstring nfcManager_doDump(JNIEnv* e, jobject) 1745525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1746525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project char buffer[100]; 1747525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project snprintf(buffer, sizeof(buffer), "libnfc llc error_count=%u", /*libnfc_llc_error_count*/ 0); 1748525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return e->NewStringUTF(buffer); 1749525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1750525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1751525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1752525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1753525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1754525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doSetP2pInitiatorModes 1755525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1756525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Set P2P initiator's activation modes. 1757525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 1758525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 1759525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** modes: Active and/or passive modes. The values are specified 1760525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** in external/libnfc-nxp/inc/phNfcTypes.h. See 1761525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** enum phNfc_eP2PMode_t. 1762525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1763525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: None. 1764525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1765525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 1766525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic void nfcManager_doSetP2pInitiatorModes (JNIEnv *e, jobject o, jint modes) 1767525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1768525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: modes=0x%X", __FUNCTION__, modes); 1769525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project struct nfc_jni_native_data *nat = getNative(e, o); 1770525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1771525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tNFA_TECHNOLOGY_MASK mask = 0; 1772525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (modes & 0x01) mask |= NFA_TECHNOLOGY_MASK_A; 1773525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (modes & 0x02) mask |= NFA_TECHNOLOGY_MASK_F; 1774525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (modes & 0x04) mask |= NFA_TECHNOLOGY_MASK_F; 1775525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (modes & 0x08) mask |= NFA_TECHNOLOGY_MASK_A_ACTIVE; 1776525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (modes & 0x10) mask |= NFA_TECHNOLOGY_MASK_F_ACTIVE; 1777525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (modes & 0x20) mask |= NFA_TECHNOLOGY_MASK_F_ACTIVE; 1778525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nat->tech_mask = mask; 1779525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1780525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1781525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1782525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1783525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1784525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doSetP2pTargetModes 1785525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1786525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Set P2P target's activation modes. 1787525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 1788525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 1789525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** modes: Active and/or passive modes. 1790525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1791525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: None. 1792525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1793525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 17942534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic void nfcManager_doSetP2pTargetModes (JNIEnv*, jobject, jint modes) 1795525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1796525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: modes=0x%X", __FUNCTION__, modes); 1797525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // Map in the right modes 1798525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tNFA_TECHNOLOGY_MASK mask = 0; 1799525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (modes & 0x01) mask |= NFA_TECHNOLOGY_MASK_A; 1800525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (modes & 0x02) mask |= NFA_TECHNOLOGY_MASK_F; 1801525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (modes & 0x04) mask |= NFA_TECHNOLOGY_MASK_F; 1802525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (modes & 0x08) mask |= NFA_TECHNOLOGY_MASK_A_ACTIVE | NFA_TECHNOLOGY_MASK_F_ACTIVE; 1803525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1804525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PeerToPeer::getInstance().setP2pListenMask(mask); 1805525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1806525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1807c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenenstatic void nfcManager_doEnableReaderMode (JNIEnv*, jobject, jint technologies) 1808c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen{ 1809c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen if (sDiscoveryEnabled) { 1810c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen sReaderModeEnabled = true; 1811c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen PeerToPeer::getInstance().enableP2pListening(false); 1812f5cd84c3a7ffb66196ab3c0745569da937d7533bMartijn Coenen NFA_PauseP2p(); 1813c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen NFA_DisableListening(); 1814c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen // Limit polling to these technologies 1815c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen int tech_mask = 0; 1816c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen if (technologies & 0x01) 1817c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen tech_mask |= NFA_TECHNOLOGY_MASK_A; 1818c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen if (technologies & 0x02) 1819c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen tech_mask |= NFA_TECHNOLOGY_MASK_B; 1820c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen if (technologies & 0x04) 1821c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen tech_mask |= NFA_TECHNOLOGY_MASK_F; 1822c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen if (technologies & 0x08) 1823c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen tech_mask |= NFA_TECHNOLOGY_MASK_ISO15693; 1824c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen if (technologies & 0x10) 1825c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen tech_mask |= NFA_TECHNOLOGY_MASK_KOVIO; 1826c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen 1827d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen enableDisableLptd(false); 1828c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen NFA_SetRfDiscoveryDuration(READER_MODE_DISCOVERY_DURATION); 1829c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen restartPollingWithTechMask(tech_mask); 1830c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen } 1831c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen} 1832c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen 1833c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenenstatic void nfcManager_doDisableReaderMode (JNIEnv* e, jobject o) 1834c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen{ 1835c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen struct nfc_jni_native_data *nat = getNative(e, o); 1836c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen if (sDiscoveryEnabled) { 1837c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen sReaderModeEnabled = false; 1838f5cd84c3a7ffb66196ab3c0745569da937d7533bMartijn Coenen NFA_ResumeP2p(); 1839c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen PeerToPeer::getInstance().enableP2pListening(true); 1840c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen NFA_EnableListening(); 1841d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen 1842d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen enableDisableLptd(true); 1843c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen NFA_SetRfDiscoveryDuration(nat->discovery_duration); 1844c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen restartPollingWithTechMask(nat->tech_mask); 1845c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen } 1846c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen} 1847c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen 1848c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen 1849525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/***************************************************************************** 1850525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1851525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** JNI functions for android-4.0.1_r1 1852525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1853525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*****************************************************************************/ 1854525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic JNINativeMethod gMethods[] = 1855525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1856525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doDownload", "()Z", 1857525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void *)nfcManager_doDownload}, 1858525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1859525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"initializeNativeStructure", "()Z", 1860525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void*) nfcManager_initNativeStruc}, 1861525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1862525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doInitialize", "()Z", 1863525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void*) nfcManager_doInitialize}, 1864525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1865525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doDeinitialize", "()Z", 1866525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void*) nfcManager_doDeinitialize}, 1867525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 18689f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen {"sendRawFrame", "([B)Z", 18699f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen (void*) nfcManager_sendRawFrame}, 18709f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 18719f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen {"routeAid", "([BI)Z", 18729f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen (void*) nfcManager_routeAid}, 18739f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 18749f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen {"unrouteAid", "([B)Z", 18759f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen (void*) nfcManager_unrouteAid}, 18769f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 1877525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"enableDiscovery", "()V", 1878525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void*) nfcManager_enableDiscovery}, 1879525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 18809f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen {"enableRoutingToHost", "()V", 18819f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen (void*) nfcManager_enableRoutingToHost}, 18829f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 18839f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen {"disableRoutingToHost", "()V", 18849f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen (void*) nfcManager_disableRoutingToHost}, 18859f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 1886525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doGetSecureElementList", "()[I", 1887525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void *)nfcManager_doGetSecureElementList}, 1888525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1889525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doSelectSecureElement", "()V", 1890525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void *)nfcManager_doSelectSecureElement}, 1891525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1892525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doDeselectSecureElement", "()V", 1893525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void *)nfcManager_doDeselectSecureElement}, 1894525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1895525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doCheckLlcp", "()Z", 1896525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void *)nfcManager_doCheckLlcp}, 1897525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1898525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doActivateLlcp", "()Z", 1899525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void *)nfcManager_doActivateLlcp}, 1900525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1901525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doCreateLlcpConnectionlessSocket", "(ILjava/lang/String;)Lcom/android/nfc/dhimpl/NativeLlcpConnectionlessSocket;", 1902525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void *)nfcManager_doCreateLlcpConnectionlessSocket}, 1903525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1904525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doCreateLlcpServiceSocket", "(ILjava/lang/String;III)Lcom/android/nfc/dhimpl/NativeLlcpServiceSocket;", 1905525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void*) nfcManager_doCreateLlcpServiceSocket}, 1906525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1907525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doCreateLlcpSocket", "(IIII)Lcom/android/nfc/dhimpl/NativeLlcpSocket;", 1908525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void*) nfcManager_doCreateLlcpSocket}, 1909525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1910525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doGetLastError", "()I", 1911525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void*) nfcManager_doGetLastError}, 1912525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1913525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"disableDiscovery", "()V", 1914525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void*) nfcManager_disableDiscovery}, 1915525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1916525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doSetTimeout", "(II)Z", 1917525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void *)nfcManager_doSetTimeout}, 1918525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1919525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doGetTimeout", "(I)I", 1920525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void *)nfcManager_doGetTimeout}, 1921525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1922525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doResetTimeouts", "()V", 1923525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void *)nfcManager_doResetTimeouts}, 1924525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1925525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doAbort", "()V", 1926525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void *)nfcManager_doAbort}, 1927525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1928525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doSetP2pInitiatorModes", "(I)V", 1929525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void *)nfcManager_doSetP2pInitiatorModes}, 1930525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1931525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doSetP2pTargetModes", "(I)V", 1932525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void *)nfcManager_doSetP2pTargetModes}, 1933525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1934c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen {"doEnableReaderMode", "(I)V", 1935c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen (void *)nfcManager_doEnableReaderMode}, 1936c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen 1937c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen {"doDisableReaderMode", "()V", 1938c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen (void *)nfcManager_doDisableReaderMode}, 1939c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen 1940525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doDump", "()Ljava/lang/String;", 1941525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void *)nfcManager_doDump}, 1942525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}; 1943525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1944525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1945525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1946525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1947525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: register_com_android_nfc_NativeNfcManager 1948525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1949525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Regisgter JNI functions with Java Virtual Machine. 1950525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: Environment of JVM. 1951525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1952525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: Status of registration. 1953525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1954525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 1955525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectint register_com_android_nfc_NativeNfcManager (JNIEnv *e) 1956525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1957525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: enter", __FUNCTION__); 1958525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PowerSwitch::getInstance ().initialize (PowerSwitch::UNKNOWN_LEVEL); 1959525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: exit", __FUNCTION__); 1960525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return jniRegisterNativeMethods (e, gNativeNfcManagerClassName, gMethods, NELEM (gMethods)); 1961525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1962525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1963525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1964525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1965525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1966525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: startRfDiscovery 1967525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1968525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Ask stack to start polling and listening for devices. 1969525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** isStart: Whether to start. 1970525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1971525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: None 1972525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1973525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 1974525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectvoid startRfDiscovery(bool isStart) 1975525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1976525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tNFA_STATUS status = NFA_STATUS_FAILED; 1977525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1978525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: is start=%d", __FUNCTION__, isStart); 1979525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaEnableDisablePollingEvent); 1980525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project status = isStart ? NFA_StartRfDiscovery () : NFA_StopRfDiscovery (); 1981525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (status == NFA_STATUS_OK) 1982525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1983525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaEnableDisablePollingEvent.wait (); //wait for NFA_RF_DISCOVERY_xxxx_EVT 1984525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sRfEnabled = isStart; 1985525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1986525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project else 1987525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1988525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: Failed to start/stop RF discovery; error=0x%X", __FUNCTION__, status); 1989525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1990525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1991525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1992525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1993525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1994525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1995525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: doStartupConfig 1996525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1997525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Configure the NFC controller. 1998525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1999525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: None 2000525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 2001525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 2002525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectvoid doStartupConfig() 2003525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 2004525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project struct nfc_jni_native_data *nat = getNative(0, 0); 2005525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tNFA_STATUS stat = NFA_STATUS_FAILED; 2006a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu int actualLen = 0; 2007525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 2008525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // If polling for Active mode, set the ordering so that we choose Active over Passive mode first. 2009525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (nat && (nat->tech_mask & (NFA_TECHNOLOGY_MASK_A_ACTIVE | NFA_TECHNOLOGY_MASK_F_ACTIVE))) 2010525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 2011525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project UINT8 act_mode_order_param[] = { 0x01 }; 2012525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaSetConfigEvent); 2013525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project stat = NFA_SetConfig(NCI_PARAM_ID_ACT_ORDER, sizeof(act_mode_order_param), &act_mode_order_param[0]); 2014525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (stat == NFA_STATUS_OK) 2015525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaSetConfigEvent.wait (); 2016525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 2017a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu 2018a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu //configure RF polling frequency for each technology 2019a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu static tNFA_DM_DISC_FREQ_CFG nfa_dm_disc_freq_cfg; 2020a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu //values in the polling_frequency[] map to members of nfa_dm_disc_freq_cfg 2021a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu UINT8 polling_frequency [8] = {1, 1, 1, 1, 1, 1, 1, 1}; 2022a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu actualLen = GetStrValue(NAME_POLL_FREQUENCY, (char*)polling_frequency, 8); 2023a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu if (actualLen == 8) 2024a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu { 2025a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu ALOGD ("%s: polling frequency", __FUNCTION__); 2026a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu memset (&nfa_dm_disc_freq_cfg, 0, sizeof(nfa_dm_disc_freq_cfg)); 2027a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu nfa_dm_disc_freq_cfg.pa = polling_frequency [0]; 2028a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu nfa_dm_disc_freq_cfg.pb = polling_frequency [1]; 2029a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu nfa_dm_disc_freq_cfg.pf = polling_frequency [2]; 2030a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu nfa_dm_disc_freq_cfg.pi93 = polling_frequency [3]; 2031a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu nfa_dm_disc_freq_cfg.pbp = polling_frequency [4]; 2032a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu nfa_dm_disc_freq_cfg.pk = polling_frequency [5]; 2033a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu nfa_dm_disc_freq_cfg.paa = polling_frequency [6]; 2034a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu nfa_dm_disc_freq_cfg.pfa = polling_frequency [7]; 2035a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu p_nfa_dm_rf_disc_freq_cfg = &nfa_dm_disc_freq_cfg; 2036a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu } 2037525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 2038525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 2039525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 2040525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 2041525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 2042525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_isNfcActive 2043525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 2044525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Used externaly to determine if NFC is active or not. 2045525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 2046525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: 'true' if the NFC stack is running, else 'false'. 2047525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 2048525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 2049525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectbool nfcManager_isNfcActive() 2050525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 2051525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return sIsNfaEnabled; 2052525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 2053525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 2054c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenenvoid restartPollingWithTechMask (int tech_mask) 2055c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen{ 2056c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen tNFA_STATUS stat = NFA_STATUS_FAILED; 2057c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen startRfDiscovery (false); 2058c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen { 2059c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen SyncEventGuard guard (sNfaEnableDisablePollingEvent); 2060c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen stat = NFA_DisablePolling (); 2061c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen if (stat == NFA_STATUS_OK) 2062c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen { 2063c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen ALOGD ("%s: wait for enable event", __FUNCTION__); 2064c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen sNfaEnableDisablePollingEvent.wait (); //wait for NFA_POLL_DISABLED_EVT 2065c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen } 2066c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen else 2067c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen { 2068c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen ALOGE ("%s: failed to disable polling; error=0x%X", __FUNCTION__, stat); 2069c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen goto TheEnd; 2070c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen } 2071c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen stat = NFA_EnablePolling (tech_mask); 2072c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen if (stat == NFA_STATUS_OK) 2073c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen { 2074c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen ALOGD ("%s: wait for enable event", __FUNCTION__); 2075c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen sNfaEnableDisablePollingEvent.wait (); //wait for NFA_POLL_ENABLED_EVT 2076c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen } 2077c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen else 2078c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen ALOGE ("%s: fail enable polling; error=0x%X", __FUNCTION__, stat); 2079c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen } 2080c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn CoenenTheEnd: 2081c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen startRfDiscovery(true); 2082c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen} 2083525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 2084525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 2085525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 2086525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: startStopPolling 2087525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 2088525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Start or stop polling. 2089525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** isStartPolling: true to start polling; false to stop polling. 2090525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 2091525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: None. 2092525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 2093525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 2094525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectvoid startStopPolling (bool isStartPolling) 2095525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 2096525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: enter; isStart=%u", __FUNCTION__, isStartPolling); 2097525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tNFA_STATUS stat = NFA_STATUS_FAILED; 2098525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 2099525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project startRfDiscovery (false); 2100525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (isStartPolling) 2101525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 2102525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tNFA_TECHNOLOGY_MASK tech_mask = DEFAULT_TECH_MASK; 2103525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project unsigned long num = 0; 2104525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (GetNumValue(NAME_POLLING_TECH_MASK, &num, sizeof(num))) 2105525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tech_mask = num; 2106525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 2107525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaEnableDisablePollingEvent); 2108525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: enable polling", __FUNCTION__); 2109525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project stat = NFA_EnablePolling (tech_mask); 2110525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (stat == NFA_STATUS_OK) 2111525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 2112525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: wait for enable event", __FUNCTION__); 2113525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaEnableDisablePollingEvent.wait (); //wait for NFA_POLL_ENABLED_EVT 2114525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 2115525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project else 2116525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: fail enable polling; error=0x%X", __FUNCTION__, stat); 2117525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 2118525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project else 2119525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 2120525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaEnableDisablePollingEvent); 2121525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: disable polling", __FUNCTION__); 2122525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project stat = NFA_DisablePolling (); 2123525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (stat == NFA_STATUS_OK) 2124525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 2125525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaEnableDisablePollingEvent.wait (); //wait for NFA_POLL_DISABLED_EVT 2126525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 2127525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project else 2128525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: fail disable polling; error=0x%X", __FUNCTION__, stat); 2129525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 2130525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project startRfDiscovery (true); 2131525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: exit", __FUNCTION__); 2132525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 2133525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 2134525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 2135525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} /* namespace android */ 2136