mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-21 05:14:52 +08:00
d5bb994bcd
Based on 1 normalized pattern(s): 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 2 of the license or at your option 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 extracted by the scancode license scanner the SPDX license identifier GPL-2.0-or-later has been chosen to replace the boilerplate/reference in 8 file(s). Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Reviewed-by: Allison Randal <allison@lohutok.net> Reviewed-by: Richard Fontana <rfontana@redhat.com> Cc: linux-spdx@vger.kernel.org Link: https://lkml.kernel.org/r/20190523091650.663497195@linutronix.de Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
46 lines
1.1 KiB
C
46 lines
1.1 KiB
C
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
/*
|
|
* Hypervisor Maintenance Interrupt (HMI) handling.
|
|
*
|
|
* Copyright 2015 IBM Corporation
|
|
* Author: Mahesh Salgaonkar <mahesh@linux.vnet.ibm.com>
|
|
*/
|
|
|
|
#undef DEBUG
|
|
|
|
#include <linux/types.h>
|
|
#include <linux/compiler.h>
|
|
#include <asm/paca.h>
|
|
#include <asm/hmi.h>
|
|
#include <asm/processor.h>
|
|
|
|
void wait_for_subcore_guest_exit(void)
|
|
{
|
|
int i;
|
|
|
|
/*
|
|
* NULL bitmap pointer indicates that KVM module hasn't
|
|
* been loaded yet and hence no guests are running.
|
|
* If no KVM is in use, no need to co-ordinate among threads
|
|
* as all of them will always be in host and no one is going
|
|
* to modify TB other than the opal hmi handler.
|
|
* Hence, just return from here.
|
|
*/
|
|
if (!local_paca->sibling_subcore_state)
|
|
return;
|
|
|
|
for (i = 0; i < MAX_SUBCORE_PER_CORE; i++)
|
|
while (local_paca->sibling_subcore_state->in_guest[i])
|
|
cpu_relax();
|
|
}
|
|
|
|
void wait_for_tb_resync(void)
|
|
{
|
|
if (!local_paca->sibling_subcore_state)
|
|
return;
|
|
|
|
while (test_bit(CORE_TB_RESYNC_REQ_BIT,
|
|
&local_paca->sibling_subcore_state->flags))
|
|
cpu_relax();
|
|
}
|