Sponsored Content
Top Forums Programming Why does this occur? *** glibc detected *** malloc(): memory corruption: 0x10013ff8 *** Post 302367056 by achenle on Saturday 31st of October 2009 08:04:51 PM
Old 10-31-2009
Quote:
Originally Posted by cdbug
Add return statement and change return type and it can work.

But it still fails after generating many vertices. Notice where failure occurs

This seems to be a general problem.

Thanks for all your help

____________________________________
Program received signal SIGSEGV, Segmentation fault.
0x0027ff92 in _int_malloc () from /lib/tls/libc.so.6
(gdb) bt
#0 0x0027ff92 in _int_malloc () from /lib/tls/libc.so.6
#1 0x0027f0fd in malloc () from /lib/tls/libc.so.6
#2 0x0804956e in make_vertex (ver=0xbfffb624, index=-1, se=0, ps=2)


Code:
vertex *root;
root = make_vertex(&root, -1, 0, -1);


static vertex* make_vertex(vertex **ver, int index, int s, int ps)
{
        ver = (vertex **)malloc(sizeof(vertex *)); //Here:fails
        if (ver == NULL)
            exit(1);

        *ver = (vertex *)malloc(sizeof(vertex));
        if ( *ver == NULL ) {
            printf("memory allocation error\n");
            exit(1);
        }

        (*ver)->id        = index;
        (*ver)->seq       = s;
        (*ver)->pos       = ps;
        (*ver)->clique    = 0;
        (*ver)->numOfPrev = 0;
        (*ver)->numOfVer  = 0;
        (*ver)->numOfNext = 0;
        (*ver)->prev      = NULL;
        (*ver)->next      = NULL;
        (*ver)->front     = NULL;
        (*ver)->back      = NULL;
        (*ver)->left      = NULL;
        (*ver)->right     = NULL;

    return *ver;
}



---------- Post updated at 12:37 PM ---------- Previous update was at 11:01 AM ----------

Tried to use make_vertex. It can change memory in this way. A new trouble takes place. Allocation really gives unexpected problems.

dataset[4] changes
__________________________________________________________________
110 r = make_vertex(&rho, -1, 0, i);
(gdb) p *(dataset+3)
$33 = 0x8145200 "AATTGTAAC"
(gdb) p *(dataset+4)
$34 = 0x8145a30 "GCTGAATGA"
(gdb) n
111 first = rho;
(gdb) p *(dataset+3)
$35 = 0x8145200 "AATTGTAAC"
(gdb) p *(dataset+4)
$36 = 0xb25a90 "\210Zē"
First, if you're going to overwrite the original contents of the pointer you pass it, why bother passing in its address in the first place?

Code:
static vertex* make_vertex( int index, int s, int ps )
{
    vertex *ver;
    ver = ( vertex * ) calloc( sizeof( vertex ) );
    if ( NULL != ver )
    {
        ver->id = index;
        ver->seq = s;
        ver->pos = ps;
    }
    return( ver );
}

If THAT blows up, your heap is getting corrupted before you even make the call to make_vertex().
 

10 More Discussions You Might Find Interesting

1. Programming

*** glibc detected *** double free or corruption: 0x40236ff4 ***

when i try to use the class i wrote, i either get this: *** glibc detected *** double free or corruption: 0x40236ff4 *** and the proccess exits with an error code of 0; or it segfaults. could someone look at my header file (with imp.) to give me some insight as to why its not working? ... (19 Replies)
Discussion started by: norsk hedensk
19 Replies

2. Programming

Pointer to a struct (with pointers) *** glibc detected *** double free

