blob: dc40359629e96321164be6f798d716adcd4773dc (
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
|
//
// Copyright 2016-2018 Ettus Research, a National Instruments Company
//
// SPDX-License-Identifier: GPL-3.0-or-later
//
#include <uhd/rfnoc/siggen_block_ctrl.hpp>
#include <uhd/utils/log.hpp>
#include <boost/format.hpp>
using namespace uhd::rfnoc;
class siggen_block_ctrl_impl : public siggen_block_ctrl
{
public:
UHD_RFNOC_BLOCK_CONSTRUCTOR(siggen_block_ctrl)
{
// nop
}
void issue_stream_cmd(const uhd::stream_cmd_t& stream_cmd, const size_t)
{
UHD_LOGGER_TRACE(unique_id()) << "issue_stream_cmd()" << std::endl;
if (not stream_cmd.stream_now) {
throw uhd::not_implemented_error(
"siggen_block does not support timed commands.");
}
switch (stream_cmd.stream_mode) {
case uhd::stream_cmd_t::STREAM_MODE_START_CONTINUOUS:
sr_write("ENABLE", true);
break;
case uhd::stream_cmd_t::STREAM_MODE_STOP_CONTINUOUS:
sr_write("ENABLE", false);
break;
case uhd::stream_cmd_t::STREAM_MODE_NUM_SAMPS_AND_DONE:
case uhd::stream_cmd_t::STREAM_MODE_NUM_SAMPS_AND_MORE:
throw uhd::not_implemented_error("siggen_block does not support "
"streaming modes other than CONTINUOUS");
default:
UHD_THROW_INVALID_CODE_PATH();
}
}
};
UHD_RFNOC_BLOCK_REGISTER(siggen_block_ctrl, "SigGen");
|