Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include "ios/chrome/browser/memory/memory_wedge.h" | |
| 6 | |
| 7 #include <stdlib.h> | |
| 8 | |
| 9 #include "base/logging.h" | |
| 10 | |
| 11 namespace { | |
|
Alexei Svitkine (slow)
2015/04/28 16:52:58
Nit: Add an empty line after and before the closin
lpromero
2015/04/28 18:12:46
Done.
| |
| 12 // Reference to the memory wedge. It is useful to: | |
| 13 // - make sure the compiler optimizations in Release don't skip |memset| and | |
| 14 // really end up putting the wedge in resident memory; | |
| 15 // - free it in tests. | |
| 16 static void* gMemoryWedge; | |
| 17 | |
| 18 // The number of bytes in a megabyte. | |
| 19 const size_t kNumBytesInMB = 1024 * 1024; | |
| 20 } // namespace | |
| 21 | |
| 22 namespace memory_wedge { | |
| 23 | |
| 24 void AddWedge(unsigned wedge_size_in_mb) { | |
| 25 DCHECK(!gMemoryWedge); | |
| 26 if (wedge_size_in_mb == 0) { | |
|
Alexei Svitkine (slow)
2015/04/28 16:52:58
Nit: No {}'s
lpromero
2015/04/28 18:12:46
Done.
| |
| 27 return; | |
| 28 } | |
| 29 | |
| 30 // Allocate a wedge and write to it to have it in resident memory. | |
| 31 const size_t wedge_size = wedge_size_in_mb * kNumBytesInMB; | |
| 32 gMemoryWedge = malloc(wedge_size); | |
| 33 memset(gMemoryWedge, -1, wedge_size); | |
| 34 } | |
| 35 | |
| 36 void RemoveWedge() { | |
| 37 DCHECK(gMemoryWedge); | |
| 38 free(gMemoryWedge); | |
| 39 gMemoryWedge = nullptr; | |
| 40 } | |
| 41 | |
| 42 } // namespace memory_wedge | |
| OLD | NEW |