
Some shrinker add lock in count_objects() may cause lock contention issues and lead all task stall on slab shrink. Add vendor hook in do_shrink_slab() for shrinker->count_objects() latency measuring. Add 3 oem data in shrink_control struct. Two is for shrinker->count_objects() and shrinker->scan_objects() latency measuring, other one to store priority, some shrinker know the reclaimer priority can control the memory reclaim more better. Bug: 188684131 Change-Id: I80e9d90179bb52a99c54d9a067c6fcee835bb2ad Signed-off-by: rongqianfeng <rongqianfeng@vivo.com>
31 lines
1.0 KiB
C
31 lines
1.0 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#undef TRACE_SYSTEM
|
|
#define TRACE_SYSTEM vmscan
|
|
|
|
#define TRACE_INCLUDE_PATH trace/hooks
|
|
|
|
#if !defined(_TRACE_HOOK_VMSCAN_H) || defined(TRACE_HEADER_MULTI_READ)
|
|
#define _TRACE_HOOK_VMSCAN_H
|
|
|
|
#include <linux/tracepoint.h>
|
|
#include <trace/hooks/vendor_hooks.h>
|
|
|
|
DECLARE_HOOK(android_vh_tune_scan_type,
|
|
TP_PROTO(char *scan_type),
|
|
TP_ARGS(scan_type));
|
|
DECLARE_HOOK(android_vh_tune_swappiness,
|
|
TP_PROTO(int *swappiness),
|
|
TP_ARGS(swappiness));
|
|
DECLARE_HOOK(android_vh_shrink_slab_bypass,
|
|
TP_PROTO(gfp_t gfp_mask, int nid, struct mem_cgroup *memcg, int priority, bool *bypass),
|
|
TP_ARGS(gfp_mask, nid, memcg, priority, bypass));
|
|
DECLARE_HOOK(android_vh_tune_inactive_ratio,
|
|
TP_PROTO(unsigned long *inactive_ratio, int file),
|
|
TP_ARGS(inactive_ratio, file))
|
|
DECLARE_HOOK(android_vh_do_shrink_slab,
|
|
TP_PROTO(struct shrinker *shrinker, struct shrink_control *shrinkctl, int priority),
|
|
TP_ARGS(shrinker, shrinkctl, priority));
|
|
#endif /* _TRACE_HOOK_VMSCAN_H */
|
|
/* This part must be outside protection */
|
|
#include <trace/define_trace.h>
|