sizeof(char*) has been used in an attempt to get string's length.

Program received signal SIGSEGV, Segmentation fault.
0x00007ffff5912dfa in _IO_vfprintf_internal (s=0x7fffffffdf60,
    format=<value optimized out>, ap=0x7fffffffe080) at vfprintf.c:1614
1614    vfprintf.c: No such file or directory.
        in vfprintf.c
(gdb) bt
#0  0x00007ffff5912dfa in _IO_vfprintf_internal (s=0x7fffffffdf60,
    format=<value optimized out>, ap=0x7fffffffe080) at vfprintf.c:1614
#1  0x00007ffff5932979 in __IO_vsprintf (string=0x7076c0 "/tmp/dtdbcache_",
    format=0x7ffff74a67e3 "%s/%s%s", args=0x7fffffffe080) at iovsprintf.c:43
#2  0x00007ffff5919a78 in __sprintf (
    s=0xffffe165 <Address 0xffffe165 out of bounds>,
    format=0x7ffff74a67e8 "%s") at sprintf.c:34
#3  0x00007ffff7484e6e in _DtDtsMMCacheName (override=<value optimized out>)
    at DtsMM.c:574
#4  0x00007ffff748512a in _DtDtsMMInit (override=0) at DtsMM.c:319
...

This fixes it:

diff --git a/cde/lib/DtSvc/DtUtil1/DtsMM.c b/cde/lib/DtSvc/DtUtil1/DtsMM.c
index dd82d6f..c7e7a63 100644
--- a/cde/lib/DtSvc/DtUtil1/DtsMM.c
+++ b/cde/lib/DtSvc/DtUtil1/DtsMM.c
@@ -566,12 +566,11 @@ _DtDtsMMCacheName(int override)
        /* are on different file systems.  Use tmpnam(3) to create the */
        /* unique file name instead. */
                char tmpnam_buf[L_tmpnam + 1];
+               size_t buflen = strlen(_DTDTSMMTEMPDIR) + 
strlen(_DTDTSMMTEMPFILE)
+ L_tmpnam + 3;

-               results = (char *)malloc(sizeof(_DTDTSMMTEMPDIR) +
-                                        sizeof(_DTDTSMMTEMPFILE) +
-                                        L_tmpnam + 3);
+               results = (char *)malloc(buflen);
                tmpnam(tmpnam_buf);
-               sprintf(results, "%s/%s%s", _DTDTSMMTEMPDIR, _DTDTSMMTEMPFILE,
+               snprintf(results, buflen, "%s/%s%s", _DTDTSMMTEMPDIR, 
_DTDTSMMTEMPFILE,
                        basename(tmpnam_buf));
        }
        return(results);

Attachment: cde-buffer_overflow-sizeof_instead_of_strlen.patch
Description: Binary data

------------------------------------------------------------------------------
Live Security Virtual Conference
Exclusive live event will cover all the ways today's security and 
threat landscape has changed and how IT managers can respond. Discussions 
will include endpoint security, mobile security and the latest in malware 
threats. http://www.accelacomm.com/jaw/sfrnl04242012/114/50122263/
_______________________________________________
cdesktopenv-devel mailing list
cdesktopenv-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/cdesktopenv-devel

Reply via email to