realloc fails in C : what next ?


 
Thread Tools Search this Thread
Top Forums Programming realloc fails in C : what next ?
# 1  
Old 09-28-2010
realloc fails in C : what next ?

Hi all

I'm trying to use someone else's software, which has a realloc that fails in it. This is probably due to memory limitations, as it only happens when I use this software on huge datasets.

First question : how to diagnose if it's a soft or hard limitation? I mean, if it's due to my computer's memory limits, or to some limits the compiler / my C implementation imposes?
I'm running Mandriva Linux, 64 bit, with 4Gb RAM and 6GB swap, I don't think I'm reaching those limits.
The same failure happens on our computer cluster, which has about 60Gb of RAM ...

I used the makefile that came with the software, which adds these options to the gcc command :
CFLAGS = -O4 -funroll-loops -fomit-frame-pointer -finline-functions

More questions might follow depending on the answer, but the obvious question is : how to get around this limit ?
# 2  
Old 09-28-2010
Well, you can check that the system isn't artificially imposing a limit on you by running `ulimit -m' which will tell you the maximum number of kB of memory the OS will allocate to you. If that reports anything other than "unlimited" you can increase the limit with `ulimit -m unlimited', but you need to be root to do this.

Other than that, you could always get realloc() to print the size of the memory it failed to move, to make sure you're not trying to move 2 GB of data or something ridiculous.
# 3  
Old 09-28-2010
Code:
[jos@faba ~]$ ulimit -m
unlimited

But you're right, the program is trying to do something ridiculous :

Code:
   k = com.npatt*com.ncatG*sizeof(double);
   if((com.fhK=(double*)realloc(com.fhK,k)) == NULL) 
    {
    printf("%d\n",k);
    error2("oom fhK");
}

Upon execution, the reported value for k is -169522176.

Thanks a lot for your suggestion, I hadn't thought about that !

jos
# 4  
Old 09-28-2010
Quote:
Originally Posted by jossojjos
I used the makefile that came with the software, which adds these options to the gcc command :
CFLAGS = -O4 -funroll-loops -fomit-frame-pointer -finline-functions
As an aside, whoever wrote the makefile was trying to be really aggressive with the optimizations. Perhaps they were using bad algorithms to start with, and thought to speed things up by cranking up the compiler optimizations. At any rate, these optimizing switches sometimes do, but sometimes don't, speed up execution time. Only a careful analysis (profiling) can provide the answer. At any rate, GCC offers up to -O3. -O4 is not an option, to my knowledge.
# 5  
Old 09-28-2010
Thanks for pointing that out, kermit !
I'll keep that in mind for the next time I analyze large datasets.

jos
# 6  
Old 09-28-2010
The omit-frame-pointer and inline-functions are enabled by default if using -O3 optimization - so this is all that is required
Code:
CFLAGS = -O3 -funroll-loops

# 7  
Old 09-28-2010
...and funroll-loops isn't often helpful.

If you're still debugging you should have -O0 and -ggdb. No optimizations and debugging support.
Login or Register to Ask a Question

Previous Thread | Next Thread

10 More Discussions You Might Find Interesting

1. Programming

problem with realloc( i think is gcc :/ )

Hi everyone, i made this program. is a simple one for practising malloc, realloc and structs. I have a struct named shop as global variable in which i take the size of the matrix from the keyboard and after i malloc it. I insert the values with the fullarray() and after i print the matrix with... (7 Replies)
Discussion started by: giampoul
7 Replies

2. UNIX for Dummies Questions & Answers

about realloc routing

#include <malloc.h> #include <stdio.h> #include <stdlib.h> #include <unistd.h> int* allocat_array(void) { int *array; int tmp; int n_values = 0 ; array = malloc(sizeof(int)); if(array == NULL) return NULL; while(scanf("%d",&tmp) != EOF) { ... (1 Reply)
Discussion started by: vincent__tse
1 Replies

3. Programming

realloc() fails

Not sure in which forum to post this. I'm trying here, in Programming. I'm working on a PC with Intel Duo processor & 2GB of ram. OS is Ubuntu 10.04. I'm having problems with a C++ program that makes extensive use of realloc(). It happens that as soon as the overall memory allocated(OS +... (14 Replies)
Discussion started by: mamboknave
14 Replies

4. Programming

Realloc() question

b = realloc(a, 1000); if realloc succeeds and b!=a (not in-place replacement), does realloc automatically free a or I should free both a and b afterwards? thank you! (5 Replies)
Discussion started by: bashuser2
5 Replies

5. Programming

What happens when realloc() fails?

Hi, I am seeing varying results about, when realloc() fails in reallocation. Which one is correct out of the below? a) realloc() maintains the original pointer (i.e) the original pointer is left unaltered/untouched but relloc() returns the NULL value. b) original buffer pointer is lost... (3 Replies)
Discussion started by: royalibrahim
3 Replies

6. Programming

malloc vs realloc

Why when using realloc, john is reversed 3 times but not the other 2 names ? But if I use malloc, then the 3 names are reversed correctly ? (but then there is a memory leak) How can I reverse all 3 names without a memory leak ? char *BUFFER = NULL; char *STRREVERSE(const char *STRING) {... (5 Replies)
Discussion started by: cyler
5 Replies

7. Programming

tolower (static pointer + malloc + realloc)

N00B here. This function would be easier using a char pointer along with free. But I wish to learn how to use char static pointers (they do not require free, right ?). How do I erase the content of a static pointer ? Terminating the string works but the static pointer's content is not being... (4 Replies)
Discussion started by: limmer
4 Replies

8. Programming

help with realloc() on Linux

hi, I'm using gcc version 3.4.6 on a Red Hat system... (not sure how to determine version of glibc) when i run the following, i get: glibc detected *** realloc(): invalid next size: 0x0804a170 I'm not sure what is wrong. The error happens on the second iteration of the while loop.... (3 Replies)
Discussion started by: Andrewkl
3 Replies

9. Programming

Does realloc free fairly?

Hello, my program works properly but valgrind tells me I am not freeing allocated memory. I think the problem is in realloc. I am pretty sure I do something wrong with realloc, because I changed it a bit and valgrind noticed less errors (that the program wasn't working properly with less errors... (3 Replies)
Discussion started by: samciz
3 Replies

10. Programming

Realloc

Can Any body give me a exampla which has the usage of realloc i want a function which uses realloc & increases /decreases the size of a pointer (0 Replies)
Discussion started by: wojtyla
0 Replies
Login or Register to Ask a Question