ANDROID: vendor_hooks: Add hook in shrink_node_memcgs
Add vendor hook in shrink_node_memcgs to adjust whether to skip memory reclamation of memcg. Bug: 226482420 Bug: 365942441 Signed-off-by: Liujie Xie <xieliujie@oppo.com> Change-Id: I925856353e63c5a821027de4f8476c833e21b982
This commit is contained in:
committed by
Treehugger Robot
parent
8f5f6798e1
commit
b165e16c2e
@@ -551,3 +551,4 @@ EXPORT_TRACEPOINT_SYMBOL_GPL(android_vh_do_swap_page);
|
|||||||
EXPORT_TRACEPOINT_SYMBOL_GPL(android_vh_do_anonymous_page);
|
EXPORT_TRACEPOINT_SYMBOL_GPL(android_vh_do_anonymous_page);
|
||||||
EXPORT_TRACEPOINT_SYMBOL_GPL(android_vh_uprobes_replace_page);
|
EXPORT_TRACEPOINT_SYMBOL_GPL(android_vh_uprobes_replace_page);
|
||||||
EXPORT_TRACEPOINT_SYMBOL_GPL(android_vh_swap_writepage);
|
EXPORT_TRACEPOINT_SYMBOL_GPL(android_vh_swap_writepage);
|
||||||
|
EXPORT_TRACEPOINT_SYMBOL_GPL(android_vh_shrink_node_memcgs);
|
||||||
|
|||||||
@@ -101,7 +101,9 @@ DECLARE_HOOK(android_vh_direct_reclaim_end,
|
|||||||
DECLARE_HOOK(android_vh_throttle_direct_reclaim_bypass,
|
DECLARE_HOOK(android_vh_throttle_direct_reclaim_bypass,
|
||||||
TP_PROTO(bool *bypass),
|
TP_PROTO(bool *bypass),
|
||||||
TP_ARGS(bypass));
|
TP_ARGS(bypass));
|
||||||
|
DECLARE_HOOK(android_vh_shrink_node_memcgs,
|
||||||
|
TP_PROTO(struct mem_cgroup *memcg, bool *skip),
|
||||||
|
TP_ARGS(memcg, skip));
|
||||||
#endif /* _TRACE_HOOK_VMSCAN_H */
|
#endif /* _TRACE_HOOK_VMSCAN_H */
|
||||||
/* This part must be outside protection */
|
/* This part must be outside protection */
|
||||||
#include <trace/define_trace.h>
|
#include <trace/define_trace.h>
|
||||||
|
|||||||
@@ -6029,6 +6029,7 @@ static void shrink_node_memcgs(pg_data_t *pgdat, struct scan_control *sc)
|
|||||||
unsigned long reclaimed;
|
unsigned long reclaimed;
|
||||||
unsigned long scanned;
|
unsigned long scanned;
|
||||||
bool bypass = false;
|
bool bypass = false;
|
||||||
|
bool skip = false;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This loop can become CPU-bound when target memcgs
|
* This loop can become CPU-bound when target memcgs
|
||||||
@@ -6038,6 +6039,10 @@ static void shrink_node_memcgs(pg_data_t *pgdat, struct scan_control *sc)
|
|||||||
*/
|
*/
|
||||||
cond_resched();
|
cond_resched();
|
||||||
|
|
||||||
|
trace_android_vh_shrink_node_memcgs(memcg, &skip);
|
||||||
|
if (skip)
|
||||||
|
continue;
|
||||||
|
|
||||||
mem_cgroup_calculate_protection(target_memcg, memcg);
|
mem_cgroup_calculate_protection(target_memcg, memcg);
|
||||||
|
|
||||||
if (mem_cgroup_below_min(target_memcg, memcg)) {
|
if (mem_cgroup_below_min(target_memcg, memcg)) {
|
||||||
|
|||||||
Reference in New Issue
Block a user