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

Side by Side Diff: runtime/bin/crypto_linux.cc

Issue 1781883002: Fixes some memory leaks in //runtime/bin (Closed) Base URL: git@github.com:dart-lang/sdk.git@master
Patch Set: Fix tests on Windows Created 4 years, 9 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 | « runtime/bin/crypto_android.cc ('k') | runtime/bin/crypto_macos.cc » ('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) 2012, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a 2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file. 3 // BSD-style license that can be found in the LICENSE file.
4 4
5 #include "platform/globals.h" 5 #include "platform/globals.h"
6 #if defined(TARGET_OS_LINUX) 6 #if defined(TARGET_OS_LINUX)
7 7
8 #include <errno.h> // NOLINT 8 #include <errno.h> // NOLINT
9 #include <fcntl.h> // NOLINT 9 #include <fcntl.h> // NOLINT
10 10
11 #include "bin/fdutils.h" 11 #include "bin/fdutils.h"
12 #include "bin/crypto.h" 12 #include "bin/crypto.h"
13 #include "platform/signal_blocker.h" 13 #include "platform/signal_blocker.h"
14 14
15
16 namespace dart { 15 namespace dart {
17 namespace bin { 16 namespace bin {
18 17
19 bool Crypto::GetRandomBytes(intptr_t count, uint8_t* buffer) { 18 bool Crypto::GetRandomBytes(intptr_t count, uint8_t* buffer) {
20 ThreadSignalBlocker signal_blocker(SIGPROF); 19 ThreadSignalBlocker signal_blocker(SIGPROF);
21 intptr_t fd = TEMP_FAILURE_RETRY_NO_SIGNAL_BLOCKER( 20 intptr_t fd = TEMP_FAILURE_RETRY_NO_SIGNAL_BLOCKER(
22 open("/dev/urandom", O_RDONLY)); 21 open("/dev/urandom", O_RDONLY));
23 if (fd < 0) return false; 22 if (fd < 0) {
23 return false;
24 }
24 intptr_t bytes_read = 0; 25 intptr_t bytes_read = 0;
25 do { 26 do {
26 int res = TEMP_FAILURE_RETRY_NO_SIGNAL_BLOCKER( 27 int res = TEMP_FAILURE_RETRY_NO_SIGNAL_BLOCKER(
27 read(fd, buffer + bytes_read, count - bytes_read)); 28 read(fd, buffer + bytes_read, count - bytes_read));
28 if (res < 0) { 29 if (res < 0) {
29 int err = errno; 30 int err = errno;
30 VOID_TEMP_FAILURE_RETRY_NO_SIGNAL_BLOCKER(close(fd)); 31 VOID_TEMP_FAILURE_RETRY_NO_SIGNAL_BLOCKER(close(fd));
31 errno = err; 32 errno = err;
32 return false; 33 return false;
33 } 34 }
34 bytes_read += res; 35 bytes_read += res;
35 } while (bytes_read < count); 36 } while (bytes_read < count);
36 VOID_TEMP_FAILURE_RETRY_NO_SIGNAL_BLOCKER(close(fd)); 37 VOID_TEMP_FAILURE_RETRY_NO_SIGNAL_BLOCKER(close(fd));
37 return true; 38 return true;
38 } 39 }
39 40
40 } // namespace bin 41 } // namespace bin
41 } // namespace dart 42 } // namespace dart
42 43
43 #endif // defined(TARGET_OS_LINUX) 44 #endif // defined(TARGET_OS_LINUX)
OLDNEW
« no previous file with comments | « runtime/bin/crypto_android.cc ('k') | runtime/bin/crypto_macos.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698