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

#pragma once

#include <cstddef>
#include <string>

namespace uhd {

/*! Checks for FPGA compatibility, and throws an exception on mismatch.
 *
 * \throws uhd::runtime_error on mismatch.
 */
void assert_fpga_compat(const size_t uhd_major,
    const size_t uhd_minor,
    const uint64_t fpga_compat,
    const std::string& fpga_component,
    const std::string& log_component,
    const bool fail_on_minor_behind = false);

/*! Checks for FPGA compatibility, and throws an exception on mismatch.
 *
 * \throws uhd::runtime_error on mismatch.
 */
void assert_fpga_compat(const size_t uhd_major,
    const size_t uhd_minor,
    const uint32_t fpga_compat,
    const std::string& fpga_component,
    const std::string& log_component,
    const bool fail_on_minor_behind = false);

} /* namespace uhd */