Commit 98e62805 authored by Michal Wajdeczko's avatar Michal Wajdeczko

drm/xe/pf: Add SR-IOV GuC Relay PF services

We already have mechanism that allows a VF driver to communicate
with the PF driver, now add PF side handlers for VF2PF requests
defined in version 1.0 of VF/PF GuC Relay ABI specification.

The VF2PF_HANDSHAKE request must be used by the VF driver to
negotiate the ABI version prior to sending any other request.
We will reset any negotiated version later during FLR.

The outcome of the VF2PF_QUERY_RUNTIME requests depends on actual
platform, for legacy platforms used as SDV is provided as-is, for
latest platforms it is preliminary, and might be changed.
Signed-off-by: default avatarMichal Wajdeczko <michal.wajdeczko@intel.com>
Reviewed-by: default avatarPiotr Piórkowski <piotr.piorkowski@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20240423180436.2089-5-michal.wajdeczko@intel.com
parent dec79386
...@@ -164,6 +164,7 @@ xe-$(CONFIG_PCI_IOV) += \ ...@@ -164,6 +164,7 @@ xe-$(CONFIG_PCI_IOV) += \
xe_gt_sriov_pf_config.o \ xe_gt_sriov_pf_config.o \
xe_gt_sriov_pf_control.o \ xe_gt_sriov_pf_control.o \
xe_gt_sriov_pf_policy.o \ xe_gt_sriov_pf_policy.o \
xe_gt_sriov_pf_service.o \
xe_lmtt.o \ xe_lmtt.o \
xe_lmtt_2l.o \ xe_lmtt_2l.o \
xe_lmtt_ml.o \ xe_lmtt_ml.o \
......
This diff is collapsed.
/* SPDX-License-Identifier: MIT */
/*
* Copyright © 2023-2024 Intel Corporation
*/
#ifndef _XE_GT_SRIOV_PF_SERVICE_H_
#define _XE_GT_SRIOV_PF_SERVICE_H_
#include <linux/errno.h>
#include <linux/types.h>
struct drm_printer;
struct xe_gt;
int xe_gt_sriov_pf_service_init(struct xe_gt *gt);
void xe_gt_sriov_pf_service_update(struct xe_gt *gt);
void xe_gt_sriov_pf_service_reset(struct xe_gt *gt, unsigned int vfid);
int xe_gt_sriov_pf_service_print_version(struct xe_gt *gt, struct drm_printer *p);
int xe_gt_sriov_pf_service_print_runtime(struct xe_gt *gt, struct drm_printer *p);
#ifdef CONFIG_PCI_IOV
int xe_gt_sriov_pf_service_process_request(struct xe_gt *gt, u32 origin,
const u32 *msg, u32 msg_len,
u32 *response, u32 resp_size);
#else
static inline int
xe_gt_sriov_pf_service_process_request(struct xe_gt *gt, u32 origin,
const u32 *msg, u32 msg_len,
u32 *response, u32 resp_size)
{
return -EPROTO;
}
#endif
#endif
/* SPDX-License-Identifier: MIT */
/*
* Copyright © 2023-2024 Intel Corporation
*/
#ifndef _XE_GT_SRIOV_PF_SERVICE_TYPES_H_
#define _XE_GT_SRIOV_PF_SERVICE_TYPES_H_
#include <linux/types.h>
struct xe_reg;
/**
* struct xe_gt_sriov_pf_service_version - VF/PF ABI Version.
* @major: the major version of the VF/PF ABI
* @minor: the minor version of the VF/PF ABI
*
* See `GuC Relay Communication`_.
*/
struct xe_gt_sriov_pf_service_version {
u16 major;
u16 minor;
};
/**
* struct xe_gt_sriov_pf_service_runtime_regs - Runtime data shared with VFs.
* @regs: pointer to static array with register offsets.
* @values: pointer to array with captured register values.
* @size: size of the regs and value arrays.
*/
struct xe_gt_sriov_pf_service_runtime_regs {
const struct xe_reg *regs;
u32 *values;
u32 size;
};
/**
* struct xe_gt_sriov_pf_service - Data used by the PF service.
* @version: information about VF/PF ABI versions for current platform.
* @version.base: lowest VF/PF ABI version that could be negotiated with VF.
* @version.latest: latest VF/PF ABI version supported by the PF driver.
* @runtime: runtime data shared with VFs.
*/
struct xe_gt_sriov_pf_service {
struct {
struct xe_gt_sriov_pf_service_version base;
struct xe_gt_sriov_pf_service_version latest;
} version;
struct xe_gt_sriov_pf_service_runtime_regs runtime;
};
#endif
...@@ -10,6 +10,7 @@ ...@@ -10,6 +10,7 @@
#include "xe_gt_sriov_pf_config_types.h" #include "xe_gt_sriov_pf_config_types.h"
#include "xe_gt_sriov_pf_policy_types.h" #include "xe_gt_sriov_pf_policy_types.h"
#include "xe_gt_sriov_pf_service_types.h"
/** /**
* struct xe_gt_sriov_metadata - GT level per-VF metadata. * struct xe_gt_sriov_metadata - GT level per-VF metadata.
...@@ -17,15 +18,19 @@ ...@@ -17,15 +18,19 @@
struct xe_gt_sriov_metadata { struct xe_gt_sriov_metadata {
/** @config: per-VF provisioning data. */ /** @config: per-VF provisioning data. */
struct xe_gt_sriov_config config; struct xe_gt_sriov_config config;
/** @version: negotiated VF/PF ABI version */
struct xe_gt_sriov_pf_service_version version;
}; };
/** /**
* struct xe_gt_sriov_pf - GT level PF virtualization data. * struct xe_gt_sriov_pf - GT level PF virtualization data.
* @service: service data.
* @policy: policy data. * @policy: policy data.
* @spare: PF-only provisioning configuration. * @spare: PF-only provisioning configuration.
* @vfs: metadata for all VFs. * @vfs: metadata for all VFs.
*/ */
struct xe_gt_sriov_pf { struct xe_gt_sriov_pf {
struct xe_gt_sriov_pf_service service;
struct xe_gt_sriov_pf_policy policy; struct xe_gt_sriov_pf_policy policy;
struct xe_gt_sriov_spare_config spare; struct xe_gt_sriov_spare_config spare;
struct xe_gt_sriov_metadata *vfs; struct xe_gt_sriov_metadata *vfs;
......
...@@ -19,6 +19,7 @@ ...@@ -19,6 +19,7 @@
#include "xe_device.h" #include "xe_device.h"
#include "xe_gt.h" #include "xe_gt.h"
#include "xe_gt_sriov_printk.h" #include "xe_gt_sriov_printk.h"
#include "xe_gt_sriov_pf_service.h"
#include "xe_guc.h" #include "xe_guc.h"
#include "xe_guc_ct.h" #include "xe_guc_ct.h"
#include "xe_guc_hxg_helpers.h" #include "xe_guc_hxg_helpers.h"
...@@ -664,6 +665,7 @@ static int relay_testloop_action_handler(struct xe_guc_relay *relay, u32 origin, ...@@ -664,6 +665,7 @@ static int relay_testloop_action_handler(struct xe_guc_relay *relay, u32 origin,
static int relay_action_handler(struct xe_guc_relay *relay, u32 origin, static int relay_action_handler(struct xe_guc_relay *relay, u32 origin,
const u32 *msg, u32 len, u32 *response, u32 size) const u32 *msg, u32 len, u32 *response, u32 size)
{ {
struct xe_gt *gt = relay_to_gt(relay);
u32 type; u32 type;
int ret; int ret;
...@@ -674,7 +676,9 @@ static int relay_action_handler(struct xe_guc_relay *relay, u32 origin, ...@@ -674,7 +676,9 @@ static int relay_action_handler(struct xe_guc_relay *relay, u32 origin,
type = FIELD_GET(GUC_HXG_MSG_0_TYPE, msg[0]); type = FIELD_GET(GUC_HXG_MSG_0_TYPE, msg[0]);
/* XXX: PF services will be added later */ if (IS_SRIOV_PF(relay_to_xe(relay)))
ret = xe_gt_sriov_pf_service_process_request(gt, origin, msg, len, response, size);
else
ret = -EOPNOTSUPP; ret = -EOPNOTSUPP;
if (type == GUC_HXG_TYPE_EVENT) if (type == GUC_HXG_TYPE_EVENT)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment