diff options
-rw-r--r-- | base/process_util_unittest.cc | 12 | ||||
-rw-r--r-- | base/process_util_unittest_mac.h | 14 | ||||
-rw-r--r-- | base/process_util_unittest_mac.mm | 39 |
3 files changed, 49 insertions, 16 deletions
diff --git a/base/process_util_unittest.cc b/base/process_util_unittest.cc index 9c4aa5d..d58db37 100644 --- a/base/process_util_unittest.cc +++ b/base/process_util_unittest.cc @@ -630,7 +630,11 @@ TEST_F(OutOfMemoryTest, Posix_memalign) { #if defined(OS_MACOSX) // Since these allocation functions take a signed size, it's possible that -// calling them just once won't be enough to exhaust memory. +// calling them just once won't be enough to exhaust memory. In the 32-bit +// environment, it's likely that these allocation attempts will fail because +// not enough contiguous address space is availble. In the 64-bit environment, +// it's likely that they'll fail because they would require a preposterous +// amount of (virtual) memory. TEST_F(OutOfMemoryTest, CFAllocatorSystemDefault) { ASSERT_DEATH(while ((value_ = @@ -647,11 +651,17 @@ TEST_F(OutOfMemoryTest, CFAllocatorMallocZone) { base::AllocateViaCFAllocatorMallocZone(signed_test_size_))) {}, ""); } +#if !defined(ARCH_CPU_64_BITS) + +// See process_util_unittest_mac.mm for an explanation of why this test isn't +// run in the 64-bit environment. + TEST_F(OutOfMemoryTest, PsychoticallyBigObjCObject) { ASSERT_DEATH(while ((value_ = base::AllocatePsychoticallyBigObjCObject())) {}, ""); } +#endif // !ARCH_CPU_64_BITS #endif // OS_MACOSX #endif // !defined(OS_WIN) diff --git a/base/process_util_unittest_mac.h b/base/process_util_unittest_mac.h index 8402e85..7b4fe1c 100644 --- a/base/process_util_unittest_mac.h +++ b/base/process_util_unittest_mac.h @@ -14,13 +14,19 @@ namespace base { // Allocates memory via system allocators. Alas, they take a _signed_ size for // allocation. -void* AllocateViaCFAllocatorSystemDefault(int32 size); -void* AllocateViaCFAllocatorMalloc(int32 size); -void* AllocateViaCFAllocatorMallocZone(int32 size); +void* AllocateViaCFAllocatorSystemDefault(ssize_t size); +void* AllocateViaCFAllocatorMalloc(ssize_t size); +void* AllocateViaCFAllocatorMallocZone(ssize_t size); + +#if !defined(ARCH_CPU_64_BITS) +// See process_util_unittest_mac.mm for an explanation of why this function +// isn't implemented for the 64-bit environment. // Allocates a huge Objective C object. void* AllocatePsychoticallyBigObjCObject(); -} // namespace base +#endif // !ARCH_CPU_64_BITS + +} // namespace base #endif // BASE_PROCESS_UTIL_UNITTEST_MAC_H_ diff --git a/base/process_util_unittest_mac.mm b/base/process_util_unittest_mac.mm index 3cd7e16..2ef1868 100644 --- a/base/process_util_unittest_mac.mm +++ b/base/process_util_unittest_mac.mm @@ -4,13 +4,25 @@ #include "base/process_util_unittest_mac.h" -#import <Cocoa/Cocoa.h> +#import <Foundation/Foundation.h> +#include <CoreFoundation/CoreFoundation.h> + +#if !defined(ARCH_CPU_64_BITS) + +// In the 64-bit environment, the Objective-C 2.0 Runtime Reference states +// that sizeof(anInstance) is constrained to 32 bits. That's not necessarily +// "psychotically big" and in fact a 64-bit program is expected to be able to +// successfully allocate an object that large, likely reserving a good deal of +// swap space. The only way to test the behavior of memory exhaustion for +// Objective-C allocation in this environment would be to loop over allocation +// of these large objects, but that would slowly consume all available memory +// and cause swap file proliferation. That's bad, so this behavior isn't +// tested in the 64-bit environment. @interface PsychoticallyBigObjCObject : NSObject { - // On 32 bits, the compiler limits Objective C objects to < 2G in size, and on - // 64 bits, the ObjC2 Runtime Reference says that sizeof(anInstance) is - // constrained to 32 bits. Keep it < 2G for simplicity. + // In the 32-bit environment, the compiler limits Objective-C objects to + // < 2GB in size. int justUnder2Gigs_[(2U * 1024 * 1024 * 1024 - 1) / sizeof(int)]; } @@ -20,23 +32,28 @@ @end +namespace base { + +void* AllocatePsychoticallyBigObjCObject() { + return [[PsychoticallyBigObjCObject alloc] init]; +} + +} // namespace base + +#endif // ARCH_CPU_64_BITS namespace base { -void* AllocateViaCFAllocatorSystemDefault(int32 size) { +void* AllocateViaCFAllocatorSystemDefault(ssize_t size) { return CFAllocatorAllocate(kCFAllocatorSystemDefault, size, 0); } -void* AllocateViaCFAllocatorMalloc(int32 size) { +void* AllocateViaCFAllocatorMalloc(ssize_t size) { return CFAllocatorAllocate(kCFAllocatorMalloc, size, 0); } -void* AllocateViaCFAllocatorMallocZone(int32 size) { +void* AllocateViaCFAllocatorMallocZone(ssize_t size) { return CFAllocatorAllocate(kCFAllocatorMallocZone, size, 0); } -void* AllocatePsychoticallyBigObjCObject() { - return [[PsychoticallyBigObjCObject alloc] init]; -} - } // namespace base |