diff options
| author | Martin Braun <martin.braun@ettus.com> | 2020-11-11 14:28:02 +0100 | 
|---|---|---|
| committer | Aaron Rossetto <aaron.rossetto@ni.com> | 2021-05-20 14:55:34 -0500 | 
| commit | e1515c755c551fac1d218be112df745b4a15db16 (patch) | |
| tree | 0f89a79004aae06e465fe22438699456e1250c5a | |
| parent | ce56d025dd37640f12e27b1e85cd2574fb0666dc (diff) | |
| download | uhd-e1515c755c551fac1d218be112df745b4a15db16.tar.gz uhd-e1515c755c551fac1d218be112df745b4a15db16.tar.bz2 uhd-e1515c755c551fac1d218be112df745b4a15db16.zip | |
types: Add mm_iface structs
This adds two structs (mm32_iface and mm32_iface_timed) which are
a container for peek/poke interfaces.
| -rw-r--r-- | host/include/uhd/types/CMakeLists.txt | 1 | ||||
| -rw-r--r-- | host/include/uhd/types/memmap_iface.hpp | 42 | 
2 files changed, 43 insertions, 0 deletions
| diff --git a/host/include/uhd/types/CMakeLists.txt b/host/include/uhd/types/CMakeLists.txt index 108a37da4..730ee0e65 100644 --- a/host/include/uhd/types/CMakeLists.txt +++ b/host/include/uhd/types/CMakeLists.txt @@ -15,6 +15,7 @@ UHD_INSTALL(FILES      eeprom.hpp      endianness.hpp      mac_addr.hpp +    memmap_iface.hpp      metadata.hpp      ranges.hpp      ref_vector.hpp diff --git a/host/include/uhd/types/memmap_iface.hpp b/host/include/uhd/types/memmap_iface.hpp new file mode 100644 index 000000000..fa6c18d4a --- /dev/null +++ b/host/include/uhd/types/memmap_iface.hpp @@ -0,0 +1,42 @@ +// +// Copyright 2020 Ettus Research, a National Instruments Brand +// +// SPDX-License-Identifier: GPL-3.0-or-later +// + +#pragma once + +#include <uhd/config.hpp> +#include <uhd/types/time_spec.hpp> +#include <stdint.h> +#include <functional> + +namespace uhd { + +//! Represents a 32-bit, memory-mapped interface (peek/poke). +// This is a simplified version of wb_iface, useful for those cases when we use +// closures to provide bespoke peek/poke interfaces to objects. +struct UHD_API memmap32_iface +{ +    using poke32_fn_t = std::function<void(const uint32_t addr, const uint32_t data)>; +    using peek32_fn_t = std::function<uint32_t(const uint32_t addr)>; + +    poke32_fn_t poke32; +    peek32_fn_t peek32; +}; + +//! Represents a 32-bit, memory-mapped interface (peek/poke). +// +// The difference to memmap32_iface is that the poke command will require a command +// time. +struct UHD_API memmap32_iface_timed +{ +    using poke32_fn_t = std::function<void( +        const uint32_t addr, const uint32_t data, const uhd::time_spec_t& time)>; +    using peek32_fn_t = std::function<uint32_t(const uint32_t addr)>; + +    poke32_fn_t poke32; +    peek32_fn_t peek32; +}; + +} // namespace uhd | 
