linux56-tkg: BMQ v5.6-r1 - http://cchalpha.blogspot.com/2020/04/bmq-v56-r1-release.html
This commit is contained in:
parent
0660a63cf9
commit
4713bfc75e
@ -118,7 +118,7 @@ source=("https://www.kernel.org/pub/linux/kernel/v5.x/linux-${_basekernel}.tar.x
|
||||
#0008-5.6-bcachefs.patch
|
||||
0009-glitched-ondemand-bmq.patch
|
||||
0009-glitched-bmq.patch
|
||||
0009-bmq_v5.6-r0.patch
|
||||
0009-bmq_v5.6-r1.patch
|
||||
0011-ZFS-fix.patch
|
||||
#0012-linux-hardened.patch
|
||||
0013-tp_smapi_ec.patch
|
||||
@ -138,9 +138,9 @@ sha256sums=('e342b04a2aa63808ea0ef1baab28fc520bd031ef8cf93d9ee4a31d4058fcb622'
|
||||
'9ddfb1abaa01acf70e1352db1564fba591c2229d71d3c912213915388e944d6f'
|
||||
'90917e09bb06fbed6853efe9e52f8c2ba4066fca44accdf7608222212561104a'
|
||||
'2d9260b80b43bbd605cf420d6bd53aa7262103dfd77196ba590ece5600b6dc0d'
|
||||
'e27ad5ff23a81b5be73a642db5186b447f336956a427d1300e8ccc49abf0dd74'
|
||||
'9fad4a40449e09522899955762c8928ae17f4cdaa16e01239fd12592e9d58177'
|
||||
'965a517a283f265a012545fbb5cc9e516efc9f6166d2aa1baf7293a32a1086b7'
|
||||
'a214cfe4188ff24284de8ee5b0fa5ff4b0b604148a3e663e02e97cc56fec172c'
|
||||
'd42ab10e8ff39acd3a9211fc83313c6fb7a69ae0c2d39deb7946c7516c0d5cd5'
|
||||
'49262ce4a8089fa70275aad742fc914baa28d9c384f710c9a62f64796d13e104'
|
||||
'5fe8b22389d9df109f80fc4785908d1c32f1d469f5ef32fee613a0937965469e')
|
||||
|
||||
@ -243,7 +243,7 @@ prepare() {
|
||||
patch -Np1 -i ../0005-glitched-pds.patch
|
||||
elif [ "${_cpusched}" == "bmq" ]; then
|
||||
# BMQ
|
||||
patch -Np1 -i ../0009-bmq_v5.6-r0.patch
|
||||
patch -Np1 -i ../0009-bmq_v5.6-r1.patch
|
||||
if [ "${_aggressive_ondemand}" == "true" ]; then
|
||||
patch -Np1 -i ../0009-glitched-ondemand-bmq.patch
|
||||
fi
|
||||
|
@ -172,43 +172,6 @@ index f18d5067cd0f..fe489fc01c73 100644
|
||||
/*
|
||||
* Frequency of the spu scheduler tick. By default we do one SPU scheduler
|
||||
* tick for every 10 CPU scheduler ticks.
|
||||
diff --git a/drivers/cpufreq/cpufreq_conservative.c b/drivers/cpufreq/cpufreq_conservative.c
|
||||
index 737ff3b9c2c0..b5bc5a1b6de7 100644
|
||||
--- a/drivers/cpufreq/cpufreq_conservative.c
|
||||
+++ b/drivers/cpufreq/cpufreq_conservative.c
|
||||
@@ -28,8 +28,8 @@ struct cs_dbs_tuners {
|
||||
};
|
||||
|
||||
/* Conservative governor macros */
|
||||
-#define DEF_FREQUENCY_UP_THRESHOLD (80)
|
||||
-#define DEF_FREQUENCY_DOWN_THRESHOLD (20)
|
||||
+#define DEF_FREQUENCY_UP_THRESHOLD (63)
|
||||
+#define DEF_FREQUENCY_DOWN_THRESHOLD (26)
|
||||
#define DEF_FREQUENCY_STEP (5)
|
||||
#define DEF_SAMPLING_DOWN_FACTOR (1)
|
||||
#define MAX_SAMPLING_DOWN_FACTOR (10)
|
||||
diff --git a/drivers/cpufreq/cpufreq_ondemand.c b/drivers/cpufreq/cpufreq_ondemand.c
|
||||
index 82a4d37ddecb..1130e0f5db72 100644
|
||||
--- a/drivers/cpufreq/cpufreq_ondemand.c
|
||||
+++ b/drivers/cpufreq/cpufreq_ondemand.c
|
||||
@@ -18,7 +18,7 @@
|
||||
#include "cpufreq_ondemand.h"
|
||||
|
||||
/* On-demand governor macros */
|
||||
-#define DEF_FREQUENCY_UP_THRESHOLD (80)
|
||||
+#define DEF_FREQUENCY_UP_THRESHOLD (63)
|
||||
#define DEF_SAMPLING_DOWN_FACTOR (1)
|
||||
#define MAX_SAMPLING_DOWN_FACTOR (100000)
|
||||
#define MICRO_FREQUENCY_UP_THRESHOLD (95)
|
||||
@@ -127,7 +127,7 @@ static void dbs_freq_increase(struct cpufreq_policy *policy, unsigned int freq)
|
||||
}
|
||||
|
||||
/*
|
||||
- * Every sampling_rate, we check, if current idle time is less than 20%
|
||||
+ * Every sampling_rate, we check, if current idle time is less than 37%
|
||||
* (default), then we try to increase frequency. Else, we adjust the frequency
|
||||
* proportional to load.
|
||||
*/
|
||||
diff --git a/fs/proc/base.c b/fs/proc/base.c
|
||||
index c7c64272b0fa..3994241745ae 100644
|
||||
--- a/fs/proc/base.c
|
||||
@ -235,19 +198,6 @@ index 8874f681b056..59eb72bf7d5f 100644
|
||||
[RLIMIT_RTPRIO] = { 0, 0 }, \
|
||||
[RLIMIT_RTTIME] = { RLIM_INFINITY, RLIM_INFINITY }, \
|
||||
}
|
||||
diff --git a/include/linux/jiffies.h b/include/linux/jiffies.h
|
||||
index e3279ef24d28..4e08b64c56b0 100644
|
||||
--- a/include/linux/jiffies.h
|
||||
+++ b/include/linux/jiffies.h
|
||||
@@ -171,7 +171,7 @@ static inline u64 get_jiffies_64(void)
|
||||
* Have the 32 bit jiffies value wrap 5 minutes after boot
|
||||
* so jiffies wrap bugs show up earlier.
|
||||
*/
|
||||
-#define INITIAL_JIFFIES ((unsigned long)(unsigned int) (-300*HZ))
|
||||
+#define INITIAL_JIFFIES ((unsigned long)(unsigned int) (-10*HZ))
|
||||
|
||||
/*
|
||||
* Change timeval to jiffies, trying to avoid the
|
||||
diff --git a/include/linux/sched.h b/include/linux/sched.h
|
||||
index 04278493bf15..7b5838418378 100644
|
||||
--- a/include/linux/sched.h
|
||||
@ -621,10 +571,10 @@ index 21fb5a5662b5..ac31239aa51a 100644
|
||||
obj-$(CONFIG_CPU_FREQ_GOV_SCHEDUTIL) += cpufreq_schedutil.o
|
||||
diff --git a/kernel/sched/bmq.c b/kernel/sched/bmq.c
|
||||
new file mode 100644
|
||||
index 000000000000..58657044d58c
|
||||
index 000000000000..e6d6fc98bead
|
||||
--- /dev/null
|
||||
+++ b/kernel/sched/bmq.c
|
||||
@@ -0,0 +1,6005 @@
|
||||
@@ -0,0 +1,5982 @@
|
||||
+/*
|
||||
+ * kernel/sched/bmq.c
|
||||
+ *
|
||||
@ -697,7 +647,7 @@ index 000000000000..58657044d58c
|
||||
+
|
||||
+static inline void print_scheduler_version(void)
|
||||
+{
|
||||
+ printk(KERN_INFO "bmq: BMQ CPU Scheduler 5.6-r0 by Alfred Chen.\n");
|
||||
+ printk(KERN_INFO "bmq: BMQ CPU Scheduler 5.6-r1 by Alfred Chen.\n");
|
||||
+}
|
||||
+
|
||||
+/**
|
||||
@ -774,17 +724,9 @@ index 000000000000..58657044d58c
|
||||
+static cpumask_t sched_sg_idle_mask ____cacheline_aligned_in_smp;
|
||||
+static cpumask_t sched_rq_watermark[bmq_BITS] ____cacheline_aligned_in_smp;
|
||||
+
|
||||
+#if (bmq_BITS <= BITS_PER_LONG)
|
||||
+#define bmq_find_first_bit(bm) __ffs((bm[0]))
|
||||
+#define bmq_find_next_bit(bm, start) __ffs(BITMAP_FIRST_WORD_MASK(start) & bm[0])
|
||||
+#else
|
||||
+#define bmq_find_first_bit(bm) find_first_bit((bm), bmq_BITS)
|
||||
+#define bmq_find_next_bit(bm, start) find_next_bit(bm, bmq_BITS, start)
|
||||
+#endif
|
||||
+
|
||||
+static inline void update_sched_rq_watermark(struct rq *rq)
|
||||
+{
|
||||
+ unsigned long watermark = bmq_find_first_bit(rq->queue.bitmap);
|
||||
+ unsigned long watermark = find_first_bit(rq->queue.bitmap, bmq_BITS);
|
||||
+ unsigned long last_wm = rq->watermark;
|
||||
+ unsigned long i;
|
||||
+ int cpu;
|
||||
@ -825,7 +767,7 @@ index 000000000000..58657044d58c
|
||||
+
|
||||
+static inline int task_sched_prio(struct task_struct *p)
|
||||
+{
|
||||
+ return (p->prio < MAX_RT_PRIO)? 0:p->prio - MAX_RT_PRIO + p->boost_prio + 1;
|
||||
+ return (p->prio < MAX_RT_PRIO)? p->prio : p->prio + p->boost_prio;
|
||||
+}
|
||||
+
|
||||
+static inline void bmq_init(struct bmq *q)
|
||||
@ -844,27 +786,12 @@ index 000000000000..58657044d58c
|
||||
+ set_bit(IDLE_TASK_SCHED_PRIO, q->bitmap);
|
||||
+}
|
||||
+
|
||||
+static inline void bmq_add_task(struct task_struct *p, struct bmq *q, int idx)
|
||||
+{
|
||||
+ struct list_head *n;
|
||||
+
|
||||
+ if (likely(idx)) {
|
||||
+ list_add_tail(&p->bmq_node, &q->heads[idx]);
|
||||
+ return;
|
||||
+ }
|
||||
+
|
||||
+ list_for_each(n, &q->heads[idx])
|
||||
+ if (list_entry(n, struct task_struct, bmq_node)->prio > p->prio)
|
||||
+ break;
|
||||
+ __list_add(&p->bmq_node, n->prev, n);
|
||||
+}
|
||||
+
|
||||
+/*
|
||||
+ * This routine used in bmq scheduler only which assume the idle task in the bmq
|
||||
+ */
|
||||
+static inline struct task_struct *rq_first_bmq_task(struct rq *rq)
|
||||
+{
|
||||
+ unsigned long idx = bmq_find_first_bit(rq->queue.bitmap);
|
||||
+ unsigned long idx = find_first_bit(rq->queue.bitmap, bmq_BITS);
|
||||
+ const struct list_head *head = &rq->queue.heads[idx];
|
||||
+
|
||||
+ return list_first_entry(head, struct task_struct, bmq_node);
|
||||
@ -877,7 +804,7 @@ index 000000000000..58657044d58c
|
||||
+ struct list_head *head = &rq->queue.heads[idx];
|
||||
+
|
||||
+ if (list_is_last(&p->bmq_node, head)) {
|
||||
+ idx = bmq_find_next_bit(rq->queue.bitmap, idx + 1);
|
||||
+ idx = find_next_bit(rq->queue.bitmap, bmq_BITS, idx + 1);
|
||||
+ head = &rq->queue.heads[idx];
|
||||
+
|
||||
+ return list_first_entry(head, struct task_struct, bmq_node);
|
||||
@ -1162,7 +1089,7 @@ index 000000000000..58657044d58c
|
||||
+ task_cpu(p), cpu_of(rq));
|
||||
+
|
||||
+ p->bmq_idx = task_sched_prio(p);
|
||||
+ bmq_add_task(p, &rq->queue, p->bmq_idx);
|
||||
+ list_add_tail(&p->bmq_node, &rq->queue.heads[p->bmq_idx]);
|
||||
+ set_bit(p->bmq_idx, rq->queue.bitmap);
|
||||
+ update_sched_rq_watermark(rq);
|
||||
+ ++rq->nr_running;
|
||||
@ -1194,7 +1121,7 @@ index 000000000000..58657044d58c
|
||||
+ cpu_of(rq), task_cpu(p));
|
||||
+
|
||||
+ list_del(&p->bmq_node);
|
||||
+ bmq_add_task(p, &rq->queue, idx);
|
||||
+ list_add_tail(&p->bmq_node, &rq->queue.heads[idx]);
|
||||
+ if (idx != p->bmq_idx) {
|
||||
+ if (list_empty(&rq->queue.heads[p->bmq_idx]))
|
||||
+ clear_bit(p->bmq_idx, rq->queue.bitmap);
|
||||
@ -6181,10 +6108,10 @@ index 000000000000..58657044d58c
|
||||
+ cpu, (chk++)->bits[0]);
|
||||
+
|
||||
+ per_cpu(sched_cpu_affinity_end_mask, cpu) = chk;
|
||||
+ printk(KERN_INFO "bmq: cpu#%d llc_id = %d, llc_mask idx = %ld\n",
|
||||
+ printk(KERN_INFO "bmq: cpu#%d llc_id = %d, llc_mask idx = %d\n",
|
||||
+ cpu, per_cpu(sd_llc_id, cpu),
|
||||
+ per_cpu(sched_cpu_llc_mask, cpu) -
|
||||
+ &(per_cpu(sched_cpu_affinity_masks, cpu)[0]));
|
||||
+ (int) (per_cpu(sched_cpu_llc_mask, cpu) -
|
||||
+ &(per_cpu(sched_cpu_affinity_masks, cpu)[0])));
|
||||
+ }
|
||||
+}
|
||||
+#endif
|
||||
@ -6669,7 +6596,7 @@ index 000000000000..375a1a805d86
|
||||
+{}
|
||||
diff --git a/kernel/sched/bmq_sched.h b/kernel/sched/bmq_sched.h
|
||||
new file mode 100644
|
||||
index 000000000000..6fc8ae438c32
|
||||
index 000000000000..fca42b270620
|
||||
--- /dev/null
|
||||
+++ b/kernel/sched/bmq_sched.h
|
||||
@@ -0,0 +1,510 @@
|
||||
@ -6743,8 +6670,8 @@ index 000000000000..6fc8ae438c32
|
||||
+#define WF_MIGRATED 0x04 /* internal use, task got migrated */
|
||||
+
|
||||
+/* bits:
|
||||
+ * RT, Low prio adj range, nice width, high prio adj range, cpu idle task */
|
||||
+#define bmq_BITS (NICE_WIDTH + 2 * MAX_PRIORITY_ADJ + 2)
|
||||
+ * RT(0-99), Low prio adj range, nice width, high prio adj range, cpu idle task */
|
||||
+#define bmq_BITS (MAX_RT_PRIO + NICE_WIDTH + 2 * MAX_PRIORITY_ADJ + 1)
|
||||
+#define IDLE_TASK_SCHED_PRIO (bmq_BITS - 1)
|
||||
+
|
||||
+struct bmq {
|
@ -6,7 +6,7 @@ index 6b423eebfd5d..61e3271675d6 100644
|
||||
#include "cpufreq_ondemand.h"
|
||||
|
||||
/* On-demand governor macros */
|
||||
-#define DEF_FREQUENCY_UP_THRESHOLD (63)
|
||||
-#define DEF_FREQUENCY_UP_THRESHOLD (80)
|
||||
-#define DEF_SAMPLING_DOWN_FACTOR (1)
|
||||
+#define DEF_FREQUENCY_UP_THRESHOLD (55)
|
||||
+#define DEF_SAMPLING_DOWN_FACTOR (5)
|
||||
|
Loading…
x
Reference in New Issue
Block a user