Thomas Kolb
fc9e5c5229
The new module is not used yet, but this is a preparation for the future multi-client networking support.
53 lines
1.6 KiB
C
53 lines
1.6 KiB
C
/*
|
|
* SPDX-License-Identifier: GPL-3.0-or-later
|
|
*
|
|
* Copyright (C) 2024 Thomas Kolb
|
|
*/
|
|
|
|
#ifndef RESULTS_H
|
|
#define RESULTS_H
|
|
|
|
#include "logger.h"
|
|
|
|
typedef enum {
|
|
OK,
|
|
ERR_INVALID_STATE, // module or context is in an invalid state
|
|
ERR_INVALID_PARAM, // invalid / nonsense parameters given
|
|
ERR_INVALID_ADDRESS, // invalid address received or given
|
|
ERR_NO_MEM, // not enough memory or allocation error
|
|
ERR_SIZE, // a given size is invalid
|
|
ERR_LIQUID, // an error occurred in the LiquidDSP library.
|
|
ERR_SYSCALL, // a syscall failed. Use errno to determine the cause.
|
|
ERR_SOAPY, // an error occurred in the SoapySDR library.
|
|
ERR_SDR, // an error occurred in the SDR interface.
|
|
ERR_INTEGRITY, // an integrity check failed (e.g. CRC of received packet is wrong)
|
|
ERR_SEQUENCE, // an unexpected packet was received
|
|
} result_t;
|
|
|
|
#ifdef DEBUG_LIQUID
|
|
|
|
#include <liquid/liquid.h>
|
|
|
|
#define ERR_CHECK_LIQUID(call) \
|
|
do { \
|
|
liquid_error_code lq_result; \
|
|
if((lq_result = (call)) != LIQUID_OK) { \
|
|
LOG(LVL_ERR, "Liquid call failed in %s:%d: %s", __FILE__, __LINE__, liquid_error_info(lq_result)); \
|
|
return ERR_LIQUID; \
|
|
} \
|
|
} while(0);
|
|
#else
|
|
# define ERR_CHECK_LIQUID(call) if((call) != LIQUID_OK) { return ERR_LIQUID; }
|
|
#endif
|
|
|
|
#define ERR_CHECK(call) \
|
|
do { \
|
|
result_t err_check_result = call; \
|
|
if(err_check_result != OK) { \
|
|
LOG(LVL_ERR, "Error detected at %s:%d: %d", __FILE__, __LINE__, err_check_result); \
|
|
return err_check_result; \
|
|
} \
|
|
} while(0);
|
|
|
|
#endif // RESULTS_H
|