security goals re strcpy/strcat/sprintf (Re: "Secure coding" audit checkers and Kerberos)

Nicolas Williams Nicolas.Williams at sun.com
Wed Oct 15 23:04:46 EDT 2008


On Wed, Oct 15, 2008 at 09:58:00PM -0500, Nicolas Williams wrote:
> On Wed, Oct 15, 2008 at 08:06:32PM -0400, Tom Yu wrote:
> > Known issues with the printf family on Solaris include some
> > "interesting" interpretations of the precision field for %s
> > specifiers, such as counting "column width" rather than bytes.  This
> > can make dealing with gss_buffer_t and other such explicit-length
> > string-like data structures problematic, depending on the current
> > locale.  Nico or other Sun folks, any thoughts on this?
> 
> [...]
> 
> In other words, compile and link using the XPG4 or XPG6 options and
> you'll get the standard byte-counting, rather than column-counting
> behavior.
> 
> I'm not sure what this means for _libraries_, however.  I'm not sure
> whether libraries can have their own __xpg4 interposer that is local to
> their link map group.  I'll inquire and let you know.  Having this
> behavior selected by the application could certainly cause problems.

Sorry, I should have instantly known the answer.  No, the library cannot
differently interpose on libc's view of the __xpg4 symbol.  Therefore
the compilation/link options of the _application_ govern the
standards-compliance of *s*printf() with regards to string precision
(but not with regards to return value).

I'll file a bug about that too.  That behavor strikes me as not a good
idea given library use of these functions.

Nico
-- 



More information about the krbdev mailing list