/* * Copyright (c) 2013-2014 by Farsight Security, Inc. * * Permission is hereby granted, free of charge, to any person obtaining * a copy of this software and associated documentation files (the * "Software"), to deal in the Software without restriction, including * without limitation the rights to use, copy, modify, merge, publish, * distribute, sublicense, and/or sell copies of the Software, and to * permit persons to whom the Software is furnished to do so, subject to * the following conditions: * * The above copyright notice and this permission notice shall be included * in all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. * */ /*! \file * \mainpage Introduction * * This is `fstrm`, a C implementation of the Frame Streams data transport * protocol. * * Frame Streams is a light weight, binary clean protocol that allows for the * transport of arbitrarily encoded data payload sequences with minimal framing * overhead -- just four bytes per data frame. Frame Streams does not specify an * encoding format for data frames and can be used with any data serialization * format that produces byte sequences, such as [Protocol Buffers], [XML], * [JSON], [MessagePack], [YAML], etc. Frame Streams can be used as both a * streaming transport over a reliable byte stream socket (TCP sockets, TLS * connections, `AF_UNIX` sockets, etc.) for data in motion as well as a file * format for data at rest. A "Content Type" header identifies the type of * payload being carried over an individual Frame Stream and allows cooperating * programs to determine how to interpret a given sequence of data payloads. * * `fstrm` is an optimized C implementation of Frame Streams that includes a * fast, lockless circular queue implementation and exposes library interfaces * for setting up a dedicated Frame Streams I/O thread and asynchronously * submitting data frames for transport from worker threads. It was originally * written to facilitate the addition of high speed binary logging to DNS * servers written in C using the [dnstap] log format. * * This is the API documentation for the `fstrm` library. For the project * hosting site, see <https://github.com/farsightsec/fstrm>. * * \authors Farsight Security, Inc. and the `fstrm` authors. * * \copyright 2013-2018. Licensed under the terms of the [MIT] license. * * [Protocol Buffers]: https://developers.google.com/protocol-buffers/ * [XML]: http://www.w3.org/TR/xml11/ * [JSON]: http://www.json.org/ * [MessagePack]: http://msgpack.org/ * [YAML]: http://www.yaml.org/ * [dnstap]: http://dnstap.info/ * [MIT]: https://opensource.org/licenses/MIT * * \page overview Library overview * * \section init Initializing the library * * `fstrm` has no global library state. In most cases, only a single * \ref fstrm_iothr library context object will be needed for the entire process, * which will implicitly create a background I/O serialization thread. This I/O * thread is bound to a particular output writer (for example, an `AF_UNIX` * socket) and is fully buffered -- submitted data frames will be accumulated in * an output buffer and periodically flushed, minimizing the number of system * calls that need to be performed. This frees worker threads from waiting for a * write() to complete. * * `fstrm` abstracts the actual I/O operations needed to read or write a byte * stream. File and socket I/O implementations are included in the library, but * if necessary `fstrm` can be extended to support new types of byte stream * transports. See the \ref fstrm_reader, \ref fstrm_writer, and \ref fstrm_rdwr * interfaces for details. * * The following code example shows the initialization of an `fstrm_iothr` * library context object connected to an \ref fstrm_file writer. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ const char *file_path = "/tmp/output.fs"; struct fstrm_file_options *fopt; struct fstrm_iothr *iothr; struct fstrm_writer *writer; fopt = fstrm_file_options_init(); fstrm_file_options_set_file_path(fopt, file_path); writer = fstrm_file_writer_init(fopt, NULL); if (!writer) { fprintf(stderr, "Error: fstrm_file_writer_init() failed.\n"); exit(EXIT_FAILURE); } iothr = fstrm_iothr_init(NULL, &writer); if (!iothr) { fprintf(stderr, "Error: fstrm_iothr_init() failed.\n"); exit(EXIT_FAILURE); } fstrm_file_options_destroy(&fopt); ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * * Since the I/O operations are abstracted through the `fstrm_writer` interface, * the `writer` variable in the above example could instead have been * initialized with a completely different implementation. For example, * \ref fstrm_unix_writer objects can be initialized as follows: ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ const char *socket_path = "/tmp/output.sock"; struct fstrm_writer *writer; struct fstrm_unix_writer_options *uwopt; uwopt = fstrm_unix_writer_options_init(); fstrm_unix_writer_options_set_socket_path(uwopt, socket_path); writer = fstrm_unix_writer_init(uwopt, NULL); if (!writer) { fprintf(stderr, "Error: fstrm_unix_writer_init() failed.\n"); exit(EXIT_FAILURE); } ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * * \section queue Getting an input queue * * After the `fstrm_iothr` object has been created with fstrm_iothr_init(), an * input queue handle can be obtained with the fstrm_iothr_get_input_queue() * function, which returns an `fstrm_iothr_queue` object. This function is * thread-safe and returns a unique queue each time it is called, up to the * number of queues specified by fstrm_iothr_options_set_num_input_queues(). * `fstrm_iothr_queue` objects belong to their parent `fstrm_iothr` object and * will be destroyed when the parent `fstrm_iothr` object is destroyed. * * The following code example shows a single `fstrm_iothr_queue` handle being * obtained from an already initialized `fstrm_iothr` library context object. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ // 'iothr' is a struct fstrm_iothr * struct fstrm_iothr_queue *ioq; ioq = fstrm_iothr_get_input_queue(iothr); if (!ioq) { fprintf(stderr, "Error: fstrm_iothr_get_input_queue() failed.\n"); exit(EXIT_FAILURE); } ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * * \section submit Submitting data frames * * Once the `fstrm_iothr` object has been created and an `fstrm_iothr_queue` * handle is available, data frames can be submitted for asynchronous writing * using the fstrm_iothr_submit() function. A callback is passed to this * function which will be invoked to deallocate the data frame once the I/O * thread has completed processing it. In the common case where the data frame * is dynamically allocated with `malloc()`, the deallocation callback must call * `free()`. fstrm_free_wrapper() is provided as a convenience function which * does this and can be specified as the `free_func` parameter to * fstrm_iothr_submit(). * * If space is available in the queue, fstrm_iothr_submit() will return * #fstrm_res_success, indicating that ownership of the memory allocation for the * data frame has passed from the caller to the library. The caller must not * reuse or deallocate the memory for the data frame after a successful call to * fstrm_iothr_submit(). * * Callers must check the return value of fstrm_iothr_submit(). If this function * fails, that is, it returns any result code other than #fstrm_res_success, the * caller must deallocate or otherwise dispose of memory allocated for the data * frame, in order to avoid leaking memory. fstrm_iothr_submit() can fail with * #fstrm_res_again if there is currently no space in the circular queue for an * additional frame, in which case a later call to fstrm_iothr_submit() with the * same parameters may succeed. However, if fstrm_iothr_submit() fails with * #fstrm_res_invalid, then there is a problem with the parameters and a later * call will not succeed. * * The following code example shows data frames containing a short sequence of * bytes being created and submitted repeatedly, with appropriate error * handling. Note that the data frames in this example intentionally contain * embedded unprintable characters, showing that Frame Streams is binary clean. * This example follows from the previous examples, where the `iothr` and `ioq` * variables have already been initialized. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ // 'iothr' is a struct fstrm_iothr * // 'ioq' is a struct fstrm_queue * const unsigned num_frames = 100; const uint8_t frame_template[] = { 'H', 'e', 'l', 'l', 'o', 0x00, 0x01, 0x02, 0x03, 'W', 'o', 'r', 'l', 'd', 0x04, 0x05, 0x06, 0x07, }; for (unsigned i = 0; i < num_frames; i++) { // Allocate a new frame from the template. uint8_t *frame = malloc(sizeof(frame_template)); if (!frame) break; memcpy(frame, frame_template, sizeof(frame_template)); // Submit the frame for writing. for (;;) { fstrm_res res; res = fstrm_iothr_submit(iothr, ioq, frame, sizeof(frame_template), fstrm_free_wrapper, NULL); if (res == fstrm_res_success) { // Frame successfully queued. break; } else if (res == fstrm_res_again) { // Queue is full. Try again in a busy loop. // Alternatively, if loss can be tolerated we // could free the frame here and break out of // the loop. continue; } else { // Permanent failure. free(frame); fputs("fstrm_iothr_submit() failed.\n", stderr); break; } } } ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * * \section shutdown Shutting down * * Calling fstrm_iothr_destroy() on the `fstrm_iothr` object will signal the I/O * thread to flush any outstanding data frames being written and will deallocate * all associated resources. This function is synchronous and does not return * until the I/O thread has terminated. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ // 'iothr' is a struct fstrm_iothr * fstrm_iothr_destroy(&iothr); ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ */ #ifndef FSTRM_H #define FSTRM_H #ifdef __cplusplus extern "C" { #endif #include <sys/uio.h> #include <stddef.h> #include <stdint.h> /** * \defgroup fstrm_res fstrm_res * * Library result codes. * @{ */ /** * Result codes for functions. */ typedef enum { /** Success. */ fstrm_res_success, /** Failure. */ fstrm_res_failure, /** Resource temporarily unavailable. */ fstrm_res_again, /** Parameters were invalid. */ fstrm_res_invalid, /** The end of a stream has been reached. */ fstrm_res_stop, } fstrm_res; /**@}*/ struct fstrm_control; struct fstrm_file_options; struct fstrm_iothr; struct fstrm_iothr_options; struct fstrm_iothr_queue; struct fstrm_rdwr; struct fstrm_reader_options; struct fstrm_unix_writer_options; struct fstrm_writer; struct fstrm_writer_options; #include <fstrm/control.h> #include <fstrm/file.h> #include <fstrm/iothr.h> #include <fstrm/rdwr.h> #include <fstrm/reader.h> #include <fstrm/tcp_writer.h> #include <fstrm/unix_writer.h> #include <fstrm/writer.h> #ifdef __cplusplus } #endif #endif /* FSTRM_H */
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
GL | Folder | 0755 |
|
|
X11 | Folder | 0755 |
|
|
apache2 | Folder | 0755 |
|
|
arpa | Folder | 0755 |
|
|
asm | Folder | 0755 |
|
|
asm-generic | Folder | 0755 |
|
|
bind9 | Folder | 0755 |
|
|
bits | Folder | 0755 |
|
|
bsock | Folder | 0755 |
|
|
c++ | Folder | 0755 |
|
|
criu | Folder | 0755 |
|
|
curl | Folder | 0755 |
|
|
drm | Folder | 0755 |
|
|
e2p | Folder | 0755 |
|
|
et | Folder | 0755 |
|
|
event2 | Folder | 0755 |
|
|
ext2fs | Folder | 0755 |
|
|
finclude | Folder | 0755 |
|
|
fontconfig | Folder | 0755 |
|
|
freetype2 | Folder | 0755 |
|
|
fstrm | Folder | 0755 |
|
|
gdb | Folder | 0755 |
|
|
gdbm | Folder | 0755 |
|
|
gnu | Folder | 0755 |
|
|
Folder | 0755 |
|
||
gssapi | Folder | 0755 |
|
|
gssrpc | Folder | 0755 |
|
|
json-c | Folder | 0755 |
|
|
kadm5 | Folder | 0755 |
|
|
krb5 | Folder | 0755 |
|
|
libdb | Folder | 0755 |
|
|
libexslt | Folder | 0755 |
|
|
libltdl | Folder | 0755 |
|
|
libpng16 | Folder | 0755 |
|
|
libxml2 | Folder | 0755 |
|
|
libxslt | Folder | 0755 |
|
|
linux | Folder | 0755 |
|
|
lua-5.1 | Folder | 0755 |
|
|
lzma | Folder | 0755 |
|
|
misc | Folder | 0755 |
|
|
mtd | Folder | 0755 |
|
|
mysql | Folder | 0755 |
|
|
ncurses | Folder | 0755 |
|
|
ncursesw | Folder | 0755 |
|
|
net | Folder | 0755 |
|
|
netash | Folder | 0755 |
|
|
netatalk | Folder | 0755 |
|
|
netax25 | Folder | 0755 |
|
|
neteconet | Folder | 0755 |
|
|
netinet | Folder | 0755 |
|
|
netipx | Folder | 0755 |
|
|
netiucv | Folder | 0755 |
|
|
netpacket | Folder | 0755 |
|
|
netrom | Folder | 0755 |
|
|
netrose | Folder | 0755 |
|
|
nfs | Folder | 0755 |
|
|
openssl | Folder | 0755 |
|
|
perf | Folder | 0755 |
|
|
protobuf-c | Folder | 0755 |
|
|
protocols | Folder | 0755 |
|
|
python2.7 | Folder | 0755 |
|
|
python3.6m | Folder | 0755 |
|
|
python3.8 | Folder | 0755 |
|
|
rdma | Folder | 0755 |
|
|
rpc | Folder | 0755 |
|
|
sasl | Folder | 0755 |
|
|
scsi | Folder | 0755 |
|
|
security | Folder | 0755 |
|
|
selinux | Folder | 0755 |
|
|
sepol | Folder | 0755 |
|
|
sound | Folder | 0755 |
|
|
sys | Folder | 0755 |
|
|
uuid | Folder | 0755 |
|
|
video | Folder | 0755 |
|
|
webp | Folder | 0755 |
|
|
xcb | Folder | 0755 |
|
|
xen | Folder | 0755 |
|
|
FlexLexer.h | File | 6.73 KB | 0644 |
|
a.out.h | File | 4.25 KB | 0644 |
|
aio.h | File | 7.28 KB | 0644 |
|
aliases.h | File | 1.98 KB | 0644 |
|
alloca.h | File | 1.17 KB | 0644 |
|
ar.h | File | 1.69 KB | 0644 |
|
argp.h | File | 24.82 KB | 0644 |
|
argz.h | File | 5.91 KB | 0644 |
|
assert.h | File | 4.45 KB | 0644 |
|
autosprintf.h | File | 2.33 KB | 0644 |
|
byteswap.h | File | 1.37 KB | 0644 |
|
bzlib.h | File | 6.1 KB | 0644 |
|
com_err.h | File | 2.07 KB | 0644 |
|
complex.h | File | 7 KB | 0644 |
|
cpio.h | File | 2.21 KB | 0644 |
|
cpuidle.h | File | 844 B | 0644 |
|
crypt.h | File | 8.9 KB | 0644 |
|
ctype.h | File | 10.71 KB | 0644 |
|
curses.h | File | 97.29 KB | 0644 |
|
cursesapp.h | File | 6.62 KB | 0644 |
|
cursesf.h | File | 27.2 KB | 0644 |
|
cursesm.h | File | 19.22 KB | 0644 |
|
cursesp.h | File | 8.4 KB | 0644 |
|
cursesw.h | File | 48.55 KB | 0644 |
|
cursslk.h | File | 7.13 KB | 0644 |
|
db.h | File | 120.22 KB | 0444 |
|
db_185.h | File | 5.84 KB | 0444 |
|
dbm.h | File | 1.38 KB | 0644 |
|
dirent.h | File | 12.19 KB | 0644 |
|
dlfcn.h | File | 7.07 KB | 0644 |
|
elf.h | File | 170.73 KB | 0644 |
|
endian.h | File | 3.11 KB | 0644 |
|
entities.h | File | 4.81 KB | 0644 |
|
envz.h | File | 2.8 KB | 0644 |
|
err.h | File | 2.16 KB | 0644 |
|
errno.h | File | 1.64 KB | 0644 |
|
error.h | File | 1.99 KB | 0644 |
|
eti.h | File | 2.82 KB | 0644 |
|
etip.h | File | 9.47 KB | 0644 |
|
evdns.h | File | 1.97 KB | 0644 |
|
event.h | File | 2.68 KB | 0644 |
|
evhttp.h | File | 1.99 KB | 0644 |
|
evrpc.h | File | 1.97 KB | 0644 |
|
evutil.h | File | 1.74 KB | 0644 |
|
execinfo.h | File | 1.49 KB | 0644 |
|
expat.h | File | 42.66 KB | 0644 |
|
expat_config.h | File | 3.43 KB | 0644 |
|
expat_external.h | File | 5.4 KB | 0644 |
|
fcntl.h | File | 10.7 KB | 0644 |
|
features.h | File | 15.69 KB | 0644 |
|
fenv.h | File | 5.72 KB | 0644 |
|
fmtmsg.h | File | 3.16 KB | 0644 |
|
fnmatch.h | File | 2.24 KB | 0644 |
|
form.h | File | 18.17 KB | 0644 |
|
fpu_control.h | File | 3.5 KB | 0644 |
|
fstab.h | File | 3.04 KB | 0644 |
|
fstrm.h | File | 12.71 KB | 0644 |
|
fts.h | File | 8.18 KB | 0644 |
|
ftw.h | File | 5.13 KB | 0644 |
|
gconv.h | File | 4.31 KB | 0644 |
|
gcrypt.h | File | 68.71 KB | 0644 |
|
gd.h | File | 56.42 KB | 0644 |
|
gd_color_map.h | File | 478 B | 0644 |
|
gd_errors.h | File | 1.47 KB | 0644 |
|
gd_io.h | File | 3.05 KB | 0644 |
|
gdbm.h | File | 10.1 KB | 0644 |
|
gdcache.h | File | 2.83 KB | 0644 |
|
gdfontg.h | File | 553 B | 0644 |
|
gdfontl.h | File | 551 B | 0644 |
|
gdfontmb.h | File | 519 B | 0644 |
|
gdfonts.h | File | 515 B | 0644 |
|
gdfontt.h | File | 546 B | 0644 |
|
gdfx.h | File | 497 B | 0644 |
|
gdpp.h | File | 50.94 KB | 0644 |
|
getopt.h | File | 1.43 KB | 0644 |
|
gettext-po.h | File | 15.17 KB | 0644 |
|
glob.h | File | 6.46 KB | 0644 |
|
gnu-versions.h | File | 2.29 KB | 0644 |
|
gnumake.h | File | 2.84 KB | 0644 |
|
gpg-error.h | File | 66.29 KB | 0644 |
|
gpgrt.h | File | 66.29 KB | 0644 |
|
grp.h | File | 6.53 KB | 0644 |
|
gshadow.h | File | 4.42 KB | 0644 |
|
gssapi.h | File | 181 B | 0644 |
|
iconv.h | File | 1.81 KB | 0644 |
|
idn-free.h | File | 2.41 KB | 0644 |
|
idn-int.h | File | 20 B | 0644 |
|
idna.h | File | 3.48 KB | 0644 |
|
ieee754.h | File | 4.79 KB | 0644 |
|
ifaddrs.h | File | 2.77 KB | 0644 |
|
inttypes.h | File | 11.61 KB | 0644 |
|
jconfig-64.h | File | 2.17 KB | 0644 |
|
jconfig.h | File | 246 B | 0644 |
|
jerror.h | File | 14.73 KB | 0644 |
|
jmorecfg.h | File | 14.7 KB | 0644 |
|
jpegint.h | File | 15.22 KB | 0644 |
|
jpeglib.h | File | 48.71 KB | 0644 |
|
kdb.h | File | 67.66 KB | 0644 |
|
keyutils.h | File | 7.52 KB | 0644 |
|
krad.h | File | 8.72 KB | 0644 |
|
krb5.h | File | 402 B | 0644 |
|
langinfo.h | File | 17.43 KB | 0644 |
|
lastlog.h | File | 126 B | 0644 |
|
lber.h | File | 14.95 KB | 0644 |
|
lber_types.h | File | 1.43 KB | 0644 |
|
ldap.h | File | 63.57 KB | 0644 |
|
ldap_cdefs.h | File | 9.24 KB | 0644 |
|
ldap_features.h | File | 1.77 KB | 0644 |
|
ldap_schema.h | File | 9.23 KB | 0644 |
|
ldap_utf8.h | File | 3.39 KB | 0644 |
|
ldif.h | File | 4.58 KB | 0644 |
|
libaio.h | File | 8.73 KB | 0644 |
|
libgen.h | File | 1.35 KB | 0644 |
|
libintl.h | File | 4.47 KB | 0644 |
|
limits.h | File | 5.29 KB | 0644 |
|
link.h | File | 7.05 KB | 0644 |
|
locale.h | File | 7.49 KB | 0644 |
|
ltdl.h | File | 5.58 KB | 0644 |
|
lzma.h | File | 9.59 KB | 0644 |
|
magic.h | File | 5.46 KB | 0644 |
|
malloc.h | File | 5.96 KB | 0644 |
|
math.h | File | 52.07 KB | 0644 |
|
mcheck.h | File | 2.38 KB | 0644 |
|
memory.h | File | 955 B | 0644 |
|
menu.h | File | 11.91 KB | 0644 |
|
mntent.h | File | 3.28 KB | 0644 |
|
monetary.h | File | 1.76 KB | 0644 |
|
mqueue.h | File | 3.67 KB | 0644 |
|
nc_tparm.h | File | 4.1 KB | 0644 |
|
ncurses.h | File | 97.29 KB | 0644 |
|
ncurses_dll.h | File | 4.18 KB | 0644 |
|
ndbm.h | File | 2.4 KB | 0644 |
|
netdb.h | File | 27.44 KB | 0644 |
|
nl_types.h | File | 1.71 KB | 0644 |
|
nss.h | File | 1.83 KB | 0644 |
|
obstack.h | File | 20.81 KB | 0644 |
|
panel.h | File | 4.03 KB | 0644 |
|
paths.h | File | 2.91 KB | 0644 |
|
pcre.h | File | 30.97 KB | 0644 |
|
pcre2.h | File | 43.75 KB | 0644 |
|
pcre2posix.h | File | 5.67 KB | 0644 |
|
pcre_scanner.h | File | 6.45 KB | 0644 |
|
pcre_stringpiece.h | File | 6.16 KB | 0644 |
|
pcrecpp.h | File | 25.91 KB | 0644 |
|
pcrecpparg.h | File | 6.62 KB | 0644 |
|
pcreposix.h | File | 5.32 KB | 0644 |
|
png.h | File | 140.77 KB | 0644 |
|
pngconf.h | File | 22.31 KB | 0644 |
|
pnglibconf.h | File | 7.39 KB | 0644 |
|
poll.h | File | 22 B | 0644 |
|
pr29.h | File | 2.07 KB | 0644 |
|
printf.h | File | 6.64 KB | 0644 |
|
proc_service.h | File | 3.39 KB | 0644 |
|
profile.h | File | 11.87 KB | 0644 |
|
pthread.h | File | 40.3 KB | 0644 |
|
pty.h | File | 1.53 KB | 0644 |
|
punycode.h | File | 9.16 KB | 0644 |
|
pwd.h | File | 6.01 KB | 0644 |
|
re_comp.h | File | 962 B | 0644 |
|
regex.h | File | 24.14 KB | 0644 |
|
regexp.h | File | 1.41 KB | 0644 |
|
resolv.h | File | 11.79 KB | 0644 |
|
sched.h | File | 4.62 KB | 0644 |
|
search.h | File | 5.1 KB | 0644 |
|
semaphore.h | File | 2.34 KB | 0644 |
|
setjmp.h | File | 3.58 KB | 0644 |
|
sgtty.h | File | 1.31 KB | 0644 |
|
shadow.h | File | 5.34 KB | 0644 |
|
signal.h | File | 11.96 KB | 0644 |
|
slapi-plugin.h | File | 37.45 KB | 0644 |
|
spawn.h | File | 6.53 KB | 0644 |
|
stab.h | File | 264 B | 0644 |
|
stdc-predef.h | File | 2.24 KB | 0644 |
|
stdint.h | File | 8.27 KB | 0644 |
|
stdio.h | File | 29.46 KB | 0644 |
|
stdio_ext.h | File | 2.73 KB | 0644 |
|
stdlib.h | File | 34.82 KB | 0644 |
|
string.h | File | 17.17 KB | 0644 |
|
stringprep.h | File | 8.03 KB | 0644 |
|
strings.h | File | 4.64 KB | 0644 |
|
syscall.h | File | 25 B | 0644 |
|
sysexits.h | File | 5.11 KB | 0644 |
|
syslog.h | File | 24 B | 0644 |
|
tar.h | File | 3.7 KB | 0644 |
|
term.h | File | 40.22 KB | 0644 |
|
term_entry.h | File | 8.55 KB | 0644 |
|
termcap.h | File | 3.39 KB | 0644 |
|
termio.h | File | 214 B | 0644 |
|
termios.h | File | 3.51 KB | 0644 |
|
tgmath.h | File | 30.75 KB | 0644 |
|
thread_db.h | File | 15.65 KB | 0644 |
|
threads.h | File | 6.5 KB | 0644 |
|
tic.h | File | 13.32 KB | 0644 |
|
tiff.h | File | 35.14 KB | 0644 |
|
tiffconf-64.h | File | 3.35 KB | 0644 |
|
tiffconf.h | File | 250 B | 0644 |
|
tiffio.h | File | 22.68 KB | 0644 |
|
tiffio.hxx | File | 1.66 KB | 0644 |
|
tiffvers.h | File | 410 B | 0644 |
|
time.h | File | 10.12 KB | 0644 |
|
tld.h | File | 4.54 KB | 0644 |
|
ttyent.h | File | 2.44 KB | 0644 |
|
uchar.h | File | 1.95 KB | 0644 |
|
ucontext.h | File | 1.99 KB | 0644 |
|
ulimit.h | File | 1.55 KB | 0644 |
|
unctrl.h | File | 3.03 KB | 0644 |
|
unistd.h | File | 41.74 KB | 0644 |
|
utime.h | File | 1.47 KB | 0644 |
|
utmp.h | File | 3.15 KB | 0644 |
|
utmpx.h | File | 4 KB | 0644 |
|
values.h | File | 1.91 KB | 0644 |
|
verto-module.h | File | 6.48 KB | 0644 |
|
verto.h | File | 18.98 KB | 0644 |
|
wait.h | File | 22 B | 0644 |
|
wchar.h | File | 30.38 KB | 0644 |
|
wctype.h | File | 5.42 KB | 0644 |
|
wordexp.h | File | 2.44 KB | 0644 |
|
zconf.h | File | 15.88 KB | 0644 |
|
zlib.h | File | 94 KB | 0644 |
|