1 /* 2 * Copyright (c) 2018-2021 mcumgr authors 3 * Copyright (c) 2022-2023 Nordic Semiconductor ASA 4 * 5 * SPDX-License-Identifier: Apache-2.0 6 */ 7 8 #ifndef H_MGMT_MGMT_DEFINES_ 9 #define H_MGMT_MGMT_DEFINES_ 10 11 #include <inttypes.h> 12 13 #ifdef __cplusplus 14 extern "C" { 15 #endif 16 17 /** 18 * @brief MCUmgr mgmt API 19 * @defgroup mcumgr_mgmt_api MCUmgr mgmt API 20 * @ingroup mcumgr 21 * @{ 22 */ 23 24 /** 25 * Used at end of MCUmgr handlers to return an error if the message size limit was reached, 26 * or OK if it was not 27 */ 28 #define MGMT_RETURN_CHECK(ok) ok ? MGMT_ERR_EOK : MGMT_ERR_EMSGSIZE 29 30 /** Opcodes; encoded in first byte of header. */ 31 enum mcumgr_op_t { 32 /** Read op-code */ 33 MGMT_OP_READ = 0, 34 35 /** Read response op-code */ 36 MGMT_OP_READ_RSP, 37 38 /** Write op-code */ 39 MGMT_OP_WRITE, 40 41 /** Write response op-code */ 42 MGMT_OP_WRITE_RSP, 43 }; 44 45 /** 46 * MCUmgr groups. The first 64 groups are reserved for system level mcumgr 47 * commands. Per-user commands are then defined after group 64. 48 */ 49 enum mcumgr_group_t { 50 /** OS (operating system) group */ 51 MGMT_GROUP_ID_OS = 0, 52 53 /** Image management group, used for uploading firmware images */ 54 MGMT_GROUP_ID_IMAGE, 55 56 /** Statistic management group, used for retrieving statistics */ 57 MGMT_GROUP_ID_STAT, 58 59 /** Settings management (config) group, used for reading/writing settings */ 60 MGMT_GROUP_ID_SETTINGS, 61 62 /** Log management group (unused) */ 63 MGMT_GROUP_ID_LOG, 64 65 /** Crash group (unused) */ 66 MGMT_GROUP_ID_CRASH, 67 68 /** Split image management group (unused) */ 69 MGMT_GROUP_ID_SPLIT, 70 71 /** Run group (unused) */ 72 MGMT_GROUP_ID_RUN, 73 74 /** FS (file system) group, used for performing file IO operations */ 75 MGMT_GROUP_ID_FS, 76 77 /** Shell management group, used for executing shell commands */ 78 MGMT_GROUP_ID_SHELL, 79 80 /** User groups defined from 64 onwards */ 81 MGMT_GROUP_ID_PERUSER = 64, 82 83 /** Zephyr-specific groups decrease from PERUSER to avoid collision with upstream and 84 * user-defined groups. 85 * Zephyr-specific: Basic group 86 */ 87 ZEPHYR_MGMT_GRP_BASIC = (MGMT_GROUP_ID_PERUSER - 1), 88 }; 89 90 /** 91 * MCUmgr error codes. 92 */ 93 enum mcumgr_err_t { 94 /** No error (success). */ 95 MGMT_ERR_EOK = 0, 96 97 /** Unknown error. */ 98 MGMT_ERR_EUNKNOWN, 99 100 /** Insufficient memory (likely not enough space for CBOR object). */ 101 MGMT_ERR_ENOMEM, 102 103 /** Error in input value. */ 104 MGMT_ERR_EINVAL, 105 106 /** Operation timed out. */ 107 MGMT_ERR_ETIMEOUT, 108 109 /** No such file/entry. */ 110 MGMT_ERR_ENOENT, 111 112 /** Current state disallows command. */ 113 MGMT_ERR_EBADSTATE, 114 115 /** Response too large. */ 116 MGMT_ERR_EMSGSIZE, 117 118 /** Command not supported. */ 119 MGMT_ERR_ENOTSUP, 120 121 /** Corrupt */ 122 MGMT_ERR_ECORRUPT, 123 124 /** Command blocked by processing of other command */ 125 MGMT_ERR_EBUSY, 126 127 /** Access to specific function, command or resource denied */ 128 MGMT_ERR_EACCESSDENIED, 129 130 /** Requested SMP MCUmgr protocol version is not supported (too old) */ 131 MGMT_ERR_UNSUPPORTED_TOO_OLD, 132 133 /** Requested SMP MCUmgr protocol version is not supported (too new) */ 134 MGMT_ERR_UNSUPPORTED_TOO_NEW, 135 136 /** User errors defined from 256 onwards */ 137 MGMT_ERR_EPERUSER = 256 138 }; 139 140 #define MGMT_HDR_SIZE 8 141 142 /** 143 * @} 144 */ 145 146 #ifdef __cplusplus 147 } 148 #endif 149 150 #endif /* MGMT_MGMT_DEFINES_H_ */ 151