C standard library¶
The C standard library is an integral part of any C program, and Zephyr provides two implementations for the application to choose from.
The first one, named “minimal libc” is part of the Zephyr code base and provides
the minimal subset of the standard C library required to meet the needs of
Zephyr and its subsystems and features, primarily in the areas of string
manipulation and display. It is very low footprint and is suitable for projects
that do not rely on less frequently used portions of the ISO C standard library.
Its implementation can be found in lib/libc/minimal
in the main zephyr
tree.
The second one is newlib, a complete C library implementation written for
embedded systems. Newlib is separate open source project and is not included in
source code form with Zephyr. Instead, the Install the Zephyr Software Development Kit (SDK) comes with a
precompiled library for each supported architecture (libc.a
and
libm.a
). Other 3rd-party toolchains, such as GNU ARM Embedded,
also bundle newlib as a precompiled library.
Newlib can be enabled by selecting the :kconfig:`CONFIG_NEWLIB_LIBC` in the
application configuration file. Part of the support for newlib
is a set of
hooks available under lib/libc/newlib/libc-hooks.c
which integrates
the C standard library with basic kernel services.
API Reference¶
Error numbers¶
Error numbers are used throughout Zephyr APIs to signal error conditions as
return values from functions. They are typically returned as the negative value
of the integer literals defined in this section, and are defined in the
errno.h
header file.
A subset of the error numbers are defined in the POSIX errno.h specification,
and others have been added to it from other sources.
A conscious effort is made in Zephyr to keep the values of system error numbers
consistent between the different implementations of the C standard library. The
version of errno.h
that is in the main zephyr tree, errno.h, is
checked against newlib’s own list to ensure that the error numbers are kept
aligned.
Below is a list of the error number definitions. For the actual numeric values please refer to errno.h.
-
group
system_errno
System error numbers Error codes returned by functions. Includes a list of those defined by IEEE Std 1003.1-2017.
Defines
-
errno
¶
-
EPERM
¶ Not owner
-
ENOENT
¶ No such file or directory
-
ESRCH
¶ No such context
-
EINTR
¶ Interrupted system call
-
EIO
¶ I/O error
-
ENXIO
¶ No such device or address
-
E2BIG
¶ Arg list too long
-
ENOEXEC
¶ Exec format error
-
EBADF
¶ Bad file number
-
ECHILD
¶ No children
-
EAGAIN
¶ No more contexts
-
ENOMEM
¶ Not enough core
-
EACCES
¶ Permission denied
-
EFAULT
¶ Bad address
-
ENOTBLK
¶ Block device required
-
EBUSY
¶ Mount device busy
-
EEXIST
¶ File exists
-
EXDEV
¶ Cross-device link
-
ENODEV
¶ No such device
-
ENOTDIR
¶ Not a directory
-
EISDIR
¶ Is a directory
-
EINVAL
¶ Invalid argument
-
ENFILE
¶ File table overflow
-
EMFILE
¶ Too many open files
-
ENOTTY
¶ Not a typewriter
-
ETXTBSY
¶ Text file busy
-
EFBIG
¶ File too large
-
ENOSPC
¶ No space left on device
-
ESPIPE
¶ Illegal seek
-
EROFS
¶ Read-only file system
-
EMLINK
¶ Too many links
-
EPIPE
¶ Broken pipe
-
EDOM
¶ Argument too large
-
ERANGE
¶ Result too large
-
ENOMSG
¶ Unexpected message type
-
EDEADLK
¶ Resource deadlock avoided
-
ENOLCK
¶ No locks available
-
ENOSTR
¶ STREAMS device required
-
ENODATA
¶ Missing expected message data
-
ETIME
¶ STREAMS timeout occurred
-
ENOSR
¶ Insufficient memory
-
EPROTO
¶ Generic STREAMS error
-
EBADMSG
¶ Invalid STREAMS message
-
ENOSYS
¶ Function not implemented
-
ENOTEMPTY
¶ Directory not empty
-
ENAMETOOLONG
¶ File name too long
-
ELOOP
¶ Too many levels of symbolic links
-
EOPNOTSUPP
¶ Operation not supported on socket
-
EPFNOSUPPORT
¶ Protocol family not supported
-
ECONNRESET
¶ Connection reset by peer
-
ENOBUFS
¶ No buffer space available
-
EAFNOSUPPORT
¶ Addr family not supported
-
EPROTOTYPE
¶ Protocol wrong type for socket
-
ENOTSOCK
¶ Socket operation on non-socket
-
ENOPROTOOPT
¶ Protocol not available
-
ESHUTDOWN
¶ Can’t send after socket shutdown
-
ECONNREFUSED
¶ Connection refused
-
EADDRINUSE
¶ Address already in use
-
ECONNABORTED
¶ Software caused connection abort
-
ENETUNREACH
¶ Network is unreachable
-
ENETDOWN
¶ Network is down
-
ETIMEDOUT
¶ Connection timed out
-
EHOSTDOWN
¶ Host is down
-
EHOSTUNREACH
¶ No route to host
-
EINPROGRESS
¶ Operation now in progress
-
EALREADY
¶ Operation already in progress
-
EDESTADDRREQ
¶ Destination address required
-
EMSGSIZE
¶ Message size
-
EPROTONOSUPPORT
¶ Protocol not supported
-
ESOCKTNOSUPPORT
¶ Socket type not supported
-
EADDRNOTAVAIL
¶ Can’t assign requested address
-
ENETRESET
¶ Network dropped connection on reset
-
EISCONN
¶ Socket is already connected
-
ENOTCONN
¶ Socket is not connected
-
ETOOMANYREFS
¶ Too many references: can’t splice
-
ENOTSUP
¶ Unsupported value
-
EILSEQ
¶ Illegal byte sequence
-
EOVERFLOW
¶ Value overflow
-
ECANCELED
¶ Operation canceled
-
EWOULDBLOCK
¶ Operation would block
-