aboutsummaryrefslogtreecommitdiffstats
path: root/host/lib/utils/prefs.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'host/lib/utils/prefs.cpp')
-rw-r--r--host/lib/utils/prefs.cpp45
1 files changed, 34 insertions, 11 deletions
diff --git a/host/lib/utils/prefs.cpp b/host/lib/utils/prefs.cpp
index 2ccc538fc..88be300cb 100644
--- a/host/lib/utils/prefs.cpp
+++ b/host/lib/utils/prefs.cpp
@@ -48,6 +48,23 @@ namespace {
uhd::prefs::get_uhd_config().get<std::string>(key_str, key);
}
}
+
+ device_addr_t get_args(
+ const uhd::device_addr_t& user_args,
+ const std::vector<std::string>& keys_to_update_from
+ ) {
+ device_addr_t args;
+ for (const auto& key : keys_to_update_from) {
+ update_from_key(key, user_args.get(key, ""), args);
+ }
+
+ // Finally, copy over the original user args:
+ for (const auto& user_key : user_args.keys()) {
+ args[user_key] = user_args[user_key];
+ }
+
+ return args;
+ }
}
config_parser& uhd::prefs::get_uhd_config()
@@ -81,22 +98,28 @@ config_parser& uhd::prefs::get_uhd_config()
device_addr_t uhd::prefs::get_usrp_args(
const uhd::device_addr_t &user_args
) {
- device_addr_t usrp_args;
const std::vector<std::string> keys_to_update_from = {
"type",
"product",
"serial"
};
+ return get_args(user_args, keys_to_update_from);
+}
- for (const auto& key : keys_to_update_from) {
- update_from_key(key, user_args.get(key, ""), usrp_args);
- }
-
- // Finally, copy over the original user args:
- for (const auto &user_key : user_args.keys()) {
- usrp_args[user_key] = user_args[user_key];
- }
-
- return usrp_args;
+device_addr_t uhd::prefs::get_dpdk_args(
+ const uhd::device_addr_t &user_args
+) {
+ const std::vector<std::string> keys_to_update_from = {
+ "use_dpdk"
+ };
+ return get_args(user_args, keys_to_update_from);
}
+device_addr_t uhd::prefs::get_dpdk_nic_args(
+ const uhd::device_addr_t &user_args
+) {
+ const std::vector<std::string> keys_to_update_from = {
+ "dpdk-mac"
+ };
+ return get_args(user_args, keys_to_update_from);
+}