API Status Codes
Methods return 0 if all goes well. Exceptionally, there are some methods that return nothing, such as sleep() functions.
All the return codes have the EmodRet type, which is a 4-byte integer (int32_t). The EmodRet type is composed by
ID | Function | Status Code |
---|---|---|
1 Byte | 1 Byte | 2 Bytes |
Identifies the type of module that produced the return code | Identifies the returning function | The return code itself |
where the ID
is the most significant byte.
Module and error codes are mandatory.
Modules
Module | ID |
---|---|
8SR | 3 |
10DI | 4 |
7AI+2PR | 5 |
12AI | 6 |
6_3 Level | 7 |
5DI+2PR | 8 |
EM3 | 10 |
2DI+1PR+2T | 11 |
EM3_250 | 14 |
Supercap | 255 |
On the other hand, return codes are classified into the following groups:
General codes
Constant | Status Code | Description |
---|---|---|
EmodRetOk | 0x0 | Success |
EmodRetErr | 0xffff | Error |
Standard errno error codes
When system requests fail, error codes are returned. GNU/Linux OS system error codes are described by the file asm-generic/errno.h
. This file defines the integer variable errno, which is used by system calls and some library functions in the event of an error to indicate what went wrong.
Here is brief description of the errno
type.
Constant | Status Code | Description |
---|---|---|
EPERM | 1 | Operation not permitted |
ENOENT | 2 | No such file or directory |
ESRCH | 3 | No such process |
EINTR | 4 | Interrupted system call |
EIO | 5 | I/O error |
ENXIO | 6 | No such device or address |
E2BIG | 7 | Argument list too long |
ENOEXEC | 8 | Exec format error |
EBADF | 9 | Bad file number |
ECHILD | 10 | No child processes |
EAGAIN | 11 | Try again |
ENOMEM | 12 | Out of memory |
EACCES | 13 | Permission denied |
EFAULT | 14 | Bad address |
ENOTBLK | 15 | Block device required |
EBUSY | 16 | Device or resource busy |
EEXIST | 17 | File exists |
EXDEV | 18 | Cross-device link |
ENODEV | 19 | No such device |
ENOTDIR | 20 | Not a directory |
EISDIR | 21 | Is a directory |
EINVAL | 22 | Invalid argument |
ENFILE | 23 | File table overflow |
EMFILE | 24 | Too many open files |
ENOTTY | 25 | Not a typewriter |
ETXTBSY | 26 | Text file busy |
EFBIG | 27 | File too large |
ENOSPC | 28 | No space left on device |
ESPIPE | 29 | Illegal seek |
EROFS | 30 | Read-only file system |
EMLINK | 31 | Too many links |
EPIPE | 32 | Broken pipe |
EDOM | 33 | Math argument out of domain of func |
ERANGE | 34 | Math result not representable |
EDEADLK | 35 | Resource deadlock would occur |
ENAMETOOLONG | 36 | File name too long |
ENOLCK | 37 | No record locks available |
ENOSYS | 38 | Invalid system call number |
ENOTEMPTY | 39 | Directory not empty |
ELOOP | 40 | Too many symbolic links encountered |
EWOULDBLOCK | EAGAIN | Operation would block |
ENOMSG | 42 | No message of desired type |
EIDRM | 43 | Identifier removed |
ECHRNG | 44 | Channel number out of range |
EL2NSYNC | 45 | Level 2 not synchronized |
EL3HLT | 46 | Level 3 halted |
EL3RST | 47 | Level 3 reset |
ELNRNG | 48 | Link number out of range |
EUNATCH | 49 | Protocol driver not attached |
ENOCSI | 50 | No CSI structure available |
EL2HLT | 51 | Level 2 halted |
EBADE | 52 | Invalid exchange |
EBADR | 53 | Invalid request descriptor |
EXFULL | 54 | Exchange full |
ENOANO | 55 | No anode |
EBADRQC | 56 | Invalid request code |
EBADSLT | 57 | Invalid slot |
EBFONT | 59 | Bad font file format |
ENOSTR | 60 | Device not a stream |
ENODATA | 61 | No data available |
ETIME | 62 | Timer expired |
ENOSR | 63 | Out of streams resources |
ENONET | 64 | Machine is not on the network |
ENOPKG | 65 | Package not installed |
EREMOTE | 66 | Object is remote |
ENOLINK | 67 | Link has been severed |
EADV | 68 | Advertise error |
ESRMNT | 69 | Srmount error |
ECOMM | 70 | Communication error on send |
EPROTO | 71 | Protocol error |
EMULTIHOP | 72 | Multihop attempted |
EDOTDOT | 73 | RFS specific error |
EBADMSG | 74 | Not a data message |
EOVERFLOW | 75 | Value too large for defined data type |
ENOTUNIQ | 76 | Name not unique on network |
EBADFD | 77 | File descriptor in bad state |
EREMCHG | 78 | Remote address changed |
ELIBACC | 79 | Can not access a needed shared library |
ELIBBAD | 80 | Accessing a corrupted shared library |
ELIBSCN | 81 | .lib section in a.out corrupted |
ELIBMAX | 82 | Attempting to link in too many shared libraries |
ELIBEXEC | 83 | Cannot exec a shared library directly |
EILSEQ | 84 | Illegal byte sequence |
ERESTART | 85 | Interrupted system call should be restarted |
ESTRPIPE | 86 | Streams pipe error |
EUSERS | 87 | Too many users |
ENOTSOCK | 88 | Socket operation on non-socket |
EDESTADDRREQ | 89 | Destination address required |
EMSGSIZE | 90 | Message too long |
EPROTOTYPE | 91 | Protocol wrong type for socket |
ENOPROTOOPT | 92 | Protocol not available |
EPROTONOSUPPORT | 93 | Protocol not supported |
ESOCKTNOSUPPORT | 94 | Socket type not supported |
EOPNOTSUPP | 95 | Operation not supported on transport endpoint |
EPFNOSUPPORT | 96 | Protocol family not supported |
EAFNOSUPPORT | 97 | Address family not supported by protocol |
EADDRINUSE | 98 | Address already in use |
EADDRNOTAVAIL | 99 | Cannot assign requested address |
ENETDOWN | 100 | Network is down |
ENETUNREACH | 101 | Network is unreachable |
ENETRESET | 102 | Network dropped connection because of reset |
ECONNABORTED | 103 | Software caused connection abort |
ECONNRESET | 104 | Connection reset by peer |
ENOBUFS | 105 | No buffer space available |
EISCONN | 106 | Transport endpoint is already connected |
ENOTCONN | 107 | Transport endpoint is not connected |
ESHUTDOWN | 108 | Cannot send after transport endpoint shutdown |
ETOOMANYREFS | 109 | Too many references: cannot splice |
ETIMEDOUT | 110 | Connection timed out |
ECONNREFUSED | 111 | Connection refused |
EHOSTDOWN | 112 | Host is down |
EHOSTUNREACH | 113 | No route to host |
EALREADY | 114 | Operation already in progress |
EINPROGRESS | 115 | Operation now in progress |
ESTALE | 116 | Stale file handle |
EUCLEAN | 117 | Structure needs cleaning |
ENOTNAM | 118 | Not a XENIX named type file |
ENAVAIL | 119 | No XENIX semaphores available |
EISNAM | 120 | Is a named type file |
EREMOTEIO | 121 | Remote I/O error |
EDQUOT | 122 | Quota exceeded |
ENOMEDIUM | 123 | No medium found |
EMEDIUMTYPE | 124 | Wrong medium type |
ECANCELED | 125 | Operation Canceled |
ENOKEY | 126 | Required key not available |
EKEYEXPIRED | 127 | Key has expired |
EKEYREVOKED | 128 | Key has been revoked |
EKEYREJECTED | 129 | Key was rejected by service |
EOWNERDEAD | 130 | Owner died |
ENOTRECOVERABLE | 131 | State not recoverable |
ERFKILL | 132 | Operation not possible due to RF-kill |
EHWPOISON | 133 | Memory page has hardware error |
eMOD error codes
In contrast with the system errno codes, the following error codes are related to the eMOD libraries and modules performance.
Constant | Status Code | Description |
---|---|---|
EmodRetErrWriteBus | 0x1001 | Cannot write frame into eMod bus |
EmodRetErrNoDataReceived | 0x1002 | No module data received |
EmodRetErrWrongdataReceived | 0x1003 | Wrong data received |
EmodRetErrNotAck | 0x1004 | Command that requires acknowledgement has not been ACKed |
EmodRetErrSendConfig | 0x1005 | Configuration could not be sent to module |
EmodRetErrRecvConfig | 0x1006 | Configuration could not be retrieved from module |
EmodRetErrModuleNotFound | 0x1007 | Module not found |
EmodRetErrNoModulesFound | 0x1008 | None of the modules have been found |
EmodRetErrValueOutOfRange | 0x1009 | Array index or parameter out of range |
EmodRetErrConfigMismatch | 0x100a | Config is not possible due to incoherent variables or types |
EmodRetErrReadFileError | 0x100b | Error reading from file |
EmodRetErrWriteFileError | 0x100c | Error writing to file |
EmodRetErrSendBuffer | 0x100d | Error trying to send buffer over the module |
EmodRetErrInputConfig | 0x100e | Wrongly configured input. |
eMOD warning codes
Constant | Status Code | Description |
---|---|---|
EmodRetWrnPollingNotApply | 0x2001 | Callback is enabled. Polling does not apply |
EmodRetWrnBadInputParam | 0x2002 | The value of the parameter passed to the function is incorrect |
eMOD information codes
At the moment there are not information codes available in the API.