Re: strdup(NULL) supposed to create SIGSEGV?
On Tue, Apr 22, 2008 at 11:50 PM, Mike Meyer <mwm@mired.org> wrote:
> On Tue, 22 Apr 2008 22:40:21 -0700
> "Garrett Cooper" <yanefbsd@gmail.com> wrote:
>
> > Hi all,
> > I made an oops in a program, which uncovered "feature" in strdup(2)
> > that I wasn't aware of before. So I was wondering, is strdup(pointer =
> NULL)
> > supposed to segfault should this just return NULL and set errno?
>
> Yes, it's supposed to segfault. Check out what, say, strcpy does if
> you ask it to copy a NULL pointer. And this is an improvement from the
> bad old days, when they would happily walk through memory starting at
> 0.....
>
> Besides, errno is used to signal errors from system calls. strdup
> isn't a system call, it's a library function (says so at the top of
> the man page).
>
> > Good news is that Linux does the same thing (yay?), so at least
> FreeBSD
> > isn't alone..
>
> Do you have examples of systems where strdup doesn't behave this way?
>
> <mike
No, I don't, but then again I just noticed this.
-Garrett
_______________________________________________
freebsd-hackers@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/freebsd-hackers
To unsubscribe, send any mail to "freebsd-hackers-unsubscribe@freebsd.org"
討論串 (同標題文章)
完整討論串 (本文為第 6 之 25 篇):