mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-09-04 20:19:47 +08:00
Common:
- improve heuristic for boosting preempted spinlocks by ignoring VCPUs
in user mode
ARM:
- fix for decoding external abort types from guests
- added support for migrating the active priority of interrupts when
running a GICv2 guest on a GICv3 host
- minor cleanup
PPC:
- expose storage keys to userspace
- merge powerpc/topic/ppc-kvm branch that contains
find_linux_pte_or_hugepte and POWER9 thread management cleanup
- merge kvm-ppc-fixes with a fix that missed 4.13 because of vacations
- fixes
s390:
- merge of topic branch tlb-flushing from the s390 tree to get the
no-dat base features
- merge of kvm/master to avoid conflicts with additional sthyi fixes
- wire up the no-dat enhancements in KVM
- multiple epoch facility (z14 feature)
- Configuration z/Architecture Mode
- more sthyi fixes
- gdb server range checking fix
- small code cleanups
x86:
- emulate Hyper-V TSC frequency MSRs
- add nested INVPCID
- emulate EPTP switching VMFUNC
- support Virtual GIF
- support 5 level page tables
- speedup nested VM exits by packing byte operations
- speedup MMIO by using hardware provided physical address
- a lot of fixes and cleanups, especially nested
-----BEGIN PGP SIGNATURE-----
iQEcBAABCAAGBQJZspE1AAoJEED/6hsPKofoDcMIALT11n+LKV50QGwQdg2W1GOt
aChbgnj/Kegit3hQlDhVNb8kmdZEOZzSL81Lh0VPEr7zXU8QiWn2snbizDPv8sde
MpHhcZYZZ0YrpoiZKjl8yiwcu88OWGn2qtJ7OpuTS5hvEGAfxMncp0AMZho6fnz/
ySTwJ9GK2MTgBw39OAzCeDOeoYn4NKYMwjJGqBXRhNX8PG/1wmfqv0vPrd6wfg31
KJ58BumavwJjr8YbQ1xELm9rpQrAmaayIsG0R1dEUqCbt5a1+t2gt4h2uY7tWcIv
ACt2bIze7eF3xA+OpRs+eT+yemiH3t9btIVmhCfzUpnQ+V5Z55VMSwASLtTuJRQ=
=R8Ry
-----END PGP SIGNATURE-----
Merge tag 'kvm-4.14-1' of git://git.kernel.org/pub/scm/virt/kvm/kvm
Pull KVM updates from Radim Krčmář:
"First batch of KVM changes for 4.14
Common:
- improve heuristic for boosting preempted spinlocks by ignoring
VCPUs in user mode
ARM:
- fix for decoding external abort types from guests
- added support for migrating the active priority of interrupts when
running a GICv2 guest on a GICv3 host
- minor cleanup
PPC:
- expose storage keys to userspace
- merge kvm-ppc-fixes with a fix that missed 4.13 because of
vacations
- fixes
s390:
- merge of kvm/master to avoid conflicts with additional sthyi fixes
- wire up the no-dat enhancements in KVM
- multiple epoch facility (z14 feature)
- Configuration z/Architecture Mode
- more sthyi fixes
- gdb server range checking fix
- small code cleanups
x86:
- emulate Hyper-V TSC frequency MSRs
- add nested INVPCID
- emulate EPTP switching VMFUNC
- support Virtual GIF
- support 5 level page tables
- speedup nested VM exits by packing byte operations
- speedup MMIO by using hardware provided physical address
- a lot of fixes and cleanups, especially nested"
* tag 'kvm-4.14-1' of git://git.kernel.org/pub/scm/virt/kvm/kvm: (67 commits)
KVM: arm/arm64: Support uaccess of GICC_APRn
KVM: arm/arm64: Extract GICv3 max APRn index calculation
KVM: arm/arm64: vITS: Drop its_ite->lpi field
KVM: arm/arm64: vgic: constify seq_operations and file_operations
KVM: arm/arm64: Fix guest external abort matching
KVM: PPC: Book3S HV: Fix memory leak in kvm_vm_ioctl_get_htab_fd
KVM: s390: vsie: cleanup mcck reinjection
KVM: s390: use WARN_ON_ONCE only for checking
KVM: s390: guestdbg: fix range check
KVM: PPC: Book3S HV: Report storage key support to userspace
KVM: PPC: Book3S HV: Fix case where HDEC is treated as 32-bit on POWER9
KVM: PPC: Book3S HV: Fix invalid use of register expression
KVM: PPC: Book3S HV: Fix H_REGISTER_VPA VPA size validation
KVM: PPC: Book3S HV: Fix setting of storage key in H_ENTER
KVM: PPC: e500mc: Fix a NULL dereference
KVM: PPC: e500: Fix some NULL dereferences on error
KVM: PPC: Book3S HV: Protect updates to spapr_tce_tables list
KVM: s390: we are always in czam mode
KVM: s390: expose no-DAT to guest and migration support
KVM: s390: sthyi: remove invalid guest write access
...
142 lines
3.5 KiB
C
142 lines
3.5 KiB
C
/*
|
|
* Simple program to generate defines out of facility lists that use the bit
|
|
* numbering scheme from the Princples of Operations: most significant bit
|
|
* has bit number 0.
|
|
*
|
|
* Copyright IBM Corp. 2015
|
|
*
|
|
*/
|
|
|
|
#include <strings.h>
|
|
#include <string.h>
|
|
#include <stdlib.h>
|
|
#include <stdio.h>
|
|
|
|
struct facility_def {
|
|
char *name;
|
|
int *bits;
|
|
};
|
|
|
|
static struct facility_def facility_defs[] = {
|
|
{
|
|
/*
|
|
* FACILITIES_ALS contains the list of facilities that are
|
|
* required to run a kernel that is compiled e.g. with
|
|
* -march=<machine>.
|
|
*/
|
|
.name = "FACILITIES_ALS",
|
|
.bits = (int[]){
|
|
#ifdef CONFIG_HAVE_MARCH_Z900_FEATURES
|
|
0, /* N3 instructions */
|
|
1, /* z/Arch mode installed */
|
|
#endif
|
|
#ifdef CONFIG_HAVE_MARCH_Z990_FEATURES
|
|
18, /* long displacement facility */
|
|
#endif
|
|
#ifdef CONFIG_HAVE_MARCH_Z9_109_FEATURES
|
|
21, /* extended-immediate facility */
|
|
25, /* store clock fast */
|
|
#endif
|
|
#ifdef CONFIG_HAVE_MARCH_Z10_FEATURES
|
|
27, /* mvcos */
|
|
32, /* compare and swap and store */
|
|
33, /* compare and swap and store 2 */
|
|
34, /* general instructions extension */
|
|
35, /* execute extensions */
|
|
#endif
|
|
#ifdef CONFIG_HAVE_MARCH_Z196_FEATURES
|
|
45, /* fast-BCR, etc. */
|
|
#endif
|
|
#ifdef CONFIG_HAVE_MARCH_ZEC12_FEATURES
|
|
49, /* misc-instruction-extensions */
|
|
52, /* interlocked facility 2 */
|
|
#endif
|
|
#ifdef CONFIG_HAVE_MARCH_Z13_FEATURES
|
|
53, /* load-and-zero-rightmost-byte, etc. */
|
|
#endif
|
|
#ifdef CONFIG_HAVE_MARCH_Z14_FEATURES
|
|
58, /* miscellaneous-instruction-extension 2 */
|
|
#endif
|
|
-1 /* END */
|
|
}
|
|
},
|
|
{
|
|
.name = "FACILITIES_KVM",
|
|
.bits = (int[]){
|
|
0, /* N3 instructions */
|
|
1, /* z/Arch mode installed */
|
|
2, /* z/Arch mode active */
|
|
3, /* DAT-enhancement */
|
|
4, /* idte segment table */
|
|
5, /* idte region table */
|
|
6, /* ASN-and-LX reuse */
|
|
7, /* stfle */
|
|
8, /* enhanced-DAT 1 */
|
|
9, /* sense-running-status */
|
|
10, /* conditional sske */
|
|
13, /* ipte-range */
|
|
14, /* nonquiescing key-setting */
|
|
73, /* transactional execution */
|
|
75, /* access-exception-fetch/store indication */
|
|
76, /* msa extension 3 */
|
|
77, /* msa extension 4 */
|
|
78, /* enhanced-DAT 2 */
|
|
130, /* instruction-execution-protection */
|
|
131, /* enhanced-SOP 2 and side-effect */
|
|
139, /* multiple epoch facility */
|
|
146, /* msa extension 8 */
|
|
-1 /* END */
|
|
}
|
|
},
|
|
};
|
|
|
|
static void print_facility_list(struct facility_def *def)
|
|
{
|
|
unsigned int high, bit, dword, i;
|
|
unsigned long long *array;
|
|
|
|
array = calloc(1, 8);
|
|
if (!array)
|
|
exit(EXIT_FAILURE);
|
|
high = 0;
|
|
for (i = 0; def->bits[i] != -1; i++) {
|
|
bit = 63 - (def->bits[i] & 63);
|
|
dword = def->bits[i] / 64;
|
|
if (dword > high) {
|
|
array = realloc(array, (dword + 1) * 8);
|
|
if (!array)
|
|
exit(EXIT_FAILURE);
|
|
memset(array + high + 1, 0, (dword - high) * 8);
|
|
high = dword;
|
|
}
|
|
array[dword] |= 1ULL << bit;
|
|
}
|
|
printf("#define %s ", def->name);
|
|
for (i = 0; i <= high; i++)
|
|
printf("_AC(0x%016llx,UL)%c", array[i], i < high ? ',' : '\n');
|
|
free(array);
|
|
}
|
|
|
|
static void print_facility_lists(void)
|
|
{
|
|
unsigned int i;
|
|
|
|
for (i = 0; i < sizeof(facility_defs) / sizeof(facility_defs[0]); i++)
|
|
print_facility_list(&facility_defs[i]);
|
|
}
|
|
|
|
int main(int argc, char **argv)
|
|
{
|
|
printf("#ifndef __ASM_S390_FACILITIES__\n");
|
|
printf("#define __ASM_S390_FACILITIES__\n");
|
|
printf("/*\n");
|
|
printf(" * DO NOT MODIFY.\n");
|
|
printf(" *\n");
|
|
printf(" * This file was generated by %s\n", __FILE__);
|
|
printf(" */\n\n");
|
|
printf("#include <linux/const.h>\n\n");
|
|
print_facility_lists();
|
|
printf("\n#endif\n");
|
|
return 0;
|
|
}
|