aboutsummaryrefslogtreecommitdiffstats
path: root/lib/bladerf/bladerf_common.h
blob: 3f366fa8fb8ff8b12b53810195dd4c3b794b2e2a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
/* -*- c++ -*- */
/*
 * Copyright 2013-2017 Nuand LLC
 * Copyright 2013 Dimitri Stolnikov <horiz0n@gmx.net>
 *
 * GNU Radio is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 3, or (at your option)
 * any later version.
 *
 * GNU Radio is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with GNU Radio; see the file COPYING.  If not, write to
 * the Free Software Foundation, Inc., 51 Franklin Street,
 * Boston, MA 02110-1301, USA.
 */
#ifndef INCLUDED_BLADERF_COMMON_H
#define INCLUDED_BLADERF_COMMON_H

#include <vector>
#include <string>

#include <boost/circular_buffer.hpp>
#include <boost/thread/mutex.hpp>
#include <boost/thread/shared_mutex.hpp>
#include <boost/thread/condition_variable.hpp>
#include <boost/assign.hpp>
#include <boost/format.hpp>
#include <boost/lexical_cast.hpp>
#include <boost/weak_ptr.hpp>

#include <gnuradio/thread/thread.h>
#include <gnuradio/gr_complex.h>

#include <libbladeRF.h>

#include "osmosdr/ranges.h"
#include "arg_helpers.h"

#ifdef _MSC_VER
#include <cstddef>
typedef ptrdiff_t ssize_t;
#endif                          //_MSC_VER

typedef boost::shared_ptr < struct bladerf >bladerf_sptr;
typedef enum {
  BLADERF_REV_INVALID,
  BLADERF_REV_1,
  BLADERF_REV_2
} bladerf_board_type;

class bladerf_common
{
public:
  bladerf_common();
  virtual ~ bladerf_common();

protected:

  /* Handle initialized and parameters common to both source & sink */
  void init(dict_t &dict, bladerf_direction direction);

  bool start(bladerf_direction direction);
  bool stop(bladerf_direction direction);

  size_t get_num_channels(bladerf_direction direction);
  bladerf_board_type get_board_type(struct bladerf *dev);

  double set_sample_rate(bladerf_direction direction, double rate);
  double get_sample_rate(bladerf_direction direction);

  osmosdr::freq_range_t get_freq_range(size_t chan = 0);
  double set_center_freq(double freq, size_t chan = 0);
  double get_center_freq(size_t chan = 0);

  std::vector < std::string > get_gain_names(size_t chan = 0);
  osmosdr::gain_range_t get_gain_range(size_t chan = 0);
  osmosdr::gain_range_t get_gain_range(const std::string &name, size_t chan =
                                         0);
  bool set_gain_mode(bool automatic, size_t chan = 0);
  bool get_gain_mode(size_t chan = 0);
  double set_gain(double gain, size_t chan = 0);
  double set_gain(double gain, const std::string &name, size_t chan = 0);
  double get_gain(size_t chan = 0);
  double get_gain(const std::string &name, size_t chan = 0);

  int set_dc_offset(bladerf_direction direction,
                    const std::complex < double > &offset, size_t chan);
  int set_iq_balance(bladerf_direction direction,
                     const std::complex < double > &balance, size_t chan);

  void set_clock_source(const std::string &source, const size_t mboard = 0);
  std::string get_clock_source(const size_t mboard = 0);
  std::vector < std::string > get_clock_sources(const size_t mboard = 0);

  void set_smb_frequency(double frequency);
  double get_smb_frequency();

  osmosdr::freq_range_t freq_range(bladerf_channel chan);
  osmosdr::meta_range_t sample_rates();
  osmosdr::freq_range_t filter_bandwidths();

  static std::vector < std::string > devices();

  bladerf_sptr _dev;

  size_t _num_buffers;
  size_t _samples_per_buffer;
  size_t _num_transfers;
  unsigned int _stream_timeout_ms;

  int16_t *_conv_buf;
  int _conv_buf_size;           /* In units of samples */

  bool _use_metadata;
  bool _use_mimo;

  std::string _pfx;

  bool _xb_200_attached;
  unsigned int _consecutive_failures;

  /* BladeRF IQ correction parameters */
  static const int16_t DCOFF_SCALE = 2048;
  static const int16_t GAIN_SCALE = 4096;
  static const int16_t PHASE_SCALE = 4096;

  static const unsigned int MAX_CONSECUTIVE_FAILURES = 3;

private:
  bladerf_sptr open(const std::string &device_name);
  static void close(void *dev); /* called by shared_ptr */
  static bladerf_sptr get_cached_device(struct bladerf_devinfo devinfo);

  void set_verbosity(const std::string &verbosity);
  void set_loopback_mode(const std::string &loopback);

  static boost::mutex _devs_mutex;
  static std::list < boost::weak_ptr < struct bladerf >>_devs;
};

#endif