Confused by segfault with legitimate call to strerror(3) on amd64 / sysctl (3) setting `odd' errno's

Danny Braniss danny at cs.huji.ac.il
Fri Jan 16 03:33:42 PST 2009


> Garrett Cooper schrieb:
> >     Ok, I just installworld'ed, recompiled the program with the
> > following modifications, and I still get segfaults. And the question
> > of the night is: why amd64 on a VERY recent CURRENT?
> >     I'm going to try the same app on an amd64 freebsd VMware instance
> > with RELENG_7.
> >     Remember: just because a bunch of other people aren't reporting
> > issues with CURRENT/amd64 doesn't mean that it isn't environmental,
> > related to my hardware or compile options ;).
> > Cheers,
> > -Garrett
> > 
> > #include <errno.h>
> > #include <stdio.h>
> > #include <sys/stat.h>
> > 
> > int
> > main()
> > {
> > 
> >         struct stat sb;
> > 
> >         int o_errno;
> > 
> >         if (stat("/some/file/that/doesn't/exist", &sb) != 0) {
> >                 o_errno = errno;
> >                 printf("Errno: %d\n", errno);
> >                 printf("%s\n", strerror(o_errno));
> >         }
> > 
> >         return 0;
> > 
> > }
> > 
> > #include <errno.h>
> > #include <stdio.h>
> > #include <sys/stat.h>
> > 
> > int
> > main()
> > {
> > 
> >         struct stat sb;
> > 
> >         int o_errno;
> > 
> >         if (stat("/some/file/that/doesn't/exist", &sb) != 0) {
> >                 o_errno = errno;
> >                 printf("Errno: %d\n", errno);
> >                 printf("%s\n", strerror(o_errno));
> >         }
> > 
> >         return 0;
> > 
> > }
> > 
> > [gcooper at optimus ~]$ gcc -o badfile badfile.c
> > [gcooper at optimus ~]$ ./badfile
> > Errno: 2
> > Segmentation fault: 11 (core dumped)
> > [gcooper at optimus ~]$
> 
> Well, compile with -g, start in gdb, check what value is wrong, the 
> usual stuff. Probably the return value of strerror() is interesting.

some facts:
#include <stdio.h>
int
main()
{
     printf("%s\n", strerror(2));
     return 0;
}

	1- it works fine on i386
	2- it bombs on amd64
	3- with a local strerror.c (instead of the one in libc)
	   works fine
so, there is something realy wrong going on here!
(and it gows back to at least 7.0-stable)

danny




More information about the freebsd-hackers mailing list