diff options
Diffstat (limited to 'host')
-rw-r--r-- | host/include/uhd/rfnoc/node.hpp | 11 | ||||
-rw-r--r-- | host/lib/rfnoc/node.cpp | 5 |
2 files changed, 14 insertions, 2 deletions
diff --git a/host/include/uhd/rfnoc/node.hpp b/host/include/uhd/rfnoc/node.hpp index 04b3d863f..eaeea20af 100644 --- a/host/include/uhd/rfnoc/node.hpp +++ b/host/include/uhd/rfnoc/node.hpp @@ -182,6 +182,15 @@ protected: /*! Register a property for this block * + * This is typically called from the constructor. It is possible to register + * properties later, but then the node must take care of serialization. + * + * This has the intentional side-effect of setting the access mode to RW for + * the property. The idea is that after registering a property, the node + * might need some time to settle on the default value. The access mode will + * either be reset after the constructor is finished, or the next time + * properties are resolved. + * * \param prop A reference to the property * \param clean_callback A callback that gets executed whenever this property * is dirty and gets marked clean @@ -454,7 +463,7 @@ private: */ void resolve_all(); - /*! Mark all properties as clean + /*! Mark all properties as clean and read-only * * When dirty properties have a clean-callback registered, that will also * get triggered. diff --git a/host/lib/rfnoc/node.cpp b/host/lib/rfnoc/node.cpp index cdb69e158..d97588bab 100644 --- a/host/lib/rfnoc/node.cpp +++ b/host/lib/rfnoc/node.cpp @@ -94,6 +94,8 @@ void node_t::register_property(property_base_t* prop, resolve_callback_t&& clean if (clean_callback) { _clean_cb_registry[prop] = std::move(clean_callback); } + + prop_accessor_t{}.set_access(prop, property_base_t::RW); } void node_t::add_property_resolver( @@ -353,7 +355,7 @@ void node_t::init_props() } } - // 4) Mark properties as clean + // 4) Mark properties as clean and read-only clean_props(); } @@ -429,6 +431,7 @@ void node_t::clean_props() _clean_cb_registry.at(prop)(); } prop_accessor.mark_clean(*prop); + prop_accessor.set_access(prop, property_base_t::RO); } } } |