2 .\" Copyright (c) 1992, X/Open Company Limited. All Rights Reserved. Portions Copyright (c) 2003, Sun Microsystems, Inc. All Rights Reserved.
3 .\" Sun Microsystems, Inc. gratefully acknowledges The Open Group for permission to reproduce portions of its copyrighted documentation. Original documentation from The Open Group can be obtained online at
4 .\" http://www.opengroup.org/bookstore/.
5 .\" The Institute of Electrical and Electronics Engineers and The Open Group, have given us permission to reprint portions of their documentation. In the following statement, the phrase "this text" refers to portions of the system documentation. Portions of this text are reprinted and reproduced in electronic form in the Sun OS Reference Manual, from IEEE Std 1003.1, 2004 Edition, Standard for Information Technology -- Portable Operating System Interface (POSIX), The Open Group Base Specifications Issue 6, Copyright (C) 2001-2004 by the Institute of Electrical and Electronics Engineers, Inc and The Open Group. In the event of any discrepancy between these versions and the original IEEE and The Open Group Standard, the original IEEE and The Open Group Standard is the referee document. The original Standard can be obtained online at http://www.opengroup.org/unix/online.html.
6 .\" This notice shall appear on any product containing this material.
7 .\" The contents of this file are subject to the terms of the Common Development and Distribution License (the "License"). You may not use this file except in compliance with the License.
8 .\" You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE or http://www.opensolaris.org/os/licensing. See the License for the specific language governing permissions and limitations under the License.
9 .\" When distributing Covered Code, include this CDDL HEADER in each file and include the License file at usr/src/OPENSOLARIS.LICENSE. If applicable, add the following below this CDDL HEADER, with the fields enclosed by brackets "[]" replaced with your own identifying information: Portions Copyright [yyyy] [name of copyright owner]
10 .TH CONFSTR 3C "Dec 15, 2003"
12 confstr \- get configurable variables
18 \fBsize_t\fR \fBconfstr\fR(\fBint\fR \fIname\fR, \fBchar *\fR\fIbuf\fR, \fBsize_t\fR \fIlen\fR);
24 The \fBconfstr()\fR function provides a method for applications to get
25 configuration-defined string values. Its use and purpose are similar to the
26 \fBsysconf\fR(3C) function, but it is used where string values rather than
27 numeric values are returned.
30 The \fIname\fR argument represents the system variable to be queried.
33 If \fIlen\fR is not \fB0\fR, and if \fIname\fR has a configuration-defined
34 value, \fBconfstr()\fR copies that value into the \fIlen\fR-byte buffer
35 pointed to by \fIbuf\fR. If the string to be returned is longer than \fIlen\fR
36 bytes, including the terminating null, then \fBconfstr()\fR truncates the
37 string to \fIlen\fR\(mi1 bytes and null-terminates the result. The application
38 can detect that the string was truncated by comparing the value returned by
39 \fBconfstr()\fR with \fIlen\fR.
42 If \fIlen\fR is \fB0\fR, \fBconfstr()\fR still returns the integer value as
43 defined below, but does not return the string.
46 The \fBconfstr()\fR function supports the following values for \fIname\fR,
47 defined in \fB<unistd.h>\fR, for both SPARC and x86:
51 \fB\fB_CS_LFS64_CFLAGS\fR\fR
55 If \fB_LFS64_LARGEFILE\fR is defined in \fB<unistd.h>\fR, this value is the set
56 of initial options to be given to the \fBcc\fR and \fBc89\fR utilities to build
57 an application using the Large File Summit transitional compilation environment
58 (see \fBlfcompile64\fR(5)).
64 \fB\fB_CS_LFS64_LDFLAGS\fR\fR
68 If \fB_LFS64_LARGEFILE\fR is defined in \fB<unistd.h>\fR, this value is the set
69 of final options to be given to the \fBcc\fR and \fBc89\fR utilities to build
70 an application using the Large File Summit transitional compilation environment
71 (see \fBlfcompile64\fR(5)).
77 \fB\fB_CS_LFS64_LIBS\fR\fR
81 If \fB_LFS64_LARGEFILE\fR is defined in \fB<unistd.h>\fR, this value is the set
82 of libraries to be given to the \fBcc\fR and \fBc89\fR utilities to build an
83 application using the Large File Summit transitional compilation environment
84 (see \fBlfcompile64\fR(5)).
90 \fB\fB_CS_LFS64_LINTFLAGS\fR\fR
94 If \fB_LFS64_LARGEFILE\fR is defined in \fB<unistd.h>\fR, this value is the set
95 of options to be given to the \fBlint\fR utility to check application source
96 using the Large File Summit transitional compilation environment (see
97 \fBlfcompile64\fR(5)).
103 \fB\fB_CS_LFS_CFLAGS\fR\fR
107 If \fB_LFS_LARGEFILE\fR is defined in \fB<unistd.h>\fR, this value is the set
108 of initial options to be given to the \fBcc\fR and \fBc89\fR utilities to build
109 an application using the Large File Summit large file compilation environment
110 for 32-bit applications (see \fBlfcompile\fR(5)).
116 \fB\fB_CS_LFS_LDFLAGS\fR\fR
120 If \fB_LFS_LARGEFILE\fR is defined in \fB<unistd.h>\fR, this value is the set
121 of final options to be given to the \fBcc\fR and \fBc89\fR utilities to build
122 an application using the Large File Summit large file compilation environment
123 for 32-bit applications (see \fBlfcompile\fR(5)).
129 \fB\fB_CS_LFS_LIBS\fR\fR
133 If \fB_LFS_LARGEFILE\fR is defined in \fB<unistd.h>\fR, this value is the set
134 of libraries to be given to the \fBcc\fR and \fBc89\fR utilities to build an
135 application using the Large File Summit large file compilation environment for
136 32-bit applications (see \fBlfcompile\fR(5)).
142 \fB\fB_CS_LFS_LINTFLAGS\fR\fR
146 If \fB_LFS_LARGEFILE\fR is defined in \fB<unistd.h>\fR, this value is the set
147 of options to be given to the \fBlint\fR utility to check application source
148 using the Large File Summit large file compilation environment for 32-bit
149 applications (see \fBlfcompile\fR(5)).
159 If the ISO POSIX.2 standard is supported, this is the value for the \fBPATH\fR
160 environment variable that finds all standard utilities. Otherwise the meaning
161 of this value is unspecified.
167 \fB\fB_CS_POSIX_V6_ILP32_OFF32_CFLAGS\fR\fR
171 If \fBsysconf\fR(\fB_SC_V6_ILP32_OFF32\fR) returns -1, the meaning of this
172 value is unspecified. Otherwise, this value is the set of initial options to
173 be given to the \fBc99\fR utility to build an application using a programming
174 model with 32-bit \fBint\fR, \fBlong\fR, \fBpointer\fR, and \fBoff_t\fR types.
180 \fB\fB_CS_POSIX_V6_ILP32_OFF32_LDFLAGS\fR\fR
184 If \fBsysconf\fR(\fB_SC_V6_ILP32_OFF32\fR) returns -1, the meaning of this
185 value is unspecified. Otherwise, this value is the set of final options to be
186 given to the \fBc99\fR utility to build an application using a programming
187 model with 32-bit \fBint\fR, \fBlong\fR, \fBpointer\fR, and \fBoff_t\fR types.
193 \fB\fB_CS_POSIX_V6_ILP32_OFF32_LIBS\fR\fR
197 If \fBsysconf\fR(\fB_SC_V6_ILP32_OFF32\fR) returns -1, the meaning of this
198 value is unspecified. Otherwise, this value is the set of libraries to be given
199 to the \fBc99\fR utility to build an application using a programming model with
200 32-bit \fBint\fR, \fBlong\fR, \fBpointer\fR, and \fBoff_t\fR types.
206 \fB\fB_CS_POSIX_V6_ILP32_OFFBIG_CFLAGS\fR\fR
210 If \fBsysconf\fR(\fB_SC_V6_ILP32_OFFBIG\fR) returns -1, the meaning of this
211 value is unspecified. Otherwise, this value is the set of initial options to be
212 given to the \fBc99\fR utility to build an application using a programming
213 model with 32-bit \fBint\fR, \fBlong\fR, and \fBpointer\fR types, and an
214 \fBoff_t\fR type using at least 64 bits.
220 \fB\fB_CS_POSIX_V6_ILP32_OFFBIG_LDFLAGS\fR\fR
224 If \fBsysconf\fR(\fB_SC_V6_ILP32_OFFBIG\fR) returns -1, the meaning of this
225 value is unspecified. Otherwise, this value is the set of final options to be
226 given to the \fBc99\fR utility to build an application using a programming
227 model with 32-bit \fBint\fR, \fBlong\fR, and \fBpointer\fR types, and an
228 \fBoff_t\fR type using at least 64 bits.
234 \fB\fB_CS_POSIX_V6_ILP32_OFFBIG_LIBS\fR\fR
238 If \fBsysconf\fR(\fB_SC_V6_ILP32_OFFBIG\fR) returns -1, the meaning of this
239 value is unspecified. Otherwise, this value is the set of libraries to be given
240 to the \fBc99\fR utility to build an application using a programming model with
241 32-bit \fBint\fR, \fBlong\fR, and \fBpointer\fR types, and an \fBoff_t\fR type
242 using at least 64 bits.
248 \fB\fB_CS_POSIX_V6_LP64_OFF64_CFLAGS\fR\fR
252 If \fBsysconf\fR(\fB_SC_V6_LP64_OFF64\fR) returns -1, the meaning of this value
253 is unspecified. Otherwise, this value is the set of initial options to be given
254 to the \fBc99\fR utility to build an application using a programming model with
255 64-bit \fBint\fR, \fBlong\fR, \fBpointer\fR, and \fBoff_t\fR types.
261 \fB\fB_CS_POSIX_V6_LP64_OFF64_LDFLAGS\fR\fR
265 If \fBsysconf\fR(\fB_SC_V6_LP64_OFF64\fR) returns -1, the meaning of this value
266 is unspecified. Otherwise, this value is the set of final options to be given
267 to the \fBc99\fR utility to build an application using a programming model with
268 64-bit \fBint\fR, \fBlong\fR, \fBpointer\fR, and \fBoff_t\fR types.
274 \fB\fB_CS_POSIX_V6_LP64_OFF64_LIBS\fR\fR
278 If \fBsysconf\fR(\fB_SC_V6_LP64_OFF64\fR) returns -1, the meaning of this value
279 is unspecified. Otherwise, this value is the set of libraries to be given to
280 the \fBc99\fR utility to build an application using a programming model with
281 64-bit \fBint\fR, \fBlong\fR, \fBpointer\fR, and \fBoff_t\fR types.
287 \fB\fB_CS_POSIX_V6_LPBIG_OFFBIG_CFLAGS\fR\fR
291 If \fBsysconf\fR(\fB_SC_V6_LPBIG_OFFBIG\fR) returns -1, the meaning of this
292 value is unspecified. Otherwise, this value is the set of initial options to be
293 given to the \fBc99\fR utility to build an application using a programming
294 model with an \fBint\fR type using at least 32 bits and \fBlong\fR,
295 \fBpointer\fR, and \fBoff_t\fR types using at least 64 bits.
301 \fB\fB_CS_POSIX_V6_LPBIG_OFFBIG_LDFLAGS\fR\fR
305 If \fBsysconf\fR(\fB_SC_V6_LPBIG_OFFBIG\fR) returns -1, the meaning of this
306 value is unspecified. Otherwise, this value is the set of final options to be
307 given to the \fBc99\fR utility to build an application using a programming
308 model with an \fBint\fR type using at least 32 bits and \fBlong\fR,
309 \fBpointer\fR, and \fBoff_t\fR types using at least 64 bits.
315 \fB\fB_CS_POSIX_V6_LPBIG_OFFBIG_LIBS\fR\fR
319 If \fBsysconf\fR(\fB_SC_V6_LPBIG_OFFBIG\fR) returns -1, the meaning of this
320 value is unspecified. Otherwise, this value is the set of libraries to be given
321 to the \fBc99\fR utility to build an application using a programming model with
322 an \fBint\fR type using at least 32 bits and \fBlong\fR, \fBpointer\fR, and
323 \fBoff_t\fR types using at least 64 bits.
329 \fB\fB_CS_POSIX_V6_WIDTH_RESTRICTED_ENVS\fR\fR
333 This value is a <newline>-separated list of names of programming environments
334 supported by the implementation in which the widths of the \fBblksize_t\fR,
335 \fBcc_t\fR, \fBmode_t\fR, \fBnfds_t\fR, \fBpid_t\fR, \fBptrdiff_t\fR,
336 \fBsize_t\fR, \fBspeed_t\fR, \fBssize_t\fR, \fBsuseconds_t\fR, \fBtcflag_t\fR,
337 \fBuseconds_t\fR, \fBwchar_t\fR, and \fBwint_t\fR types are no greater than the
338 width of type \fBlong\fR.
344 \fB\fB_CS_XBS5_ILP32_OFF32_CFLAGS\fR\fR
348 If \fBsysconf(_SC_XBS5_ILP32_OFF32)\fR returns \(mi1 the meaning of this value
349 is unspecified. Otherwise, this value is the set of initial options to be
350 given to the \fBcc\fR and \fBc89\fR utilities to build an application using a
351 programming model with 32-bit \fBint\fR, \fBlong\fR, \fBpointer\fR, and
358 \fB\fB_CS_XBS5_ILP32_OFF32_LDFLAGS\fR\fR
362 If \fBsysconf(_SC_XBS5_ILP32_OFF32)\fR returns \(mi1 the meaning of this value
363 is unspecified. Otherwise, this value is the set of final options to be given
364 to the \fBcc\fR and \fBc89\fR utilities to build an application using a
365 programming model with 32-bit \fBint\fR, \fBlong\fR, \fBpointer\fR, and
372 \fB\fB_CS_XBS5_ILP32_OFF32_LIBS\fR\fR
376 If \fBsysconf(_SC_XBS5_ILP32_OFF32)\fR returns \(mi1 the meaning of this value
377 is unspecified. Otherwise, this value is the set of libraries to be given to
378 the \fBcc\fR and \fBc89\fR utilities to build an application using a
379 programming model with 32-bit \fBint\fR, \fBlong\fR, \fBpointer\fR, and
386 \fB\fB_CS_XBS5_ILP32_OFF32_LINTFLAGS\fR\fR
390 If \fBsysconf(_SC_XBS5_ILP32_OFF32)\fR returns \(mi1 the meaning of this value
391 is unspecified. Otherwise, this value is the set of options to be given to the
392 \fBlint\fR utility to check application source using a programming model with
393 32-bit \fBint\fR, \fBlong\fR, \fBpointer\fR, and \fBoff_t\fR types.
399 \fB\fB_CS_XBS5_ILP32_OFFBIG_CFLAGS\fR\fR
403 If \fBsysconf(_SC_XBS5_ILP32_OFFBIG)\fR returns \(mi1 the meaning of this value
404 is unspecified. Otherwise, this value is the set of initial options to be
405 given to the \fBcc\fR and \fBc89\fR utilities to build an application using a
406 programming model with 32-bit \fBint\fR, \fBlong\fR, and \fBpointer\fR types,
407 and an \fBoff_t\fR type using at least 64 bits.
413 \fB\fB_CS_XBS5_ILP32_OFFBIG_LDFLAGS\fR\fR
417 If \fBsysconf(SC_XBS5_ILP32_OFFBIG)\fR returns \(mi1 the meaning of this value
418 is unspecified. Otherwise, this value is the set of final options to be given
419 to the \fBcc\fR and \fBc89\fR utilities to build an application using a
420 programming model with 32-bit \fBint\fR, \fBlong\fR, and \fBpointer\fR types,
421 and an \fBoff_t\fR type using at least 64 bits.
427 \fB\fB_CS_XBS5_ILP32_OFFBIG_LIBS\fR\fR
431 If \fBsysconf(_SC_XBS5_ILP32_OFFBIG)\fR returns \(mi1 the meaning of this value
432 is unspecified. Otherwise, this value is the set of libraries to be given to
433 the \fBcc\fR and \fBc89\fR utilities to build an application using a
434 programming model with 32-bit \fBint\fR, \fBlong\fR, and \fBpointer\fR types,
435 and an \fBoff_t\fR type using at least 64 bits.
441 \fB\fB_CS_XBS5_ILP32_OFFBIG_LINTFLAGS\fR\fR
445 If \fBsysconf(_SC_XBS5_ILP32_OFFBIG)\fR returns \(mi1 the meaning of this value
446 is unspecified. Otherwise, this value is the set of options to be given to the
447 \fBlint\fR utility to check an application using a programming model with
448 32-bit \fBint\fR, \fBlong\fR, and \fBpointer\fR types, and an \fBoff_t\fR type
449 using at least 64 bits.
454 The \fBconfstr()\fR function supports the following values for \fIname\fR,
455 defined in \fB<unistd.h>\fR, for SPARC only:
459 \fB\fB_CS_XBS5_LP64_OFF64_CFLAGS\fR\fR
463 If \fBsysconf(_SC_XBS5_LP64_OFF64)\fR returns \(mi1 the meaning of this value
464 is unspecified. Otherwise, this value is the set of initial options to be
465 given to the \fBcc\fR and \fBc89\fR utilities to build an application using a
466 programming model with 64-bit \fBint\fR, \fBlong\fR, \fBpointer\fR, and
473 \fB\fB_CS_XBS5_LP64_OFF64_LDFLAGS\fR\fR
477 If \fBsysconf(_SC_XBS5_LP64_OFF64)\fR returns \(mi1 the meaning of this value
478 is unspecified. Otherwise, this value is the set of final options to be given
479 to the \fBcc\fR and \fBc89\fR utilities to build an application using a
480 programming model with 64-bit \fBint\fR, \fBlong\fR, \fBpointer\fR, and
487 \fB\fB_CS_XBS5_LP64_OFF64_LIBS\fR\fR
491 If \fBsysconf(_SC_XBS5_LP64_OFF64)\fR returns \(mi1 the meaning of this value
492 is unspecified. Otherwise, this value is the set of libraries to be given to
493 the \fBcc\fR and \fBc89\fR utilities to build an application using a
494 programming model with 64-bit \fBint\fR, \fBlong\fR, \fBpointer\fR, and
501 \fB\fB_CS_XBS5_LP64_OFF64_LINTFLAGS\fR\fR
505 If \fBsysconf(_SC_XBS5_LP64_OFF64)\fR returns \(mi1 the meaning of this value
506 is unspecified. Otherwise, this value is the set of options to be given to the
507 \fBlint\fR utility to check application source using a programming model with
508 64-bit \fBint\fR, \fBlong\fR, \fBpointer\fR, and \fBoff_t\fR types.
514 \fB\fB_CS_XBS5_LPBIG_OFFBIG_CFLAGS\fR\fR
518 If \fBsysconf(_SC_XBS5_LPBIG_OFFBIG)\fR returns \(mi1 the meaning of this value
519 is unspecified. Otherwise, this value is the set of initial options to be
520 given to the \fBcc\fR and \fBc89\fR utilities to build an application using a
521 programming model with an \fBint\fR type using at least 32 bits and \fBlong\fR,
522 \fBpointer\fR, and \fBoff_t\fR types using at least 64 bits.
528 \fB\fB_CS_XBS5_LPBIG_OFFBIG_LDFLAGS\fR\fR
532 If \fBsysconf(_SC_XBS5_LPBIG_OFFBIG)\fR returns \(mi1 the meaning of this value
533 is unspecified. Otherwise, this value is the set of final options to be given
534 to the \fBcc\fR and \fBc89\fR utilities to build an application using a
535 programming model with an \fBint\fR type using at least 32 bits and \fBlong\fR,
536 \fBpointer\fR, and \fBoff_t\fR types using at least 64 bits.
542 \fB\fB_CS_XBS5_LPBIG_OFFBIG_LIBS\fR\fR
546 If \fBsysconf(_SC_XBS5_LPBIG_OFFBIG)\fR returns \(mi1 the meaning of this value
547 is unspecified. Otherwise, this value is the set of libraries to be given to
548 the \fBcc\fR and \fBc89\fR utilities to build an application using a
549 programming model with an \fBint\fR type using at least 32 bits and \fBlong\fR,
550 \fBpointer\fR, and \fBoff_t\fR types using at least 64 bits.
556 \fB\fB_CS_XBS5_LPBIG_OFFBIG_LINTFLAGS\fR\fR
560 If \fBsysconf(_SC_XBS5_LPBIG_OFFBIG)\fR returns \(mi1 the meaning of this value
561 is unspecified. Otherwise, this value is the set of options to be given to the
562 \fBlint\fR utility to check application source using a programming model with
563 an \fBint\fR type using at least 32 bits and \fBlong\fR, \fBpointer\fR, and
564 \fBoff_t\fR types using at least 64 bits.
570 If \fIname\fR has a configuration-defined value, the \fBconfstr()\fR function
571 returns the size of buffer that would be needed to hold the entire
572 configuration-defined value. If this return value is greater than \fIlen\fR,
573 the string returned in \fIbuf\fR is truncated.
576 If \fIname\fR is invalid, \fBconfstr()\fR returns \fB0\fR and sets \fBerrno\fR
577 to indicate the error.
580 If \fIname\fR does not have a configuration-defined value, \fBconfstr()\fR
581 returns \fB0\fR and leaves \fBerrno\fR unchanged.
585 The \fBconfstr()\fR function will fail if:
592 The value of the \fIname\fR argument is invalid.
598 See \fBattributes\fR(5) for descriptions of the following attributes:
606 ATTRIBUTE TYPE ATTRIBUTE VALUE
608 Interface Stability Standard
616 \fBpathconf\fR(2), \fBsysconf\fR(3C), \fBattributes\fR(5), \fBlfcompile\fR(5),
617 \fBlfcompile64\fR(5), \fBstandards\fR(5)