Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(52)

Side by Side Diff: base/crypto/rsa_private_key_mac.cc

Issue 259026: Implement signature_creator_mac (Closed)
Patch Set: cr change Created 11 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « base/crypto/cssm_init.cc ('k') | base/crypto/signature_creator.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2009 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 "base/crypto/rsa_private_key.h" 5 #include "base/crypto/rsa_private_key.h"
6 6
7 #include <list> 7 #include <list>
8 8
9 #include "base/crypto/cssm_init.h" 9 #include "base/crypto/cssm_init.h"
10 #include "base/logging.h" 10 #include "base/logging.h"
11 #include "base/scoped_ptr.h" 11 #include "base/scoped_ptr.h"
12 12
13 namespace { 13 namespace {
14 14
15 // ASN.1 encoding of the AlgorithmIdentifier from PKCS #8. 15 // ASN.1 encoding of the AlgorithmIdentifier from PKCS #8.
16 const uint8 kRsaAlgorithmIdentifier[] = { 16 const uint8 kRsaAlgorithmIdentifier[] = {
17 0x30, 0x0D, 0x06, 0x09, 0x2A, 0x86, 0x48, 0x86, 0xF7, 0x0D, 0x01, 0x01, 0x01, 17 0x30, 0x0D, 0x06, 0x09, 0x2A, 0x86, 0x48, 0x86, 0xF7, 0x0D, 0x01, 0x01, 0x01,
18 0x05, 0x00 18 0x05, 0x00
19 }; 19 };
20 20
21 // ASN.1 tags for some types we use. 21 // ASN.1 tags for some types we use.
22 const uint8 kSequenceTag = 0x30; 22 const uint8 kSequenceTag = 0x30;
23 const uint8 kIntegerTag = 0x02; 23 const uint8 kIntegerTag = 0x02;
24 const uint8 kNullTag = 0x05; 24 const uint8 kNullTag = 0x05;
25 const uint8 kOctetStringTag = 0x04; 25 const uint8 kOctetStringTag = 0x04;
26 const uint8 kBitStringTag = 0x03; 26 const uint8 kBitStringTag = 0x03;
27 27
28 // TODO(hawk): Move the App* functions into a shared location,
29 // perhaps cssm_init.cc.
30 void* AppMalloc(CSSM_SIZE size, void *alloc_ref) {
31 return malloc(size);
32 }
33
34 void AppFree(void* mem_ptr, void* alloc_ref) {
35 free(mem_ptr);
36 }
37
38 void* AppRealloc(void* ptr, CSSM_SIZE size, void* alloc_ref) {
39 return realloc(ptr, size);
40 }
41
42 void* AppCalloc(uint32 num, CSSM_SIZE size, void* alloc_ref) {
43 return calloc(num, size);
44 }
45
46 const CSSM_API_MEMORY_FUNCS mem_funcs = {
47 AppMalloc,
48 AppFree,
49 AppRealloc,
50 AppCalloc,
51 NULL
52 };
53
54 // Helper for error handling during key import. 28 // Helper for error handling during key import.
55 #define READ_ASSERT(truth) \ 29 #define READ_ASSERT(truth) \
56 if (!(truth)) { \ 30 if (!(truth)) { \
57 NOTREACHED(); \ 31 NOTREACHED(); \
58 return false; \ 32 return false; \
59 } 33 }
60 34
61 static void PrependBytesInOrder(uint8* val, int start, int num_bytes, 35 static void PrependBytesInOrder(uint8* val, int start, int num_bytes,
62 std::list<uint8>* data) { 36 std::list<uint8>* data) {
63 while(num_bytes > start) { 37 while(num_bytes > start) {
(...skipping 246 matching lines...) Expand 10 before | Expand all | Expand 10 after
310 return result.release(); 284 return result.release();
311 } 285 }
312 286
313 RSAPrivateKey::RSAPrivateKey() : csp_handle_(0) { 287 RSAPrivateKey::RSAPrivateKey() : csp_handle_(0) {
314 memset(&key_, 0, sizeof(key_)); 288 memset(&key_, 0, sizeof(key_));
315 289
316 EnsureCSSMInit(); 290 EnsureCSSMInit();
317 291
318 static CSSM_VERSION version = {2, 0}; 292 static CSSM_VERSION version = {2, 0};
319 CSSM_RETURN crtn; 293 CSSM_RETURN crtn;
320 crtn = CSSM_ModuleAttach(&gGuidAppleCSP, &version, &mem_funcs, 0, 294 crtn = CSSM_ModuleAttach(&gGuidAppleCSP, &version, &kCssmMemoryFunctions, 0,
321 CSSM_SERVICE_CSP, 0, CSSM_KEY_HIERARCHY_NONE, 295 CSSM_SERVICE_CSP, 0, CSSM_KEY_HIERARCHY_NONE,
322 NULL, 0, NULL, &csp_handle_); 296 NULL, 0, NULL, &csp_handle_);
323 DCHECK(crtn == CSSM_OK); 297 DCHECK(crtn == CSSM_OK);
324 } 298 }
325 299
326 RSAPrivateKey::~RSAPrivateKey() { 300 RSAPrivateKey::~RSAPrivateKey() {
327 if (csp_handle_) { 301 if (csp_handle_) {
328 if (key_.KeyData.Data) { 302 if (key_.KeyData.Data) {
329 CSSM_FreeKey(csp_handle_, NULL, &key_, CSSM_FALSE); 303 CSSM_FreeKey(csp_handle_, NULL, &key_, CSSM_FALSE);
330 } 304 }
(...skipping 58 matching lines...) Expand 10 before | Expand all | Expand 10 after
389 363
390 // Copy everything into the output. 364 // Copy everything into the output.
391 output->reserve(content.size()); 365 output->reserve(content.size());
392 for (std::list<uint8>::iterator i = content.begin(); i != content.end(); ++i) 366 for (std::list<uint8>::iterator i = content.begin(); i != content.end(); ++i)
393 output->push_back(*i); 367 output->push_back(*i);
394 368
395 return true; 369 return true;
396 } 370 }
397 371
398 } // namespace base 372 } // namespace base
OLDNEW
« no previous file with comments | « base/crypto/cssm_init.cc ('k') | base/crypto/signature_creator.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698