NativeNfcManager.cpp revision d53c2b599c73f7404b5a604be4d9a5449cafdd72
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 []; 47525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectnamespace android 48525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 49525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern bool gIsTagDeactivating; 50525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern bool gIsSelectingRfInterface; 51525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern void nativeNfcTag_doTransceiveStatus (uint8_t * buf, uint32_t buflen); 52525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern void nativeNfcTag_doConnectStatus (jboolean is_connect_ok); 53525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern void nativeNfcTag_doDeactivateStatus (int status); 54525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern void nativeNfcTag_doWriteStatus (jboolean is_write_ok); 55525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern void nativeNfcTag_doCheckNdefResult (tNFA_STATUS status, uint32_t max_size, uint32_t current_size, uint8_t flags); 56525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern void nativeNfcTag_doMakeReadonlyResult (tNFA_STATUS status); 57525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern void nativeNfcTag_doPresenceCheckResult (tNFA_STATUS status); 58525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern void nativeNfcTag_formatStatus (bool is_ok); 59525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern void nativeNfcTag_resetPresenceCheck (); 60525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern void nativeNfcTag_doReadCompleted (tNFA_STATUS status); 61525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern void nativeNfcTag_abortWaits (); 62525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern void nativeLlcpConnectionlessSocket_abortWait (); 63525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern void nativeNfcTag_registerNdefTypeHandler (); 64525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project extern void nativeLlcpConnectionlessSocket_receiveData (uint8_t* data, uint32_t len, uint32_t remote_sap); 65525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 66525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 67525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 68525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/***************************************************************************** 69525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 70525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** public variables and functions 71525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 72525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*****************************************************************************/ 73525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 74525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectnamespace android 75525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 76525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project int gGeneralTransceiveTimeout = 1000; 77525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project jmethodID gCachedNfcManagerNotifyNdefMessageListeners; 78525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project jmethodID gCachedNfcManagerNotifyTransactionListeners; 79525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project jmethodID gCachedNfcManagerNotifyLlcpLinkActivation; 80525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project jmethodID gCachedNfcManagerNotifyLlcpLinkDeactivated; 8157a44d07a3de327e8cdbbcd622118aa517313dbeMartijn Coenen jmethodID gCachedNfcManagerNotifyLlcpFirstPacketReceived; 82525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project jmethodID gCachedNfcManagerNotifySeFieldActivated; 83525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project jmethodID gCachedNfcManagerNotifySeFieldDeactivated; 84525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project jmethodID gCachedNfcManagerNotifySeListenActivated; 85525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project jmethodID gCachedNfcManagerNotifySeListenDeactivated; 869f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen jmethodID gCachedNfcManagerNotifyHostEmuActivated; 879f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen jmethodID gCachedNfcManagerNotifyHostEmuData; 889f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen jmethodID gCachedNfcManagerNotifyHostEmuDeactivated; 89525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project const char* gNativeP2pDeviceClassName = "com/android/nfc/dhimpl/NativeP2pDevice"; 90525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project const char* gNativeLlcpServiceSocketClassName = "com/android/nfc/dhimpl/NativeLlcpServiceSocket"; 91525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project const char* gNativeLlcpConnectionlessSocketClassName = "com/android/nfc/dhimpl/NativeLlcpConnectionlessSocket"; 92525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project const char* gNativeLlcpSocketClassName = "com/android/nfc/dhimpl/NativeLlcpSocket"; 93525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project const char* gNativeNfcTagClassName = "com/android/nfc/dhimpl/NativeNfcTag"; 94525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project const char* gNativeNfcManagerClassName = "com/android/nfc/dhimpl/NativeNfcManager"; 95525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project const char* gNativeNfcSecureElementClassName = "com/android/nfc/dhimpl/NativeNfcSecureElement"; 96525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project void doStartupConfig (); 97525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project void startStopPolling (bool isStartPolling); 98525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project void startRfDiscovery (bool isStart); 9961beae816af13f75dabb484d287739723c716deeMartijn Coenen void setUiccIdleTimeout (bool enable); 100525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 101525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 102525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 103525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/***************************************************************************** 104525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 105525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** private variables and functions 106525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 107525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*****************************************************************************/ 108525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectnamespace android 109525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 110525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic jint sLastError = ERROR_BUFFER_TOO_SMALL; 111525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic jmethodID sCachedNfcManagerNotifySeApduReceived; 112525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic jmethodID sCachedNfcManagerNotifySeMifareAccess; 113525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic jmethodID sCachedNfcManagerNotifySeEmvCardRemoval; 114525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic jmethodID sCachedNfcManagerNotifyTargetDeselected; 115525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic SyncEvent sNfaEnableEvent; //event for NFA_Enable() 116525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic SyncEvent sNfaDisableEvent; //event for NFA_Disable() 117525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic SyncEvent sNfaEnableDisablePollingEvent; //event for NFA_EnablePolling(), NFA_DisablePolling() 118525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic SyncEvent sNfaSetConfigEvent; // event for Set_Config.... 119f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenenstatic SyncEvent sNfaGetConfigEvent; // event for Get_Config.... 120525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool sIsNfaEnabled = false; 121525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool sDiscoveryEnabled = false; //is polling for tag? 122525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool sIsDisabling = false; 123525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool sRfEnabled = false; // whether RF discovery is enabled 124525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool sSeRfActive = false; // whether RF with SE is likely active 125525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool sP2pActive = false; // whether p2p was last active 126525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool sAbortConnlessWait = false; 127525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool sIsSecElemSelected = false; //has NFC service selected a sec elem 128525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project#define CONFIG_UPDATE_TECH_MASK (1 << 1) 129525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project#define DEFAULT_TECH_MASK (NFA_TECHNOLOGY_MASK_A \ 130525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project | NFA_TECHNOLOGY_MASK_B \ 131525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project | NFA_TECHNOLOGY_MASK_F \ 132525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project | NFA_TECHNOLOGY_MASK_ISO15693 \ 133525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project | NFA_TECHNOLOGY_MASK_B_PRIME \ 134525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project | NFA_TECHNOLOGY_MASK_A_ACTIVE \ 13597a71fe90493efd5947bb6f18c7b58a7e795c1ddEvan Chu | NFA_TECHNOLOGY_MASK_F_ACTIVE \ 13697a71fe90493efd5947bb6f18c7b58a7e795c1ddEvan Chu | NFA_TECHNOLOGY_MASK_KOVIO) 137525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 138525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 139525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic void nfaConnectionCallback (UINT8 event, tNFA_CONN_EVT_DATA *eventData); 140525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic void nfaDeviceManagementCallback (UINT8 event, tNFA_DM_CBACK_DATA *eventData); 141525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool isPeerToPeer (tNFA_ACTIVATED& activated); 142525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool isListenMode(tNFA_ACTIVATED& activated); 143525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 144f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenenstatic UINT16 sCurrentConfigLen; 145f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenenstatic UINT8 sConfig[256]; 146525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project///////////////////////////////////////////////////////////// 147525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project///////////////////////////////////////////////////////////// 148525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 149525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 150525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 151525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 152525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: getNative 153525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 154525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Get native data 155525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 156525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: Native data structure. 157525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 158525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 159525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectnfc_jni_native_data *getNative (JNIEnv* e, jobject o) 160525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 161525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project static struct nfc_jni_native_data *sCachedNat = NULL; 162525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (e) 163525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 164525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sCachedNat = nfc_jni_get_nat(e, o); 165525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 166525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return sCachedNat; 167525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 168525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 169525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 170525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 171525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 172525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: handleRfDiscoveryEvent 173525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 174525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Handle RF-discovery events from the stack. 175525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** discoveredDevice: Discovered device. 176525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 177525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: None 178525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 179525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 180525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic void handleRfDiscoveryEvent (tNFC_RESULT_DEVT* discoveredDevice) 181525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 182525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (discoveredDevice->more) 183525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 184525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project //there is more discovery notification coming 185525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return; 186525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 187525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 188525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project bool isP2p = NfcTag::getInstance ().isP2pDiscovered (); 189525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (isP2p) 190525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 191525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project //select the peer that supports P2P 192525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcTag::getInstance ().selectP2p(); 193525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 194525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project else 195525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 196525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project //select the first of multiple tags that is discovered 197525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcTag::getInstance ().selectFirstTag(); 198525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 199525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 200525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 201525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 202525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 203525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 204525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfaConnectionCallback 205525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 206525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Receive connection-related events from stack. 207525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** connEvent: Event code. 208525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** eventData: Event data. 209525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 210525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: None 211525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 212525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 213525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic void nfaConnectionCallback (UINT8 connEvent, tNFA_CONN_EVT_DATA* eventData) 214525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 215525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tNFA_STATUS status = NFA_STATUS_FAILED; 216525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: event= %u", __FUNCTION__, connEvent); 217525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 218525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project switch (connEvent) 219525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 220525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_POLL_ENABLED_EVT: // whether polling successfully started 221525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 222525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_POLL_ENABLED_EVT: status = %u", __FUNCTION__, eventData->status); 223525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 224525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaEnableDisablePollingEvent); 225525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaEnableDisablePollingEvent.notifyOne (); 226525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 227525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 228525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 229525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_POLL_DISABLED_EVT: // Listening/Polling stopped 230525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 231525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_POLL_DISABLED_EVT: status = %u", __FUNCTION__, eventData->status); 232525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 233525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaEnableDisablePollingEvent); 234525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaEnableDisablePollingEvent.notifyOne (); 235525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 236525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 237525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 238525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_RF_DISCOVERY_STARTED_EVT: // RF Discovery started 239525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 240525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_RF_DISCOVERY_STARTED_EVT: status = %u", __FUNCTION__, eventData->status); 241525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 242525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaEnableDisablePollingEvent); 243525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaEnableDisablePollingEvent.notifyOne (); 244525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 245525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 246525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 247525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_RF_DISCOVERY_STOPPED_EVT: // RF Discovery stopped event 248525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 249525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_RF_DISCOVERY_STOPPED_EVT: status = %u", __FUNCTION__, eventData->status); 250525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 251525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaEnableDisablePollingEvent); 252525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaEnableDisablePollingEvent.notifyOne (); 253525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 254525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 255525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 256525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_DISC_RESULT_EVT: // NFC link/protocol discovery notificaiton 257525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project status = eventData->disc_result.status; 258525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_DISC_RESULT_EVT: status = %d", __FUNCTION__, status); 259525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (status != NFA_STATUS_OK) 260525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 261525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE("%s: NFA_DISC_RESULT_EVT error: status = %d", __FUNCTION__, status); 262525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 263525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project else 264525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 265525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcTag::getInstance().connectionEventHandler(connEvent, eventData); 266525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project handleRfDiscoveryEvent(&eventData->disc_result.discovery_ntf); 267525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 268525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 269525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 270525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_SELECT_RESULT_EVT: // NFC link/protocol discovery select response 271525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_SELECT_RESULT_EVT: status = %d, gIsSelectingRfInterface = %d, sIsDisabling=%d", __FUNCTION__, eventData->status, gIsSelectingRfInterface, sIsDisabling); 272525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 273525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (sIsDisabling) 274525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 275525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 276525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (eventData->status != NFA_STATUS_OK) 277525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 278525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (gIsSelectingRfInterface) 279525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 280525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_doConnectStatus(false); 281525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 282525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 283525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE("%s: NFA_SELECT_RESULT_EVT error: status = %d", __FUNCTION__, eventData->status); 284525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NFA_Deactivate (FALSE); 285525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 286525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 287525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 288525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_DEACTIVATE_FAIL_EVT: 289525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_DEACTIVATE_FAIL_EVT: status = %d", __FUNCTION__, eventData->status); 290525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 291525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 292525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_ACTIVATED_EVT: // NFC link/protocol activated 293525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_ACTIVATED_EVT: gIsSelectingRfInterface=%d, sIsDisabling=%d", __FUNCTION__, gIsSelectingRfInterface, sIsDisabling); 294b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen if (sIsDisabling || !sIsNfaEnabled) 295525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 296525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 297525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcTag::getInstance().setActivationState (); 298525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (gIsSelectingRfInterface) 299525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 300525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_doConnectStatus(true); 301525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 302525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 303525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 304525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_resetPresenceCheck(); 305525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (isPeerToPeer(eventData->activated)) 306525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 307525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sP2pActive = true; 308525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_ACTIVATED_EVT; is p2p", __FUNCTION__); 309525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // Disable RF field events in case of p2p 310525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project UINT8 nfa_disable_rf_events[] = { 0x00 }; 311525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: Disabling RF field events", __FUNCTION__); 312525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project status = NFA_SetConfig(NCI_PARAM_ID_RF_FIELD_INFO, sizeof(nfa_disable_rf_events), 313525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project &nfa_disable_rf_events[0]); 314525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (status == NFA_STATUS_OK) { 315525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: Disabled RF field events", __FUNCTION__); 316525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } else { 317525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: Failed to disable RF field events", __FUNCTION__); 318525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 31957a44d07a3de327e8cdbbcd622118aa517313dbeMartijn Coenen // For the SE, consider the field to be on while p2p is active. 32057a44d07a3de327e8cdbbcd622118aa517313dbeMartijn Coenen SecureElement::getInstance().notifyRfFieldEvent (true); 321525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 322525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project else if (pn544InteropIsBusy() == false) 323525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 324525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcTag::getInstance().connectionEventHandler (connEvent, eventData); 325525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 326525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // We know it is not activating for P2P. If it activated in 32757a44d07a3de327e8cdbbcd622118aa517313dbeMartijn Coenen // listen mode then it is likely for an SE transaction. 328525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // Send the RF Event. 329525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (isListenMode(eventData->activated)) 330525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 331525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sSeRfActive = true; 332525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SecureElement::getInstance().notifyListenModeState (true); 333525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 334525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 335525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 336525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 337525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 338525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_DEACTIVATED_EVT: // NFC link/protocol deactivated 339525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_DEACTIVATED_EVT Type: %u, gIsTagDeactivating: %d", __FUNCTION__, eventData->deactivated.type,gIsTagDeactivating); 340525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcTag::getInstance().setDeactivationState (eventData->deactivated); 341525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (eventData->deactivated.type != NFA_DEACTIVATE_TYPE_SLEEP) 342525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 343525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_resetPresenceCheck(); 344525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcTag::getInstance().connectionEventHandler (connEvent, eventData); 345525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_abortWaits(); 346525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcTag::getInstance().abort (); 347525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 348525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project else if (gIsTagDeactivating) 349525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 350525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_doDeactivateStatus(0); 351525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 352525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 353525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // If RF is activated for what we think is a Secure Element transaction 354525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // and it is deactivated to either IDLE or DISCOVERY mode, notify w/event. 355525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if ((eventData->deactivated.type == NFA_DEACTIVATE_TYPE_IDLE) 356525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project || (eventData->deactivated.type == NFA_DEACTIVATE_TYPE_DISCOVERY)) 357525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 358525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (sSeRfActive) { 359525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sSeRfActive = false; 360b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen if (!sIsDisabling && sIsNfaEnabled) 361b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen SecureElement::getInstance().notifyListenModeState (false); 362525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } else if (sP2pActive) { 363525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sP2pActive = false; 364525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // Make sure RF field events are re-enabled 365b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen ALOGD("%s: NFA_DEACTIVATED_EVT; is p2p", __FUNCTION__); 366525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // Disable RF field events in case of p2p 367525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project UINT8 nfa_enable_rf_events[] = { 0x01 }; 368525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 369b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen if (!sIsDisabling && sIsNfaEnabled) 370b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen { 371b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen ALOGD ("%s: Enabling RF field events", __FUNCTION__); 372b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen status = NFA_SetConfig(NCI_PARAM_ID_RF_FIELD_INFO, sizeof(nfa_enable_rf_events), 373b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen &nfa_enable_rf_events[0]); 374b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen if (status == NFA_STATUS_OK) { 375b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen ALOGD ("%s: Enabled RF field events", __FUNCTION__); 376b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen } else { 377b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen ALOGE ("%s: Failed to enable RF field events", __FUNCTION__); 378b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen } 379b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen // Consider the field to be off at this point 380b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen SecureElement::getInstance().notifyRfFieldEvent (false); 381525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 382525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 383525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 384525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 385525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 386525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 387525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_TLV_DETECT_EVT: // TLV Detection complete 388525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project status = eventData->tlv_detect.status; 389525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_TLV_DETECT_EVT: status = %d, protocol = %d, num_tlvs = %d, num_bytes = %d", 390525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project __FUNCTION__, status, eventData->tlv_detect.protocol, 391525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project eventData->tlv_detect.num_tlvs, eventData->tlv_detect.num_bytes); 392525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (status != NFA_STATUS_OK) 393525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 394525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE("%s: NFA_TLV_DETECT_EVT error: status = %d", __FUNCTION__, status); 395525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 396525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 397525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 398525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_NDEF_DETECT_EVT: // NDEF Detection complete; 399525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project //if status is failure, it means the tag does not contain any or valid NDEF data; 400525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project //pass the failure status to the NFC Service; 401525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project status = eventData->ndef_detect.status; 402525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_NDEF_DETECT_EVT: status = 0x%X, protocol = %u, " 403525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project "max_size = %lu, cur_size = %lu, flags = 0x%X", __FUNCTION__, 404525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project status, 405525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project eventData->ndef_detect.protocol, eventData->ndef_detect.max_size, 406525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project eventData->ndef_detect.cur_size, eventData->ndef_detect.flags); 407525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcTag::getInstance().connectionEventHandler (connEvent, eventData); 408525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_doCheckNdefResult(status, 409525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project eventData->ndef_detect.max_size, eventData->ndef_detect.cur_size, 410525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project eventData->ndef_detect.flags); 411525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 412525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 413525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_DATA_EVT: // Data message received (for non-NDEF reads) 414525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_DATA_EVT: len = %d", __FUNCTION__, eventData->data.len); 415525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_doTransceiveStatus(eventData->data.p_data,eventData->data.len); 416525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 417525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 418525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_SELECT_CPLT_EVT: // Select completed 419525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project status = eventData->status; 420525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_SELECT_CPLT_EVT: status = %d", __FUNCTION__, status); 421525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (status != NFA_STATUS_OK) 422525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 423525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE("%s: NFA_SELECT_CPLT_EVT error: status = %d", __FUNCTION__, status); 424525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 425525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 426525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 427525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_READ_CPLT_EVT: // NDEF-read or tag-specific-read completed 428525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_READ_CPLT_EVT: status = 0x%X", __FUNCTION__, eventData->status); 429525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_doReadCompleted (eventData->status); 430525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcTag::getInstance().connectionEventHandler (connEvent, eventData); 431525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 432525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 433525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_WRITE_CPLT_EVT: // Write completed 434525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_WRITE_CPLT_EVT: status = %d", __FUNCTION__, eventData->status); 435525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_doWriteStatus (eventData->status == NFA_STATUS_OK); 436525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 437525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 438525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_SET_TAG_RO_EVT: // Tag set as Read only 439525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_SET_TAG_RO_EVT: status = %d", __FUNCTION__, eventData->status); 440525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_doMakeReadonlyResult(eventData->status); 441525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 442525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 443525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_CE_NDEF_WRITE_START_EVT: // NDEF write started 444525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_CE_NDEF_WRITE_START_EVT: status: %d", __FUNCTION__, eventData->status); 445525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 446525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (eventData->status != NFA_STATUS_OK) 447525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE("%s: NFA_CE_NDEF_WRITE_START_EVT error: status = %d", __FUNCTION__, eventData->status); 448525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 449525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 450525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_CE_NDEF_WRITE_CPLT_EVT: // NDEF write completed 451525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: FA_CE_NDEF_WRITE_CPLT_EVT: len = %lu", __FUNCTION__, eventData->ndef_write_cplt.len); 452525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 453525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 454525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_LLCP_ACTIVATED_EVT: // LLCP link is activated 455525c260303268a83da4c3413b953d13c9084e834The 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", 456525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project __FUNCTION__, 457525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project eventData->llcp_activated.is_initiator, 458525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project eventData->llcp_activated.remote_wks, 459525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project eventData->llcp_activated.remote_lsc, 460525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project eventData->llcp_activated.remote_link_miu, 461525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project eventData->llcp_activated.local_link_miu); 462525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 463525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PeerToPeer::getInstance().llcpActivatedHandler (getNative(0, 0), eventData->llcp_activated); 464525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 465525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 466525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_LLCP_DEACTIVATED_EVT: // LLCP link is deactivated 467525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_LLCP_DEACTIVATED_EVT", __FUNCTION__); 468525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PeerToPeer::getInstance().llcpDeactivatedHandler (getNative(0, 0), eventData->llcp_deactivated); 469525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 47057a44d07a3de327e8cdbbcd622118aa517313dbeMartijn Coenen case NFA_LLCP_FIRST_PACKET_RECEIVED_EVT: // Received first packet over llcp 47157a44d07a3de327e8cdbbcd622118aa517313dbeMartijn Coenen ALOGD("%s: NFA_LLCP_FIRST_PACKET_RECEIVED_EVT", __FUNCTION__); 47257a44d07a3de327e8cdbbcd622118aa517313dbeMartijn Coenen PeerToPeer::getInstance().llcpFirstPacketHandler (getNative(0, 0)); 47357a44d07a3de327e8cdbbcd622118aa517313dbeMartijn Coenen break; 474525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_PRESENCE_CHECK_EVT: 475525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_PRESENCE_CHECK_EVT", __FUNCTION__); 476525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_doPresenceCheckResult (eventData->status); 477525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 478525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_FORMAT_CPLT_EVT: 479525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_FORMAT_CPLT_EVT: status=0x%X", __FUNCTION__, eventData->status); 480525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_formatStatus (eventData->status == NFA_STATUS_OK); 481525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 482525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 483525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_I93_CMD_CPLT_EVT: 484525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_I93_CMD_CPLT_EVT: status=0x%X", __FUNCTION__, eventData->status); 485525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 486525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 487525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_CE_UICC_LISTEN_CONFIGURED_EVT : 488525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_CE_UICC_LISTEN_CONFIGURED_EVT : status=0x%X", __FUNCTION__, eventData->status); 489525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SecureElement::getInstance().connectionEventHandler (connEvent, eventData); 490525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 491525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 492525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_SET_P2P_LISTEN_TECH_EVT: 493525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s: NFA_SET_P2P_LISTEN_TECH_EVT", __FUNCTION__); 494525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PeerToPeer::getInstance().connectionEventHandler (connEvent, eventData); 495525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 496525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 497525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project default: 498525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE("%s: unknown event ????", __FUNCTION__); 499525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 500525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 501525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 502525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 503525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 504525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 505525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 506525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_initNativeStruc 507525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 508525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Initialize variables. 509525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 510525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 511525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 512525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: True if ok. 513525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 514525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 515525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic jboolean nfcManager_initNativeStruc (JNIEnv* e, jobject o) 516525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 517525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: enter", __FUNCTION__); 518525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 5192534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes nfc_jni_native_data* nat = (nfc_jni_native_data*)malloc(sizeof(struct nfc_jni_native_data)); 520525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (nat == NULL) 521525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 522525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: fail allocate native data", __FUNCTION__); 523525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return JNI_FALSE; 524525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 525525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 526525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project memset (nat, 0, sizeof(*nat)); 5272534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes e->GetJavaVM(&(nat->vm)); 5282534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes nat->env_version = e->GetVersion(); 5292534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes nat->manager = e->NewGlobalRef(o); 530525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 5312534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes ScopedLocalRef<jclass> cls(e, e->GetObjectClass(o)); 5322534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes jfieldID f = e->GetFieldID(cls.get(), "mNative", "I"); 5332534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes e->SetIntField(o, f, (jint)nat); 534525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 535525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project /* Initialize native cached references */ 5362534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes gCachedNfcManagerNotifyNdefMessageListeners = e->GetMethodID(cls.get(), 537525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project "notifyNdefMessageListeners", "(Lcom/android/nfc/dhimpl/NativeNfcTag;)V"); 5382534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes gCachedNfcManagerNotifyTransactionListeners = e->GetMethodID(cls.get(), 539525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project "notifyTransactionListeners", "([B)V"); 5402534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes gCachedNfcManagerNotifyLlcpLinkActivation = e->GetMethodID(cls.get(), 541525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project "notifyLlcpLinkActivation", "(Lcom/android/nfc/dhimpl/NativeP2pDevice;)V"); 5422534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes gCachedNfcManagerNotifyLlcpLinkDeactivated = e->GetMethodID(cls.get(), 543525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project "notifyLlcpLinkDeactivated", "(Lcom/android/nfc/dhimpl/NativeP2pDevice;)V"); 54457a44d07a3de327e8cdbbcd622118aa517313dbeMartijn Coenen gCachedNfcManagerNotifyLlcpFirstPacketReceived = e->GetMethodID(cls.get(), 54557a44d07a3de327e8cdbbcd622118aa517313dbeMartijn Coenen "notifyLlcpLinkFirstPacketReceived", "(Lcom/android/nfc/dhimpl/NativeP2pDevice;)V"); 5462534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes sCachedNfcManagerNotifyTargetDeselected = e->GetMethodID(cls.get(), 547525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project "notifyTargetDeselected","()V"); 5482534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes gCachedNfcManagerNotifySeFieldActivated = e->GetMethodID(cls.get(), 549525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project "notifySeFieldActivated", "()V"); 5502534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes gCachedNfcManagerNotifySeFieldDeactivated = e->GetMethodID(cls.get(), 551525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project "notifySeFieldDeactivated", "()V"); 5522534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes gCachedNfcManagerNotifySeListenActivated = e->GetMethodID(cls.get(), 553525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project "notifySeListenActivated", "()V"); 5542534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes gCachedNfcManagerNotifySeListenDeactivated = e->GetMethodID(cls.get(), 555525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project "notifySeListenDeactivated", "()V"); 556525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 5579f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen gCachedNfcManagerNotifyHostEmuActivated = e->GetMethodID(cls.get(), 5589f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen "notifyHostEmuActivated", "()V"); 5599f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 5609f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen gCachedNfcManagerNotifyHostEmuData = e->GetMethodID(cls.get(), 5619f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen "notifyHostEmuData", "([B)V"); 5629f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 5639f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen gCachedNfcManagerNotifyHostEmuDeactivated = e->GetMethodID(cls.get(), 5649f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen "notifyHostEmuDeactivated", "()V"); 5659f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 5662534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes sCachedNfcManagerNotifySeApduReceived = e->GetMethodID(cls.get(), 567525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project "notifySeApduReceived", "([B)V"); 568525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 5692534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes sCachedNfcManagerNotifySeMifareAccess = e->GetMethodID(cls.get(), 570525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project "notifySeMifareAccess", "([B)V"); 571525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 5722534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes sCachedNfcManagerNotifySeEmvCardRemoval = e->GetMethodID(cls.get(), 573525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project "notifySeEmvCardRemoval", "()V"); 574525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 5752534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes if (nfc_jni_cache_object(e, gNativeNfcTagClassName, &(nat->cached_NfcTag)) == -1) 576525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 577525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: fail cache NativeNfcTag", __FUNCTION__); 578525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return JNI_FALSE; 579525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 580525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 5812534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes if (nfc_jni_cache_object(e, gNativeP2pDeviceClassName, &(nat->cached_P2pDevice)) == -1) 582525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 583525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: fail cache NativeP2pDevice", __FUNCTION__); 584525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return JNI_FALSE; 585525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 586525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 587525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: exit", __FUNCTION__); 588525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return JNI_TRUE; 589525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 590525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 591525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 592525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 593525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 594525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfaDeviceManagementCallback 595525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 596525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Receive device management events from stack. 597525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** dmEvent: Device-management event ID. 598525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** eventData: Data associated with event ID. 599525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 600525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: None 601525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 602525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 603525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectvoid nfaDeviceManagementCallback (UINT8 dmEvent, tNFA_DM_CBACK_DATA* eventData) 604525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 605525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: enter; event=0x%X", __FUNCTION__, dmEvent); 606525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 607525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project switch (dmEvent) 608525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 609525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_DM_ENABLE_EVT: /* Result of NFA_Enable */ 610525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 611525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaEnableEvent); 612525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: NFA_DM_ENABLE_EVT; status=0x%X", 613525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project __FUNCTION__, eventData->status); 614525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sIsNfaEnabled = eventData->status == NFA_STATUS_OK; 615525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sIsDisabling = false; 616525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaEnableEvent.notifyOne (); 617525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 618525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 619525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 620525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_DM_DISABLE_EVT: /* Result of NFA_Disable */ 621525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 622525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaDisableEvent); 623525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: NFA_DM_DISABLE_EVT", __FUNCTION__); 624525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sIsNfaEnabled = false; 625525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sIsDisabling = false; 626525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaDisableEvent.notifyOne (); 627525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 628525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 629525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 630525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_DM_SET_CONFIG_EVT: //result of NFA_SetConfig 631525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: NFA_DM_SET_CONFIG_EVT", __FUNCTION__); 632525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 633525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaSetConfigEvent); 634525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaSetConfigEvent.notifyOne(); 635525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 636525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 637525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 638525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_DM_GET_CONFIG_EVT: /* Result of NFA_GetConfig */ 639525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: NFA_DM_GET_CONFIG_EVT", __FUNCTION__); 640f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen { 641f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen SyncEventGuard guard (sNfaGetConfigEvent); 642f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen if (eventData->status == NFA_STATUS_OK && 643f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen eventData->get_config.tlv_size <= sizeof(sConfig)) 644f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen { 645f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen sCurrentConfigLen = eventData->get_config.tlv_size; 646f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen memcpy(sConfig, eventData->get_config.param_tlvs, eventData->get_config.tlv_size); 647f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen } 648f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen else 649f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen { 650f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen ALOGE("%s: NFA_DM_GET_CONFIG failed", __FUNCTION__); 651f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen sCurrentConfigLen = 0; 652f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen } 653f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen sNfaGetConfigEvent.notifyOne(); 654f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen } 655525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 656525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 657525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_DM_RF_FIELD_EVT: 658525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: NFA_DM_RF_FIELD_EVT; status=0x%X; field status=%u", __FUNCTION__, 659525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project eventData->rf_field.status, eventData->rf_field.rf_field_status); 660b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen if (sIsDisabling || !sIsNfaEnabled) 661b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen break; 662525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 663b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen if (!sP2pActive && eventData->rf_field.status == NFA_STATUS_OK) 664b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen SecureElement::getInstance().notifyRfFieldEvent ( 665b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen eventData->rf_field.rf_field_status == NFA_DM_RF_FIELD_ON); 666525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 667525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 668525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_DM_NFCC_TRANSPORT_ERR_EVT: 669525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_DM_NFCC_TIMEOUT_EVT: 670525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 671525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (dmEvent == NFA_DM_NFCC_TIMEOUT_EVT) 672525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: NFA_DM_NFCC_TIMEOUT_EVT; abort all outstanding operations", __FUNCTION__); 673525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project else 674525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: NFA_DM_NFCC_TRANSPORT_ERR_EVT; abort all outstanding operations", __FUNCTION__); 675525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 676525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_abortWaits(); 677525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcTag::getInstance().abort (); 678525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sAbortConnlessWait = true; 679525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeLlcpConnectionlessSocket_abortWait(); 680525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 681525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: aborting sNfaEnableDisablePollingEvent", __FUNCTION__); 682525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaEnableDisablePollingEvent); 683525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaEnableDisablePollingEvent.notifyOne(); 684525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 685525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 686525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: aborting sNfaEnableEvent", __FUNCTION__); 687525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaEnableEvent); 688525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaEnableEvent.notifyOne(); 689525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 690525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 691525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: aborting sNfaDisableEvent", __FUNCTION__); 692525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaDisableEvent); 693525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaDisableEvent.notifyOne(); 694525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 695525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sDiscoveryEnabled = false; 696525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PowerSwitch::getInstance ().abort (); 697525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 698525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (!sIsDisabling && sIsNfaEnabled) 699525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 700525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NFA_Disable(FALSE); 701525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sIsDisabling = true; 702525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 703525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project else 704525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 705525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sIsNfaEnabled = false; 706525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sIsDisabling = false; 707525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 708525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PowerSwitch::getInstance ().initialize (PowerSwitch::UNKNOWN_LEVEL); 709525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: aborted all waiting events", __FUNCTION__); 710525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 711525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 712525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 713525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project case NFA_DM_PWR_MODE_CHANGE_EVT: 714525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PowerSwitch::getInstance ().deviceManagementCallback (dmEvent, eventData); 715525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 716525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 717525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project default: 718525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: unhandled event", __FUNCTION__); 719525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project break; 720525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 721525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 722525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 7239f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen/******************************************************************************* 7249f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 7259f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Function: nfcManager_sendRawFrame 7269f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 7279f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Description: Send a raw frame. 7289f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** e: JVM environment. 7299f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** o: Java object. 7309f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 7319f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Returns: True if ok. 7329f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 7339f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen*******************************************************************************/ 7349f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenenstatic jboolean nfcManager_sendRawFrame (JNIEnv* e, jobject o, jbyteArray data) 7359f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen{ 7369f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen ScopedByteArrayRO bytes(e, data); 7379f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen uint8_t* buf = const_cast<uint8_t*>(reinterpret_cast<const uint8_t*>(&bytes[0])); 7389f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen size_t bufLen = bytes.size(); 7399f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen tNFA_STATUS status = NFA_SendRawFrame (buf, bufLen, 0); 7409f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 7419f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen return (status == NFA_STATUS_OK); 7429f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen} 7439f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 7449f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen/******************************************************************************* 7459f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 7469f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Function: nfcManager_routeAid 7479f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 7489f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Description: Route an AID to an EE 7499f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** e: JVM environment. 7509f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** o: Java object. 7519f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 7529f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Returns: True if ok. 7539f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 7549f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen*******************************************************************************/ 7559f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenenstatic jboolean nfcManager_routeAid (JNIEnv* e, jobject o, jbyteArray aid, jint route) 7569f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen{ 7579f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen ScopedByteArrayRO bytes(e, aid); 7589f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen uint8_t* buf = const_cast<uint8_t*>(reinterpret_cast<const uint8_t*>(&bytes[0])); 7599f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen size_t bufLen = bytes.size(); 7609f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen bool result = RoutingManager::getInstance().addAidRouting(buf, bufLen, route); 7619f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen return result; 7629f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen} 7639f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 7649f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen/******************************************************************************* 7659f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 7669f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Function: nfcManager_unrouteAid 7679f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 7689f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Description: Remove a AID routing 7699f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** e: JVM environment. 7709f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** o: Java object. 7719f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 7729f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Returns: True if ok. 7739f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 7749f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen*******************************************************************************/ 7759f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenenstatic jboolean nfcManager_unrouteAid (JNIEnv* e, jobject o, jbyteArray aid) 7769f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen{ 7779f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen ScopedByteArrayRO bytes(e, aid); 7789f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen uint8_t* buf = const_cast<uint8_t*>(reinterpret_cast<const uint8_t*>(&bytes[0])); 7799f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen size_t bufLen = bytes.size(); 7809f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen bool result = RoutingManager::getInstance().removeAidRouting(buf, bufLen); 7819f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen return result; 7829f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen} 783525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 784525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 785525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 786525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doInitialize 787525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 788525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Turn on NFC. 789525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 790525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 791525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 792525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: True if ok. 793525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 794525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 795525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic jboolean nfcManager_doInitialize (JNIEnv* e, jobject o) 796525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 797525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: enter; NCI_VERSION=0x%02X", __FUNCTION__, NCI_VERSION); 798525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tNFA_STATUS stat = NFA_STATUS_OK; 799525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 800525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (sIsNfaEnabled) 801525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 802525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: already enabled", __FUNCTION__); 803525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project goto TheEnd; 804525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 805525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 806525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PowerSwitch::getInstance ().initialize (PowerSwitch::FULL_POWER); 807525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 808525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 809525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project unsigned long num = 0; 810525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 811525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcAdaptation& theInstance = NfcAdaptation::GetInstance(); 812525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project theInstance.Initialize(); //start GKI, NCI task, NFC task 813525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 814525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 815525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaEnableEvent); 816525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tHAL_NFC_ENTRY* halFuncEntries = theInstance.GetHalEntryFuncs (); 817525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 818525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NFA_Init (halFuncEntries); 819525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 820525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project stat = NFA_Enable (nfaDeviceManagementCallback, nfaConnectionCallback); 821525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (stat == NFA_STATUS_OK) 822525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 823525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project num = initializeGlobalAppLogLevel (); 824525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project CE_SetTraceLevel (num); 825525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project LLCP_SetTraceLevel (num); 826525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NFC_SetTraceLevel (num); 827525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project RW_SetTraceLevel (num); 828525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NFA_SetTraceLevel (num); 829525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NFA_P2pSetTraceLevel (num); 830525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaEnableEvent.wait(); //wait for NFA command to finish 831525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 832525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 833525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 834525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (stat == NFA_STATUS_OK) 835525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 836525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project //sIsNfaEnabled indicates whether stack started successfully 837525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (sIsNfaEnabled) 838525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 839525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SecureElement::getInstance().initialize (getNative(e, o)); 8409f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen RoutingManager::getInstance().initialize(getNative(e, o)); 841525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_registerNdefTypeHandler (); 842525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcTag::getInstance().initialize (getNative(e, o)); 843525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PeerToPeer::getInstance().initialize (); 844525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PeerToPeer::getInstance().handleNfcOnOff (true); 845525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 846525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ///////////////////////////////////////////////////////////////////////////////// 847525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // Add extra configuration here (work-arounds, etc.) 848525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 849525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project struct nfc_jni_native_data *nat = getNative(e, o); 850525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 851525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if ( nat ) 852525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 853525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (GetNumValue(NAME_POLLING_TECH_MASK, &num, sizeof(num))) 854525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nat->tech_mask = num; 855525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project else 856525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nat->tech_mask = DEFAULT_TECH_MASK; 857525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 858525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: tag polling tech mask=0x%X", __FUNCTION__, nat->tech_mask); 859525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 860525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 861525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // if this value exists, set polling interval. 862525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (GetNumValue(NAME_NFA_DM_DISC_DURATION_POLL, &num, sizeof(num))) 863525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NFA_SetRfDiscoveryDuration(num); 864525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 865525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // Do custom NFCA startup configuration. 866525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project doStartupConfig(); 867525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project goto TheEnd; 868525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 869525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 870525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 871525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: fail nfa enable; error=0x%X", __FUNCTION__, stat); 872525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 873525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (sIsNfaEnabled) 874525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project stat = NFA_Disable (FALSE /* ungraceful */); 875525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 876525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project theInstance.Finalize(); 877525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 878525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 879525c260303268a83da4c3413b953d13c9084e834The Android Open Source ProjectTheEnd: 880525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (sIsNfaEnabled) 881525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PowerSwitch::getInstance ().setLevel (PowerSwitch::LOW_POWER); 882525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: exit", __FUNCTION__); 883525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return sIsNfaEnabled ? JNI_TRUE : JNI_FALSE; 884525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 885525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 886525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 887525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 888525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 889525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_enableDiscovery 890525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 891525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Start polling and listening for devices. 892525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 893525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 894525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** mode: Not used. 895525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 896525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: None 897525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 898525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 899525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic void nfcManager_enableDiscovery (JNIEnv* e, jobject o) 900525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 901525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tNFA_TECHNOLOGY_MASK tech_mask = DEFAULT_TECH_MASK; 902525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project struct nfc_jni_native_data *nat = getNative(e, o); 903525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 904525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (nat) 905525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tech_mask = (tNFA_TECHNOLOGY_MASK)nat->tech_mask; 906525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 907525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: enter; tech_mask = %02x", __FUNCTION__, tech_mask); 908525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 909525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (sDiscoveryEnabled) 910525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 911525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: already polling", __FUNCTION__); 912525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return; 913525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 914525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 915525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tNFA_STATUS stat = NFA_STATUS_OK; 916525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 917525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: sIsSecElemSelected=%u", __FUNCTION__, sIsSecElemSelected); 918525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 919525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PowerSwitch::getInstance ().setLevel (PowerSwitch::FULL_POWER); 920525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 921525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (sRfEnabled) { 922525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // Stop RF discovery to reconfigure 923525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project startRfDiscovery(false); 924525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 925525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 926525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 927525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaEnableDisablePollingEvent); 928525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project stat = NFA_EnablePolling (tech_mask); 929525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (stat == NFA_STATUS_OK) 930525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 931525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: wait for enable event", __FUNCTION__); 932525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sDiscoveryEnabled = true; 933525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaEnableDisablePollingEvent.wait (); //wait for NFA_POLL_ENABLED_EVT 934525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: got enabled event", __FUNCTION__); 935525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 936525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project else 937525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 938525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: fail enable discovery; error=0x%X", __FUNCTION__, stat); 939525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 940525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 941525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 942525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // Start P2P listening if tag polling was enabled or the mask was 0. 943525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (sDiscoveryEnabled || (tech_mask == 0)) 944525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 945525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: Enable p2pListening", __FUNCTION__); 946525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PeerToPeer::getInstance().enableP2pListening (true); 947525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 948525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 949525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // Actually start discovery. 950525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project startRfDiscovery (true); 951525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 952525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PowerSwitch::getInstance ().setModeOn (PowerSwitch::DISCOVERY); 953525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 954525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: exit", __FUNCTION__); 955525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 956525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 957525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 958525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 959525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 960525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_disableDiscovery 961525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 962525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Stop polling and listening for devices. 963525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 964525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 965525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 966525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: None 967525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 968525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 9692534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesvoid nfcManager_disableDiscovery (JNIEnv*, jobject) 970525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 971525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tNFA_STATUS status = NFA_STATUS_OK; 972525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: enter;", __FUNCTION__); 973525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 974525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project pn544InteropAbortNow (); 975525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (sDiscoveryEnabled == false) 976525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 977525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: already disabled", __FUNCTION__); 978525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project goto TheEnd; 979525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 980525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 981525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // Stop RF Discovery. 982525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project startRfDiscovery (false); 983525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 984525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (sDiscoveryEnabled) 985525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 986525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaEnableDisablePollingEvent); 987525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project status = NFA_DisablePolling (); 988525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (status == NFA_STATUS_OK) 989525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 990525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sDiscoveryEnabled = false; 991525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaEnableDisablePollingEvent.wait (); //wait for NFA_POLL_DISABLED_EVT 992525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 993525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project else 994525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: Failed to disable polling; error=0x%X", __FUNCTION__, status); 995525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 996525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 997525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PeerToPeer::getInstance().enableP2pListening (false); 998525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 999525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project //if nothing is active after this, then tell the controller to power down 1000525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (! PowerSwitch::getInstance ().setModeOff (PowerSwitch::DISCOVERY)) 1001525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PowerSwitch::getInstance ().setLevel (PowerSwitch::LOW_POWER); 1002525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1003b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen // We may have had RF field notifications that did not cause 1004b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen // any activate/deactive events. For example, caused by wireless 1005b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen // charging orbs. Those may cause us to go to sleep while the last 1006b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen // field event was indicating a field. To prevent sticking in that 1007b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen // state, always reset the rf field status when we disable discovery. 1008b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen SecureElement::getInstance().resetRfFieldStatus(); 1009525c260303268a83da4c3413b953d13c9084e834The Android Open Source ProjectTheEnd: 1010525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: exit", __FUNCTION__); 1011525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1012525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 101361beae816af13f75dabb484d287739723c716deeMartijn Coenenvoid setUiccIdleTimeout (bool enable) 101461beae816af13f75dabb484d287739723c716deeMartijn Coenen{ 1015f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen // This method is *NOT* thread-safe. Right now 1016f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen // it is only called from the same thread so it's 1017f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen // not an issue. 101861beae816af13f75dabb484d287739723c716deeMartijn Coenen tNFA_STATUS stat = NFA_STATUS_OK; 1019f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen UINT8 swp_cfg_byte0 = 0x00; 102061beae816af13f75dabb484d287739723c716deeMartijn Coenen { 1021f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen SyncEventGuard guard (sNfaGetConfigEvent); 1022f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen stat = NFA_GetConfig(1, new tNFA_PMID[1] {0xC2}); 1023f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen if (stat != NFA_STATUS_OK) 1024f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen { 1025f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen ALOGE("%s: NFA_GetConfig failed", __FUNCTION__); 1026f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen return; 1027f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen } 1028f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen sNfaGetConfigEvent.wait (); 1029f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen if (sCurrentConfigLen < 4 || sConfig[1] != 0xC2) { 1030f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen ALOGE("%s: Config TLV length %d returned is too short", __FUNCTION__, 1031f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen sCurrentConfigLen); 1032f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen return; 1033f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen } 1034f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen swp_cfg_byte0 = sConfig[3]; 103561beae816af13f75dabb484d287739723c716deeMartijn Coenen } 1036f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen SyncEventGuard guard(sNfaSetConfigEvent); 1037f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen if (enable) 1038f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen swp_cfg_byte0 |= 0x01; 103961beae816af13f75dabb484d287739723c716deeMartijn Coenen else 1040f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen swp_cfg_byte0 &= ~0x01; 1041f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen 1042f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen stat = NFA_SetConfig(0xC2, 1, &swp_cfg_byte0); 1043f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen if (stat == NFA_STATUS_OK) 1044f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen sNfaSetConfigEvent.wait (); 1045f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen else 1046f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen ALOGE("%s: Could not configure UICC idle timeout feature", __FUNCTION__); 1047f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen return; 104861beae816af13f75dabb484d287739723c716deeMartijn Coenen} 1049525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1050525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1051525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function nfc_jni_cache_object_local 1052525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1053525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description Allocates a java object and calls it's constructor 1054525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1055525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns -1 on failure, 0 on success 1056525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1057525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 10582534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic int nfc_jni_cache_object_local (JNIEnv *e, const char *className, jobject *cachedObj) 1059525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 10602534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes ScopedLocalRef<jclass> cls(e, e->FindClass(className)); 10612534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes if(cls.get() == NULL) { 1062525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: find class error", __FUNCTION__); 1063525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return -1; 1064525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1065525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 10662534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes jmethodID ctor = e->GetMethodID(cls.get(), "<init>", "()V"); 10672534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes jobject obj = e->NewObject(cls.get(), ctor); 10682534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes if (obj == NULL) { 1069525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: create object error", __FUNCTION__); 1070525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return -1; 1071525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1072525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 10732534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes *cachedObj = obj; 10742534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes if (*cachedObj == NULL) { 1075525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: global ref error", __FUNCTION__); 1076525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return -1; 1077525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1078525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return 0; 1079525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1080525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1081525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1082525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1083525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1084525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doCreateLlcpServiceSocket 1085525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1086525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Create a new LLCP server socket. 1087525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 1088525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 1089525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** nSap: Service access point. 1090525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** sn: Service name 1091525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** miu: Maximum information unit. 1092525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** rw: Receive window size. 1093525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** linearBufferLength: Max buffer size. 1094525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1095525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: NativeLlcpServiceSocket Java object. 1096525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1097525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 10982534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jobject nfcManager_doCreateLlcpServiceSocket (JNIEnv* e, jobject, jint nSap, jstring sn, jint miu, jint rw, jint linearBufferLength) 1099525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1100525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PeerToPeer::tJNI_HANDLE jniHandle = PeerToPeer::getInstance().getNewJniHandle (); 1101525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 11022534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes ScopedUtfChars serviceName(e, sn); 11032534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes 11042534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes ALOGD ("%s: enter: sap=%i; name=%s; miu=%i; rw=%i; buffLen=%i", __FUNCTION__, nSap, serviceName.c_str(), miu, rw, linearBufferLength); 1105525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1106525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project /* Create new NativeLlcpServiceSocket object */ 11072534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes jobject serviceSocket = NULL; 1108525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (nfc_jni_cache_object(e, gNativeLlcpServiceSocketClassName, &(serviceSocket)) == -1) 1109525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1110525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: Llcp socket object creation error", __FUNCTION__); 1111525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return NULL; 1112525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1113525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1114525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project /* Get NativeLlcpServiceSocket class object */ 11152534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes ScopedLocalRef<jclass> clsNativeLlcpServiceSocket(e, e->GetObjectClass(serviceSocket)); 1116525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (e->ExceptionCheck()) 1117525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1118525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project e->ExceptionClear(); 1119525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE("%s: Llcp Socket get object class error", __FUNCTION__); 1120525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return NULL; 1121525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1122525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 11232534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes if (!PeerToPeer::getInstance().registerServer (jniHandle, serviceName.c_str())) 1124525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1125525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE("%s: RegisterServer error", __FUNCTION__); 1126525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return NULL; 1127525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1128525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 11292534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes jfieldID f; 11302534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes 1131525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project /* Set socket handle to be the same as the NfaHandle*/ 11322534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes f = e->GetFieldID(clsNativeLlcpServiceSocket.get(), "mHandle", "I"); 11332534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes e->SetIntField(serviceSocket, f, (jint) jniHandle); 1134525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: socket Handle = 0x%X", __FUNCTION__, jniHandle); 1135525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1136525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project /* Set socket linear buffer length */ 11372534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes f = e->GetFieldID(clsNativeLlcpServiceSocket.get(), "mLocalLinearBufferLength", "I"); 11382534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes e->SetIntField(serviceSocket, f,(jint)linearBufferLength); 1139525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: buffer length = %d", __FUNCTION__, linearBufferLength); 1140525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1141525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project /* Set socket MIU */ 11422534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes f = e->GetFieldID(clsNativeLlcpServiceSocket.get(), "mLocalMiu", "I"); 11432534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes e->SetIntField(serviceSocket, f,(jint)miu); 1144525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: MIU = %d", __FUNCTION__, miu); 1145525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1146525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project /* Set socket RW */ 11472534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes f = e->GetFieldID(clsNativeLlcpServiceSocket.get(), "mLocalRw", "I"); 11482534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes e->SetIntField(serviceSocket, f,(jint)rw); 1149525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: RW = %d", __FUNCTION__, rw); 1150525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1151525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sLastError = 0; 1152525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: exit", __FUNCTION__); 1153525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return serviceSocket; 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_doGetLastError 1160525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1161525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Get the last error code. 1162525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 1163525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 1164525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1165525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: Last error code. 1166525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1167525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 11682534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jint nfcManager_doGetLastError(JNIEnv*, jobject) 1169525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1170525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: last error=%i", __FUNCTION__, sLastError); 1171525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return sLastError; 1172525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1173525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1174525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1175525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1176525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1177525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doDeinitialize 1178525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1179525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Turn off NFC. 1180525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 1181525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 1182525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1183525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: True if ok. 1184525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1185525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 11862534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jboolean nfcManager_doDeinitialize (JNIEnv*, jobject) 1187525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1188525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: enter", __FUNCTION__); 1189525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1190525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sIsDisabling = true; 1191525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project pn544InteropAbortNow (); 1192525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SecureElement::getInstance().finalize (); 1193525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1194525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (sIsNfaEnabled) 1195525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1196525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaDisableEvent); 1197525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tNFA_STATUS stat = NFA_Disable (TRUE /* graceful */); 1198525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (stat == NFA_STATUS_OK) 1199525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1200525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: wait for completion", __FUNCTION__); 1201525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaDisableEvent.wait (); //wait for NFA command to finish 1202525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PeerToPeer::getInstance ().handleNfcOnOff (false); 1203525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1204525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project else 1205525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1206525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: fail disable; error=0x%X", __FUNCTION__, stat); 1207525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1208525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1209525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeNfcTag_abortWaits(); 1210525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcTag::getInstance().abort (); 1211525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sAbortConnlessWait = true; 1212525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nativeLlcpConnectionlessSocket_abortWait(); 1213525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sIsNfaEnabled = false; 1214525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sDiscoveryEnabled = false; 1215525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sIsDisabling = false; 1216525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sIsSecElemSelected = false; 1217525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1218525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1219525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project //unblock NFA_EnablePolling() and NFA_DisablePolling() 1220525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaEnableDisablePollingEvent); 1221525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaEnableDisablePollingEvent.notifyOne (); 1222525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1223525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1224525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project NfcAdaptation& theInstance = NfcAdaptation::GetInstance(); 1225525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project theInstance.Finalize(); 1226525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1227525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: exit", __FUNCTION__); 1228525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return JNI_TRUE; 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_doCreateLlcpSocket 1235525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1236525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Create a LLCP connection-oriented socket. 1237525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 1238525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 1239525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** nSap: Service access point. 1240525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** miu: Maximum information unit. 1241525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** rw: Receive window size. 1242525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** linearBufferLength: Max buffer size. 1243525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1244525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: NativeLlcpSocket Java object. 1245525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1246525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 12472534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jobject nfcManager_doCreateLlcpSocket (JNIEnv* e, jobject, jint nSap, jint miu, jint rw, jint linearBufferLength) 1248525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1249525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: enter; sap=%d; miu=%d; rw=%d; buffer len=%d", __FUNCTION__, nSap, miu, rw, linearBufferLength); 1250525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 12512534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes PeerToPeer::tJNI_HANDLE jniHandle = PeerToPeer::getInstance().getNewJniHandle (); 12522534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes bool stat = PeerToPeer::getInstance().createClient (jniHandle, miu, rw); 1253525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1254525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project /* Create new NativeLlcpSocket object */ 12552534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes jobject clientSocket = NULL; 1256525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (nfc_jni_cache_object_local(e, gNativeLlcpSocketClassName, &(clientSocket)) == -1) 1257525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1258525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: fail Llcp socket creation", __FUNCTION__); 12592534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes return clientSocket; 1260525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1261525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1262525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project /* Get NativeConnectionless class object */ 12632534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes ScopedLocalRef<jclass> clsNativeLlcpSocket(e, e->GetObjectClass(clientSocket)); 1264525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (e->ExceptionCheck()) 1265525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1266525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project e->ExceptionClear(); 1267525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: fail get class object", __FUNCTION__); 12682534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes return clientSocket; 1269525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1270525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 12712534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes jfieldID f; 12722534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes 1273525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project /* Set socket SAP */ 12742534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes f = e->GetFieldID (clsNativeLlcpSocket.get(), "mSap", "I"); 1275525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project e->SetIntField (clientSocket, f, (jint) nSap); 1276525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1277525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project /* Set socket handle */ 12782534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes f = e->GetFieldID (clsNativeLlcpSocket.get(), "mHandle", "I"); 1279525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project e->SetIntField (clientSocket, f, (jint) jniHandle); 1280525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1281525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project /* Set socket MIU */ 12822534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes f = e->GetFieldID (clsNativeLlcpSocket.get(), "mLocalMiu", "I"); 1283525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project e->SetIntField (clientSocket, f, (jint) miu); 1284525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1285525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project /* Set socket RW */ 12862534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes f = e->GetFieldID (clsNativeLlcpSocket.get(), "mLocalRw", "I"); 1287525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project e->SetIntField (clientSocket, f, (jint) rw); 1288525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1289525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: exit", __FUNCTION__); 1290525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return clientSocket; 1291525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1292525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1293525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1294525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1295525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1296525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doCreateLlcpConnectionlessSocket 1297525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1298525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Create a connection-less socket. 1299525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 1300525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 1301525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** nSap: Service access point. 1302525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** sn: Service name. 1303525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1304525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: NativeLlcpConnectionlessSocket Java object. 1305525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1306525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 13072534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jobject nfcManager_doCreateLlcpConnectionlessSocket (JNIEnv *, jobject, jint nSap, jstring /*sn*/) 1308525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1309525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: nSap=0x%X", __FUNCTION__, nSap); 1310525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return NULL; 1311525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1312525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1313525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1314525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1315525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1316525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doGetSecureElementList 1317525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1318525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Get a list of secure element handles. 1319525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 1320525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 1321525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1322525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: List of secure element handles. 1323525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1324525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 13252534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jintArray nfcManager_doGetSecureElementList(JNIEnv* e, jobject) 1326525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1327525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s", __FUNCTION__); 1328525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return SecureElement::getInstance().getListOfEeHandles (e); 1329525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1330525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 13319f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen/******************************************************************************* 13329f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 13339f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Function: nfcManager_enableRoutingToHost 13349f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 1335d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen** Description: NFC controller starts routing data to host. 13369f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** e: JVM environment. 13379f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** o: Java object. 13389f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 13399f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Returns: None 13409f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 13419f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen*******************************************************************************/ 13429f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenenstatic void nfcManager_enableRoutingToHost(JNIEnv*, jobject) 13439f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen{ 13449f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen ALOGD ("%s: enter", __FUNCTION__); 13459f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen PowerSwitch::getInstance ().setLevel (PowerSwitch::FULL_POWER); 13469f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen PowerSwitch::getInstance ().setModeOn (PowerSwitch::HOST_ROUTING); 13479f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen if (sRfEnabled) { 13489f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen // Stop RF discovery to reconfigure 13499f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen startRfDiscovery(false); 13509f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen } 13519f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen RoutingManager::getInstance().commitRouting(); 13529f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen startRfDiscovery(true); 13539f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 13549f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn CoenenTheEnd: 13559f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen ALOGD ("%s: exit", __FUNCTION__); 13569f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen} 13579f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 13589f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen/******************************************************************************* 13599f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 13609f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Function: nfcManager_disableRoutingToHost 13619f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 1362d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen** Description: NFC controller stops routing data to host. 13639f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** e: JVM environment. 13649f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** o: Java object. 13659f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 13669f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Returns: None 13679f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** 13689f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen*******************************************************************************/ 13699f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenenstatic void nfcManager_disableRoutingToHost(JNIEnv*, jobject) 13709f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen{ 13719f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen ALOGD ("%s: enter", __FUNCTION__); 1372d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen bool rfWasEnabled = false; 13739f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 1374d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen if (PowerSwitch::getInstance ().getLevel() == PowerSwitch::LOW_POWER) 1375d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen { 1376d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen ALOGD ("%s: no need to disable routing while power is OFF", __FUNCTION__); 1377d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen goto TheEnd; 1378d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen } 1379d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen 1380d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen if (sRfEnabled) { 1381d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen rfWasEnabled = true; 1382d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen // Stop RF discovery to reconfigure 1383d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen startRfDiscovery(false); 1384d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen } 1385d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen RoutingManager::getInstance().commitRouting(); 1386d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen if (rfWasEnabled) 1387d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen { 1388d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen startRfDiscovery(true); 1389d53c2b599c73f7404b5a604be4d9a5449cafdd72Martijn Coenen } 13909f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen if (! PowerSwitch::getInstance ().setModeOff (PowerSwitch::HOST_ROUTING)) 13919f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen PowerSwitch::getInstance ().setLevel (PowerSwitch::LOW_POWER); 13929f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn CoenenTheEnd: 13939f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen ALOGD ("%s: exit", __FUNCTION__); 13949f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen} 1395525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1396525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1397525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1398525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doSelectSecureElement 1399525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1400525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: NFC controller starts routing data in listen mode. 1401525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 1402525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 1403525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1404525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: None 1405525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1406525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 14072534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic void nfcManager_doSelectSecureElement(JNIEnv*, jobject) 1408525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1409525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: enter", __FUNCTION__); 1410525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project bool stat = true; 1411525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1412aafca6482d0b65b1ecab990659c07e4a82582db8Martijn Coenen if (sIsSecElemSelected) 1413aafca6482d0b65b1ecab990659c07e4a82582db8Martijn Coenen { 1414aafca6482d0b65b1ecab990659c07e4a82582db8Martijn Coenen ALOGD ("%s: already selected", __FUNCTION__); 1415aafca6482d0b65b1ecab990659c07e4a82582db8Martijn Coenen goto TheEnd; 1416aafca6482d0b65b1ecab990659c07e4a82582db8Martijn Coenen } 1417aafca6482d0b65b1ecab990659c07e4a82582db8Martijn Coenen 1418525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PowerSwitch::getInstance ().setLevel (PowerSwitch::FULL_POWER); 1419525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1420525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (sRfEnabled) { 1421525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // Stop RF Discovery if we were polling 1422525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project startRfDiscovery (false); 1423525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1424525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 14259f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 1426525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project stat = SecureElement::getInstance().activate (0xABCDEF); 1427525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sIsSecElemSelected = true; 1428525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1429525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project startRfDiscovery (true); 1430525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PowerSwitch::getInstance ().setModeOn (PowerSwitch::SE_ROUTING); 1431aafca6482d0b65b1ecab990659c07e4a82582db8Martijn CoenenTheEnd: 1432525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: exit", __FUNCTION__); 1433525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1434525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1435525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1436525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1437525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1438525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doDeselectSecureElement 1439525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1440525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: NFC controller stops routing data in listen mode. 1441525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 1442525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 1443525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1444525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: None 1445525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1446525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 14472534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic void nfcManager_doDeselectSecureElement(JNIEnv*, jobject) 1448525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1449525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: enter", __FUNCTION__); 1450525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project bool stat = false; 1451be1939b4b6003ac7a65fcb95a3912f5e1ce8e75fThe Android Open Source Project bool bRestartDiscovery = false; 1452525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1453525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (! sIsSecElemSelected) 1454525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1455525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: already deselected", __FUNCTION__); 1456525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project goto TheEnd; 1457525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1458525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1459525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (PowerSwitch::getInstance ().getLevel() == PowerSwitch::LOW_POWER) 1460525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1461525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: do not deselect while power is OFF", __FUNCTION__); 1462525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sIsSecElemSelected = false; 1463525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project goto TheEnd; 1464525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1465525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1466be1939b4b6003ac7a65fcb95a3912f5e1ce8e75fThe Android Open Source Project if (sRfEnabled) { 1467be1939b4b6003ac7a65fcb95a3912f5e1ce8e75fThe Android Open Source Project // Stop RF Discovery if we were polling 1468be1939b4b6003ac7a65fcb95a3912f5e1ce8e75fThe Android Open Source Project startRfDiscovery (false); 1469be1939b4b6003ac7a65fcb95a3912f5e1ce8e75fThe Android Open Source Project bRestartDiscovery = true; 1470be1939b4b6003ac7a65fcb95a3912f5e1ce8e75fThe Android Open Source Project } 1471be1939b4b6003ac7a65fcb95a3912f5e1ce8e75fThe Android Open Source Project 1472525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project //if controller is not routing to sec elems AND there is no pipe connected, 1473525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project //then turn off the sec elems 1474525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (SecureElement::getInstance().isBusy() == false) 1475525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SecureElement::getInstance().deactivate (0xABCDEF); 1476525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 14779f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen sIsSecElemSelected = false; 1478525c260303268a83da4c3413b953d13c9084e834The Android Open Source ProjectTheEnd: 1479be1939b4b6003ac7a65fcb95a3912f5e1ce8e75fThe Android Open Source Project if (bRestartDiscovery) 1480be1939b4b6003ac7a65fcb95a3912f5e1ce8e75fThe Android Open Source Project startRfDiscovery (true); 1481be1939b4b6003ac7a65fcb95a3912f5e1ce8e75fThe Android Open Source Project 1482525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project //if nothing is active after this, then tell the controller to power down 1483525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (! PowerSwitch::getInstance ().setModeOff (PowerSwitch::SE_ROUTING)) 1484525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PowerSwitch::getInstance ().setLevel (PowerSwitch::LOW_POWER); 1485525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1486525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: exit", __FUNCTION__); 1487525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1488525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1489525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1490525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1491525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1492525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: isPeerToPeer 1493525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1494525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Whether the activation data indicates the peer supports NFC-DEP. 1495525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** activated: Activation data. 1496525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1497525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: True if the peer supports NFC-DEP. 1498525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1499525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 1500525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool isPeerToPeer (tNFA_ACTIVATED& activated) 1501525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1502525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return activated.activate_ntf.protocol == NFA_PROTOCOL_NFC_DEP; 1503525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1504525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1505525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1506525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1507525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: isListenMode 1508525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1509525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Indicates whether the activation data indicates it is 1510525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** listen mode. 1511525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1512525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: True if this listen mode. 1513525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1514525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 1515525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool isListenMode(tNFA_ACTIVATED& activated) 1516525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1517525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return ((NFC_DISCOVERY_TYPE_LISTEN_A == activated.activate_ntf.rf_tech_param.mode) 1518525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project || (NFC_DISCOVERY_TYPE_LISTEN_B == activated.activate_ntf.rf_tech_param.mode) 1519525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project || (NFC_DISCOVERY_TYPE_LISTEN_F == activated.activate_ntf.rf_tech_param.mode) 1520525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project || (NFC_DISCOVERY_TYPE_LISTEN_A_ACTIVE == activated.activate_ntf.rf_tech_param.mode) 1521525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project || (NFC_DISCOVERY_TYPE_LISTEN_F_ACTIVE == activated.activate_ntf.rf_tech_param.mode) 1522525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project || (NFC_DISCOVERY_TYPE_LISTEN_ISO15693 == activated.activate_ntf.rf_tech_param.mode) 1523525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project || (NFC_DISCOVERY_TYPE_LISTEN_B_PRIME == activated.activate_ntf.rf_tech_param.mode)); 1524525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1525525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1526525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1527525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1528525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doCheckLlcp 1529525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1530525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Not used. 1531525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1532525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: True 1533525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1534525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 15352534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jboolean nfcManager_doCheckLlcp(JNIEnv*, jobject) 1536525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1537525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s", __FUNCTION__); 1538525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return JNI_TRUE; 1539525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1540525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1541525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1542525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1543525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1544525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doActivateLlcp 1545525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1546525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Not used. 1547525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1548525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: True 1549525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1550525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 15512534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jboolean nfcManager_doActivateLlcp(JNIEnv*, jobject) 1552525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1553525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s", __FUNCTION__); 1554525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return JNI_TRUE; 1555525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1556525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1557525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1558525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1559525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1560525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doAbort 1561525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1562525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Not used. 1563525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1564525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: None 1565525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1566525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 15672534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic void nfcManager_doAbort(JNIEnv*, jobject) 1568525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1569525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE("%s: abort()", __FUNCTION__); 1570525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project abort(); 1571525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1572525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1573525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1574525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1575525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1576525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doDownload 1577525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1578525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Not used. 1579525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1580525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: True 1581525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1582525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 15832534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jboolean nfcManager_doDownload(JNIEnv*, jobject) 1584525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1585525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD("%s", __FUNCTION__); 1586525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return JNI_TRUE; 1587525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1588525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1589525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1590525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1591525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1592525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doResetTimeouts 1593525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1594525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Not used. 1595525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1596525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: None 1597525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1598525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 15992534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic void nfcManager_doResetTimeouts(JNIEnv*, jobject) 1600525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1601525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: %d millisec", __FUNCTION__, DEFAULT_GENERAL_TRANS_TIMEOUT); 1602525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project gGeneralTransceiveTimeout = DEFAULT_GENERAL_TRANS_TIMEOUT; 1603525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1604525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1605525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1606525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1607525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1608525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doSetTimeout 1609525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1610525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Set timeout value. 1611525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 1612525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 1613525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** timeout: Timeout value. 1614525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1615525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: True if ok. 1616525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1617525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 16182534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic bool nfcManager_doSetTimeout(JNIEnv*, jobject, jint /*tech*/, jint timeout) 1619525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1620525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (timeout <= 0) 1621525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1622525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE("%s: Timeout must be positive.",__FUNCTION__); 1623525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return false; 1624525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1625525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1626525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: timeout=%d", __FUNCTION__, timeout); 1627525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project gGeneralTransceiveTimeout = timeout; 1628525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return true; 1629525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 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** Function: nfcManager_doGetTimeout 1635525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1636525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Get timeout value. 1637525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 1638525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 1639525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** tech: Not used. 1640525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1641525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: Timeout value. 1642525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1643525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 16442534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jint nfcManager_doGetTimeout(JNIEnv*, jobject, jint /*tech*/) 1645525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1646525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: timeout=%d", __FUNCTION__, gGeneralTransceiveTimeout); 1647525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return gGeneralTransceiveTimeout; 1648525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1649525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1650525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1651525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1652525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1653525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doDump 1654525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1655525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Not used. 1656525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 1657525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 1658525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1659525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: Text dump. 1660525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1661525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 16622534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jstring nfcManager_doDump(JNIEnv* e, jobject) 1663525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1664525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project char buffer[100]; 1665525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project snprintf(buffer, sizeof(buffer), "libnfc llc error_count=%u", /*libnfc_llc_error_count*/ 0); 1666525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return e->NewStringUTF(buffer); 1667525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 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** Function: nfcManager_doSetP2pInitiatorModes 1673525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1674525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Set P2P initiator's activation modes. 1675525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 1676525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 1677525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** modes: Active and/or passive modes. The values are specified 1678525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** in external/libnfc-nxp/inc/phNfcTypes.h. See 1679525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** enum phNfc_eP2PMode_t. 1680525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1681525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: None. 1682525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1683525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 1684525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic void nfcManager_doSetP2pInitiatorModes (JNIEnv *e, jobject o, jint modes) 1685525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1686525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: modes=0x%X", __FUNCTION__, modes); 1687525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project struct nfc_jni_native_data *nat = getNative(e, o); 1688525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1689525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tNFA_TECHNOLOGY_MASK mask = 0; 1690525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (modes & 0x01) mask |= NFA_TECHNOLOGY_MASK_A; 1691525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (modes & 0x02) mask |= NFA_TECHNOLOGY_MASK_F; 1692525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (modes & 0x04) mask |= NFA_TECHNOLOGY_MASK_F; 1693525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (modes & 0x08) mask |= NFA_TECHNOLOGY_MASK_A_ACTIVE; 1694525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (modes & 0x10) mask |= NFA_TECHNOLOGY_MASK_F_ACTIVE; 1695525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (modes & 0x20) mask |= NFA_TECHNOLOGY_MASK_F_ACTIVE; 1696525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project nat->tech_mask = mask; 1697525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1698525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project //this function is not called by the NFC service nor exposed by public API. 1699525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1700525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1701525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1702525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1703525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1704525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_doSetP2pTargetModes 1705525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1706525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Set P2P target's activation modes. 1707525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: JVM environment. 1708525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** o: Java object. 1709525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** modes: Active and/or passive modes. 1710525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1711525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: None. 1712525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1713525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 17142534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic void nfcManager_doSetP2pTargetModes (JNIEnv*, jobject, jint modes) 1715525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1716525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: modes=0x%X", __FUNCTION__, modes); 1717525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // Map in the right modes 1718525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tNFA_TECHNOLOGY_MASK mask = 0; 1719525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (modes & 0x01) mask |= NFA_TECHNOLOGY_MASK_A; 1720525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (modes & 0x02) mask |= NFA_TECHNOLOGY_MASK_F; 1721525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (modes & 0x04) mask |= NFA_TECHNOLOGY_MASK_F; 1722525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (modes & 0x08) mask |= NFA_TECHNOLOGY_MASK_A_ACTIVE | NFA_TECHNOLOGY_MASK_F_ACTIVE; 1723525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1724525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PeerToPeer::getInstance().setP2pListenMask(mask); 1725525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project //this function is not called by the NFC service nor exposed by public API. 1726525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1727525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1728525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/***************************************************************************** 1729525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1730525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** JNI functions for android-4.0.1_r1 1731525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1732525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*****************************************************************************/ 1733525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic JNINativeMethod gMethods[] = 1734525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1735525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doDownload", "()Z", 1736525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void *)nfcManager_doDownload}, 1737525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1738525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"initializeNativeStructure", "()Z", 1739525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void*) nfcManager_initNativeStruc}, 1740525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1741525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doInitialize", "()Z", 1742525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void*) nfcManager_doInitialize}, 1743525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1744525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doDeinitialize", "()Z", 1745525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void*) nfcManager_doDeinitialize}, 1746525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 17479f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen {"sendRawFrame", "([B)Z", 17489f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen (void*) nfcManager_sendRawFrame}, 17499f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 17509f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen {"routeAid", "([BI)Z", 17519f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen (void*) nfcManager_routeAid}, 17529f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 17539f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen {"unrouteAid", "([B)Z", 17549f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen (void*) nfcManager_unrouteAid}, 17559f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 1756525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"enableDiscovery", "()V", 1757525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void*) nfcManager_enableDiscovery}, 1758525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 17599f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen {"enableRoutingToHost", "()V", 17609f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen (void*) nfcManager_enableRoutingToHost}, 17619f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 17629f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen {"disableRoutingToHost", "()V", 17639f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen (void*) nfcManager_disableRoutingToHost}, 17649f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen 1765525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doGetSecureElementList", "()[I", 1766525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void *)nfcManager_doGetSecureElementList}, 1767525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1768525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doSelectSecureElement", "()V", 1769525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void *)nfcManager_doSelectSecureElement}, 1770525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1771525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doDeselectSecureElement", "()V", 1772525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void *)nfcManager_doDeselectSecureElement}, 1773525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1774525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doCheckLlcp", "()Z", 1775525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void *)nfcManager_doCheckLlcp}, 1776525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1777525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doActivateLlcp", "()Z", 1778525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void *)nfcManager_doActivateLlcp}, 1779525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1780525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doCreateLlcpConnectionlessSocket", "(ILjava/lang/String;)Lcom/android/nfc/dhimpl/NativeLlcpConnectionlessSocket;", 1781525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void *)nfcManager_doCreateLlcpConnectionlessSocket}, 1782525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1783525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doCreateLlcpServiceSocket", "(ILjava/lang/String;III)Lcom/android/nfc/dhimpl/NativeLlcpServiceSocket;", 1784525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void*) nfcManager_doCreateLlcpServiceSocket}, 1785525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1786525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doCreateLlcpSocket", "(IIII)Lcom/android/nfc/dhimpl/NativeLlcpSocket;", 1787525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void*) nfcManager_doCreateLlcpSocket}, 1788525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1789525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doGetLastError", "()I", 1790525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void*) nfcManager_doGetLastError}, 1791525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1792525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"disableDiscovery", "()V", 1793525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void*) nfcManager_disableDiscovery}, 1794525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1795525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doSetTimeout", "(II)Z", 1796525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void *)nfcManager_doSetTimeout}, 1797525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1798525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doGetTimeout", "(I)I", 1799525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void *)nfcManager_doGetTimeout}, 1800525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1801525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doResetTimeouts", "()V", 1802525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void *)nfcManager_doResetTimeouts}, 1803525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1804525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doAbort", "()V", 1805525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void *)nfcManager_doAbort}, 1806525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1807525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doSetP2pInitiatorModes", "(I)V", 1808525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void *)nfcManager_doSetP2pInitiatorModes}, 1809525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1810525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doSetP2pTargetModes", "(I)V", 1811525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void *)nfcManager_doSetP2pTargetModes}, 1812525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1813525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project {"doDump", "()Ljava/lang/String;", 1814525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project (void *)nfcManager_doDump}, 1815525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}; 1816525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1817525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1818525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1819525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1820525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: register_com_android_nfc_NativeNfcManager 1821525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1822525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Regisgter JNI functions with Java Virtual Machine. 1823525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** e: Environment of JVM. 1824525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1825525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: Status of registration. 1826525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1827525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 1828525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectint register_com_android_nfc_NativeNfcManager (JNIEnv *e) 1829525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1830525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: enter", __FUNCTION__); 1831525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project PowerSwitch::getInstance ().initialize (PowerSwitch::UNKNOWN_LEVEL); 1832525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: exit", __FUNCTION__); 1833525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return jniRegisterNativeMethods (e, gNativeNfcManagerClassName, gMethods, NELEM (gMethods)); 1834525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1835525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1836525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1837525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1838525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1839525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: startRfDiscovery 1840525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1841525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Ask stack to start polling and listening for devices. 1842525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** isStart: Whether to start. 1843525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1844525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: None 1845525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1846525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 1847525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectvoid startRfDiscovery(bool isStart) 1848525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1849525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tNFA_STATUS status = NFA_STATUS_FAILED; 1850525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1851525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: is start=%d", __FUNCTION__, isStart); 1852525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaEnableDisablePollingEvent); 1853525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project status = isStart ? NFA_StartRfDiscovery () : NFA_StopRfDiscovery (); 1854525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (status == NFA_STATUS_OK) 1855525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1856525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaEnableDisablePollingEvent.wait (); //wait for NFA_RF_DISCOVERY_xxxx_EVT 1857525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sRfEnabled = isStart; 1858525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1859525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project else 1860525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1861525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: Failed to start/stop RF discovery; error=0x%X", __FUNCTION__, status); 1862525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1863525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1864525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1865525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1866525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1867525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1868525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: doStartupConfig 1869525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1870525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Configure the NFC controller. 1871525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1872525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: None 1873525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1874525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 1875525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectvoid doStartupConfig() 1876525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1877525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project unsigned long num = 0; 1878525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project struct nfc_jni_native_data *nat = getNative(0, 0); 1879525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tNFA_STATUS stat = NFA_STATUS_FAILED; 1880525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1881525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project // If polling for Active mode, set the ordering so that we choose Active over Passive mode first. 1882525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (nat && (nat->tech_mask & (NFA_TECHNOLOGY_MASK_A_ACTIVE | NFA_TECHNOLOGY_MASK_F_ACTIVE))) 1883525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1884525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project UINT8 act_mode_order_param[] = { 0x01 }; 1885525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaSetConfigEvent); 1886525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project stat = NFA_SetConfig(NCI_PARAM_ID_ACT_ORDER, sizeof(act_mode_order_param), &act_mode_order_param[0]); 1887525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (stat == NFA_STATUS_OK) 1888525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaSetConfigEvent.wait (); 1889525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1890525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1891525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1892525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1893525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1894525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1895525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: nfcManager_isNfcActive 1896525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1897525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Used externaly to determine if NFC is active or not. 1898525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1899525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: 'true' if the NFC stack is running, else 'false'. 1900525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1901525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 1902525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectbool nfcManager_isNfcActive() 1903525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1904525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project return sIsNfaEnabled; 1905525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1906525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1907525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1908525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/******************************************************************************* 1909525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1910525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function: startStopPolling 1911525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1912525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description: Start or stop polling. 1913525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** isStartPolling: true to start polling; false to stop polling. 1914525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1915525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns: None. 1916525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** 1917525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/ 1918525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectvoid startStopPolling (bool isStartPolling) 1919525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{ 1920525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: enter; isStart=%u", __FUNCTION__, isStartPolling); 1921525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tNFA_STATUS stat = NFA_STATUS_FAILED; 1922525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1923525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project startRfDiscovery (false); 1924525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (isStartPolling) 1925525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1926525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tNFA_TECHNOLOGY_MASK tech_mask = DEFAULT_TECH_MASK; 1927525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project unsigned long num = 0; 1928525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (GetNumValue(NAME_POLLING_TECH_MASK, &num, sizeof(num))) 1929525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project tech_mask = num; 1930525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1931525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaEnableDisablePollingEvent); 1932525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: enable polling", __FUNCTION__); 1933525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project stat = NFA_EnablePolling (tech_mask); 1934525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (stat == NFA_STATUS_OK) 1935525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1936525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: wait for enable event", __FUNCTION__); 1937525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaEnableDisablePollingEvent.wait (); //wait for NFA_POLL_ENABLED_EVT 1938525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1939525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project else 1940525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: fail enable polling; error=0x%X", __FUNCTION__, stat); 1941525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1942525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project else 1943525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1944525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project SyncEventGuard guard (sNfaEnableDisablePollingEvent); 1945525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: disable polling", __FUNCTION__); 1946525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project stat = NFA_DisablePolling (); 1947525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project if (stat == NFA_STATUS_OK) 1948525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project { 1949525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project sNfaEnableDisablePollingEvent.wait (); //wait for NFA_POLL_DISABLED_EVT 1950525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1951525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project else 1952525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGE ("%s: fail disable polling; error=0x%X", __FUNCTION__, stat); 1953525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project } 1954525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project startRfDiscovery (true); 1955525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project ALOGD ("%s: exit", __FUNCTION__); 1956525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} 1957525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1958525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project 1959525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} /* namespace android */ 1960