//
// Copyright 2012 Ettus Research LLC
// Copyright 2018 Ettus Research, a National Instruments Company
//
// SPDX-License-Identifier: GPL-3.0-or-later
//

#include "convert_common.hpp"
#include <uhd/utils/byteswap.hpp>

#define __DECLARE_ITEM32_CONVERTER(cpu_type, wire_type, xe, htoxx, xxtoh)             \
    DECLARE_CONVERTER(cpu_type, 1, wire_type##_item32_##xe, 1, PRIORITY_GENERAL)      \
    {                                                                                 \
        const cpu_type##_t* input = reinterpret_cast<const cpu_type##_t*>(inputs[0]); \
        item32_t* output          = reinterpret_cast<item32_t*>(outputs[0]);          \
        xx_to_item32_##wire_type<htoxx>(input, output, nsamps, scale_factor);         \
    }                                                                                 \
    DECLARE_CONVERTER(wire_type##_item32_##xe, 1, cpu_type, 1, PRIORITY_GENERAL)      \
    {                                                                                 \
        const item32_t* input = reinterpret_cast<const item32_t*>(inputs[0]);         \
        cpu_type##_t* output  = reinterpret_cast<cpu_type##_t*>(outputs[0]);          \
        item32_##wire_type##_to_xx<xxtoh>(input, output, nsamps, scale_factor);       \
    }

#define _DECLARE_ITEM32_CONVERTER(cpu_type, wire_type)                          \
    __DECLARE_ITEM32_CONVERTER(cpu_type, wire_type, be, uhd::htonx, uhd::ntohx) \
    __DECLARE_ITEM32_CONVERTER(cpu_type, wire_type, le, uhd::htowx, uhd::wtohx)

#define DECLARE_ITEM32_CONVERTER(cpu_type)   \
    _DECLARE_ITEM32_CONVERTER(cpu_type, sc8) \
    _DECLARE_ITEM32_CONVERTER(cpu_type, sc16)

/* Create sc16<->sc16,sc8(otw) */
DECLARE_ITEM32_CONVERTER(sc16)
/* Create fc32<->sc16,sc8(otw) */
DECLARE_ITEM32_CONVERTER(fc32)
/* Create fc64<->sc16,sc8(otw) */
DECLARE_ITEM32_CONVERTER(fc64)
_DECLARE_ITEM32_CONVERTER(sc8, sc8)