| Index: remoting/client/jni/jni_interface.cc | 
| diff --git a/remoting/client/jni/jni_interface.cc b/remoting/client/jni/jni_interface.cc | 
| index 205b05b3a23bd78dc57b36a8270546910c5078ca..b78ff0513a98f8a9715bccb31f6f180f9872997e 100644 | 
| --- a/remoting/client/jni/jni_interface.cc | 
| +++ b/remoting/client/jni/jni_interface.cc | 
| @@ -40,7 +40,8 @@ JNIEXPORT void JNICALL JNI_IMPLEMENTATION(loadNative)(JNIEnv* env, | 
| // them from DCHECKing out when they go looking. | 
| CommandLine::Init(0, NULL); | 
|  | 
| -  remoting::ChromotingJNIInstance::GetInstance(); // Initialize threads now. | 
| +  // Create the singleton now so that the Chromoting threads will be set up. | 
| +  remoting::ChromotingJNIInstance::GetInstance(); | 
| } | 
|  | 
| JNIEXPORT jstring JNICALL JNI_IMPLEMENTATION(getApiKey)(JNIEnv* env, | 
| @@ -60,18 +61,32 @@ JNIEXPORT jstring JNICALL JNI_IMPLEMENTATION(getClientSecret)(JNIEnv* env, | 
| google_apis::GetOAuth2ClientSecret(google_apis::CLIENT_REMOTING).c_str()); | 
| } | 
|  | 
| -JNIEXPORT void JNICALL JNI_IMPLEMENTATION(connectNative)(JNIEnv* env, | 
| -                                                         jobject that, | 
| -                                                         jstring username, | 
| -                                                         jstring auth_token, | 
| -                                                         jstring host_jid, | 
| -                                                         jstring host_id, | 
| -                                                         jstring host_pubkey) { | 
| -  remoting::ChromotingJNIInstance::GetInstance()->ConnectToHost(username, | 
| -                                                                auth_token, | 
| -                                                                host_jid, | 
| -                                                                host_id, | 
| -                                                                host_pubkey); | 
| +JNIEXPORT void JNICALL JNI_IMPLEMENTATION(connectNative)( | 
| +    JNIEnv* env, | 
| +    jobject that, | 
| +    jstring username_jstr, | 
| +    jstring auth_token_jstr, | 
| +    jstring host_jid_jstr, | 
| +    jstring host_id_jstr, | 
| +    jstring host_pubkey_jstr) { | 
| +  const char* username_cstr = env->GetStringUTFChars(username_jstr, NULL); | 
| +  const char* auth_token_cstr = env->GetStringUTFChars(auth_token_jstr, NULL); | 
| +  const char* host_jid_cstr = env->GetStringUTFChars(host_jid_jstr, NULL); | 
| +  const char* host_id_cstr = env->GetStringUTFChars(host_id_jstr, NULL); | 
| +  const char* host_pubkey_cstr = env->GetStringUTFChars(host_pubkey_jstr, NULL); | 
| + | 
| +  remoting::ChromotingJNIInstance::GetInstance()->ConnectToHost( | 
| +      username_cstr, | 
| +      auth_token_cstr, | 
| +      host_jid_cstr, | 
| +      host_id_cstr, | 
| +      host_pubkey_cstr); | 
| + | 
| +  env->ReleaseStringUTFChars(username_jstr, username_cstr); | 
| +  env->ReleaseStringUTFChars(auth_token_jstr, auth_token_cstr); | 
| +  env->ReleaseStringUTFChars(host_jid_jstr, host_jid_cstr); | 
| +  env->ReleaseStringUTFChars(host_id_jstr, host_id_cstr); | 
| +  env->ReleaseStringUTFChars(host_pubkey_jstr, host_pubkey_cstr); | 
| } | 
|  | 
| JNIEXPORT void JNICALL JNI_IMPLEMENTATION(disconnectNative)(JNIEnv* env, | 
| @@ -79,10 +94,15 @@ JNIEXPORT void JNICALL JNI_IMPLEMENTATION(disconnectNative)(JNIEnv* env, | 
| remoting::ChromotingJNIInstance::GetInstance()->DisconnectFromHost(); | 
| } | 
|  | 
| -JNIEXPORT void JNICALL JNI_IMPLEMENTATION(authenticationResponse)(JNIEnv* env, | 
| -                                                                  jobject that, | 
| -                                                                  jstring pin) { | 
| -  remoting::ChromotingJNIInstance::GetInstance()->AuthenticateWithPin(pin); | 
| +JNIEXPORT void JNICALL JNI_IMPLEMENTATION(authenticationResponse)( | 
| +    JNIEnv* env, | 
| +    jobject that, | 
| +    jstring pin_jstr) { | 
| +  const char* pin_cstr = env->GetStringUTFChars(pin_jstr, NULL); | 
| + | 
| +  remoting::ChromotingJNIInstance::GetInstance()->ProvideSecret(pin_cstr); | 
| + | 
| +  env->ReleaseStringUTFChars(pin_jstr, pin_cstr); | 
| } | 
|  | 
| }  // extern "C" | 
|  |