[asterisk-bugs] [Asterisk 0012886]: crash asterisk.c compiled for i486sx with out fpu

noreply at bugs.digium.com noreply at bugs.digium.com
Wed Jun 18 19:10:53 CDT 2008


The following issue has been UPDATED. 
====================================================================== 
http://bugs.digium.com/view.php?id=12886 
====================================================================== 
Reported By:                tecnoxarxa
Assigned To:                
====================================================================== 
Project:                    Asterisk
Issue ID:                   12886
Category:                   General
Reproducibility:            always
Severity:                   crash
Priority:                   normal
Status:                     new
Asterisk Version:           1.4.21-rc1 
SVN Branch (only for SVN checkouts, not tarball releases): N/A 
SVN Revision (number only!):  
Disclaimer on File?:        N/A 
Request Review:              
====================================================================== 
Date Submitted:             06-18-2008 19:03 CDT
Last Modified:              06-18-2008 19:10 CDT
====================================================================== 
Summary:                    crash asterisk.c compiled for i486sx with out fpu
Description: 
Crash:

http://bugs.digium.com/view.php?id=0  0x08069847 in rdtsc () at asterisk.c:433
No locals.
http://bugs.digium.com/view.php?id=1  0x08069659 in ast_mark (i=0, startstop=1)
at asterisk.c:442
No locals.
http://bugs.digium.com/view.php?id=2  0x080b8a04 in extension_match_core
(pattern=0x817f4d8 "200",
data=0xb7c71bc4 "69", mode=E_MATCH) at pbx.c:878
        i = 135787688
        prof_id = 0



File: asterisk.c

---- Start Line 416 --------

#if defined ( __i386__) && (defined(__FreeBSD__) || defined(linux))
#if defined(__FreeBSD__)
#include <machine/cpufunc.h>
#elif defined(linux)
static __inline uint64_t
rdtsc(void)
{
        uint64_t rv;

        __asm __volatile(".byte 0x0f, 0x31" : "=A" (rv));
        return (rv);
}
#endif
#else   /* supply a dummy function on other platforms */
static __inline uint64_t
rdtsc(void)
{
        return 0;
}
#endif

int64_t ast_mark(int i, int startstop)
{
        if (!prof_data || i < 0 || i > prof_data->entries) /* invalid
index */
                return 0;
        if (startstop == 1)
                prof_data->e[i].mark = rdtsc();
        else {
                prof_data->e[i].mark = (rdtsc() - prof_data->e[i].mark);
                if (prof_data->e[i].scale > 1)
                        prof_data->e[i].mark /= prof_data->e[i].scale;
                prof_data->e[i].value += prof_data->e[i].mark;
                prof_data->e[i].events++;
        }
        return prof_data->e[i].mark;
}

---- end ----
====================================================================== 

---------------------------------------------------------------------- 
 Corydon76 - 06-18-08 19:10  
---------------------------------------------------------------------- 
Please do NOT place patches in the Additional Information field.  Instead,
all patches must be uploaded as files, with a license submitted for the
file contribution. 

Issue History 
Date Modified   Username       Field                    Change               
====================================================================== 
06-18-08 19:10  Corydon76      Note Added: 0088893                          
06-18-08 19:10  Corydon76      Additional Information Updated                   

======================================================================




More information about the asterisk-bugs mailing list