#include "xe_device.h"
#include "xe_gt_sriov_pf_control.h"
#include "xe_gt_sriov_pf_migration.h"
#include "xe_sriov_packet.h"
#include "xe_sriov_pf_control.h"
#include "xe_sriov_printk.h"
int xe_sriov_pf_control_pause_vf(struct xe_device *xe, unsigned int vfid)
{
struct xe_gt *gt;
unsigned int id;
int result = 0;
int err;
for_each_gt(gt, xe, id) {
err = xe_gt_sriov_pf_control_pause_vf(gt, vfid);
result = result ? -EUCLEAN : err;
}
if (result)
return result;
xe_sriov_info(xe, "VF%u paused!\n", vfid);
return 0;
}
int xe_sriov_pf_control_resume_vf(struct xe_device *xe, unsigned int vfid)
{
struct xe_gt *gt;
unsigned int id;
int result = 0;
int err;
for_each_gt(gt, xe, id) {
err = xe_gt_sriov_pf_control_resume_vf(gt, vfid);
result = result ? -EUCLEAN : err;
}
if (result)
return result;
xe_sriov_info(xe, "VF%u resumed!\n", vfid);
return 0;
}
int xe_sriov_pf_control_stop_vf(struct xe_device *xe, unsigned int vfid)
{
struct xe_gt *gt;
unsigned int id;
int result = 0;
int err;
for_each_gt(gt, xe, id) {
err = xe_gt_sriov_pf_control_stop_vf(gt, vfid);
result = result ? -EUCLEAN : err;
}
if (result)
return result;
xe_sriov_info(xe, "VF%u stopped!\n", vfid);
return 0;
}
int xe_sriov_pf_control_reset_vf(struct xe_device *xe, unsigned int vfid)
{
struct xe_gt *gt;
unsigned int id;
int result = 0;
int err;
for_each_gt(gt, xe, id) {
err = xe_gt_sriov_pf_control_trigger_flr(gt, vfid);
result = result ? -EUCLEAN : err;
}
for_each_gt(gt, xe, id) {
err = xe_gt_sriov_pf_control_wait_flr(gt, vfid);
result = result ? -EUCLEAN : err;
}
return result;
}
int xe_sriov_pf_control_wait_flr(struct xe_device *xe, unsigned int vfid)
{
struct xe_gt *gt;
unsigned int id;
int result = 0;
int err;
for_each_gt(gt, xe, id) {
err = xe_gt_sriov_pf_control_wait_flr(gt, vfid);
result = result ? -EUCLEAN : err;
}
return result;
}
int xe_sriov_pf_control_sync_flr(struct xe_device *xe, unsigned int vfid)
{
struct xe_gt *gt;
unsigned int id;
int ret;
for_each_gt(gt, xe, id) {
ret = xe_gt_sriov_pf_control_sync_flr(gt, vfid, false);
if (ret < 0)
return ret;
}
for_each_gt(gt, xe, id) {
ret = xe_gt_sriov_pf_control_sync_flr(gt, vfid, true);
if (ret < 0)
return ret;
}
return 0;
}
int xe_sriov_pf_control_trigger_save_vf(struct xe_device *xe, unsigned int vfid)
{
struct xe_gt *gt;
unsigned int id;
int ret;
ret = xe_sriov_packet_save_init(xe, vfid);
if (ret)
return ret;
for_each_gt(gt, xe, id) {
xe_gt_sriov_pf_migration_save_init(gt, vfid);
ret = xe_gt_sriov_pf_control_trigger_save_vf(gt, vfid);
if (ret)
return ret;
}
return 0;
}
int xe_sriov_pf_control_finish_save_vf(struct xe_device *xe, unsigned int vfid)
{
struct xe_gt *gt;
unsigned int id;
int ret;
for_each_gt(gt, xe, id) {
ret = xe_gt_sriov_pf_control_finish_save_vf(gt, vfid);
if (ret)
break;
}
return ret;
}
int xe_sriov_pf_control_trigger_restore_vf(struct xe_device *xe, unsigned int vfid)
{
struct xe_gt *gt;
unsigned int id;
int ret;
for_each_gt(gt, xe, id) {
ret = xe_gt_sriov_pf_control_trigger_restore_vf(gt, vfid);
if (ret)
return ret;
}
return ret;
}
int xe_sriov_pf_control_finish_restore_vf(struct xe_device *xe, unsigned int vfid)
{
struct xe_gt *gt;
unsigned int id;
int ret;
for_each_gt(gt, xe, id) {
ret = xe_gt_sriov_pf_control_finish_restore_vf(gt, vfid);
if (ret)
break;
}
return ret;
}