Nicholas Piggin
b755745147
KVM: PPC: Book3S HV: Lockless tlbie for HPT hcalls
...
tlbies to an LPAR do not have to be serialised since POWER4/PPC970,
after which the MMU_FTR_LOCKLESS_TLBIE feature was introduced to
avoid tlbie locking.
Since commit c17b98cf60 ("KVM: PPC: Book3S HV: Remove code for
PPC970 processors"), KVM no longer supports processors that do not
have this feature, so the tlbie locking can be removed completely.
A sanity check for the feature is put in kvmppc_mmu_hv_init.
Testing was done on a POWER9 system in HPT mode, with a -smp 32 guest
in HPT mode. 32 instances of the powerpc fork benchmark from selftests
were run with --fork, and the results measured.
Without this patch, total throughput was about 13.5K/sec, and this is
the top of the host profile:
74.52% [k] do_tlbies
2.95% [k] kvmppc_book3s_hv_page_fault
1.80% [k] calc_checksum
1.80% [k] kvmppc_vcpu_run_hv
1.49% [k] kvmppc_run_core
After this patch, throughput was about 51K/sec, with this profile:
21.28% [k] do_tlbies
5.26% [k] kvmppc_run_core
4.88% [k] kvmppc_book3s_hv_page_fault
3.30% [k] _raw_spin_lock_irqsave
3.25% [k] gup_pgd_range
Signed-off-by: Nicholas Piggin <npiggin@gmail.com >
Signed-off-by: Paul Mackerras <paulus@ozlabs.org >
2018-05-18 15:38:23 +10:00
..
2018-05-17 11:13:29 +10:00
2018-03-06 09:21:24 +11:00
2017-01-14 09:54:12 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-08-31 14:26:47 +10:00
2018-03-24 08:43:18 +11:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-03-31 00:10:34 +11:00
2017-06-02 19:23:56 +10:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-01-22 11:44:24 +11:00
2017-11-02 11:10:55 +01:00
2018-03-20 16:47:53 +11:00
2017-11-02 11:10:55 +01:00
2017-03-04 23:07:17 +11:00
2017-11-02 11:10:55 +01:00
2018-01-21 15:06:25 +11:00
2018-01-15 19:56:20 -06:00
2017-11-02 11:10:55 +01:00
2014-10-08 20:15:37 +11:00
2018-01-20 23:29:02 -06:00
2017-11-02 11:10:55 +01:00
2018-01-20 23:29:02 -06:00
2017-11-02 11:10:55 +01:00
2016-07-21 20:33:57 +10:00
2017-11-02 11:10:55 +01:00
2018-04-13 23:51:44 +10:00
2017-11-02 11:10:55 +01:00
2017-02-01 09:14:07 +01:00
2017-11-02 11:10:55 +01:00
2017-06-19 19:46:27 +10:00
2014-05-23 08:28:02 +09:00
2016-08-01 11:15:03 +10:00
2017-11-02 11:10:55 +01:00
2018-03-27 23:52:43 +11:00
2017-04-11 07:46:03 +10:00
2017-07-02 20:40:24 +10:00
2017-01-24 12:23:35 -05:00
2017-04-20 11:36:41 +10:00
2018-03-20 10:01:59 +01:00
2018-01-10 16:41:14 +01:00
2017-11-02 11:10:55 +01:00
2018-01-16 23:26:29 +11:00
2017-11-02 11:10:55 +01:00
2015-05-28 15:31:53 +02:00
2018-03-27 23:44:58 +11:00
2018-03-27 23:45:19 +11:00
2017-07-10 16:32:36 -07:00
2017-09-27 08:23:22 +10:00
2018-03-13 15:50:32 +11:00
2018-01-10 03:07:30 +11:00
2018-02-08 23:56:10 +11:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-08-31 14:26:04 +10:00
2017-11-02 11:10:55 +01:00
2018-01-10 21:27:06 +11:00
2018-02-22 14:32:32 +11:00
2017-08-15 22:55:58 +10:00
2017-10-19 16:37:08 +02:00
2017-08-10 23:32:12 +10:00
2012-11-15 13:00:58 +11:00
2017-02-27 18:43:46 -08:00
2015-01-12 05:04:13 -08:00
2015-02-03 18:47:18 +01:00
2016-03-04 23:50:27 -06:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-01-18 15:43:43 +11:00
2018-01-19 22:37:02 +11:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-01-18 15:31:25 +11:00
2018-04-07 12:08:19 -07:00
2018-03-27 23:55:49 +11:00
2017-11-02 11:10:55 +01:00
2018-04-04 21:54:02 +10:00
2018-02-08 23:56:10 +11:00
2016-03-01 19:27:20 +11:00
2017-11-02 11:10:55 +01:00
2013-06-12 12:37:26 +01:00
2017-09-01 16:42:50 +10:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-01-19 23:05:00 +11:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2013-01-03 15:57:04 -08:00
2018-04-05 14:58:52 +10:00
2017-06-28 06:54:33 -07:00
2018-03-13 15:50:37 +11:00
2018-03-13 15:50:38 +11:00
2018-01-19 22:37:01 +11:00
2017-11-02 11:10:55 +01:00
2016-08-05 09:00:54 -04:00
2018-01-03 09:02:11 -08:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-04-13 17:10:27 -07:00
2017-11-02 11:10:55 +01:00
2012-07-24 15:27:29 +08:00
2017-10-04 23:42:17 +11:00
2018-03-24 00:39:13 +11:00
2013-10-17 14:45:05 +02:00
2018-05-18 15:38:23 +10:00
2018-03-24 00:39:13 +11:00
2018-05-18 15:38:23 +10:00
2014-03-19 19:57:15 -05:00
2018-05-18 15:38:23 +10:00
2018-05-18 15:38:23 +10:00
2018-03-06 18:40:44 +01:00
2018-04-09 11:42:31 -07:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2016-12-19 11:15:25 +01:00
2018-01-19 22:37:04 +11:00
2018-04-03 21:50:07 +10:00
2012-04-24 15:34:16 -07:00
2018-01-21 23:21:14 +11:00
2017-11-02 11:10:55 +01:00
2017-10-16 23:12:01 +11:00
2017-11-02 11:10:55 +01:00
2018-02-05 21:34:31 +01:00
2015-06-24 17:49:41 -07:00
2018-03-18 07:38:47 -07:00
2018-03-31 00:10:38 +11:00
2018-03-13 23:43:06 +11:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-04-01 00:47:50 +11:00
2017-11-02 11:10:55 +01:00
2018-04-09 13:21:02 +10:00
2017-11-02 11:10:55 +01:00
2015-10-22 16:06:08 +02:00
2016-07-14 21:12:06 +10:00
2015-03-31 22:23:17 -05:00
2015-10-22 15:19:40 +02:00
2017-11-02 11:10:55 +01:00
2016-09-20 20:57:12 +10:00
2018-01-21 15:06:16 +11:00
2017-11-02 11:10:55 +01:00
2015-10-05 21:32:50 +11:00
2018-01-18 15:43:43 +11:00
2015-03-23 14:05:49 +11:00
2017-11-02 11:10:55 +01:00
2018-03-13 15:50:30 +11:00
2018-04-11 00:05:23 +10:00
2014-07-28 14:10:25 +10:00
2018-03-31 09:09:36 +11:00
2017-11-02 11:10:55 +01:00
2018-03-06 09:21:22 +11:00
2018-03-13 15:50:41 +11:00
2017-11-02 11:10:55 +01:00
2018-01-27 20:39:01 +11:00
2018-02-28 16:18:53 -06:00
2017-11-02 11:10:55 +01:00
2013-08-07 18:38:03 -05:00
2018-03-27 19:25:10 +11:00
2014-10-15 11:23:20 +11:00
2017-11-15 18:21:04 -08:00
2017-11-16 12:47:46 -08:00
2017-11-16 12:47:46 -08:00
2017-11-02 11:10:55 +01:00
2018-01-21 01:06:10 +11:00
2018-03-30 23:34:22 +11:00
2016-06-14 13:58:26 +10:00
2017-11-02 11:10:55 +01:00
2018-03-30 23:34:22 +11:00
2018-01-24 11:42:58 +11:00
2018-03-13 15:50:30 +11:00
2018-04-24 09:46:57 +10:00
2013-01-10 15:08:37 +11:00
2016-07-14 21:12:06 +10:00
2018-04-01 00:47:49 +11:00
2018-03-24 08:43:18 +11:00
2016-11-22 11:57:08 +11:00
2013-06-20 16:55:09 +10:00
2018-04-01 00:47:46 +11:00
2018-01-21 16:21:46 +11:00
2017-01-24 12:23:35 -05:00
2016-06-14 13:58:26 +10:00
2018-01-16 23:47:14 +11:00
2017-08-17 23:13:46 +10:00
2016-06-14 13:58:27 +10:00
2018-01-16 23:47:12 +11:00
2014-06-11 16:35:38 +10:00
2017-08-03 16:06:52 +10:00
2017-11-02 11:10:55 +01:00
2018-05-17 16:36:48 +10:00
2014-09-25 23:14:43 +10:00
2017-02-17 17:57:30 +11:00
2017-11-02 11:10:55 +01:00
2013-11-06 14:13:49 +11:00
2017-11-02 11:10:55 +01:00
2018-01-09 10:45:37 +01:00
2018-04-03 21:50:08 +10:00
2018-03-31 09:09:36 +11:00
2013-10-11 17:26:49 +11:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-03-13 23:43:05 +11:00
2018-03-30 23:34:27 +11:00
2017-11-02 11:10:55 +01:00
2018-03-31 00:07:10 +11:00
2017-11-02 11:10:55 +01:00
2018-04-03 21:50:07 +10:00
2015-08-18 19:29:49 +10:00
2012-10-09 09:47:26 +01:00
2014-10-08 20:14:54 +11:00
2017-09-01 16:42:44 +10:00
2017-11-16 12:47:46 -08:00
2015-03-24 13:33:52 +11:00
2018-01-15 09:35:26 +01:00
2018-03-13 15:50:35 +11:00
2018-03-31 00:10:34 +11:00
2015-07-29 11:56:13 +10:00
2017-11-02 11:10:55 +01:00
2018-01-21 01:06:16 +11:00
2016-07-17 16:42:47 +10:00
2012-10-09 09:47:26 +01:00
2018-03-13 15:50:37 +11:00
2018-03-24 08:43:18 +11:00
2017-11-02 11:10:55 +01:00
2017-08-23 22:28:38 +10:00
2017-11-06 16:48:14 +11:00
2017-11-16 12:47:46 -08:00
2018-02-15 10:10:02 +11:00
2015-08-06 16:36:23 +10:00
2017-11-02 11:10:55 +01:00
2015-09-16 15:47:51 +02:00
2016-06-14 13:58:26 +10:00
2016-06-14 13:58:27 +10:00
2018-03-13 15:50:41 +11:00
2014-09-25 23:14:43 +10:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-01-21 01:06:16 +11:00
2013-11-20 16:31:01 +01:00
2017-11-02 11:10:55 +01:00
2017-11-12 09:03:10 +11:00
2015-11-26 22:11:17 +11:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2015-05-05 13:35:39 -06:00
2016-11-14 11:11:51 +11:00
2017-11-02 11:10:55 +01:00
2016-11-29 09:14:50 +00:00
2018-01-12 15:24:41 +11:00
2018-02-10 13:16:35 -08:00
2017-04-10 21:41:34 +10:00
2016-08-01 11:15:03 +10:00