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"
249f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen#include "RoutingManager.h"
25525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project#include "NfcTag.h"
26525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project#include "config.h"
27525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project#include "PowerSwitch.h"
28525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project#include "JavaClassConstants.h"
29525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project#include "Pn544Interop.h"
302534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes#include <ScopedLocalRef.h>
312534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes#include <ScopedUtfChars.h>
329f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen#include <ScopedPrimitiveArray.h>
33525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
34525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectextern "C"
35525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
36525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    #include "nfa_api.h"
37525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    #include "nfa_p2p_api.h"
38525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    #include "rw_api.h"
39525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    #include "nfa_ee_api.h"
40525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    #include "nfc_brcm_defs.h"
41525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    #include "ce_api.h"
42525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
43525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
44525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectextern const UINT8 nfca_version_string [];
45a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chuextern const UINT8 nfa_version_string [];
46a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chuextern tNFA_DM_DISC_FREQ_CFG* p_nfa_dm_rf_disc_freq_cfg; //defined in stack
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;
51b5a6c9615433734869c7a73a06c1b3799ebe0c9fMartijn Coenen    extern void nativeNfcTag_doTransceiveStatus (tNFA_STATUS status, uint8_t * buf, uint32_t buflen);
52a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu    extern void nativeNfcTag_notifyRfTimeout ();
53525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    extern void nativeNfcTag_doConnectStatus (jboolean is_connect_ok);
54525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    extern void nativeNfcTag_doDeactivateStatus (int status);
55525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    extern void nativeNfcTag_doWriteStatus (jboolean is_write_ok);
56525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    extern void nativeNfcTag_doCheckNdefResult (tNFA_STATUS status, uint32_t max_size, uint32_t current_size, uint8_t flags);
57525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    extern void nativeNfcTag_doMakeReadonlyResult (tNFA_STATUS status);
58525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    extern void nativeNfcTag_doPresenceCheckResult (tNFA_STATUS status);
59525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    extern void nativeNfcTag_formatStatus (bool is_ok);
60525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    extern void nativeNfcTag_resetPresenceCheck ();
61525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    extern void nativeNfcTag_doReadCompleted (tNFA_STATUS status);
62525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    extern void nativeNfcTag_abortWaits ();
63525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    extern void nativeLlcpConnectionlessSocket_abortWait ();
64525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    extern void nativeNfcTag_registerNdefTypeHandler ();
65525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    extern void nativeLlcpConnectionlessSocket_receiveData (uint8_t* data, uint32_t len, uint32_t remote_sap);
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**
71525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** public variables and functions
72525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
73525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*****************************************************************************/
74a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chubool                        gActivated = false;
75a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan ChuSyncEvent                   gDeactivatedEvent;
76525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
77525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectnamespace android
78525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
79525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    jmethodID               gCachedNfcManagerNotifyNdefMessageListeners;
80525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    jmethodID               gCachedNfcManagerNotifyTransactionListeners;
81525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    jmethodID               gCachedNfcManagerNotifyLlcpLinkActivation;
82525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    jmethodID               gCachedNfcManagerNotifyLlcpLinkDeactivated;
8357a44d07a3de327e8cdbbcd622118aa517313dbeMartijn Coenen    jmethodID               gCachedNfcManagerNotifyLlcpFirstPacketReceived;
849f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen    jmethodID               gCachedNfcManagerNotifyHostEmuActivated;
859f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen    jmethodID               gCachedNfcManagerNotifyHostEmuData;
869f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen    jmethodID               gCachedNfcManagerNotifyHostEmuDeactivated;
87c19c065b6d0e1a088780c4dca27a1404d5926765Martijn Coenen    jmethodID               gCachedNfcManagerNotifyRfFieldActivated;
88c19c065b6d0e1a088780c4dca27a1404d5926765Martijn Coenen    jmethodID               gCachedNfcManagerNotifyRfFieldDeactivated;
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    void                    doStartupConfig ();
96525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    void                    startStopPolling (bool isStartPolling);
97525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    void                    startRfDiscovery (bool isStart);
98525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
99525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
100525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
101525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*****************************************************************************
102525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
103525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** private variables and functions
104525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
105525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*****************************************************************************/
106525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectnamespace android
107525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
108525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic jint                 sLastError = ERROR_BUFFER_TOO_SMALL;
109525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic jmethodID            sCachedNfcManagerNotifySeApduReceived;
110525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic jmethodID            sCachedNfcManagerNotifySeMifareAccess;
111525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic jmethodID            sCachedNfcManagerNotifySeEmvCardRemoval;
112525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic jmethodID            sCachedNfcManagerNotifyTargetDeselected;
113525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic SyncEvent            sNfaEnableEvent;  //event for NFA_Enable()
114525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic SyncEvent            sNfaDisableEvent;  //event for NFA_Disable()
115525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic SyncEvent            sNfaEnableDisablePollingEvent;  //event for NFA_EnablePolling(), NFA_DisablePolling()
116525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic SyncEvent            sNfaSetConfigEvent;  // event for Set_Config....
117f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenenstatic SyncEvent            sNfaGetConfigEvent;  // event for Get_Config....
118525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool                 sIsNfaEnabled = false;
1190799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Moralesstatic bool                 sDiscoveryEnabled = false;  //is polling or listening
1200799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Moralesstatic bool                 sPollingEnabled = false;  //is polling for tag?
121525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool                 sIsDisabling = false;
122525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool                 sRfEnabled = false; // whether RF discovery is enabled
123525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool                 sSeRfActive = false;  // whether RF with SE is likely active
124c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenenstatic bool                 sReaderModeEnabled = false; // whether we're only reading tags, not allowing P2p/card emu
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 Project#define CONFIG_UPDATE_TECH_MASK     (1 << 1)
128525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project#define DEFAULT_TECH_MASK           (NFA_TECHNOLOGY_MASK_A \
129525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                                     | NFA_TECHNOLOGY_MASK_B \
130525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                                     | NFA_TECHNOLOGY_MASK_F \
131525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                                     | NFA_TECHNOLOGY_MASK_ISO15693 \
132525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                                     | NFA_TECHNOLOGY_MASK_B_PRIME \
133525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                                     | NFA_TECHNOLOGY_MASK_A_ACTIVE \
13497a71fe90493efd5947bb6f18c7b58a7e795c1ddEvan Chu                                     | NFA_TECHNOLOGY_MASK_F_ACTIVE \
13597a71fe90493efd5947bb6f18c7b58a7e795c1ddEvan Chu                                     | NFA_TECHNOLOGY_MASK_KOVIO)
136c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen#define DEFAULT_DISCOVERY_DURATION       500
1378d154680537afa5242edeb98c8f414d6186558cfMartijn Coenen#define READER_MODE_DISCOVERY_DURATION   200
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);
143d2604c0544f7bc26e5b2407f0215cccfffedae2cAndres Moralesstatic void enableDisableLptd (bool enable);
1440799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Moralesstatic tNFA_STATUS stopPolling_rfDiscoveryDisabled();
1450799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Moralesstatic tNFA_STATUS startPolling_rfDiscoveryDisabled(tNFA_TECHNOLOGY_MASK tech_mask);
146525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
147f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenenstatic UINT16 sCurrentConfigLen;
148f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenenstatic UINT8 sConfig[256];
149c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen
150525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/////////////////////////////////////////////////////////////
151525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/////////////////////////////////////////////////////////////
152525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
153525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
154525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
155525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
156525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        getNative
157525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
158525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Get native data
159525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
160525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         Native data structure.
161525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
162525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
163525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectnfc_jni_native_data *getNative (JNIEnv* e, jobject o)
164525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
165525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    static struct nfc_jni_native_data *sCachedNat = NULL;
166525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    if (e)
167525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {
168525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        sCachedNat = nfc_jni_get_nat(e, o);
169525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    }
170525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    return sCachedNat;
171525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
172525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
173525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
174525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
175525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
176525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        handleRfDiscoveryEvent
177525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
178525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Handle RF-discovery events from the stack.
179525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  discoveredDevice: Discovered device.
180525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
181525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         None
182525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
183525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
184525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic void handleRfDiscoveryEvent (tNFC_RESULT_DEVT* discoveredDevice)
185525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
186525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    if (discoveredDevice->more)
187525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {
188525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        //there is more discovery notification coming
189525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        return;
190525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    }
191525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
192525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    bool isP2p = NfcTag::getInstance ().isP2pDiscovered ();
193c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen    if (!sReaderModeEnabled && isP2p)
194525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {
195525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        //select the peer that supports P2P
196525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        NfcTag::getInstance ().selectP2p();
197525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    }
198525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    else
199525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {
200525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        //select the first of multiple tags that is discovered
201525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        NfcTag::getInstance ().selectFirstTag();
202525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    }
203525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
204525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
205525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
206525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
207525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
208525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        nfaConnectionCallback
209525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
210525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Receive connection-related events from stack.
211525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  connEvent: Event code.
212525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  eventData: Event data.
213525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
214525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         None
215525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
216525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
217525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic void nfaConnectionCallback (UINT8 connEvent, tNFA_CONN_EVT_DATA* eventData)
218525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
219525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    tNFA_STATUS status = NFA_STATUS_FAILED;
220525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGD("%s: event= %u", __FUNCTION__, connEvent);
221525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
222525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    switch (connEvent)
223525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {
224525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_POLL_ENABLED_EVT: // whether polling successfully started
225525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        {
226525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            ALOGD("%s: NFA_POLL_ENABLED_EVT: status = %u", __FUNCTION__, eventData->status);
227525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
228525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            SyncEventGuard guard (sNfaEnableDisablePollingEvent);
229525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            sNfaEnableDisablePollingEvent.notifyOne ();
230525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        }
231525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
232525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
233525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_POLL_DISABLED_EVT: // Listening/Polling stopped
234525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        {
235525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            ALOGD("%s: NFA_POLL_DISABLED_EVT: status = %u", __FUNCTION__, eventData->status);
236525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
237525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            SyncEventGuard guard (sNfaEnableDisablePollingEvent);
238525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            sNfaEnableDisablePollingEvent.notifyOne ();
239525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        }
240525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
241525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
242525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_RF_DISCOVERY_STARTED_EVT: // RF Discovery started
243525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        {
244525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            ALOGD("%s: NFA_RF_DISCOVERY_STARTED_EVT: status = %u", __FUNCTION__, eventData->status);
245525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
246525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            SyncEventGuard guard (sNfaEnableDisablePollingEvent);
247525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            sNfaEnableDisablePollingEvent.notifyOne ();
248525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        }
249525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
250525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
251525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_RF_DISCOVERY_STOPPED_EVT: // RF Discovery stopped event
252525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        {
253525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            ALOGD("%s: NFA_RF_DISCOVERY_STOPPED_EVT: status = %u", __FUNCTION__, eventData->status);
254525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
255525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            SyncEventGuard guard (sNfaEnableDisablePollingEvent);
256525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            sNfaEnableDisablePollingEvent.notifyOne ();
257525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        }
258525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
259525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
260525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_DISC_RESULT_EVT: // NFC link/protocol discovery notificaiton
261525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        status = eventData->disc_result.status;
262525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGD("%s: NFA_DISC_RESULT_EVT: status = %d", __FUNCTION__, status);
263525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        if (status != NFA_STATUS_OK)
264525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        {
265525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            ALOGE("%s: NFA_DISC_RESULT_EVT error: status = %d", __FUNCTION__, status);
266525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        }
267525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        else
268525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        {
269525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            NfcTag::getInstance().connectionEventHandler(connEvent, eventData);
270525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            handleRfDiscoveryEvent(&eventData->disc_result.discovery_ntf);
271525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        }
272525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
273525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
274525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_SELECT_RESULT_EVT: // NFC link/protocol discovery select response
275525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGD("%s: NFA_SELECT_RESULT_EVT: status = %d, gIsSelectingRfInterface = %d, sIsDisabling=%d", __FUNCTION__, eventData->status, gIsSelectingRfInterface, sIsDisabling);
276525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
277525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        if (sIsDisabling)
278525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            break;
279525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
280525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        if (eventData->status != NFA_STATUS_OK)
281525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        {
282525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            if (gIsSelectingRfInterface)
283525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            {
284525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                nativeNfcTag_doConnectStatus(false);
285525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            }
286525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
287525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            ALOGE("%s: NFA_SELECT_RESULT_EVT error: status = %d", __FUNCTION__, eventData->status);
288525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            NFA_Deactivate (FALSE);
289525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        }
290525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
291525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
292525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_DEACTIVATE_FAIL_EVT:
293525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGD("%s: NFA_DEACTIVATE_FAIL_EVT: status = %d", __FUNCTION__, eventData->status);
294525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
295525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
296525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_ACTIVATED_EVT: // NFC link/protocol activated
297525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGD("%s: NFA_ACTIVATED_EVT: gIsSelectingRfInterface=%d, sIsDisabling=%d", __FUNCTION__, gIsSelectingRfInterface, sIsDisabling);
298a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu        NfcTag::getInstance().setActive(true);
299b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen        if (sIsDisabling || !sIsNfaEnabled)
300525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            break;
301a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu        gActivated = true;
302525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
303525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        NfcTag::getInstance().setActivationState ();
304525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        if (gIsSelectingRfInterface)
305525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        {
306525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            nativeNfcTag_doConnectStatus(true);
307525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            break;
308525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        }
309525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
310525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        nativeNfcTag_resetPresenceCheck();
311525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        if (isPeerToPeer(eventData->activated))
312525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        {
313f5cd84c3a7ffb66196ab3c0745569da937d7533bMartijn Coenen            if (sReaderModeEnabled)
314f5cd84c3a7ffb66196ab3c0745569da937d7533bMartijn Coenen            {
315f5cd84c3a7ffb66196ab3c0745569da937d7533bMartijn Coenen                ALOGD("%s: ignoring peer target in reader mode.", __FUNCTION__);
316f5cd84c3a7ffb66196ab3c0745569da937d7533bMartijn Coenen                NFA_Deactivate (FALSE);
317f5cd84c3a7ffb66196ab3c0745569da937d7533bMartijn Coenen                break;
318f5cd84c3a7ffb66196ab3c0745569da937d7533bMartijn Coenen            }
319525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            sP2pActive = true;
320525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            ALOGD("%s: NFA_ACTIVATED_EVT; is p2p", __FUNCTION__);
321525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            // Disable RF field events in case of p2p
322525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            UINT8  nfa_disable_rf_events[] = { 0x00 };
323525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            ALOGD ("%s: Disabling RF field events", __FUNCTION__);
324525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            status = NFA_SetConfig(NCI_PARAM_ID_RF_FIELD_INFO, sizeof(nfa_disable_rf_events),
325525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                    &nfa_disable_rf_events[0]);
326525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            if (status == NFA_STATUS_OK) {
327525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                ALOGD ("%s: Disabled RF field events", __FUNCTION__);
328525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            } else {
329525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                ALOGE ("%s: Failed to disable RF field events", __FUNCTION__);
330525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            }
331525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        }
332525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        else if (pn544InteropIsBusy() == false)
333525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        {
334525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            NfcTag::getInstance().connectionEventHandler (connEvent, eventData);
335525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
336525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            // We know it is not activating for P2P.  If it activated in
33757a44d07a3de327e8cdbbcd622118aa517313dbeMartijn Coenen            // listen mode then it is likely for an SE transaction.
338525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            // Send the RF Event.
339525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            if (isListenMode(eventData->activated))
340525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            {
341525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                sSeRfActive = true;
342525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            }
343525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        }
344525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
345525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
346525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_DEACTIVATED_EVT: // NFC link/protocol deactivated
347525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGD("%s: NFA_DEACTIVATED_EVT   Type: %u, gIsTagDeactivating: %d", __FUNCTION__, eventData->deactivated.type,gIsTagDeactivating);
348525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        NfcTag::getInstance().setDeactivationState (eventData->deactivated);
349525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        if (eventData->deactivated.type != NFA_DEACTIVATE_TYPE_SLEEP)
350525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        {
351a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu            {
352a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu                SyncEventGuard g (gDeactivatedEvent);
353a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu                gActivated = false; //guard this variable from multi-threaded access
354a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu                gDeactivatedEvent.notifyOne ();
355a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu            }
356525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            nativeNfcTag_resetPresenceCheck();
357525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            NfcTag::getInstance().connectionEventHandler (connEvent, eventData);
358525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            nativeNfcTag_abortWaits();
359525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            NfcTag::getInstance().abort ();
360525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        }
361525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        else if (gIsTagDeactivating)
362525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        {
363a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu            NfcTag::getInstance().setActive(false);
364525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            nativeNfcTag_doDeactivateStatus(0);
365525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        }
366525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
367525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        // If RF is activated for what we think is a Secure Element transaction
368525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        // and it is deactivated to either IDLE or DISCOVERY mode, notify w/event.
369525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        if ((eventData->deactivated.type == NFA_DEACTIVATE_TYPE_IDLE)
370525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                || (eventData->deactivated.type == NFA_DEACTIVATE_TYPE_DISCOVERY))
371525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        {
372525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            if (sSeRfActive) {
373525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                sSeRfActive = false;
374525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            } else if (sP2pActive) {
375525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                sP2pActive = false;
376525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                // Make sure RF field events are re-enabled
377b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen                ALOGD("%s: NFA_DEACTIVATED_EVT; is p2p", __FUNCTION__);
378525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                // Disable RF field events in case of p2p
379525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                UINT8  nfa_enable_rf_events[] = { 0x01 };
380525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
381b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen                if (!sIsDisabling && sIsNfaEnabled)
382b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen                {
383b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen                    ALOGD ("%s: Enabling RF field events", __FUNCTION__);
384b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen                    status = NFA_SetConfig(NCI_PARAM_ID_RF_FIELD_INFO, sizeof(nfa_enable_rf_events),
385b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen                            &nfa_enable_rf_events[0]);
386b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen                    if (status == NFA_STATUS_OK) {
387b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen                        ALOGD ("%s: Enabled RF field events", __FUNCTION__);
388b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen                    } else {
389b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen                        ALOGE ("%s: Failed to enable RF field events", __FUNCTION__);
390b408fc371821c397b47c8722c339c6b4359e062fMartijn Coenen                    }
391525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                }
392525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            }
393525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        }
394525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
395525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
396525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
397525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_TLV_DETECT_EVT: // TLV Detection complete
398525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        status = eventData->tlv_detect.status;
399525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGD("%s: NFA_TLV_DETECT_EVT: status = %d, protocol = %d, num_tlvs = %d, num_bytes = %d",
400525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project             __FUNCTION__, status, eventData->tlv_detect.protocol,
401525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project             eventData->tlv_detect.num_tlvs, eventData->tlv_detect.num_bytes);
402525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        if (status != NFA_STATUS_OK)
403525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        {
404525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            ALOGE("%s: NFA_TLV_DETECT_EVT error: status = %d", __FUNCTION__, status);
405525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        }
406525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
407525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
408525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_NDEF_DETECT_EVT: // NDEF Detection complete;
409525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        //if status is failure, it means the tag does not contain any or valid NDEF data;
410525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        //pass the failure status to the NFC Service;
411525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        status = eventData->ndef_detect.status;
412525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGD("%s: NFA_NDEF_DETECT_EVT: status = 0x%X, protocol = %u, "
413525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project             "max_size = %lu, cur_size = %lu, flags = 0x%X", __FUNCTION__,
414525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project             status,
415525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project             eventData->ndef_detect.protocol, eventData->ndef_detect.max_size,
416525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project             eventData->ndef_detect.cur_size, eventData->ndef_detect.flags);
417525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        NfcTag::getInstance().connectionEventHandler (connEvent, eventData);
418525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        nativeNfcTag_doCheckNdefResult(status,
419525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            eventData->ndef_detect.max_size, eventData->ndef_detect.cur_size,
420525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            eventData->ndef_detect.flags);
421525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
422525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
423525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_DATA_EVT: // Data message received (for non-NDEF reads)
424b5a6c9615433734869c7a73a06c1b3799ebe0c9fMartijn Coenen        ALOGD("%s: NFA_DATA_EVT: status = 0x%X, len = %d", __FUNCTION__, eventData->status, eventData->data.len);
425b5a6c9615433734869c7a73a06c1b3799ebe0c9fMartijn Coenen        nativeNfcTag_doTransceiveStatus(eventData->status, eventData->data.p_data, eventData->data.len);
426525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
427a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu    case NFA_RW_INTF_ERROR_EVT:
428a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu        ALOGD("%s: NFC_RW_INTF_ERROR_EVT", __FUNCTION__);
429a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu        nativeNfcTag_notifyRfTimeout();
430b5a6c9615433734869c7a73a06c1b3799ebe0c9fMartijn Coenen        nativeNfcTag_doReadCompleted (NFA_STATUS_TIMEOUT);
431a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu        break;
432525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_SELECT_CPLT_EVT: // Select completed
433525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        status = eventData->status;
434525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGD("%s: NFA_SELECT_CPLT_EVT: status = %d", __FUNCTION__, status);
435525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        if (status != NFA_STATUS_OK)
436525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        {
437525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            ALOGE("%s: NFA_SELECT_CPLT_EVT error: status = %d", __FUNCTION__, status);
438525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        }
439525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
440525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
441525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_READ_CPLT_EVT: // NDEF-read or tag-specific-read completed
442525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGD("%s: NFA_READ_CPLT_EVT: status = 0x%X", __FUNCTION__, eventData->status);
443525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        nativeNfcTag_doReadCompleted (eventData->status);
444525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        NfcTag::getInstance().connectionEventHandler (connEvent, eventData);
445525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
446525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
447525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_WRITE_CPLT_EVT: // Write completed
448525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGD("%s: NFA_WRITE_CPLT_EVT: status = %d", __FUNCTION__, eventData->status);
449525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        nativeNfcTag_doWriteStatus (eventData->status == NFA_STATUS_OK);
450525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
451525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
452525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_SET_TAG_RO_EVT: // Tag set as Read only
453525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGD("%s: NFA_SET_TAG_RO_EVT: status = %d", __FUNCTION__, eventData->status);
454525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        nativeNfcTag_doMakeReadonlyResult(eventData->status);
455525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
456525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
457525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_CE_NDEF_WRITE_START_EVT: // NDEF write started
458525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGD("%s: NFA_CE_NDEF_WRITE_START_EVT: status: %d", __FUNCTION__, eventData->status);
459525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
460525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        if (eventData->status != NFA_STATUS_OK)
461525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            ALOGE("%s: NFA_CE_NDEF_WRITE_START_EVT error: status = %d", __FUNCTION__, eventData->status);
462525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
463525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
464525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_CE_NDEF_WRITE_CPLT_EVT: // NDEF write completed
465525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGD("%s: FA_CE_NDEF_WRITE_CPLT_EVT: len = %lu", __FUNCTION__, eventData->ndef_write_cplt.len);
466525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
467525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
468525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_LLCP_ACTIVATED_EVT: // LLCP link is activated
469525c260303268a83da4c3413b953d13c9084e834The 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",
470525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project             __FUNCTION__,
471525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project             eventData->llcp_activated.is_initiator,
472525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project             eventData->llcp_activated.remote_wks,
473525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project             eventData->llcp_activated.remote_lsc,
474525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project             eventData->llcp_activated.remote_link_miu,
475525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project             eventData->llcp_activated.local_link_miu);
476525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
477525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        PeerToPeer::getInstance().llcpActivatedHandler (getNative(0, 0), eventData->llcp_activated);
478525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
479525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
480525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_LLCP_DEACTIVATED_EVT: // LLCP link is deactivated
481525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGD("%s: NFA_LLCP_DEACTIVATED_EVT", __FUNCTION__);
482525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        PeerToPeer::getInstance().llcpDeactivatedHandler (getNative(0, 0), eventData->llcp_deactivated);
483525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
48457a44d07a3de327e8cdbbcd622118aa517313dbeMartijn Coenen    case NFA_LLCP_FIRST_PACKET_RECEIVED_EVT: // Received first packet over llcp
48557a44d07a3de327e8cdbbcd622118aa517313dbeMartijn Coenen        ALOGD("%s: NFA_LLCP_FIRST_PACKET_RECEIVED_EVT", __FUNCTION__);
48657a44d07a3de327e8cdbbcd622118aa517313dbeMartijn Coenen        PeerToPeer::getInstance().llcpFirstPacketHandler (getNative(0, 0));
48757a44d07a3de327e8cdbbcd622118aa517313dbeMartijn Coenen        break;
488525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_PRESENCE_CHECK_EVT:
489525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGD("%s: NFA_PRESENCE_CHECK_EVT", __FUNCTION__);
490525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        nativeNfcTag_doPresenceCheckResult (eventData->status);
491525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
492525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_FORMAT_CPLT_EVT:
493525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGD("%s: NFA_FORMAT_CPLT_EVT: status=0x%X", __FUNCTION__, eventData->status);
494525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        nativeNfcTag_formatStatus (eventData->status == NFA_STATUS_OK);
495525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
496525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
497525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_I93_CMD_CPLT_EVT:
498525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGD("%s: NFA_I93_CMD_CPLT_EVT: status=0x%X", __FUNCTION__, eventData->status);
499525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
500525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
501525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_CE_UICC_LISTEN_CONFIGURED_EVT :
502525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGD("%s: NFA_CE_UICC_LISTEN_CONFIGURED_EVT : status=0x%X", __FUNCTION__, eventData->status);
503525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
504525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
505525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_SET_P2P_LISTEN_TECH_EVT:
506525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGD("%s: NFA_SET_P2P_LISTEN_TECH_EVT", __FUNCTION__);
507525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        PeerToPeer::getInstance().connectionEventHandler (connEvent, eventData);
508525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
509525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
510525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    default:
511525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGE("%s: unknown event ????", __FUNCTION__);
512525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
513525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    }
514525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
515525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
516525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
517525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
518525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
519525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        nfcManager_initNativeStruc
520525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
521525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Initialize variables.
522525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  e: JVM environment.
523525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  o: Java object.
524525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
525525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         True if ok.
526525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
527525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
528525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic jboolean nfcManager_initNativeStruc (JNIEnv* e, jobject o)
529525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
530525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGD ("%s: enter", __FUNCTION__);
531525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
5322534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    nfc_jni_native_data* nat = (nfc_jni_native_data*)malloc(sizeof(struct nfc_jni_native_data));
533525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    if (nat == NULL)
534525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {
535525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGE ("%s: fail allocate native data", __FUNCTION__);
536525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        return JNI_FALSE;
537525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    }
538525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
539525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    memset (nat, 0, sizeof(*nat));
5402534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    e->GetJavaVM(&(nat->vm));
5412534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    nat->env_version = e->GetVersion();
5422534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    nat->manager = e->NewGlobalRef(o);
543525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
5442534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    ScopedLocalRef<jclass> cls(e, e->GetObjectClass(o));
545fb18ffb259fe8f40e81516842497735a7c0b6a8cAndres Morales    jfieldID f = e->GetFieldID(cls.get(), "mNative", "J");
546fb18ffb259fe8f40e81516842497735a7c0b6a8cAndres Morales    e->SetLongField(o, f, (jlong)nat);
547525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
548525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    /* Initialize native cached references */
5492534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    gCachedNfcManagerNotifyNdefMessageListeners = e->GetMethodID(cls.get(),
550525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            "notifyNdefMessageListeners", "(Lcom/android/nfc/dhimpl/NativeNfcTag;)V");
5512534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    gCachedNfcManagerNotifyLlcpLinkActivation = e->GetMethodID(cls.get(),
552525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            "notifyLlcpLinkActivation", "(Lcom/android/nfc/dhimpl/NativeP2pDevice;)V");
5532534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    gCachedNfcManagerNotifyLlcpLinkDeactivated = e->GetMethodID(cls.get(),
554525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            "notifyLlcpLinkDeactivated", "(Lcom/android/nfc/dhimpl/NativeP2pDevice;)V");
55557a44d07a3de327e8cdbbcd622118aa517313dbeMartijn Coenen    gCachedNfcManagerNotifyLlcpFirstPacketReceived = e->GetMethodID(cls.get(),
55657a44d07a3de327e8cdbbcd622118aa517313dbeMartijn Coenen            "notifyLlcpLinkFirstPacketReceived", "(Lcom/android/nfc/dhimpl/NativeP2pDevice;)V");
557525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
5589f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen    gCachedNfcManagerNotifyHostEmuActivated = e->GetMethodID(cls.get(),
5599f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen            "notifyHostEmuActivated", "()V");
5609f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen
5619f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen    gCachedNfcManagerNotifyHostEmuData = e->GetMethodID(cls.get(),
5629f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen            "notifyHostEmuData", "([B)V");
5639f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen
5649f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen    gCachedNfcManagerNotifyHostEmuDeactivated = e->GetMethodID(cls.get(),
5659f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen            "notifyHostEmuDeactivated", "()V");
5669f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen
567c19c065b6d0e1a088780c4dca27a1404d5926765Martijn Coenen    gCachedNfcManagerNotifyRfFieldActivated = e->GetMethodID(cls.get(),
568c19c065b6d0e1a088780c4dca27a1404d5926765Martijn Coenen            "notifyRfFieldActivated", "()V");
569c19c065b6d0e1a088780c4dca27a1404d5926765Martijn Coenen    gCachedNfcManagerNotifyRfFieldDeactivated = e->GetMethodID(cls.get(),
570c19c065b6d0e1a088780c4dca27a1404d5926765Martijn Coenen            "notifyRfFieldDeactivated", "()V");
571c19c065b6d0e1a088780c4dca27a1404d5926765Martijn Coenen
5722534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    if (nfc_jni_cache_object(e, gNativeNfcTagClassName, &(nat->cached_NfcTag)) == -1)
573525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {
574525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGE ("%s: fail cache NativeNfcTag", __FUNCTION__);
575525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        return JNI_FALSE;
576525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    }
577525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
5782534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    if (nfc_jni_cache_object(e, gNativeP2pDeviceClassName, &(nat->cached_P2pDevice)) == -1)
579525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {
580525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGE ("%s: fail cache NativeP2pDevice", __FUNCTION__);
581525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        return JNI_FALSE;
582525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    }
583525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
584525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGD ("%s: exit", __FUNCTION__);
585525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    return JNI_TRUE;
586525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
587525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
588525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
589525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
590525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
591525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        nfaDeviceManagementCallback
592525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
593525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Receive device management events from stack.
594525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  dmEvent: Device-management event ID.
595525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  eventData: Data associated with event ID.
596525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
597525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         None
598525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
599525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
600525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectvoid nfaDeviceManagementCallback (UINT8 dmEvent, tNFA_DM_CBACK_DATA* eventData)
601525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
602525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGD ("%s: enter; event=0x%X", __FUNCTION__, dmEvent);
603525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
604525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    switch (dmEvent)
605525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {
606525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_DM_ENABLE_EVT: /* Result of NFA_Enable */
607525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        {
608525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            SyncEventGuard guard (sNfaEnableEvent);
609525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            ALOGD ("%s: NFA_DM_ENABLE_EVT; status=0x%X",
610525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                    __FUNCTION__, eventData->status);
611525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            sIsNfaEnabled = eventData->status == NFA_STATUS_OK;
612525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            sIsDisabling = false;
613525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            sNfaEnableEvent.notifyOne ();
614525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        }
615525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
616525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
617525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_DM_DISABLE_EVT: /* Result of NFA_Disable */
618525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        {
619525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            SyncEventGuard guard (sNfaDisableEvent);
620525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            ALOGD ("%s: NFA_DM_DISABLE_EVT", __FUNCTION__);
621525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            sIsNfaEnabled = false;
622525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            sIsDisabling = false;
623525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            sNfaDisableEvent.notifyOne ();
624525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        }
625525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
626525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
627525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_DM_SET_CONFIG_EVT: //result of NFA_SetConfig
628525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGD ("%s: NFA_DM_SET_CONFIG_EVT", __FUNCTION__);
629525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        {
630525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            SyncEventGuard guard (sNfaSetConfigEvent);
631525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            sNfaSetConfigEvent.notifyOne();
632525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        }
633525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
634525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
635525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_DM_GET_CONFIG_EVT: /* Result of NFA_GetConfig */
636525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGD ("%s: NFA_DM_GET_CONFIG_EVT", __FUNCTION__);
637f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen        {
638f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen            SyncEventGuard guard (sNfaGetConfigEvent);
639f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen            if (eventData->status == NFA_STATUS_OK &&
640f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen                    eventData->get_config.tlv_size <= sizeof(sConfig))
641f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen            {
642f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen                sCurrentConfigLen = eventData->get_config.tlv_size;
643f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen                memcpy(sConfig, eventData->get_config.param_tlvs, eventData->get_config.tlv_size);
644f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen            }
645f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen            else
646f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen            {
647f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen                ALOGE("%s: NFA_DM_GET_CONFIG failed", __FUNCTION__);
648f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen                sCurrentConfigLen = 0;
649f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen            }
650f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen            sNfaGetConfigEvent.notifyOne();
651f5954743f1d8b8ace641880fd55466fff4d914cbMartijn Coenen        }
652525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
653525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
654525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_DM_RF_FIELD_EVT:
655525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGD ("%s: NFA_DM_RF_FIELD_EVT; status=0x%X; field status=%u", __FUNCTION__,
656525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project              eventData->rf_field.status, eventData->rf_field.rf_field_status);
657c19c065b6d0e1a088780c4dca27a1404d5926765Martijn Coenen        if (!sP2pActive && eventData->rf_field.status == NFA_STATUS_OK)
658c19c065b6d0e1a088780c4dca27a1404d5926765Martijn Coenen        {
659c19c065b6d0e1a088780c4dca27a1404d5926765Martijn Coenen            struct nfc_jni_native_data *nat = getNative(NULL, NULL);
660c19c065b6d0e1a088780c4dca27a1404d5926765Martijn Coenen            JNIEnv* e = NULL;
661c19c065b6d0e1a088780c4dca27a1404d5926765Martijn Coenen            ScopedAttach attach(nat->vm, &e);
662c19c065b6d0e1a088780c4dca27a1404d5926765Martijn Coenen            if (e == NULL)
663c19c065b6d0e1a088780c4dca27a1404d5926765Martijn Coenen            {
664c19c065b6d0e1a088780c4dca27a1404d5926765Martijn Coenen                ALOGE ("jni env is null");
665c19c065b6d0e1a088780c4dca27a1404d5926765Martijn Coenen                return;
666c19c065b6d0e1a088780c4dca27a1404d5926765Martijn Coenen            }
667c19c065b6d0e1a088780c4dca27a1404d5926765Martijn Coenen            if (eventData->rf_field.rf_field_status == NFA_DM_RF_FIELD_ON)
668c19c065b6d0e1a088780c4dca27a1404d5926765Martijn Coenen                e->CallVoidMethod (nat->manager, android::gCachedNfcManagerNotifyRfFieldActivated);
669c19c065b6d0e1a088780c4dca27a1404d5926765Martijn Coenen            else
670c19c065b6d0e1a088780c4dca27a1404d5926765Martijn Coenen                e->CallVoidMethod (nat->manager, android::gCachedNfcManagerNotifyRfFieldDeactivated);
671c19c065b6d0e1a088780c4dca27a1404d5926765Martijn Coenen        }
672525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
673525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
674525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_DM_NFCC_TRANSPORT_ERR_EVT:
675525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_DM_NFCC_TIMEOUT_EVT:
676525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        {
677525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            if (dmEvent == NFA_DM_NFCC_TIMEOUT_EVT)
678a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu                ALOGE ("%s: NFA_DM_NFCC_TIMEOUT_EVT; abort", __FUNCTION__);
679a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu            else if (dmEvent == NFA_DM_NFCC_TRANSPORT_ERR_EVT)
680a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu                ALOGE ("%s: NFA_DM_NFCC_TRANSPORT_ERR_EVT; abort", __FUNCTION__);
681525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
682525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            nativeNfcTag_abortWaits();
683525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            NfcTag::getInstance().abort ();
684525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            sAbortConnlessWait = true;
685525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            nativeLlcpConnectionlessSocket_abortWait();
686525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            {
687525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                ALOGD ("%s: aborting  sNfaEnableDisablePollingEvent", __FUNCTION__);
688525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                SyncEventGuard guard (sNfaEnableDisablePollingEvent);
689525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                sNfaEnableDisablePollingEvent.notifyOne();
690525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            }
691525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            {
692525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                ALOGD ("%s: aborting  sNfaEnableEvent", __FUNCTION__);
693525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                SyncEventGuard guard (sNfaEnableEvent);
694525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                sNfaEnableEvent.notifyOne();
695525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            }
696525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            {
697525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                ALOGD ("%s: aborting  sNfaDisableEvent", __FUNCTION__);
698525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                SyncEventGuard guard (sNfaDisableEvent);
699525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                sNfaDisableEvent.notifyOne();
700525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            }
701525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            sDiscoveryEnabled = false;
7020799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales            sPollingEnabled = false;
703525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            PowerSwitch::getInstance ().abort ();
704525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
705525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            if (!sIsDisabling && sIsNfaEnabled)
706525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            {
707525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                NFA_Disable(FALSE);
708525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                sIsDisabling = true;
709525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            }
710525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            else
711525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            {
712525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                sIsNfaEnabled = false;
713525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                sIsDisabling = false;
714525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            }
715525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            PowerSwitch::getInstance ().initialize (PowerSwitch::UNKNOWN_LEVEL);
716a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu            ALOGE ("%s: crash NFC service", __FUNCTION__);
717a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu            //////////////////////////////////////////////
718a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu            //crash the NFC service process so it can restart automatically
719a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu            abort ();
720a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu            //////////////////////////////////////////////
721525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        }
722525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
723525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
724525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    case NFA_DM_PWR_MODE_CHANGE_EVT:
725525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        PowerSwitch::getInstance ().deviceManagementCallback (dmEvent, eventData);
726525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
727525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
728525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    default:
729525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGD ("%s: unhandled event", __FUNCTION__);
730525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        break;
731525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    }
732525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
733525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
7349f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen/*******************************************************************************
7359f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen**
7369f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Function:        nfcManager_sendRawFrame
7379f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen**
7389f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Description:     Send a raw frame.
7399f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen**                  e: JVM environment.
7409f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen**                  o: Java object.
7419f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen**
7429f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Returns:         True if ok.
7439f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen**
7449f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen*******************************************************************************/
745c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenenstatic jboolean nfcManager_sendRawFrame (JNIEnv* e, jobject, jbyteArray data)
7469f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen{
7479f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen    ScopedByteArrayRO bytes(e, data);
7489f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen    uint8_t* buf = const_cast<uint8_t*>(reinterpret_cast<const uint8_t*>(&bytes[0]));
7499f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen    size_t bufLen = bytes.size();
7509f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen    tNFA_STATUS status = NFA_SendRawFrame (buf, bufLen, 0);
7519f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen
7529f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen    return (status == NFA_STATUS_OK);
7539f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen}
7549f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen
7559f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen/*******************************************************************************
7569f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen**
7579f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Function:        nfcManager_routeAid
7589f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen**
7599f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Description:     Route an AID to an EE
7609f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen**                  e: JVM environment.
7619f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen**                  o: Java object.
7629f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen**
7639f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Returns:         True if ok.
7649f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen**
7659f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen*******************************************************************************/
766c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenenstatic jboolean nfcManager_routeAid (JNIEnv* e, jobject, jbyteArray aid, jint route)
7679f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen{
7689f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen    ScopedByteArrayRO bytes(e, aid);
7699f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen    uint8_t* buf = const_cast<uint8_t*>(reinterpret_cast<const uint8_t*>(&bytes[0]));
7709f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen    size_t bufLen = bytes.size();
7719f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen    bool result = RoutingManager::getInstance().addAidRouting(buf, bufLen, route);
7729f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen    return result;
7739f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen}
7749f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen
7759f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen/*******************************************************************************
7769f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen**
7779f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Function:        nfcManager_unrouteAid
7789f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen**
7799f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Description:     Remove a AID routing
7809f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen**                  e: JVM environment.
7819f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen**                  o: Java object.
7829f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen**
7839f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen** Returns:         True if ok.
7849f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen**
7859f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen*******************************************************************************/
786c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenenstatic jboolean nfcManager_unrouteAid (JNIEnv* e, jobject, jbyteArray aid)
7879f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen{
7889f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen    ScopedByteArrayRO bytes(e, aid);
7899f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen    uint8_t* buf = const_cast<uint8_t*>(reinterpret_cast<const uint8_t*>(&bytes[0]));
7909f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen    size_t bufLen = bytes.size();
7919f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen    bool result = RoutingManager::getInstance().removeAidRouting(buf, bufLen);
7929f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen    return result;
7939f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen}
794525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
795525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
796525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
797f5c979220fadb2c3ac0bca09e16d0d281ed20eb2Martijn Coenen** Function:        nfcManager_commitRouting
798f5c979220fadb2c3ac0bca09e16d0d281ed20eb2Martijn Coenen**
799f5c979220fadb2c3ac0bca09e16d0d281ed20eb2Martijn Coenen** Description:     Sends the AID routing table to the controller
800f5c979220fadb2c3ac0bca09e16d0d281ed20eb2Martijn Coenen**                  e: JVM environment.
801f5c979220fadb2c3ac0bca09e16d0d281ed20eb2Martijn Coenen**                  o: Java object.
802f5c979220fadb2c3ac0bca09e16d0d281ed20eb2Martijn Coenen**
803f5c979220fadb2c3ac0bca09e16d0d281ed20eb2Martijn Coenen** Returns:         True if ok.
804f5c979220fadb2c3ac0bca09e16d0d281ed20eb2Martijn Coenen**
805f5c979220fadb2c3ac0bca09e16d0d281ed20eb2Martijn Coenen*******************************************************************************/
806f5c979220fadb2c3ac0bca09e16d0d281ed20eb2Martijn Coenenstatic jboolean nfcManager_commitRouting (JNIEnv* e, jobject)
807f5c979220fadb2c3ac0bca09e16d0d281ed20eb2Martijn Coenen{
808f5c979220fadb2c3ac0bca09e16d0d281ed20eb2Martijn Coenen    return RoutingManager::getInstance().commitRouting();
809f5c979220fadb2c3ac0bca09e16d0d281ed20eb2Martijn Coenen}
810f5c979220fadb2c3ac0bca09e16d0d281ed20eb2Martijn Coenen
811f5c979220fadb2c3ac0bca09e16d0d281ed20eb2Martijn Coenen/*******************************************************************************
812f5c979220fadb2c3ac0bca09e16d0d281ed20eb2Martijn Coenen**
813525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        nfcManager_doInitialize
814525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
815525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Turn on NFC.
816525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  e: JVM environment.
817525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  o: Java object.
818525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
819525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         True if ok.
820525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
821525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
822304a6342ee7e5620d3b50d988755c035f1686dc2Martijn Coenenstatic jboolean nfcManager_doInitialize (JNIEnv* e, jobject o)
823525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
824a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu    ALOGD ("%s: enter; ver=%s nfa=%s NCI_VERSION=0x%02X",
825a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu        __FUNCTION__, nfca_version_string, nfa_version_string, NCI_VERSION);
826525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    tNFA_STATUS stat = NFA_STATUS_OK;
827525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
828d2604c0544f7bc26e5b2407f0215cccfffedae2cAndres Morales    PowerSwitch & powerSwitch = PowerSwitch::getInstance ();
829d2604c0544f7bc26e5b2407f0215cccfffedae2cAndres Morales
830525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    if (sIsNfaEnabled)
831525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {
832525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGD ("%s: already enabled", __FUNCTION__);
833525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        goto TheEnd;
834525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    }
835525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
836d2604c0544f7bc26e5b2407f0215cccfffedae2cAndres Morales    powerSwitch.initialize (PowerSwitch::FULL_POWER);
837525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
838525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {
839525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        unsigned long num = 0;
840525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
841525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        NfcAdaptation& theInstance = NfcAdaptation::GetInstance();
842525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        theInstance.Initialize(); //start GKI, NCI task, NFC task
843525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
844525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        {
845525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            SyncEventGuard guard (sNfaEnableEvent);
846525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            tHAL_NFC_ENTRY* halFuncEntries = theInstance.GetHalEntryFuncs ();
847525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
848525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            NFA_Init (halFuncEntries);
849525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
850525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            stat = NFA_Enable (nfaDeviceManagementCallback, nfaConnectionCallback);
851525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            if (stat == NFA_STATUS_OK)
852525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            {
853525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                num = initializeGlobalAppLogLevel ();
854525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                CE_SetTraceLevel (num);
855525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                LLCP_SetTraceLevel (num);
856525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                NFC_SetTraceLevel (num);
857525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                RW_SetTraceLevel (num);
858525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                NFA_SetTraceLevel (num);
859525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                NFA_P2pSetTraceLevel (num);
860525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                sNfaEnableEvent.wait(); //wait for NFA command to finish
861525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            }
862525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        }
863525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
864525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        if (stat == NFA_STATUS_OK)
865525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        {
866525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            //sIsNfaEnabled indicates whether stack started successfully
867525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            if (sIsNfaEnabled)
868525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            {
8699f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen                RoutingManager::getInstance().initialize(getNative(e, o));
870525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                nativeNfcTag_registerNdefTypeHandler ();
871525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                NfcTag::getInstance().initialize (getNative(e, o));
872525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                PeerToPeer::getInstance().initialize ();
873525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                PeerToPeer::getInstance().handleNfcOnOff (true);
874525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
875525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                /////////////////////////////////////////////////////////////////////////////////
876525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                // Add extra configuration here (work-arounds, etc.)
877525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
878525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                struct nfc_jni_native_data *nat = getNative(e, o);
879525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
880525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                if ( nat )
881525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                {
882525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                    if (GetNumValue(NAME_POLLING_TECH_MASK, &num, sizeof(num)))
883525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                        nat->tech_mask = num;
884525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                    else
885525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                        nat->tech_mask = DEFAULT_TECH_MASK;
886525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                    ALOGD ("%s: tag polling tech mask=0x%X", __FUNCTION__, nat->tech_mask);
887525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                }
888525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
889525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                // if this value exists, set polling interval.
890525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                if (GetNumValue(NAME_NFA_DM_DISC_DURATION_POLL, &num, sizeof(num)))
891c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen                    nat->discovery_duration = num;
892c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen                else
893c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen                    nat->discovery_duration = DEFAULT_DISCOVERY_DURATION;
894c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen
895c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen                NFA_SetRfDiscoveryDuration(nat->discovery_duration);
896525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
897525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                // Do custom NFCA startup configuration.
898525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                doStartupConfig();
899525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project                goto TheEnd;
900525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            }
901525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        }
902525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
903525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGE ("%s: fail nfa enable; error=0x%X", __FUNCTION__, stat);
904525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
905525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        if (sIsNfaEnabled)
906525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            stat = NFA_Disable (FALSE /* ungraceful */);
907525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
908525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        theInstance.Finalize();
909525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    }
910525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
911525c260303268a83da4c3413b953d13c9084e834The Android Open Source ProjectTheEnd:
912525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    if (sIsNfaEnabled)
913525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        PowerSwitch::getInstance ().setLevel (PowerSwitch::LOW_POWER);
914525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGD ("%s: exit", __FUNCTION__);
915525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    return sIsNfaEnabled ? JNI_TRUE : JNI_FALSE;
916525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
917525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
918525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
919525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
920525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
921525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        nfcManager_enableDiscovery
922525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
923525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Start polling and listening for devices.
924525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  e: JVM environment.
925525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  o: Java object.
926d2604c0544f7bc26e5b2407f0215cccfffedae2cAndres Morales**                  technologies_mask: the bitmask of technologies for which to enable discovery
927d2604c0544f7bc26e5b2407f0215cccfffedae2cAndres Morales**                  enable_lptd: whether to enable low power polling (default: false)
928525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
929525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         None
930525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
931525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
932d2604c0544f7bc26e5b2407f0215cccfffedae2cAndres Moralesstatic void nfcManager_enableDiscovery (JNIEnv* e, jobject o, jint technologies_mask, \
9330799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    jboolean enable_lptd, jboolean reader_mode, jboolean enable_host_routing,
9340799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    jboolean restart)
935525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
936525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    tNFA_TECHNOLOGY_MASK tech_mask = DEFAULT_TECH_MASK;
937525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    struct nfc_jni_native_data *nat = getNative(e, o);
938525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
9390799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    if (technologies_mask == -1 && nat)
940525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        tech_mask = (tNFA_TECHNOLOGY_MASK)nat->tech_mask;
9410799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    else if (technologies_mask != -1)
942d2604c0544f7bc26e5b2407f0215cccfffedae2cAndres Morales        tech_mask = (tNFA_TECHNOLOGY_MASK) technologies_mask;
943525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGD ("%s: enter; tech_mask = %02x", __FUNCTION__, tech_mask);
944525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
9450799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    if (sDiscoveryEnabled && !restart)
946525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {
9470799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales        ALOGE ("%s: already discovering", __FUNCTION__);
948525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        return;
949525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    }
950525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
951525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    tNFA_STATUS stat = NFA_STATUS_OK;
952525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
953525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    PowerSwitch::getInstance ().setLevel (PowerSwitch::FULL_POWER);
954525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
955525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    if (sRfEnabled) {
956525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        // Stop RF discovery to reconfigure
957525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        startRfDiscovery(false);
958525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    }
959525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
9600799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    // Check polling configuration
9610799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    if (tech_mask != 0)
962a1e95d30dbe8dad0a8bb333b4ca17c009fc34e2fAndres Morales    {
9630799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales        stopPolling_rfDiscoveryDisabled();
9640799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales        enableDisableLptd(enable_lptd);
9650799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales        startPolling_rfDiscoveryDisabled(tech_mask);
9660799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales
9670799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales        // Start P2P listening if tag polling was enabled
9680799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales        if (sPollingEnabled)
969a1e95d30dbe8dad0a8bb333b4ca17c009fc34e2fAndres Morales        {
9700799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales            ALOGD ("%s: Enable p2pListening", __FUNCTION__);
9710799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales            PeerToPeer::getInstance().enableP2pListening (!reader_mode);
9720799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales
9730799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales            if (reader_mode && !sReaderModeEnabled)
9740799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales            {
9750799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales                sReaderModeEnabled = true;
9760799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales                NFA_PauseP2p();
9770799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales                NFA_DisableListening();
9780799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales                NFA_SetRfDiscoveryDuration(READER_MODE_DISCOVERY_DURATION);
9790799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales            }
9800799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales            else if (sReaderModeEnabled)
9810799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales            {
9820799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales                struct nfc_jni_native_data *nat = getNative(e, o);
9830799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales                sReaderModeEnabled = false;
9840799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales                NFA_ResumeP2p();
9850799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales                NFA_EnableListening();
9860799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales                NFA_SetRfDiscoveryDuration(nat->discovery_duration);
9870799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales            }
988a1e95d30dbe8dad0a8bb333b4ca17c009fc34e2fAndres Morales        }
989a1e95d30dbe8dad0a8bb333b4ca17c009fc34e2fAndres Morales    }
9900799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    else
991525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {
9920799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales        // No technologies configured, stop polling
9930799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales        stopPolling_rfDiscoveryDisabled();
994525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    }
995525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
9960799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    // Check listen configuration
9970799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    if (enable_host_routing)
9980799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    {
9990799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales        RoutingManager::getInstance().enableRoutingToHost();
10000799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales        RoutingManager::getInstance().commitRouting();
10010799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    }
10020799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    else
10030799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    {
10040799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales        RoutingManager::getInstance().disableRoutingToHost();
10050799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales        RoutingManager::getInstance().commitRouting();
10060799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    }
1007525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    // Actually start discovery.
1008525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    startRfDiscovery (true);
10090799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    sDiscoveryEnabled = true;
1010a1e95d30dbe8dad0a8bb333b4ca17c009fc34e2fAndres Morales
1011525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    PowerSwitch::getInstance ().setModeOn (PowerSwitch::DISCOVERY);
1012525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1013525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGD ("%s: exit", __FUNCTION__);
1014525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
1015525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1016525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1017525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
1018525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1019525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        nfcManager_disableDiscovery
1020525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1021525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Stop polling and listening for devices.
1022525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  e: JVM environment.
1023525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  o: Java object.
1024525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1025525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         None
1026525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1027525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
10280799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Moralesvoid nfcManager_disableDiscovery (JNIEnv* e, jobject o)
1029525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
1030525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    tNFA_STATUS status = NFA_STATUS_OK;
1031525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGD ("%s: enter;", __FUNCTION__);
1032525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1033525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    pn544InteropAbortNow ();
1034525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    if (sDiscoveryEnabled == false)
1035525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {
1036525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGD ("%s: already disabled", __FUNCTION__);
1037525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        goto TheEnd;
1038525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    }
1039525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1040525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    // Stop RF Discovery.
1041525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    startRfDiscovery (false);
1042525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
10430799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    if (sPollingEnabled)
10440799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales        status = stopPolling_rfDiscoveryDisabled();
1045525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1046525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    PeerToPeer::getInstance().enableP2pListening (false);
1047525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
10480799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    sDiscoveryEnabled = false;
1049525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    //if nothing is active after this, then tell the controller to power down
1050525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    if (! PowerSwitch::getInstance ().setModeOff (PowerSwitch::DISCOVERY))
1051525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        PowerSwitch::getInstance ().setLevel (PowerSwitch::LOW_POWER);
1052525c260303268a83da4c3413b953d13c9084e834The Android Open Source ProjectTheEnd:
1053525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGD ("%s: exit", __FUNCTION__);
1054525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
1055525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1056d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenenvoid enableDisableLptd (bool enable)
1057d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen{
1058d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen    // This method is *NOT* thread-safe. Right now
1059d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen    // it is only called from the same thread so it's
1060d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen    // not an issue.
1061d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen    static bool sCheckedLptd = false;
1062d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen    static bool sHasLptd = false;
1063d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen
1064d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen    tNFA_STATUS stat = NFA_STATUS_OK;
1065d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen    if (!sCheckedLptd)
1066d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen    {
1067d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen        sCheckedLptd = true;
1068d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen        SyncEventGuard guard (sNfaGetConfigEvent);
1069d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen        tNFA_PMID configParam[1] = {NCI_PARAM_ID_TAGSNIFF_CFG};
1070d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen        stat = NFA_GetConfig(1, configParam);
1071d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen        if (stat != NFA_STATUS_OK)
1072d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen        {
1073d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen            ALOGE("%s: NFA_GetConfig failed", __FUNCTION__);
1074d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen            return;
1075d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen        }
1076d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen        sNfaGetConfigEvent.wait ();
1077d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen        if (sCurrentConfigLen < 4 || sConfig[1] != NCI_PARAM_ID_TAGSNIFF_CFG) {
1078d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen            ALOGE("%s: Config TLV length %d returned is too short", __FUNCTION__,
1079d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen                    sCurrentConfigLen);
1080d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen            return;
1081d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen        }
10824181521d0157554a59e32bf06f80bfbc6288f01dMartijn Coenen        if (sConfig[3] == 0) {
10834181521d0157554a59e32bf06f80bfbc6288f01dMartijn Coenen            ALOGE("%s: LPTD is disabled, not enabling in current config", __FUNCTION__);
10844181521d0157554a59e32bf06f80bfbc6288f01dMartijn Coenen            return;
10854181521d0157554a59e32bf06f80bfbc6288f01dMartijn Coenen        }
1086d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen        sHasLptd = true;
1087d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen    }
1088d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen    // Bail if we checked and didn't find any LPTD config before
1089d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen    if (!sHasLptd) return;
109033aeb7c13f8fd9d9bd301f31680836b8ec912d51Martijn Coenen    UINT8 enable_byte = enable ? 0x01 : 0x00;
1091d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen
1092d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen    SyncEventGuard guard(sNfaSetConfigEvent);
1093d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen
109433aeb7c13f8fd9d9bd301f31680836b8ec912d51Martijn Coenen    stat = NFA_SetConfig(NCI_PARAM_ID_TAGSNIFF_CFG, 1, &enable_byte);
1095d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen    if (stat == NFA_STATUS_OK)
1096d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen        sNfaSetConfigEvent.wait ();
1097d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen    else
1098d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen        ALOGE("%s: Could not configure LPTD feature", __FUNCTION__);
1099d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen    return;
1100d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen}
1101d6ead4d11c56cc4b1e90a93d6d5fe7583abbbfb8Martijn Coenen
1102525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1103525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
1104525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1105525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        nfcManager_doCreateLlcpServiceSocket
1106525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1107525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Create a new LLCP server socket.
1108525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  e: JVM environment.
1109525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  o: Java object.
1110525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  nSap: Service access point.
1111525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  sn: Service name
1112525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  miu: Maximum information unit.
1113525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  rw: Receive window size.
1114525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  linearBufferLength: Max buffer size.
1115525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1116525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         NativeLlcpServiceSocket Java object.
1117525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1118525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
11192534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jobject nfcManager_doCreateLlcpServiceSocket (JNIEnv* e, jobject, jint nSap, jstring sn, jint miu, jint rw, jint linearBufferLength)
1120525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
1121525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    PeerToPeer::tJNI_HANDLE jniHandle = PeerToPeer::getInstance().getNewJniHandle ();
1122525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
11232534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    ScopedUtfChars serviceName(e, sn);
11242534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes
11252534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    ALOGD ("%s: enter: sap=%i; name=%s; miu=%i; rw=%i; buffLen=%i", __FUNCTION__, nSap, serviceName.c_str(), miu, rw, linearBufferLength);
1126525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1127525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    /* Create new NativeLlcpServiceSocket object */
11282534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    jobject serviceSocket = NULL;
1129b5a6c9615433734869c7a73a06c1b3799ebe0c9fMartijn Coenen    if (nfc_jni_cache_object_local(e, gNativeLlcpServiceSocketClassName, &(serviceSocket)) == -1)
1130525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {
1131525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGE ("%s: Llcp socket object creation error", __FUNCTION__);
1132525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        return NULL;
1133525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    }
1134525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1135525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    /* Get NativeLlcpServiceSocket class object */
11362534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    ScopedLocalRef<jclass> clsNativeLlcpServiceSocket(e, e->GetObjectClass(serviceSocket));
1137525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    if (e->ExceptionCheck())
1138525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {
1139525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        e->ExceptionClear();
1140525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGE("%s: Llcp Socket get object class error", __FUNCTION__);
1141525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        return NULL;
1142525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    }
1143525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
11442534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    if (!PeerToPeer::getInstance().registerServer (jniHandle, serviceName.c_str()))
1145525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {
1146525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGE("%s: RegisterServer error", __FUNCTION__);
1147525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        return NULL;
1148525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    }
1149525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
11502534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    jfieldID f;
11512534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes
1152525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    /* Set socket handle to be the same as the NfaHandle*/
11532534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    f = e->GetFieldID(clsNativeLlcpServiceSocket.get(), "mHandle", "I");
11542534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    e->SetIntField(serviceSocket, f, (jint) jniHandle);
1155525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGD ("%s: socket Handle = 0x%X", __FUNCTION__, jniHandle);
1156525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1157525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    /* Set socket linear buffer length */
11582534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    f = e->GetFieldID(clsNativeLlcpServiceSocket.get(), "mLocalLinearBufferLength", "I");
11592534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    e->SetIntField(serviceSocket, f,(jint)linearBufferLength);
1160525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGD ("%s: buffer length = %d", __FUNCTION__, linearBufferLength);
1161525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1162525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    /* Set socket MIU */
11632534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    f = e->GetFieldID(clsNativeLlcpServiceSocket.get(), "mLocalMiu", "I");
11642534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    e->SetIntField(serviceSocket, f,(jint)miu);
1165525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGD ("%s: MIU = %d", __FUNCTION__, miu);
1166525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1167525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    /* Set socket RW */
11682534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    f = e->GetFieldID(clsNativeLlcpServiceSocket.get(), "mLocalRw", "I");
11692534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    e->SetIntField(serviceSocket, f,(jint)rw);
1170525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGD ("%s:  RW = %d", __FUNCTION__, rw);
1171525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1172525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    sLastError = 0;
1173525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGD ("%s: exit", __FUNCTION__);
1174525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    return serviceSocket;
1175525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
1176525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1177525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1178525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
1179525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1180525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        nfcManager_doGetLastError
1181525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1182525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Get the last error code.
1183525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  e: JVM environment.
1184525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  o: Java object.
1185525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1186525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         Last error code.
1187525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1188525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
11892534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jint nfcManager_doGetLastError(JNIEnv*, jobject)
1190525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
1191525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGD ("%s: last error=%i", __FUNCTION__, sLastError);
1192525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    return sLastError;
1193525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
1194525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1195525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1196525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
1197525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1198525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        nfcManager_doDeinitialize
1199525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1200525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Turn off NFC.
1201525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  e: JVM environment.
1202525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  o: Java object.
1203525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1204525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         True if ok.
1205525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1206525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
12072534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jboolean nfcManager_doDeinitialize (JNIEnv*, jobject)
1208525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
1209525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGD ("%s: enter", __FUNCTION__);
1210525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1211525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    sIsDisabling = true;
1212525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    pn544InteropAbortNow ();
1213f3e09e66825850178879e76ccc7708509dbbc5b6Martijn Coenen    RoutingManager::getInstance().onNfccShutdown();
1214a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu    PowerSwitch::getInstance ().initialize (PowerSwitch::UNKNOWN_LEVEL);
1215525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1216525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    if (sIsNfaEnabled)
1217525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {
1218525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        SyncEventGuard guard (sNfaDisableEvent);
1219525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        tNFA_STATUS stat = NFA_Disable (TRUE /* graceful */);
1220525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        if (stat == NFA_STATUS_OK)
1221525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        {
1222525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            ALOGD ("%s: wait for completion", __FUNCTION__);
1223525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            sNfaDisableEvent.wait (); //wait for NFA command to finish
1224525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            PeerToPeer::getInstance ().handleNfcOnOff (false);
1225525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        }
1226525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        else
1227525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        {
1228525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            ALOGE ("%s: fail disable; error=0x%X", __FUNCTION__, stat);
1229525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        }
1230525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    }
1231525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    nativeNfcTag_abortWaits();
1232525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    NfcTag::getInstance().abort ();
1233525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    sAbortConnlessWait = true;
1234525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    nativeLlcpConnectionlessSocket_abortWait();
1235525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    sIsNfaEnabled = false;
1236525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    sDiscoveryEnabled = false;
12370799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    sPollingEnabled = false;
1238525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    sIsDisabling = false;
12398d154680537afa5242edeb98c8f414d6186558cfMartijn Coenen    gActivated = false;
1240525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1241525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {
1242525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        //unblock NFA_EnablePolling() and NFA_DisablePolling()
1243525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        SyncEventGuard guard (sNfaEnableDisablePollingEvent);
1244525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        sNfaEnableDisablePollingEvent.notifyOne ();
1245525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    }
1246525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1247525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    NfcAdaptation& theInstance = NfcAdaptation::GetInstance();
1248525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    theInstance.Finalize();
1249525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1250525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGD ("%s: exit", __FUNCTION__);
1251525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    return JNI_TRUE;
1252525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
1253525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1254525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1255525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
1256525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1257525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        nfcManager_doCreateLlcpSocket
1258525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1259525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Create a LLCP connection-oriented socket.
1260525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  e: JVM environment.
1261525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  o: Java object.
1262525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  nSap: Service access point.
1263525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  miu: Maximum information unit.
1264525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  rw: Receive window size.
1265525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  linearBufferLength: Max buffer size.
1266525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1267525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         NativeLlcpSocket Java object.
1268525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1269525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
12702534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jobject nfcManager_doCreateLlcpSocket (JNIEnv* e, jobject, jint nSap, jint miu, jint rw, jint linearBufferLength)
1271525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
1272525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGD ("%s: enter; sap=%d; miu=%d; rw=%d; buffer len=%d", __FUNCTION__, nSap, miu, rw, linearBufferLength);
1273525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
12742534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    PeerToPeer::tJNI_HANDLE jniHandle = PeerToPeer::getInstance().getNewJniHandle ();
1275a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu    PeerToPeer::getInstance().createClient (jniHandle, miu, rw);
1276525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1277525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    /* Create new NativeLlcpSocket object */
12782534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    jobject clientSocket = NULL;
1279525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    if (nfc_jni_cache_object_local(e, gNativeLlcpSocketClassName, &(clientSocket)) == -1)
1280525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {
1281525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGE ("%s: fail Llcp socket creation", __FUNCTION__);
12822534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes        return clientSocket;
1283525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    }
1284525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1285525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    /* Get NativeConnectionless class object */
12862534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    ScopedLocalRef<jclass> clsNativeLlcpSocket(e, e->GetObjectClass(clientSocket));
1287525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    if (e->ExceptionCheck())
1288525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {
1289525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        e->ExceptionClear();
1290525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGE ("%s: fail get class object", __FUNCTION__);
12912534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes        return clientSocket;
1292525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    }
1293525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
12942534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    jfieldID f;
12952534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes
1296525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    /* Set socket SAP */
12972534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    f = e->GetFieldID (clsNativeLlcpSocket.get(), "mSap", "I");
1298525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    e->SetIntField (clientSocket, f, (jint) nSap);
1299525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1300525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    /* Set socket handle */
13012534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    f = e->GetFieldID (clsNativeLlcpSocket.get(), "mHandle", "I");
1302525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    e->SetIntField (clientSocket, f, (jint) jniHandle);
1303525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1304525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    /* Set socket MIU */
13052534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    f = e->GetFieldID (clsNativeLlcpSocket.get(), "mLocalMiu", "I");
1306525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    e->SetIntField (clientSocket, f, (jint) miu);
1307525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1308525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    /* Set socket RW */
13092534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughes    f = e->GetFieldID (clsNativeLlcpSocket.get(), "mLocalRw", "I");
1310525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    e->SetIntField (clientSocket, f, (jint) rw);
1311525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1312525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGD ("%s: exit", __FUNCTION__);
1313525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    return clientSocket;
1314525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
1315525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1316525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1317525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
1318525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1319525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        nfcManager_doCreateLlcpConnectionlessSocket
1320525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1321525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Create a connection-less socket.
1322525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  e: JVM environment.
1323525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  o: Java object.
1324525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  nSap: Service access point.
1325525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  sn: Service name.
1326525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1327525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         NativeLlcpConnectionlessSocket Java object.
1328525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1329525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
13302534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jobject nfcManager_doCreateLlcpConnectionlessSocket (JNIEnv *, jobject, jint nSap, jstring /*sn*/)
1331525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
1332525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGD ("%s: nSap=0x%X", __FUNCTION__, nSap);
1333525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    return NULL;
1334525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
1335525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1336525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
1337525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1338525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        isPeerToPeer
1339525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1340525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Whether the activation data indicates the peer supports NFC-DEP.
1341525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  activated: Activation data.
1342525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1343525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         True if the peer supports NFC-DEP.
1344525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1345525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
1346525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool isPeerToPeer (tNFA_ACTIVATED& activated)
1347525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
1348525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    return activated.activate_ntf.protocol == NFA_PROTOCOL_NFC_DEP;
1349525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
1350525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1351525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
1352525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1353525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        isListenMode
1354525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1355525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Indicates whether the activation data indicates it is
1356525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  listen mode.
1357525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1358525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         True if this listen mode.
1359525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1360525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
1361525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic bool isListenMode(tNFA_ACTIVATED& activated)
1362525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
1363525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    return ((NFC_DISCOVERY_TYPE_LISTEN_A == activated.activate_ntf.rf_tech_param.mode)
1364525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            || (NFC_DISCOVERY_TYPE_LISTEN_B == activated.activate_ntf.rf_tech_param.mode)
1365525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            || (NFC_DISCOVERY_TYPE_LISTEN_F == activated.activate_ntf.rf_tech_param.mode)
1366525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            || (NFC_DISCOVERY_TYPE_LISTEN_A_ACTIVE == activated.activate_ntf.rf_tech_param.mode)
1367525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            || (NFC_DISCOVERY_TYPE_LISTEN_F_ACTIVE == activated.activate_ntf.rf_tech_param.mode)
1368525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            || (NFC_DISCOVERY_TYPE_LISTEN_ISO15693 == activated.activate_ntf.rf_tech_param.mode)
1369525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            || (NFC_DISCOVERY_TYPE_LISTEN_B_PRIME == activated.activate_ntf.rf_tech_param.mode));
1370525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
1371525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1372525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
1373525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1374525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        nfcManager_doCheckLlcp
1375525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1376525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Not used.
1377525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1378525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         True
1379525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1380525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
13812534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jboolean nfcManager_doCheckLlcp(JNIEnv*, jobject)
1382525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
1383525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGD("%s", __FUNCTION__);
1384525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    return JNI_TRUE;
1385525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
1386525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1387525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1388525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
1389525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1390525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        nfcManager_doActivateLlcp
1391525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1392525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Not used.
1393525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1394525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         True
1395525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1396525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
13972534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jboolean nfcManager_doActivateLlcp(JNIEnv*, jobject)
1398525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
1399525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGD("%s", __FUNCTION__);
1400525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    return JNI_TRUE;
1401525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
1402525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1403525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1404525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
1405525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1406525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        nfcManager_doAbort
1407525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1408525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Not used.
1409525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1410525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         None
1411525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1412525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
14132534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic void nfcManager_doAbort(JNIEnv*, jobject)
1414525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
1415525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGE("%s: abort()", __FUNCTION__);
1416525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    abort();
1417525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
1418525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1419525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1420525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
1421525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1422525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        nfcManager_doDownload
1423525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1424a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu** Description:     Download firmware patch files.  Do not turn on NFC.
1425525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1426a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu** Returns:         True if ok.
1427525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1428525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
14292534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jboolean nfcManager_doDownload(JNIEnv*, jobject)
1430525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
1431a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu    ALOGD ("%s: enter", __FUNCTION__);
1432a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu    NfcAdaptation& theInstance = NfcAdaptation::GetInstance();
1433a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu
1434a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu    theInstance.Initialize(); //start GKI, NCI task, NFC task
1435a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu    theInstance.DownloadFirmware ();
1436a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu    theInstance.Finalize();
1437a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu    ALOGD ("%s: exit", __FUNCTION__);
1438525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    return JNI_TRUE;
1439525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
1440525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1441525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1442525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
1443525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1444525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        nfcManager_doResetTimeouts
1445525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1446525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Not used.
1447525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1448525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         None
1449525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1450525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
14512534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic void nfcManager_doResetTimeouts(JNIEnv*, jobject)
1452525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
1453a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu    ALOGD ("%s", __FUNCTION__);
1454a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu    NfcTag::getInstance().resetAllTransceiveTimeouts ();
1455525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
1456525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1457525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1458525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
1459525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1460525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        nfcManager_doSetTimeout
1461525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1462525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Set timeout value.
1463525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  e: JVM environment.
1464525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  o: Java object.
1465a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu**                  tech: technology ID.
1466525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  timeout: Timeout value.
1467525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1468525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         True if ok.
1469525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1470525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
1471a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chustatic bool nfcManager_doSetTimeout(JNIEnv*, jobject, jint tech, jint timeout)
1472525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
1473525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    if (timeout <= 0)
1474525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {
1475525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGE("%s: Timeout must be positive.",__FUNCTION__);
1476525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        return false;
1477525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    }
1478a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu    ALOGD ("%s: tech=%d, timeout=%d", __FUNCTION__, tech, timeout);
1479a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu    NfcTag::getInstance().setTransceiveTimeout (tech, timeout);
1480525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    return true;
1481525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
1482525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1483525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1484525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
1485525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1486525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        nfcManager_doGetTimeout
1487525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1488525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Get timeout value.
1489525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  e: JVM environment.
1490525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  o: Java object.
1491a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu**                  tech: technology ID.
1492525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1493525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         Timeout value.
1494525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1495525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
1496a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chustatic jint nfcManager_doGetTimeout(JNIEnv*, jobject, jint tech)
1497525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
1498a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu    int timeout = NfcTag::getInstance().getTransceiveTimeout (tech);
1499a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu    ALOGD ("%s: tech=%d, timeout=%d", __FUNCTION__, tech, timeout);
1500a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu    return timeout;
1501525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
1502525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1503525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1504525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
1505525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1506525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        nfcManager_doDump
1507525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1508525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Not used.
1509525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  e: JVM environment.
1510525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  o: Java object.
1511525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1512525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         Text dump.
1513525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1514525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
15152534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic jstring nfcManager_doDump(JNIEnv* e, jobject)
1516525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
1517525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    char buffer[100];
1518525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    snprintf(buffer, sizeof(buffer), "libnfc llc error_count=%u", /*libnfc_llc_error_count*/ 0);
1519525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    return e->NewStringUTF(buffer);
1520525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
1521525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1522525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1523525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
1524525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1525525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        nfcManager_doSetP2pInitiatorModes
1526525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1527525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Set P2P initiator's activation modes.
1528525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  e: JVM environment.
1529525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  o: Java object.
1530525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  modes: Active and/or passive modes.  The values are specified
1531525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                          in external/libnfc-nxp/inc/phNfcTypes.h.  See
1532525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                          enum phNfc_eP2PMode_t.
1533525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1534525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         None.
1535525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1536525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
1537525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic void nfcManager_doSetP2pInitiatorModes (JNIEnv *e, jobject o, jint modes)
1538525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
1539525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGD ("%s: modes=0x%X", __FUNCTION__, modes);
1540525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    struct nfc_jni_native_data *nat = getNative(e, o);
1541525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1542525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    tNFA_TECHNOLOGY_MASK mask = 0;
1543525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    if (modes & 0x01) mask |= NFA_TECHNOLOGY_MASK_A;
1544525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    if (modes & 0x02) mask |= NFA_TECHNOLOGY_MASK_F;
1545525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    if (modes & 0x04) mask |= NFA_TECHNOLOGY_MASK_F;
1546525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    if (modes & 0x08) mask |= NFA_TECHNOLOGY_MASK_A_ACTIVE;
1547525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    if (modes & 0x10) mask |= NFA_TECHNOLOGY_MASK_F_ACTIVE;
1548525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    if (modes & 0x20) mask |= NFA_TECHNOLOGY_MASK_F_ACTIVE;
1549525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    nat->tech_mask = mask;
1550525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
1551525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1552525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1553525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
1554525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1555525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        nfcManager_doSetP2pTargetModes
1556525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1557525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Set P2P target's activation modes.
1558525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  e: JVM environment.
1559525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  o: Java object.
1560525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  modes: Active and/or passive modes.
1561525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1562525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         None.
1563525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1564525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
15652534d9a546f24435d9dab8168f9ea5bf8ca1eb9bElliott Hughesstatic void nfcManager_doSetP2pTargetModes (JNIEnv*, jobject, jint modes)
1566525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
1567525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGD ("%s: modes=0x%X", __FUNCTION__, modes);
1568525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    // Map in the right modes
1569525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    tNFA_TECHNOLOGY_MASK mask = 0;
1570525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    if (modes & 0x01) mask |= NFA_TECHNOLOGY_MASK_A;
1571525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    if (modes & 0x02) mask |= NFA_TECHNOLOGY_MASK_F;
1572525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    if (modes & 0x04) mask |= NFA_TECHNOLOGY_MASK_F;
1573525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    if (modes & 0x08) mask |= NFA_TECHNOLOGY_MASK_A_ACTIVE | NFA_TECHNOLOGY_MASK_F_ACTIVE;
1574525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1575525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    PeerToPeer::getInstance().setP2pListenMask(mask);
1576525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
1577525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1578d2604c0544f7bc26e5b2407f0215cccfffedae2cAndres Moralesstatic void nfcManager_doEnableScreenOffSuspend(JNIEnv* e, jobject o)
1579d2604c0544f7bc26e5b2407f0215cccfffedae2cAndres Morales{
1580d2604c0544f7bc26e5b2407f0215cccfffedae2cAndres Morales    PowerSwitch::getInstance().setScreenOffPowerState(PowerSwitch::POWER_STATE_FULL);
1581d2604c0544f7bc26e5b2407f0215cccfffedae2cAndres Morales}
1582d2604c0544f7bc26e5b2407f0215cccfffedae2cAndres Morales
1583d2604c0544f7bc26e5b2407f0215cccfffedae2cAndres Moralesstatic void nfcManager_doDisableScreenOffSuspend(JNIEnv* e, jobject o)
1584d2604c0544f7bc26e5b2407f0215cccfffedae2cAndres Morales{
1585d2604c0544f7bc26e5b2407f0215cccfffedae2cAndres Morales    PowerSwitch::getInstance().setScreenOffPowerState(PowerSwitch::POWER_STATE_OFF);
1586d2604c0544f7bc26e5b2407f0215cccfffedae2cAndres Morales}
1587c4e4277a71c70e96198cb760676ad3b40f9e0e3dMartijn Coenen
1588525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*****************************************************************************
1589525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1590525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** JNI functions for android-4.0.1_r1
1591525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1592525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*****************************************************************************/
1593525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectstatic JNINativeMethod gMethods[] =
1594525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
1595525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {"doDownload", "()Z",
1596525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            (void *)nfcManager_doDownload},
1597525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1598525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {"initializeNativeStructure", "()Z",
1599525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            (void*) nfcManager_initNativeStruc},
1600525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1601304a6342ee7e5620d3b50d988755c035f1686dc2Martijn Coenen    {"doInitialize", "()Z",
1602525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            (void*) nfcManager_doInitialize},
1603525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1604525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {"doDeinitialize", "()Z",
1605525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            (void*) nfcManager_doDeinitialize},
1606525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
16079f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen    {"sendRawFrame", "([B)Z",
16089f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen            (void*) nfcManager_sendRawFrame},
16099f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen
16109f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen    {"routeAid", "([BI)Z",
16119f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen            (void*) nfcManager_routeAid},
16129f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen
16139f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen    {"unrouteAid", "([B)Z",
16149f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen            (void*) nfcManager_unrouteAid},
16159f8f6cf9c58405ecafe2d425801e6c14088db8c7Martijn Coenen
1616f5c979220fadb2c3ac0bca09e16d0d281ed20eb2Martijn Coenen    {"commitRouting", "()Z",
1617f5c979220fadb2c3ac0bca09e16d0d281ed20eb2Martijn Coenen            (void*) nfcManager_commitRouting},
1618f5c979220fadb2c3ac0bca09e16d0d281ed20eb2Martijn Coenen
16190799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    {"doEnableDiscovery", "(IZZZZ)V",
1620525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            (void*) nfcManager_enableDiscovery},
1621525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1622525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {"doCheckLlcp", "()Z",
1623525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            (void *)nfcManager_doCheckLlcp},
1624525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1625525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {"doActivateLlcp", "()Z",
1626525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            (void *)nfcManager_doActivateLlcp},
1627525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1628525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {"doCreateLlcpConnectionlessSocket", "(ILjava/lang/String;)Lcom/android/nfc/dhimpl/NativeLlcpConnectionlessSocket;",
1629525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            (void *)nfcManager_doCreateLlcpConnectionlessSocket},
1630525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1631525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {"doCreateLlcpServiceSocket", "(ILjava/lang/String;III)Lcom/android/nfc/dhimpl/NativeLlcpServiceSocket;",
1632525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            (void*) nfcManager_doCreateLlcpServiceSocket},
1633525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1634525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {"doCreateLlcpSocket", "(IIII)Lcom/android/nfc/dhimpl/NativeLlcpSocket;",
1635525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            (void*) nfcManager_doCreateLlcpSocket},
1636525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1637525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {"doGetLastError", "()I",
1638525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            (void*) nfcManager_doGetLastError},
1639525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1640a1e95d30dbe8dad0a8bb333b4ca17c009fc34e2fAndres Morales    {"disableDiscovery", "()V",
1641525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            (void*) nfcManager_disableDiscovery},
1642525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1643525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {"doSetTimeout", "(II)Z",
1644525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            (void *)nfcManager_doSetTimeout},
1645525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1646525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {"doGetTimeout", "(I)I",
1647525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            (void *)nfcManager_doGetTimeout},
1648525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1649525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {"doResetTimeouts", "()V",
1650525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            (void *)nfcManager_doResetTimeouts},
1651525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1652525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {"doAbort", "()V",
1653525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            (void *)nfcManager_doAbort},
1654525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1655525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {"doSetP2pInitiatorModes", "(I)V",
1656525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            (void *)nfcManager_doSetP2pInitiatorModes},
1657525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1658525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {"doSetP2pTargetModes", "(I)V",
1659525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            (void *)nfcManager_doSetP2pTargetModes},
1660525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1661d2604c0544f7bc26e5b2407f0215cccfffedae2cAndres Morales    {"doEnableScreenOffSuspend", "()V",
1662d2604c0544f7bc26e5b2407f0215cccfffedae2cAndres Morales            (void *)nfcManager_doEnableScreenOffSuspend},
1663d2604c0544f7bc26e5b2407f0215cccfffedae2cAndres Morales
1664d2604c0544f7bc26e5b2407f0215cccfffedae2cAndres Morales    {"doDisableScreenOffSuspend", "()V",
1665d2604c0544f7bc26e5b2407f0215cccfffedae2cAndres Morales            (void *)nfcManager_doDisableScreenOffSuspend},
1666d2604c0544f7bc26e5b2407f0215cccfffedae2cAndres Morales
1667525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {"doDump", "()Ljava/lang/String;",
1668525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            (void *)nfcManager_doDump},
1669525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project};
1670525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1671525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1672525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
1673525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1674525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        register_com_android_nfc_NativeNfcManager
1675525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1676525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Regisgter JNI functions with Java Virtual Machine.
1677525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  e: Environment of JVM.
1678525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1679525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         Status of registration.
1680525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1681525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
1682525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectint register_com_android_nfc_NativeNfcManager (JNIEnv *e)
1683525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
1684525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGD ("%s: enter", __FUNCTION__);
1685525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    PowerSwitch::getInstance ().initialize (PowerSwitch::UNKNOWN_LEVEL);
1686525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGD ("%s: exit", __FUNCTION__);
1687525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    return jniRegisterNativeMethods (e, gNativeNfcManagerClassName, gMethods, NELEM (gMethods));
1688525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
1689525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1690525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1691525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
1692525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1693525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        startRfDiscovery
1694525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1695525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Ask stack to start polling and listening for devices.
1696525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  isStart: Whether to start.
1697525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1698525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         None
1699525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1700525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
1701525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectvoid startRfDiscovery(bool isStart)
1702525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
1703525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    tNFA_STATUS status = NFA_STATUS_FAILED;
1704525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1705525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGD ("%s: is start=%d", __FUNCTION__, isStart);
1706525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    SyncEventGuard guard (sNfaEnableDisablePollingEvent);
1707525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    status  = isStart ? NFA_StartRfDiscovery () : NFA_StopRfDiscovery ();
1708525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    if (status == NFA_STATUS_OK)
1709525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {
1710525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        sNfaEnableDisablePollingEvent.wait (); //wait for NFA_RF_DISCOVERY_xxxx_EVT
1711525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        sRfEnabled = isStart;
1712525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    }
1713525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    else
1714525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {
1715525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        ALOGE ("%s: Failed to start/stop RF discovery; error=0x%X", __FUNCTION__, status);
1716525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    }
1717525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
1718525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1719525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1720525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
1721525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1722525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        doStartupConfig
1723525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1724525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Configure the NFC controller.
1725525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1726525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         None
1727525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1728525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
1729525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectvoid doStartupConfig()
1730525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
1731525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    struct nfc_jni_native_data *nat = getNative(0, 0);
1732525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    tNFA_STATUS stat = NFA_STATUS_FAILED;
1733a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu    int actualLen = 0;
1734525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1735525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    // If polling for Active mode, set the ordering so that we choose Active over Passive mode first.
1736525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    if (nat && (nat->tech_mask & (NFA_TECHNOLOGY_MASK_A_ACTIVE | NFA_TECHNOLOGY_MASK_F_ACTIVE)))
1737525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {
1738525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        UINT8  act_mode_order_param[] = { 0x01 };
1739525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        SyncEventGuard guard (sNfaSetConfigEvent);
1740525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        stat = NFA_SetConfig(NCI_PARAM_ID_ACT_ORDER, sizeof(act_mode_order_param), &act_mode_order_param[0]);
1741525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project        if (stat == NFA_STATUS_OK)
1742525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project            sNfaSetConfigEvent.wait ();
1743525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    }
1744a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu
1745a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu    //configure RF polling frequency for each technology
1746a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu    static tNFA_DM_DISC_FREQ_CFG nfa_dm_disc_freq_cfg;
1747a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu    //values in the polling_frequency[] map to members of nfa_dm_disc_freq_cfg
1748a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu    UINT8 polling_frequency [8] = {1, 1, 1, 1, 1, 1, 1, 1};
1749a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu    actualLen = GetStrValue(NAME_POLL_FREQUENCY, (char*)polling_frequency, 8);
1750a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu    if (actualLen == 8)
1751a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu    {
1752a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu        ALOGD ("%s: polling frequency", __FUNCTION__);
1753a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu        memset (&nfa_dm_disc_freq_cfg, 0, sizeof(nfa_dm_disc_freq_cfg));
1754a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu        nfa_dm_disc_freq_cfg.pa = polling_frequency [0];
1755a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu        nfa_dm_disc_freq_cfg.pb = polling_frequency [1];
1756a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu        nfa_dm_disc_freq_cfg.pf = polling_frequency [2];
1757a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu        nfa_dm_disc_freq_cfg.pi93 = polling_frequency [3];
1758a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu        nfa_dm_disc_freq_cfg.pbp = polling_frequency [4];
1759a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu        nfa_dm_disc_freq_cfg.pk = polling_frequency [5];
1760a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu        nfa_dm_disc_freq_cfg.paa = polling_frequency [6];
1761a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu        nfa_dm_disc_freq_cfg.pfa = polling_frequency [7];
1762a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu        p_nfa_dm_rf_disc_freq_cfg = &nfa_dm_disc_freq_cfg;
1763a8aa07142ea0078d3ae4ae486e094e2f2f4ff732Evan Chu    }
1764525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
1765525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1766525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1767525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
1768525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1769525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        nfcManager_isNfcActive
1770525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1771525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Used externaly to determine if NFC is active or not.
1772525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1773525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         'true' if the NFC stack is running, else 'false'.
1774525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1775525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
1776525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectbool nfcManager_isNfcActive()
1777525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
1778525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    return sIsNfaEnabled;
1779525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
1780525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1781525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project/*******************************************************************************
1782525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1783525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Function:        startStopPolling
1784525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1785525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Description:     Start or stop polling.
1786525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**                  isStartPolling: true to start polling; false to stop polling.
1787525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1788525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project** Returns:         None.
1789525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project**
1790525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project*******************************************************************************/
1791525c260303268a83da4c3413b953d13c9084e834The Android Open Source Projectvoid startStopPolling (bool isStartPolling)
1792525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project{
1793525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    ALOGD ("%s: enter; isStart=%u", __FUNCTION__, isStartPolling);
17940799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    startRfDiscovery (false);
17950799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales
17960799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    if (isStartPolling) startPolling_rfDiscoveryDisabled(0);
17970799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    else stopPolling_rfDiscoveryDisabled();
17980799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales
17990799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    startRfDiscovery (true);
18000799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    ALOGD ("%s: exit", __FUNCTION__);
18010799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales}
18020799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales
18030799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales
18040799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Moralesstatic tNFA_STATUS startPolling_rfDiscoveryDisabled(tNFA_TECHNOLOGY_MASK tech_mask) {
1805525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    tNFA_STATUS stat = NFA_STATUS_FAILED;
1806525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
18070799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    unsigned long num = 0;
1808a1e95d30dbe8dad0a8bb333b4ca17c009fc34e2fAndres Morales
18090799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    if (tech_mask == 0 && GetNumValue(NAME_POLLING_TECH_MASK, &num, sizeof(num)))
18100799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales        tech_mask = num;
18110799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    else if (tech_mask == 0) tech_mask = DEFAULT_TECH_MASK;
18120799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales
18130799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    SyncEventGuard guard (sNfaEnableDisablePollingEvent);
18140799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    ALOGD ("%s: enable polling", __FUNCTION__);
18150799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    stat = NFA_EnablePolling (tech_mask);
18160799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    if (stat == NFA_STATUS_OK)
18170799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    {
18180799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales        ALOGD ("%s: wait for enable event", __FUNCTION__);
18190799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales        sPollingEnabled = true;
18200799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales        sNfaEnableDisablePollingEvent.wait (); //wait for NFA_POLL_ENABLED_EVT
1821525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    }
1822525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    else
1823525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    {
18240799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales        ALOGE ("%s: fail enable polling; error=0x%X", __FUNCTION__, stat);
1825525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project    }
18260799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales
18270799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    return stat;
18280799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales}
18290799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales
18300799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Moralesstatic tNFA_STATUS stopPolling_rfDiscoveryDisabled() {
18310799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    tNFA_STATUS stat = NFA_STATUS_FAILED;
18320799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales
18330799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    SyncEventGuard guard (sNfaEnableDisablePollingEvent);
18340799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    ALOGD ("%s: disable polling", __FUNCTION__);
18350799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    stat = NFA_DisablePolling ();
18360799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    if (stat == NFA_STATUS_OK) {
18370799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales        sPollingEnabled = false;
18380799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales        sNfaEnableDisablePollingEvent.wait (); //wait for NFA_POLL_DISABLED_EVT
18390799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    } else {
18400799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales        ALOGE ("%s: fail disable polling; error=0x%X", __FUNCTION__, stat);
18410799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    }
18420799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales
18430799bcbe2469aa6a88c6cbdf0cdee5b50e1994f0Andres Morales    return stat;
1844525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project}
1845525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1846525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project
1847525c260303268a83da4c3413b953d13c9084e834The Android Open Source Project} /* namespace android */
1848