1
0
Fork 0
mirror of https://git.rwth-aachen.de/acs/public/villas/node/ synced 2025-03-16 00:00:02 +01:00
VILLASnode/common/include/villas/kernel/pci.hpp

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

141 lines
2.6 KiB
C++
Raw Normal View History

2020-06-14 21:52:29 +02:00
/** Linux PCI helpers
*
* @file
* @author Steffen Vogel <stvogel@eonerc.rwth-aachen.de>
* @copyright 2014-2020, Institute for Automation of Complex Power Systems, EONERC
* @license GNU General Public License (version 3)
*
* VILLAScommon
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*********************************************************************************/
/** @addtogroup fpga Kernel @{ */
#pragma once
#include <cstddef>
#include <cstdint>
#include <list>
namespace villas {
namespace kernel {
namespace pci {
#define PCI_SLOT(devfn) (((devfn) >> 3) & 0x1f)
#define PCI_FUNC(devfn) ((devfn) & 0x07)
class Id {
public:
Id(const std::string &str);
Id(int vid = 0, int did = 0, int cc = 0) :
vendor(vid),
device(did),
class_code(cc)
{ }
bool
operator==(const Id &i);
int vendor;
int device;
int class_code;
};
class Slot {
public:
Slot(const std::string &str);
Slot(int dom = 0, int b = 0, int dev = 0, int fcn = 0) :
domain(dom),
bus(b),
device(dev),
function(fcn)
{ }
bool
operator==(const Slot &s);
int domain;
int bus;
int device;
int function;
};
struct Region {
int num;
uintptr_t start;
uintptr_t end;
unsigned long long flags;
};
class Device {
public:
Device(Id i, Slot s) :
id(i),
slot(s)
{ }
bool
operator==(const Device &other);
bool
operator==(const Id &other);
bool
operator==(const Slot &other);
/** Get currently loaded driver for device */
std::string
getDriver() const;
/** Bind a new LKM to the PCI device */
bool
attachDriver(const std::string &driver) const;
/** Return the IOMMU group of this PCI device or -1 if the device is not in a group. */
int
getIOMMUGroup() const;
std::list<Region>
getRegions() const;
Id id;
Slot slot;
};
class DeviceList : public std::list<Device> {
public:
/** Initialize Linux PCI handle.
*
* This search for all available PCI devices under /sys/bus/pci
*/
DeviceList();
Device &
lookupDevice(const Slot &slot);
Device &
lookupDevice(const Id &id);
};
} /* namespace pci */
} /* namespace kernel */
} /* namespace villas */
/** @} */