/** FPGA card * * This class represents a FPGA device. * * Author: Steffen Vogel * Author: Daniel Krebs * SPDX-FileCopyrightText: 2017 Institute for Automation of Complex Power Systems, EONERC * SPDX-License-Identifier: Apache-2.0 *********************************************************************************/ #pragma once #include #include #include namespace villas { namespace fpga { class Card { public: bool polling; std::shared_ptr vfioDevice; // Slave address space ID to access the PCIe address space from the // FPGA MemoryManager::AddressSpaceId addrSpaceIdDeviceToHost; // Address space identifier of the master address space of this FPGA // card. This will be used for address resolution of all IPs on this // card. MemoryManager::AddressSpaceId addrSpaceIdHostToDevice; std::list > ips; virtual ~Card(); std::shared_ptr lookupIp(const std::string &name) const; std::shared_ptr lookupIp(const Vlnv &vlnv) const; std::shared_ptr lookupIp(const ip::IpIdentifier &id) const; bool mapMemoryBlock(const MemoryBlock &block); bool unmapMemoryBlock(const MemoryBlock &block); private: // Cache a set of already mapped memory blocks std::set memoryBlocksMapped; std::shared_ptr vfioContainer; protected: // Logger getLogger() const // { // return villas::logging.get(name); // } Logger logger; }; } /* namespace fpga */ } /* namespace villas */