OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "chromeos/tpm_token_loader.h" | 5 #include "chromeos/tpm_token_loader.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 | 8 |
9 #include "base/bind.h" | 9 #include "base/bind.h" |
10 #include "base/location.h" | 10 #include "base/location.h" |
(...skipping 166 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
177 NotifyTPMTokenReady(); | 177 NotifyTPMTokenReady(); |
178 return; | 178 return; |
179 } | 179 } |
180 case TPM_ENABLED: { | 180 case TPM_ENABLED: { |
181 DBusThreadManager::Get()->GetCryptohomeClient()->Pkcs11IsTpmTokenReady( | 181 DBusThreadManager::Get()->GetCryptohomeClient()->Pkcs11IsTpmTokenReady( |
182 base::Bind(&TPMTokenLoader::OnPkcs11IsTpmTokenReady, | 182 base::Bind(&TPMTokenLoader::OnPkcs11IsTpmTokenReady, |
183 weak_factory_.GetWeakPtr())); | 183 weak_factory_.GetWeakPtr())); |
184 return; | 184 return; |
185 } | 185 } |
186 case TPM_TOKEN_READY: { | 186 case TPM_TOKEN_READY: { |
187 // Retrieve token_name_ and user_pin_ here since they will never change | 187 // Retrieve user_pin_ here since they will never change |
188 // and CryptohomeClient calls are not thread safe. | 188 // and CryptohomeClient calls are not thread safe. |
189 DBusThreadManager::Get()->GetCryptohomeClient()->Pkcs11GetTpmTokenInfo( | 189 DBusThreadManager::Get()->GetCryptohomeClient()->Pkcs11GetTpmTokenInfo( |
190 base::Bind(&TPMTokenLoader::OnPkcs11GetTpmTokenInfo, | 190 base::Bind(&TPMTokenLoader::OnPkcs11GetTpmTokenInfo, |
191 weak_factory_.GetWeakPtr())); | 191 weak_factory_.GetWeakPtr())); |
192 return; | 192 return; |
193 } | 193 } |
194 case TPM_TOKEN_INFO_RECEIVED: { | 194 case TPM_TOKEN_INFO_RECEIVED: { |
195 crypto_task_runner_->PostTask( | 195 crypto_task_runner_->PostTask( |
196 FROM_HERE, | 196 FROM_HERE, |
197 base::Bind( | 197 base::Bind( |
(...skipping 58 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
256 const std::string& token_name, | 256 const std::string& token_name, |
257 const std::string& user_pin, | 257 const std::string& user_pin, |
258 int token_slot_id) { | 258 int token_slot_id) { |
259 VLOG(1) << "OnPkcs11GetTpmTokenInfo: " << token_name; | 259 VLOG(1) << "OnPkcs11GetTpmTokenInfo: " << token_name; |
260 | 260 |
261 if (call_status == DBUS_METHOD_CALL_FAILURE) { | 261 if (call_status == DBUS_METHOD_CALL_FAILURE) { |
262 RetryTokenInitializationLater(); | 262 RetryTokenInitializationLater(); |
263 return; | 263 return; |
264 } | 264 } |
265 | 265 |
266 tpm_token_name_ = token_name; | |
267 tpm_token_slot_id_ = token_slot_id; | 266 tpm_token_slot_id_ = token_slot_id; |
268 tpm_user_pin_ = user_pin; | 267 tpm_user_pin_ = user_pin; |
269 tpm_token_state_ = TPM_TOKEN_INFO_RECEIVED; | 268 tpm_token_state_ = TPM_TOKEN_INFO_RECEIVED; |
270 | 269 |
271 ContinueTokenInitialization(); | 270 ContinueTokenInitialization(); |
272 } | 271 } |
273 | 272 |
274 void TPMTokenLoader::OnTPMTokenInitialized(bool success) { | 273 void TPMTokenLoader::OnTPMTokenInitialized(bool success) { |
275 VLOG(1) << "OnTPMTokenInitialized: " << success; | 274 VLOG(1) << "OnTPMTokenInitialized: " << success; |
276 if (!success) { | 275 if (!success) { |
277 RetryTokenInitializationLater(); | 276 RetryTokenInitializationLater(); |
278 return; | 277 return; |
279 } | 278 } |
280 tpm_token_state_ = TPM_TOKEN_INITIALIZED; | 279 tpm_token_state_ = TPM_TOKEN_INITIALIZED; |
281 ContinueTokenInitialization(); | 280 ContinueTokenInitialization(); |
282 } | 281 } |
283 | 282 |
284 void TPMTokenLoader::NotifyTPMTokenReady() { | 283 void TPMTokenLoader::NotifyTPMTokenReady() { |
285 FOR_EACH_OBSERVER(Observer, observers_, OnTPMTokenReady()); | 284 FOR_EACH_OBSERVER(Observer, observers_, OnTPMTokenReady()); |
286 } | 285 } |
287 | 286 |
288 void TPMTokenLoader::LoggedInStateChanged() { | 287 void TPMTokenLoader::LoggedInStateChanged() { |
289 VLOG(1) << "LoggedInStateChanged"; | 288 VLOG(1) << "LoggedInStateChanged"; |
290 MaybeStartTokenInitialization(); | 289 MaybeStartTokenInitialization(); |
291 } | 290 } |
292 | 291 |
293 } // namespace chromeos | 292 } // namespace chromeos |
OLD | NEW |