OSDN Git Service

libitm: Add xcalloc.
authortorvald <torvald@138bc75d-0d04-0410-961f-82ee72b054a4>
Tue, 14 Feb 2012 13:13:56 +0000 (13:13 +0000)
committertorvald <torvald@138bc75d-0d04-0410-961f-82ee72b054a4>
Tue, 14 Feb 2012 13:13:56 +0000 (13:13 +0000)
libitm/
* util.cc (GTM::xcalloc): New.
* common.h (GTM::xcalloc): Declare.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@184210 138bc75d-0d04-0410-961f-82ee72b054a4

libitm/ChangeLog
libitm/common.h
libitm/util.cc

index decdad3..130c9ef 100644 (file)
@@ -1,3 +1,8 @@
+2012-02-14  Torvald Riegel  <triegel@redhat.com>
+
+       * util.cc (GTM::xcalloc): New.
+       * common.h (GTM::xcalloc): Declare.
+
 2012-02-14  Eric Botcazou  <ebotcazou@adacore.com>
 
        * config/sparc/target.h (cpu_relax): Read from CC register.
index 14d0efb..b1ef2d4 100644 (file)
@@ -54,6 +54,8 @@ namespace GTM HIDDEN {
 // cache lines that are not shared with any object used by another thread.
 extern void * xmalloc (size_t s, bool separate_cl = false)
   __attribute__((malloc, nothrow));
+extern void * xcalloc (size_t s, bool separate_cl = false)
+  __attribute__((malloc, nothrow));
 extern void * xrealloc (void *p, size_t s, bool separate_cl = false)
   __attribute__((malloc, nothrow));
 
index afd37e4..48a1bf8 100644 (file)
@@ -71,6 +71,18 @@ xmalloc (size_t size, bool separate_cl)
 }
 
 void *
+xcalloc (size_t size, bool separate_cl)
+{
+  // TODO Use posix_memalign if separate_cl is true, or some other allocation
+  // method that will avoid sharing cache lines with data used by other
+  // threads.
+  void *r = calloc (1, size);
+  if (r == 0)
+    GTM_fatal ("Out of memory allocating %lu bytes", (unsigned long) size);
+  return r;
+}
+
+void *
 xrealloc (void *old, size_t size, bool separate_cl)
 {
   // TODO Use posix_memalign if separate_cl is true, or some other allocation