25d9259519
No alternative CPU scheduler, Fsync or Nvidia prop blobs support
355 lines
11 KiB
Diff
355 lines
11 KiB
Diff
From 2ac70785613ef4c6b16414986bb18bd7b60d2a13 Mon Sep 17 00:00:00 2001
|
|
From: Arjan van de Ven <arjan@linux.intel.com>
|
|
Date: Mon, 14 Mar 2016 11:10:58 -0600
|
|
Subject: [PATCH] pci pme wakeups
|
|
|
|
Reduce wakeups for PME checks, which are a workaround for miswired
|
|
boards (sadly, too many of them) in laptops.
|
|
---
|
|
drivers/pci/pci.c | 2 +-
|
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
|
|
|
diff --git a/drivers/pci/pci.c b/drivers/pci/pci.c
|
|
index c25acace7d91..0ddebdad9f5b 100644
|
|
--- a/drivers/pci/pci.c
|
|
+++ b/drivers/pci/pci.c
|
|
@@ -61,7 +61,7 @@ struct pci_pme_device {
|
|
struct pci_dev *dev;
|
|
};
|
|
|
|
-#define PME_TIMEOUT 1000 /* How long between PME checks */
|
|
+#define PME_TIMEOUT 4000 /* How long between PME checks */
|
|
|
|
static void pci_dev_d3_sleep(struct pci_dev *dev)
|
|
{
|
|
--
|
|
2.20.1
|
|
|
|
From 7e7e36c67aa71d6a1ec5676d99d37c1fea389ceb Mon Sep 17 00:00:00 2001
|
|
From: Arjan van de Ven <arjan@linux.intel.com>
|
|
Date: Sat, 19 Mar 2016 21:32:19 -0400
|
|
Subject: [PATCH] intel_idle: tweak cpuidle cstates
|
|
|
|
Increase target_residency in cpuidle cstate
|
|
|
|
Tune intel_idle to be a bit less agressive;
|
|
Clear linux is cleaner in hygiene (wakupes) than the average linux,
|
|
so we can afford changing these in a way that increases
|
|
performance while keeping power efficiency
|
|
---
|
|
drivers/idle/intel_idle.c | 44 +++++++++++++++++++--------------------
|
|
1 file changed, 22 insertions(+), 22 deletions(-)
|
|
|
|
diff --git a/drivers/idle/intel_idle.c b/drivers/idle/intel_idle.c
|
|
index 8b5d85c91e9d..5e2d813a048d 100644
|
|
--- a/drivers/idle/intel_idle.c
|
|
+++ b/drivers/idle/intel_idle.c
|
|
@@ -466,7 +466,7 @@ static struct cpuidle_state hsw_cstates[] = {
|
|
.desc = "MWAIT 0x01",
|
|
.flags = MWAIT2flg(0x01),
|
|
.exit_latency = 10,
|
|
- .target_residency = 20,
|
|
+ .target_residency = 120,
|
|
.enter = &intel_idle,
|
|
.enter_s2idle = intel_idle_s2idle, },
|
|
{
|
|
@@ -474,7 +474,7 @@ static struct cpuidle_state hsw_cstates[] = {
|
|
.desc = "MWAIT 0x10",
|
|
.flags = MWAIT2flg(0x10) | CPUIDLE_FLAG_TLB_FLUSHED,
|
|
.exit_latency = 33,
|
|
- .target_residency = 100,
|
|
+ .target_residency = 900,
|
|
.enter = &intel_idle,
|
|
.enter_s2idle = intel_idle_s2idle, },
|
|
{
|
|
@@ -482,7 +482,7 @@ static struct cpuidle_state hsw_cstates[] = {
|
|
.desc = "MWAIT 0x20",
|
|
.flags = MWAIT2flg(0x20) | CPUIDLE_FLAG_TLB_FLUSHED,
|
|
.exit_latency = 133,
|
|
- .target_residency = 400,
|
|
+ .target_residency = 1000,
|
|
.enter = &intel_idle,
|
|
.enter_s2idle = intel_idle_s2idle, },
|
|
{
|
|
@@ -490,7 +490,7 @@ static struct cpuidle_state hsw_cstates[] = {
|
|
.desc = "MWAIT 0x32",
|
|
.flags = MWAIT2flg(0x32) | CPUIDLE_FLAG_TLB_FLUSHED,
|
|
.exit_latency = 166,
|
|
- .target_residency = 500,
|
|
+ .target_residency = 1500,
|
|
.enter = &intel_idle,
|
|
.enter_s2idle = intel_idle_s2idle, },
|
|
{
|
|
@@ -498,7 +498,7 @@ static struct cpuidle_state hsw_cstates[] = {
|
|
.desc = "MWAIT 0x40",
|
|
.flags = MWAIT2flg(0x40) | CPUIDLE_FLAG_TLB_FLUSHED,
|
|
.exit_latency = 300,
|
|
- .target_residency = 900,
|
|
+ .target_residency = 2000,
|
|
.enter = &intel_idle,
|
|
.enter_s2idle = intel_idle_s2idle, },
|
|
{
|
|
@@ -506,7 +506,7 @@ static struct cpuidle_state hsw_cstates[] = {
|
|
.desc = "MWAIT 0x50",
|
|
.flags = MWAIT2flg(0x50) | CPUIDLE_FLAG_TLB_FLUSHED,
|
|
.exit_latency = 600,
|
|
- .target_residency = 1800,
|
|
+ .target_residency = 5000,
|
|
.enter = &intel_idle,
|
|
.enter_s2idle = intel_idle_s2idle, },
|
|
{
|
|
@@ -514,7 +514,7 @@ static struct cpuidle_state hsw_cstates[] = {
|
|
.desc = "MWAIT 0x60",
|
|
.flags = MWAIT2flg(0x60) | CPUIDLE_FLAG_TLB_FLUSHED,
|
|
.exit_latency = 2600,
|
|
- .target_residency = 7700,
|
|
+ .target_residency = 9000,
|
|
.enter = &intel_idle,
|
|
.enter_s2idle = intel_idle_s2idle, },
|
|
{
|
|
@@ -534,7 +534,7 @@ static struct cpuidle_state bdw_cstates[] = {
|
|
.desc = "MWAIT 0x01",
|
|
.flags = MWAIT2flg(0x01),
|
|
.exit_latency = 10,
|
|
- .target_residency = 20,
|
|
+ .target_residency = 120,
|
|
.enter = &intel_idle,
|
|
.enter_s2idle = intel_idle_s2idle, },
|
|
{
|
|
@@ -542,7 +542,7 @@ static struct cpuidle_state bdw_cstates[] = {
|
|
.desc = "MWAIT 0x10",
|
|
.flags = MWAIT2flg(0x10) | CPUIDLE_FLAG_TLB_FLUSHED,
|
|
.exit_latency = 40,
|
|
- .target_residency = 100,
|
|
+ .target_residency = 1000,
|
|
.enter = &intel_idle,
|
|
.enter_s2idle = intel_idle_s2idle, },
|
|
{
|
|
@@ -550,7 +550,7 @@ static struct cpuidle_state bdw_cstates[] = {
|
|
.desc = "MWAIT 0x20",
|
|
.flags = MWAIT2flg(0x20) | CPUIDLE_FLAG_TLB_FLUSHED,
|
|
.exit_latency = 133,
|
|
- .target_residency = 400,
|
|
+ .target_residency = 1000,
|
|
.enter = &intel_idle,
|
|
.enter_s2idle = intel_idle_s2idle, },
|
|
{
|
|
@@ -558,7 +558,7 @@ static struct cpuidle_state bdw_cstates[] = {
|
|
.desc = "MWAIT 0x32",
|
|
.flags = MWAIT2flg(0x32) | CPUIDLE_FLAG_TLB_FLUSHED,
|
|
.exit_latency = 166,
|
|
- .target_residency = 500,
|
|
+ .target_residency = 2000,
|
|
.enter = &intel_idle,
|
|
.enter_s2idle = intel_idle_s2idle, },
|
|
{
|
|
@@ -566,7 +566,7 @@ static struct cpuidle_state bdw_cstates[] = {
|
|
.desc = "MWAIT 0x40",
|
|
.flags = MWAIT2flg(0x40) | CPUIDLE_FLAG_TLB_FLUSHED,
|
|
.exit_latency = 300,
|
|
- .target_residency = 900,
|
|
+ .target_residency = 4000,
|
|
.enter = &intel_idle,
|
|
.enter_s2idle = intel_idle_s2idle, },
|
|
{
|
|
@@ -574,7 +574,7 @@ static struct cpuidle_state bdw_cstates[] = {
|
|
.desc = "MWAIT 0x50",
|
|
.flags = MWAIT2flg(0x50) | CPUIDLE_FLAG_TLB_FLUSHED,
|
|
.exit_latency = 600,
|
|
- .target_residency = 1800,
|
|
+ .target_residency = 7000,
|
|
.enter = &intel_idle,
|
|
.enter_s2idle = intel_idle_s2idle, },
|
|
{
|
|
@@ -582,7 +582,7 @@ static struct cpuidle_state bdw_cstates[] = {
|
|
.desc = "MWAIT 0x60",
|
|
.flags = MWAIT2flg(0x60) | CPUIDLE_FLAG_TLB_FLUSHED,
|
|
.exit_latency = 2600,
|
|
- .target_residency = 7700,
|
|
+ .target_residency = 9000,
|
|
.enter = &intel_idle,
|
|
.enter_s2idle = intel_idle_s2idle, },
|
|
{
|
|
@@ -603,7 +603,7 @@ static struct cpuidle_state skl_cstates[] = {
|
|
.desc = "MWAIT 0x01",
|
|
.flags = MWAIT2flg(0x01),
|
|
.exit_latency = 10,
|
|
- .target_residency = 20,
|
|
+ .target_residency = 120,
|
|
.enter = &intel_idle,
|
|
.enter_s2idle = intel_idle_s2idle, },
|
|
{
|
|
@@ -611,7 +611,7 @@ static struct cpuidle_state skl_cstates[] = {
|
|
.desc = "MWAIT 0x10",
|
|
.flags = MWAIT2flg(0x10) | CPUIDLE_FLAG_TLB_FLUSHED,
|
|
.exit_latency = 70,
|
|
- .target_residency = 100,
|
|
+ .target_residency = 1000,
|
|
.enter = &intel_idle,
|
|
.enter_s2idle = intel_idle_s2idle, },
|
|
{
|
|
@@ -619,7 +619,7 @@ static struct cpuidle_state skl_cstates[] = {
|
|
.desc = "MWAIT 0x20",
|
|
.flags = MWAIT2flg(0x20) | CPUIDLE_FLAG_TLB_FLUSHED,
|
|
.exit_latency = 85,
|
|
- .target_residency = 200,
|
|
+ .target_residency = 600,
|
|
.enter = &intel_idle,
|
|
.enter_s2idle = intel_idle_s2idle, },
|
|
{
|
|
@@ -627,7 +627,7 @@ static struct cpuidle_state skl_cstates[] = {
|
|
.desc = "MWAIT 0x33",
|
|
.flags = MWAIT2flg(0x33) | CPUIDLE_FLAG_TLB_FLUSHED,
|
|
.exit_latency = 124,
|
|
- .target_residency = 800,
|
|
+ .target_residency = 3000,
|
|
.enter = &intel_idle,
|
|
.enter_s2idle = intel_idle_s2idle, },
|
|
{
|
|
@@ -635,7 +635,7 @@ static struct cpuidle_state skl_cstates[] = {
|
|
.desc = "MWAIT 0x40",
|
|
.flags = MWAIT2flg(0x40) | CPUIDLE_FLAG_TLB_FLUSHED,
|
|
.exit_latency = 200,
|
|
- .target_residency = 800,
|
|
+ .target_residency = 3200,
|
|
.enter = &intel_idle,
|
|
.enter_s2idle = intel_idle_s2idle, },
|
|
{
|
|
@@ -643,7 +643,7 @@ static struct cpuidle_state skl_cstates[] = {
|
|
.desc = "MWAIT 0x50",
|
|
.flags = MWAIT2flg(0x50) | CPUIDLE_FLAG_TLB_FLUSHED,
|
|
.exit_latency = 480,
|
|
- .target_residency = 5000,
|
|
+ .target_residency = 9000,
|
|
.enter = &intel_idle,
|
|
.enter_s2idle = intel_idle_s2idle, },
|
|
{
|
|
@@ -651,7 +651,7 @@ static struct cpuidle_state skl_cstates[] = {
|
|
.desc = "MWAIT 0x60",
|
|
.flags = MWAIT2flg(0x60) | CPUIDLE_FLAG_TLB_FLUSHED,
|
|
.exit_latency = 890,
|
|
- .target_residency = 5000,
|
|
+ .target_residency = 9000,
|
|
.enter = &intel_idle,
|
|
.enter_s2idle = intel_idle_s2idle, },
|
|
{
|
|
@@ -672,7 +672,7 @@ static struct cpuidle_state skx_cstates[] = {
|
|
.desc = "MWAIT 0x01",
|
|
.flags = MWAIT2flg(0x01),
|
|
.exit_latency = 10,
|
|
- .target_residency = 20,
|
|
+ .target_residency = 300,
|
|
.enter = &intel_idle,
|
|
.enter_s2idle = intel_idle_s2idle, },
|
|
{
|
|
--
|
|
2.20.1
|
|
|
|
From b8211d4f79dd88dfc2d4bd52be46103ea0b70e3e Mon Sep 17 00:00:00 2001
|
|
From: Arjan van de Ven <arjan@linux.intel.com>
|
|
Date: Fri, 6 Jan 2017 15:34:09 +0000
|
|
Subject: [PATCH] ipv4/tcp: allow the memory tuning for tcp to go a little
|
|
bigger than default
|
|
|
|
---
|
|
net/ipv4/tcp.c | 4 ++--
|
|
1 file changed, 2 insertions(+), 2 deletions(-)
|
|
|
|
diff --git a/net/ipv4/tcp.c b/net/ipv4/tcp.c
|
|
index cf3c5095c10e..b30d51837b2d 100644
|
|
--- a/net/ipv4/tcp.c
|
|
+++ b/net/ipv4/tcp.c
|
|
@@ -3897,8 +3897,8 @@ void __init tcp_init(void)
|
|
tcp_init_mem();
|
|
/* Set per-socket limits to no more than 1/128 the pressure threshold */
|
|
limit = nr_free_buffer_pages() << (PAGE_SHIFT - 7);
|
|
- max_wshare = min(4UL*1024*1024, limit);
|
|
- max_rshare = min(6UL*1024*1024, limit);
|
|
+ max_wshare = min(16UL*1024*1024, limit);
|
|
+ max_rshare = min(16UL*1024*1024, limit);
|
|
|
|
init_net.ipv4.sysctl_tcp_wmem[0] = SK_MEM_QUANTUM;
|
|
init_net.ipv4.sysctl_tcp_wmem[1] = 16*1024;
|
|
--
|
|
2.20.1
|
|
|
|
From 050223869257b87e22636158a80da38d877248ed Mon Sep 17 00:00:00 2001
|
|
From: Arjan van de Ven <arjan@linux.intel.com>
|
|
Date: Sun, 18 Feb 2018 23:35:41 +0000
|
|
Subject: [PATCH] locking: rwsem: spin faster
|
|
|
|
tweak rwsem owner spinning a bit
|
|
---
|
|
kernel/locking/rwsem.c | 4 +++-
|
|
1 file changed, 3 insertions(+), 1 deletion(-)
|
|
|
|
diff --git a/kernel/locking/rwsem.c b/kernel/locking/rwsem.c
|
|
index eef04551eae7..1ec5ab4c8ff7 100644
|
|
--- a/kernel/locking/rwsem.c
|
|
+++ b/kernel/locking/rwsem.c
|
|
@@ -720,6 +720,7 @@ rwsem_spin_on_owner(struct rw_semaphore *sem, unsigned long nonspinnable)
|
|
struct task_struct *new, *owner;
|
|
unsigned long flags, new_flags;
|
|
enum owner_state state;
|
|
+ int i = 0;
|
|
|
|
owner = rwsem_owner_flags(sem, &flags);
|
|
state = rwsem_owner_state(owner, flags, nonspinnable);
|
|
@@ -753,7 +754,8 @@ rwsem_spin_on_owner(struct rw_semaphore *sem, unsigned long nonspinnable)
|
|
break;
|
|
}
|
|
|
|
- cpu_relax();
|
|
+ if (i++ > 1000)
|
|
+ cpu_relax();
|
|
}
|
|
rcu_read_unlock();
|
|
|
|
From b836ea320114643d4354b43acb6ec8bb06ada487 Mon Sep 17 00:00:00 2001
|
|
From: Arjan van de Ven <arjan@linux.intel.com>
|
|
Date: Thu, 2 Jun 2016 23:36:32 -0500
|
|
Subject: [PATCH] drivers: Initialize ata before graphics
|
|
|
|
ATA init is the long pole in the boot process, and its asynchronous.
|
|
move the graphics init after it so that ata and graphics initialize
|
|
in parallel
|
|
---
|
|
drivers/Makefile | 15 ++++++++-------
|
|
1 file changed, 8 insertions(+), 7 deletions(-)
|
|
|
|
diff --git a/drivers/Makefile b/drivers/Makefile
|
|
index aaef17cc6512..d08f3a394929 100644
|
|
--- a/drivers/Makefile
|
|
+++ b/drivers/Makefile
|
|
@@ -58,15 +58,8 @@ obj-y += char/
|
|
# iommu/ comes before gpu as gpu are using iommu controllers
|
|
obj-y += iommu/
|
|
|
|
-# gpu/ comes after char for AGP vs DRM startup and after iommu
|
|
-obj-y += gpu/
|
|
-
|
|
obj-$(CONFIG_CONNECTOR) += connector/
|
|
|
|
-# i810fb and intelfb depend on char/agp/
|
|
-obj-$(CONFIG_FB_I810) += video/fbdev/i810/
|
|
-obj-$(CONFIG_FB_INTEL) += video/fbdev/intelfb/
|
|
-
|
|
obj-$(CONFIG_PARPORT) += parport/
|
|
obj-$(CONFIG_NVM) += lightnvm/
|
|
obj-y += base/ block/ misc/ mfd/ nfc/
|
|
@@ -79,6 +72,14 @@ obj-$(CONFIG_IDE) += ide/
|
|
obj-y += scsi/
|
|
obj-y += nvme/
|
|
obj-$(CONFIG_ATA) += ata/
|
|
+
|
|
+# gpu/ comes after char for AGP vs DRM startup and after iommu
|
|
+obj-y += gpu/
|
|
+
|
|
+# i810fb and intelfb depend on char/agp/
|
|
+obj-$(CONFIG_FB_I810) += video/fbdev/i810/
|
|
+obj-$(CONFIG_FB_INTEL) += video/fbdev/intelfb/
|
|
+
|
|
obj-$(CONFIG_TARGET_CORE) += target/
|
|
obj-$(CONFIG_MTD) += mtd/
|
|
obj-$(CONFIG_SPI) += spi/
|