blob: 1a5af954b516b2524ab9d120d330458e76bfb2f6 [file] [log] [blame]
/*
*
* Copyright (c) 2020 Project CHIP Authors
* Copyright (c) 2013-2017 Nest Labs, Inc.
* All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/**
* @file
* This file defines constants for the CHIP ASN1 subsystem.
*
* Error types, ranges, and mappings overrides may be made by
* defining the appropriate ASN1_CONFIG_* or _ASN1_CONFIG_*
* macros.
*
*/
#pragma once
#include "ASN1Config.h"
namespace chip {
namespace ASN1 {
// clang-format off
/**
* @def ASN1_NO_ERROR
*
* @brief
* This defines the InetLayer error code for success or no
* error. This value may be configured via #ASN1_CONFIG_NO_ERROR.
*
*/
#define ASN1_NO_ERROR ASN1_CONFIG_NO_ERROR
/**
* @def ASN1_ERROR_MIN
*
* @brief
* This defines the base or minimum ASN1 error number range.
* This value may be configured via #ASN1_CONFIG_ERROR_MIN.
*
*/
#define ASN1_ERROR_MIN ASN1_CONFIG_ERROR_MIN
/**
* @def ASN1_ERROR_MAX
*
* @brief
* This defines the top or maximum ASN1 error number range.
* This value may be configured via #ASN1_CONFIG_ERROR_MAX.
*
*/
#define ASN1_ERROR_MAX ASN1_CONFIG_ERROR_MAX
/**
* @def _ASN1_ERROR(e)
*
* @brief
* This defines a mapping function for ASN1 errors that allows
* mapping such errors into a platform- or system-specific
* range. This function may be configured via
* #_ASN1_CONFIG_ERROR(e).
*
* @param[in] e The ASN1 error to map.
*
* @return The mapped ASN1 error.
*
*/
#define _ASN1_ERROR(e) _ASN1_CONFIG_ERROR(e)
/**
* The basic type for all ASN1 subsystem errors.
*
* This is defined to a platform- or system-specific type.
*
*/
typedef ASN1_CONFIG_ERROR_TYPE ASN1_ERROR;
/**
* @name Error Definitions
*
* @{
*/
/**
* @def ASN1_END
*
* @brief
* An end of ASN1 container or stream condition occurred.
*
*/
#define ASN1_END _ASN1_ERROR(0)
/**
* @def ASN1_ERROR_UNDERRUN
*
* @brief
* The ASN.1 encoding ended prematurely.
*
*/
#define ASN1_ERROR_UNDERRUN _ASN1_ERROR(1)
/**
* @def ASN1_ERROR_OVERFLOW
*
* @brief
* The encoding exceeds the available space required to write it.
*
*/
#define ASN1_ERROR_OVERFLOW _ASN1_ERROR(2)
/**
* @def ASN1_ERROR_INVALID_STATE
*
* @brief
* An unexpected or invalid state was encountered.
*
*/
#define ASN1_ERROR_INVALID_STATE _ASN1_ERROR(3)
/**
* @def ASN1_ERROR_MAX_DEPTH_EXCEEDED
*
* @brief
* The maximum number of container reading contexts was exceeded.
*
*/
#define ASN1_ERROR_MAX_DEPTH_EXCEEDED _ASN1_ERROR(4)
/**
* @def ASN1_ERROR_INVALID_ENCODING
*
* @brief
* The ASN.1 encoding is invalid.
*
*/
#define ASN1_ERROR_INVALID_ENCODING _ASN1_ERROR(5)
/**
* @def ASN1_ERROR_UNSUPPORTED_ENCODING
*
* @brief
* An unsupported encoding was requested or encountered.
*
*/
#define ASN1_ERROR_UNSUPPORTED_ENCODING _ASN1_ERROR(6)
/**
* @def ASN1_ERROR_TAG_OVERFLOW
*
* @brief
* An encoded tag exceeds the available or allowed space required
* for it.
*
*/
#define ASN1_ERROR_TAG_OVERFLOW _ASN1_ERROR(7)
/**
* @def ASN1_ERROR_LENGTH_OVERFLOW
*
* @brief
* An encoded length exceeds the available or allowed space
* required for it.
*
*/
#define ASN1_ERROR_LENGTH_OVERFLOW _ASN1_ERROR(8)
/**
* @def ASN1_ERROR_VALUE_OVERFLOW
*
* @brief
* An encoded value exceeds the available or allowed space
* required for it.
*
*/
#define ASN1_ERROR_VALUE_OVERFLOW _ASN1_ERROR(9)
/**
* @def ASN1_ERROR_UNKNOWN_OBJECT_ID
*
* @brief
* A requested object identifier does not match the list of
* supported object identifiers.
*
*/
#define ASN1_ERROR_UNKNOWN_OBJECT_ID _ASN1_ERROR(10)
// !!!!! IMPORTANT !!!!!
//
// If you add new ASN1 errors, please update the translation of error
// codes to strings in ASN1Error.cpp, and add them to unittest
// in test-apps/TestErrorStr.cpp
/**
* @}
*/
// clang-format on
bool FormatASN1Error(char * buf, uint16_t bufSize, int32_t err);
} // namespace ASN1
} // namespace chip