mirror of
https://github.com/SerenityOS/serenity.git
synced 2025-01-26 03:12:07 -05:00
09b5cefd43
Add a struct named MSIInfo that stores all the relevant MSI information as a part of PCI DeviceIdentifier struct. Populate the MSI struct during the PCI device init.
40 lines
1.3 KiB
C++
40 lines
1.3 KiB
C++
/*
|
|
* Copyright (c) 2020, Liav A. <liavalb@hotmail.co.il>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include <AK/AnyOf.h>
|
|
#include <AK/Error.h>
|
|
#include <AK/NonnullRefPtr.h>
|
|
#include <AK/RefPtr.h>
|
|
#include <Kernel/Bus/PCI/Definitions.h>
|
|
|
|
namespace Kernel::PCI {
|
|
|
|
ErrorOr<NonnullRefPtr<DeviceIdentifier>> DeviceIdentifier::from_enumerable_identifier(EnumerableDeviceIdentifier const& other_identifier)
|
|
{
|
|
return adopt_nonnull_ref_or_enomem(new (nothrow) DeviceIdentifier(other_identifier));
|
|
}
|
|
|
|
void DeviceIdentifier::initialize()
|
|
{
|
|
for (auto cap : capabilities()) {
|
|
if (cap.id() == PCI::Capabilities::ID::MSIX) {
|
|
auto msix_bir_bar = (cap.read8(4) & msix_table_bir_mask);
|
|
auto msix_bir_offset = (cap.read32(4) & msix_table_offset_mask);
|
|
auto msix_count = (cap.read16(2) & msix_control_table_mask) + 1;
|
|
m_msix_info = MSIxInfo(msix_count, msix_bir_bar, msix_bir_offset);
|
|
}
|
|
|
|
if (cap.id() == PCI::Capabilities::ID::MSI) {
|
|
bool message_address_64_bit_format = (cap.read8(msi_control_offset) & msi_address_format_mask);
|
|
u8 count = 1;
|
|
u8 mme_count = (cap.read8(msi_control_offset) & msi_mmc_format_mask) >> 1;
|
|
if (mme_count)
|
|
count = mme_count;
|
|
m_msi_info = MSIInfo(message_address_64_bit_format, count);
|
|
}
|
|
}
|
|
}
|
|
}
|