I am using a structure defined as follows struct gene_square { double *x; double *y; };I have class, with a member function which is a pointer of this type: gene_square* m_Genes;I am allocating memory in the constructors like this: m_Genes = new gene_square; for (ii=0;... (1 Reply)
Discussion started by: jatoo
1 Replies

3. Programming

solved: glibc detection corruption using a fork in popen

Hi, I am having a hell of a time getting this to work. So basically, I have opened a popen to run a program that is going to prompt an action to occur half way through, when it gets to this I need to create a separate process and do some stuff, then return to the original process. This works... (0 Replies)
Discussion started by: imrank27
0 Replies

4. Programming

./match_pattern.out: malloc(): memory corruption: 0x0000000013a11600 ***

Hi All, I have a simple code which does some computation by matching string patterns. In brief: 1. The code reads .dat and .txt files. 2. .dat files are huge text files and .txt files contain some important words. 3. I am just doing strstr to find the patterns. 4. The function returns the... (3 Replies)
Discussion started by: shoaibjameel123
3 Replies

5. Programming

*** glibc detected *** ./a.out: malloc(): memory corruption (fast):

*** glibc detected *** ./a.out: malloc(): memory corruption (fast): Posted A minute ago M trying to make multiway tree and dont know what happend when this part of code get executed: 01void ins(NODE *ptr) 02{ 03 //working 04 if(ptr!=NULL) 05 { 06 SNODE *var=NULL; 07 var=(SNODE... (3 Replies)
Discussion started by: exgenome
3 Replies

6. Programming

glib detected: malloc() memory curruption

I am using libxml2 library for XMl parsing and libxml++ is C++ wrapper over that. So I am using API of libxml++. I am creating my class and composing instance xmlpp::Node *pNode in that. my class also have funciton prepareXPathQuery() which creates query string and have other fucntion... (2 Replies)
Discussion started by: sharadwagh
2 Replies

7. Programming

*** glibc detected *** : malloc(): memory corruption (fast)

Hi Friends, while executing the below code, am getting *** glibc detected *** ./ok: malloc(): memory corruption (fast) error, please suggest how to solve this issue. #include <stdio.h> #include <string.h> #include <sqlca.h> #include <alloca.h> /* Define constants for VARCHAR... (2 Replies)
Discussion started by: mpjobsrch
2 Replies

8. Programming

*** glibc detected *** ./a.out malloc() memory corruption

I am facing a problem of memory corruption. The loop runs for the first time but does not go through the second time. What could be the problem? for(int z=0;z<2;z++) { fp=fopen("poly.dat","r"); /*do something which reads this file into a 2D array*/ fclose(fp); ... (10 Replies)
Discussion started by: dare
10 Replies

9. Programming

C++ glibc detected double free or corruption(!prev) using shared library

Currently I test a shared library vendor provided in linux , the following is the simple source : #include <iostream> using namespace std; extern int test1(); extern int test2(); int main() { cout << "hello world" << endl ; return 0 ; cout << "Test 1" << endl; ... (6 Replies)
Discussion started by: barfatchen
6 Replies

10. Homework & Coursework Questions

FORTRAN error *** glibc detected ***

Use and complete the template provided. The entire template must be completed. If you don't, your post may be deleted! 1. The problem statement, all variables and given/known data: I'm doing aproximation of derivative called five-point stencil. For every value of x, in interval , in step... (0 Replies)
Discussion started by: antonija
0 Replies
elf32_fsize(3ELF)					       ELF Library Functions						 elf32_fsize(3ELF)

NAME
elf32_fsize, elf64_fsize - return the size of an object file type SYNOPSIS
cc [ flag ... ] file ... -lelf [ library ... ] #include <libelf.h> size_t elf32_fsize(Elf_Type type, size_t count, unsigned ver); size_t elf64_fsize(Elf_Type type, size_t count, unsigned ver); DESCRIPTION
elf32_fsize() gives the size in bytes of the 32-bit file representation of count data objects with the given type. The library uses version ver to calculate the size. See elf(3ELF) and elf_version(3ELF). Constant values are available for the sizes of fundamental types: Elf_Type File Size Memory Size ELF_T_ADDR ELF32_FSZ_ADDR sizeof(Elf32_Addr) ELF_T_BYTE 1 sizeof(unsigned char) ELF_T_HALF ELF32_FSZ_HALF sizeof(Elf32_Half) ELT_T_OFF ELF32_FSZ_OFF sizeof(Elf32_Off) ELF_T_SWORD ELF32_FSZ_SWORD sizeof(Elf32_Sword) ELF_T_WORD ELF32_FSZ_WORD sizeof(Elf32_Word) elf32_fsize() returns 0 if the value of type or ver is unknown. See elf32_xlatetof(3ELF) for a list of the type values. For the 64-bit class, replace 32 with 64 as appropriate. ATTRIBUTES
See attributes(5) for descriptions of the following attributes: +-----------------------------+-----------------------------+ | ATTRIBUTE TYPE | ATTRIBUTE VALUE | +-----------------------------+-----------------------------+ |Interface Stability |Stable | +-----------------------------+-----------------------------+ |MT-Level |MT-Safe | +-----------------------------+-----------------------------+ SEE ALSO
elf(3ELF), elf32_xlatetof(3ELF), elf_version(3ELF), libelf(3LIB), attributes(5) SunOS 5.10 11 Jul 2001 elf32_fsize(3ELF)
All times are GMT -4. The time now is 08:50 AM.
Unix & Linux Forums Content Copyright 1993-2022. All Rights Reserved.
Privacy Policy