aboutsummaryrefslogtreecommitdiffstats
path: root/host/lib/usrp/dboard/db_e3x0.cpp
blob: 6537c618b2c7c9d55453ed3a9dade6559dea091d (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
//
// Copyright 2014 Ettus Research LLC
//
// SPDX-License-Identifier: GPL-3.0
//

#include <uhd/utils/static.hpp>
#include <uhd/usrp/dboard_base.hpp>
#include <uhd/usrp/dboard_manager.hpp>

namespace uhd { namespace usrp {

/***********************************************************************
 * The E310 dboard
 *   AD9361 Interface, thus two subdevs
 **********************************************************************/
class e310_dboard : public xcvr_dboard_base{
public:
    e310_dboard(ctor_args_t args) : xcvr_dboard_base(args) {}

    virtual ~e310_dboard(void) {}
};

/***********************************************************************
 * The E310 dboard
 *   AD9364 Interface, thus one subdev
 **********************************************************************/
class e300_dboard : public xcvr_dboard_base{
public:
    e300_dboard(ctor_args_t args) : xcvr_dboard_base(args) {}

    virtual ~e300_dboard(void) {}
};

/***********************************************************************
 * Register the E310 dboards
 **********************************************************************/
static dboard_base::sptr make_e310_dboard(dboard_base::ctor_args_t args){
    return dboard_base::sptr(new e310_dboard(args));
}

static dboard_base::sptr make_e300_dboard(dboard_base::ctor_args_t args){
    return dboard_base::sptr(new e300_dboard(args));
}

}} // namespace

using namespace uhd::usrp;

UHD_STATIC_BLOCK(reg_e3x0_dboards){
    dboard_manager::register_dboard(0x0110, &make_e310_dboard, "E310 MIMO XCVR");
    dboard_manager::register_dboard(0x0100, &make_e300_dboard, "E300 SISO XCVR");
}