aboutsummaryrefslogtreecommitdiffstats
path: root/lib/hackrf/hackrf_source_c.cc
diff options
context:
space:
mode:
authorDimitri Stolnikov <horiz0n@gmx.net>2013-06-07 22:06:38 +0200
committerDimitri Stolnikov <horiz0n@gmx.net>2013-06-07 22:06:38 +0200
commitb59b0080f5061e09cc3d2071b8bba7f554dec83a (patch)
treed760df8d641f859fde77f70b985838dfedef4329 /lib/hackrf/hackrf_source_c.cc
parenteaec4c5acc93d327f598771bc48c756f7ffe9be0 (diff)
hackrf: add human readable error prints to all libhackrf funcs
Diffstat (limited to 'lib/hackrf/hackrf_source_c.cc')
-rw-r--r--lib/hackrf/hackrf_source_c.cc63
1 files changed, 40 insertions, 23 deletions
diff --git a/lib/hackrf/hackrf_source_c.cc b/lib/hackrf/hackrf_source_c.cc
index 64efce8..767679e 100644
--- a/lib/hackrf/hackrf_source_c.cc
+++ b/lib/hackrf/hackrf_source_c.cc
@@ -48,6 +48,14 @@ using namespace boost::assign;
#define BYTES_PER_SAMPLE 2 /* HackRF device produces 8 bit unsigned IQ data */
+#define HACKRF_THROW_ON_ERROR(ret, msg) \
+ if ( ret != HACKRF_SUCCESS ) \
+ throw std::runtime_error( boost::str( boost::format(msg " (%d) %s") \
+ % ret % hackrf_error_name((enum hackrf_error)ret) ) );
+
+#define HACKRF_FUNC_STR(func, arg) \
+ boost::str(boost::format(func "(%d)") % arg) + " has failed"
+
int hackrf_source_c::_usage = 0;
boost::mutex hackrf_source_c::_usage_mutex;
@@ -129,24 +137,21 @@ hackrf_source_c::hackrf_source_c (const std::string &args)
_dev = NULL;
ret = hackrf_open( &_dev );
- if (ret != HACKRF_SUCCESS)
- throw std::runtime_error("Failed to open HackRF device.");
+ HACKRF_THROW_ON_ERROR(ret, "Failed to open HackRF device")
uint8_t board_id;
ret = hackrf_board_id_read( _dev, &board_id );
- if (ret != HACKRF_SUCCESS)
- throw std::runtime_error("Failed to get board id.");
+ HACKRF_THROW_ON_ERROR(ret, "Failed to get HackRF board id")
char version[40];
memset(version, 0, sizeof(version));
ret = hackrf_version_string_read( _dev, version, sizeof(version));
- if (ret != HACKRF_SUCCESS)
- throw std::runtime_error("Failed to read version string.");
+ HACKRF_THROW_ON_ERROR(ret, "Failed to read version string")
+
#if 0
read_partid_serialno_t serial_number;
ret = hackrf_board_partid_serialno_read( _dev, &serial_number );
- if (ret != HACKRF_SUCCESS)
- throw std::runtime_error("Failed to read serial number.");
+ HACKRF_THROW_ON_ERROR(ret, "Failed to read serial number")
#endif
std::cerr << "Using " << hackrf_board_id_name(hackrf_board_id(board_id)) << " "
<< "with firmware " << version << " "
@@ -176,9 +181,7 @@ hackrf_source_c::hackrf_source_c (const std::string &args)
// _thread = gruel::thread(_hackrf_wait, this);
ret = hackrf_start_rx( _dev, _hackrf_rx_callback, (void *)this );
- if (ret != HACKRF_SUCCESS) {
- std::cerr << "Failed to start RX streaming (" << ret << ")" << std::endl;
- }
+ HACKRF_THROW_ON_ERROR(ret, "Failed to start RX streaming")
}
/*
@@ -189,10 +192,9 @@ hackrf_source_c::~hackrf_source_c ()
if (_dev) {
// _thread.join();
int ret = hackrf_stop_rx( _dev );
- if (ret != HACKRF_SUCCESS) {
- std::cerr << "Failed to stop RX streaming (" << ret << ")" << std::endl;
- }
- hackrf_close( _dev );
+ HACKRF_THROW_ON_ERROR(ret, "Failed to stop RX streaming")
+ ret = hackrf_close( _dev );
+ HACKRF_THROW_ON_ERROR(ret, "Failed to close HackRF")
_dev = NULL;
{
@@ -258,7 +260,7 @@ bool hackrf_source_c::start()
return false;
#if 0
int ret = hackrf_start_rx( _dev, _hackrf_rx_callback, (void *)this );
- if (ret != HACKRF_SUCCESS) {
+ if ( ret != HACKRF_SUCCESS ) {
std::cerr << "Failed to start RX streaming (" << ret << ")" << std::endl;
return false;
}
@@ -272,7 +274,7 @@ bool hackrf_source_c::stop()
return false;
#if 0
int ret = hackrf_stop_rx( _dev );
- if (ret != HACKRF_SUCCESS) {
+ if ( ret != HACKRF_SUCCESS ) {
std::cerr << "Failed to stop RX streaming (" << ret << ")" << std::endl;
return false;
}
@@ -383,7 +385,7 @@ double hackrf_source_c::set_sample_rate( double rate )
_sample_rate = rate;
set_bandwidth( rate );
} else {
- throw std::runtime_error( std::string( __FUNCTION__ ) + " has failed" );
+ HACKRF_THROW_ON_ERROR( ret, HACKRF_FUNC_STR( "hackrf_sample_rate_set", rate ) )
}
}
@@ -416,7 +418,7 @@ double hackrf_source_c::set_center_freq( double freq, size_t chan )
if ( HACKRF_SUCCESS == ret ) {
_center_freq = freq;
} else {
- throw std::runtime_error( std::string( __FUNCTION__ ) + " has failed" );
+ HACKRF_THROW_ON_ERROR( ret, HACKRF_FUNC_STR( "hackrf_set_freq", corr_freq ) )
}
}
@@ -489,14 +491,19 @@ bool hackrf_source_c::get_gain_mode( size_t chan )
double hackrf_source_c::set_gain( double gain, size_t chan )
{
+ int ret;
osmosdr::gain_range_t rf_gains = get_gain_range( "RF", chan );
if (_dev) {
double clip_gain = rf_gains.clip( gain, true );
uint8_t value = clip_gain == 14.0f ? 1 : 0;
- if ( hackrf_set_amp_enable( _dev, value ) == HACKRF_SUCCESS )
+ ret = hackrf_set_amp_enable( _dev, value );
+ if ( HACKRF_SUCCESS == ret ) {
_amp_gain = clip_gain;
+ } else {
+ HACKRF_THROW_ON_ERROR( ret, HACKRF_FUNC_STR( "hackrf_set_amp_enable", value ) )
+ }
}
return _amp_gain;
@@ -543,13 +550,18 @@ double hackrf_source_c::get_gain( const std::string & name, size_t chan )
double hackrf_source_c::set_if_gain(double gain, size_t chan)
{
+ int ret;
osmosdr::gain_range_t rf_gains = get_gain_range( "IF", chan );
if (_dev) {
double clip_gain = rf_gains.clip( gain, true );
- if ( hackrf_set_lna_gain( _dev, uint32_t(clip_gain) ) == HACKRF_SUCCESS )
+ ret = hackrf_set_lna_gain( _dev, uint32_t(clip_gain) );
+ if ( HACKRF_SUCCESS == ret ) {
_lna_gain = clip_gain;
+ } else {
+ HACKRF_THROW_ON_ERROR( ret, HACKRF_FUNC_STR( "hackrf_set_lna_gain", clip_gain ) )
+ }
}
return _lna_gain;
@@ -557,13 +569,18 @@ double hackrf_source_c::set_if_gain(double gain, size_t chan)
double hackrf_source_c::set_bb_gain( double gain, size_t chan )
{
+ int ret;
osmosdr::gain_range_t if_gains = get_gain_range( "BB", chan );
if (_dev) {
double clip_gain = if_gains.clip( gain, true );
- if ( hackrf_set_vga_gain( _dev, uint32_t(clip_gain) ) == HACKRF_SUCCESS )
+ ret = hackrf_set_vga_gain( _dev, uint32_t(clip_gain) );
+ if ( HACKRF_SUCCESS == ret ) {
_vga_gain = clip_gain;
+ } else {
+ HACKRF_THROW_ON_ERROR( ret, HACKRF_FUNC_STR( "hackrf_set_vga_gain", clip_gain ) )
+ }
}
return _vga_gain;
@@ -603,7 +620,7 @@ double hackrf_source_c::set_bandwidth( double bandwidth, size_t chan )
if ( HACKRF_SUCCESS == ret ) {
_bandwidth = bw;
} else {
- throw std::runtime_error( std::string( __FUNCTION__ ) + " has failed" );
+ HACKRF_THROW_ON_ERROR( ret, HACKRF_FUNC_STR( "hackrf_baseband_filter_bandwidth_set", bw ) )
}
}