mirror of
https://github.com/torvalds/linux.git
synced 2024-12-31 23:31:29 +00:00
staging: unisys: visorbus: Merge iovmcall_gnuc into vmcallinterface
iovmcall_gnuc was only being referenced by vmcallinterface, so merge them together. Signed-off-by: David Kershner <david.kershner@unisys.com> Reviewed-by: Tim Sell <Timothy.Sell@unisys.com> Reported-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
b6d0fa15e8
commit
77190cfc45
@ -1,48 +0,0 @@
|
||||
/* Copyright (C) 2010 - 2015 UNISYS CORPORATION
|
||||
* All rights reserved.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms and conditions of the GNU General Public License,
|
||||
* version 2, as published by the Free Software Foundation.
|
||||
*
|
||||
* 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, GOOD TITLE or
|
||||
* NON INFRINGEMENT. See the GNU General Public License for more
|
||||
* details.
|
||||
*/
|
||||
|
||||
/* Linux GCC Version (32-bit and 64-bit) */
|
||||
static inline unsigned long
|
||||
__unisys_vmcall_gnuc(unsigned long tuple, unsigned long reg_ebx,
|
||||
unsigned long reg_ecx)
|
||||
{
|
||||
unsigned long result = 0;
|
||||
unsigned int cpuid_eax, cpuid_ebx, cpuid_ecx, cpuid_edx;
|
||||
|
||||
cpuid(0x00000001, &cpuid_eax, &cpuid_ebx, &cpuid_ecx, &cpuid_edx);
|
||||
if (!(cpuid_ecx & 0x80000000))
|
||||
return -EPERM;
|
||||
|
||||
__asm__ __volatile__(".byte 0x00f, 0x001, 0x0c1" : "=a"(result) :
|
||||
"a"(tuple), "b"(reg_ebx), "c"(reg_ecx));
|
||||
return result;
|
||||
}
|
||||
|
||||
static inline unsigned long
|
||||
__unisys_extended_vmcall_gnuc(unsigned long long tuple,
|
||||
unsigned long long reg_ebx,
|
||||
unsigned long long reg_ecx,
|
||||
unsigned long long reg_edx)
|
||||
{
|
||||
unsigned long result = 0;
|
||||
unsigned int cpuid_eax, cpuid_ebx, cpuid_ecx, cpuid_edx;
|
||||
|
||||
cpuid(0x00000001, &cpuid_eax, &cpuid_ebx, &cpuid_ecx, &cpuid_edx);
|
||||
if (!(cpuid_ecx & 0x80000000))
|
||||
return -EPERM;
|
||||
|
||||
__asm__ __volatile__(".byte 0x00f, 0x001, 0x0c1" : "=a"(result) :
|
||||
"a"(tuple), "b"(reg_ebx), "c"(reg_ecx), "d"(reg_edx));
|
||||
return result;
|
||||
}
|
@ -20,10 +20,39 @@
|
||||
* Virtualization. The VMCALLs are provided by Monitor and used by IO code
|
||||
* running on IO Partitions.
|
||||
*/
|
||||
static inline unsigned long
|
||||
__unisys_vmcall_gnuc(unsigned long tuple, unsigned long reg_ebx,
|
||||
unsigned long reg_ecx)
|
||||
{
|
||||
unsigned long result = 0;
|
||||
unsigned int cpuid_eax, cpuid_ebx, cpuid_ecx, cpuid_edx;
|
||||
|
||||
#ifdef __GNUC__
|
||||
#include "iovmcall_gnuc.h"
|
||||
#endif /* */
|
||||
cpuid(0x00000001, &cpuid_eax, &cpuid_ebx, &cpuid_ecx, &cpuid_edx);
|
||||
if (!(cpuid_ecx & 0x80000000))
|
||||
return -EPERM;
|
||||
|
||||
__asm__ __volatile__(".byte 0x00f, 0x001, 0x0c1" : "=a"(result) :
|
||||
"a"(tuple), "b"(reg_ebx), "c"(reg_ecx));
|
||||
return result;
|
||||
}
|
||||
|
||||
static inline unsigned long
|
||||
__unisys_extended_vmcall_gnuc(unsigned long long tuple,
|
||||
unsigned long long reg_ebx,
|
||||
unsigned long long reg_ecx,
|
||||
unsigned long long reg_edx)
|
||||
{
|
||||
unsigned long result = 0;
|
||||
unsigned int cpuid_eax, cpuid_ebx, cpuid_ecx, cpuid_edx;
|
||||
|
||||
cpuid(0x00000001, &cpuid_eax, &cpuid_ebx, &cpuid_ecx, &cpuid_edx);
|
||||
if (!(cpuid_ecx & 0x80000000))
|
||||
return -EPERM;
|
||||
|
||||
__asm__ __volatile__(".byte 0x00f, 0x001, 0x0c1" : "=a"(result) :
|
||||
"a"(tuple), "b"(reg_ebx), "c"(reg_ecx), "d"(reg_edx));
|
||||
return result;
|
||||
}
|
||||
|
||||
#ifdef VMCALL_IO_CONTROLVM_ADDR
|
||||
#undef VMCALL_IO_CONTROLVM_ADDR
|
||||
|
Loading…
Reference in New Issue
Block a user