Lines Matching full:scheme
13 * scheme region directory
113 * scheme regions directory
779 * scheme/weights directory
1120 * scheme directory
1149 struct damon_sysfs_scheme *scheme = kmalloc(sizeof(*scheme), in damon_sysfs_scheme_alloc() local
1152 if (!scheme) in damon_sysfs_scheme_alloc()
1154 scheme->kobj = (struct kobject){}; in damon_sysfs_scheme_alloc()
1155 scheme->action = action; in damon_sysfs_scheme_alloc()
1156 return scheme; in damon_sysfs_scheme_alloc()
1160 struct damon_sysfs_scheme *scheme) in damon_sysfs_scheme_set_access_pattern() argument
1169 &damon_sysfs_access_pattern_ktype, &scheme->kobj, in damon_sysfs_scheme_set_access_pattern()
1176 scheme->access_pattern = access_pattern; in damon_sysfs_scheme_set_access_pattern()
1184 static int damon_sysfs_scheme_set_quotas(struct damon_sysfs_scheme *scheme) in damon_sysfs_scheme_set_quotas() argument
1192 &scheme->kobj, "quotas"); in damon_sysfs_scheme_set_quotas()
1198 scheme->quotas = quotas; in damon_sysfs_scheme_set_quotas()
1206 static int damon_sysfs_scheme_set_watermarks(struct damon_sysfs_scheme *scheme) in damon_sysfs_scheme_set_watermarks() argument
1215 &damon_sysfs_watermarks_ktype, &scheme->kobj, in damon_sysfs_scheme_set_watermarks()
1220 scheme->watermarks = watermarks; in damon_sysfs_scheme_set_watermarks()
1224 static int damon_sysfs_scheme_set_filters(struct damon_sysfs_scheme *scheme) in damon_sysfs_scheme_set_filters() argument
1233 &damon_sysfs_scheme_filters_ktype, &scheme->kobj, in damon_sysfs_scheme_set_filters()
1238 scheme->filters = filters; in damon_sysfs_scheme_set_filters()
1242 static int damon_sysfs_scheme_set_stats(struct damon_sysfs_scheme *scheme) in damon_sysfs_scheme_set_stats() argument
1250 &scheme->kobj, "stats"); in damon_sysfs_scheme_set_stats()
1254 scheme->stats = stats; in damon_sysfs_scheme_set_stats()
1259 struct damon_sysfs_scheme *scheme) in damon_sysfs_scheme_set_tried_regions() argument
1268 &damon_sysfs_scheme_regions_ktype, &scheme->kobj, in damon_sysfs_scheme_set_tried_regions()
1273 scheme->tried_regions = tried_regions; in damon_sysfs_scheme_set_tried_regions()
1277 static int damon_sysfs_scheme_add_dirs(struct damon_sysfs_scheme *scheme) in damon_sysfs_scheme_add_dirs() argument
1281 err = damon_sysfs_scheme_set_access_pattern(scheme); in damon_sysfs_scheme_add_dirs()
1284 err = damon_sysfs_scheme_set_quotas(scheme); in damon_sysfs_scheme_add_dirs()
1287 err = damon_sysfs_scheme_set_watermarks(scheme); in damon_sysfs_scheme_add_dirs()
1290 err = damon_sysfs_scheme_set_filters(scheme); in damon_sysfs_scheme_add_dirs()
1293 err = damon_sysfs_scheme_set_stats(scheme); in damon_sysfs_scheme_add_dirs()
1296 err = damon_sysfs_scheme_set_tried_regions(scheme); in damon_sysfs_scheme_add_dirs()
1302 kobject_put(&scheme->tried_regions->kobj); in damon_sysfs_scheme_add_dirs()
1303 scheme->tried_regions = NULL; in damon_sysfs_scheme_add_dirs()
1305 kobject_put(&scheme->filters->kobj); in damon_sysfs_scheme_add_dirs()
1306 scheme->filters = NULL; in damon_sysfs_scheme_add_dirs()
1308 kobject_put(&scheme->watermarks->kobj); in damon_sysfs_scheme_add_dirs()
1309 scheme->watermarks = NULL; in damon_sysfs_scheme_add_dirs()
1311 kobject_put(&scheme->quotas->kobj); in damon_sysfs_scheme_add_dirs()
1312 scheme->quotas = NULL; in damon_sysfs_scheme_add_dirs()
1314 kobject_put(&scheme->access_pattern->kobj); in damon_sysfs_scheme_add_dirs()
1315 scheme->access_pattern = NULL; in damon_sysfs_scheme_add_dirs()
1319 static void damon_sysfs_scheme_rm_dirs(struct damon_sysfs_scheme *scheme) in damon_sysfs_scheme_rm_dirs() argument
1321 damon_sysfs_access_pattern_rm_dirs(scheme->access_pattern); in damon_sysfs_scheme_rm_dirs()
1322 kobject_put(&scheme->access_pattern->kobj); in damon_sysfs_scheme_rm_dirs()
1323 damon_sysfs_quotas_rm_dirs(scheme->quotas); in damon_sysfs_scheme_rm_dirs()
1324 kobject_put(&scheme->quotas->kobj); in damon_sysfs_scheme_rm_dirs()
1325 kobject_put(&scheme->watermarks->kobj); in damon_sysfs_scheme_rm_dirs()
1326 damon_sysfs_scheme_filters_rm_dirs(scheme->filters); in damon_sysfs_scheme_rm_dirs()
1327 kobject_put(&scheme->filters->kobj); in damon_sysfs_scheme_rm_dirs()
1328 kobject_put(&scheme->stats->kobj); in damon_sysfs_scheme_rm_dirs()
1329 damon_sysfs_scheme_regions_rm_dirs(scheme->tried_regions); in damon_sysfs_scheme_rm_dirs()
1330 kobject_put(&scheme->tried_regions->kobj); in damon_sysfs_scheme_rm_dirs()
1336 struct damon_sysfs_scheme *scheme = container_of(kobj, in action_show() local
1340 damon_sysfs_damos_action_strs[scheme->action]); in action_show()
1346 struct damon_sysfs_scheme *scheme = container_of(kobj, in action_store() local
1352 scheme->action = action; in action_store()
1405 struct damon_sysfs_scheme **schemes_arr, *scheme; in damon_sysfs_schemes_add_dirs() local
1419 scheme = damon_sysfs_scheme_alloc(DAMOS_STAT); in damon_sysfs_schemes_add_dirs()
1420 if (!scheme) { in damon_sysfs_schemes_add_dirs()
1425 err = kobject_init_and_add(&scheme->kobj, in damon_sysfs_schemes_add_dirs()
1430 err = damon_sysfs_scheme_add_dirs(scheme); in damon_sysfs_schemes_add_dirs()
1434 schemes_arr[i] = scheme; in damon_sysfs_schemes_add_dirs()
1441 kobject_put(&scheme->kobj); in damon_sysfs_schemes_add_dirs()
1536 static int damon_sysfs_set_scheme_filters(struct damos *scheme, in damon_sysfs_set_scheme_filters() argument
1542 damos_for_each_filter_safe(filter, next, scheme) in damon_sysfs_set_scheme_filters()
1574 damos_add_filter(scheme, filter); in damon_sysfs_set_scheme_filters()
1589 struct damos *scheme; in damon_sysfs_mk_scheme() local
1616 scheme = damon_new_scheme(&pattern, sysfs_scheme->action, "a, in damon_sysfs_mk_scheme()
1618 if (!scheme) in damon_sysfs_mk_scheme()
1621 err = damon_sysfs_set_scheme_filters(scheme, sysfs_filters); in damon_sysfs_mk_scheme()
1623 damon_destroy_scheme(scheme); in damon_sysfs_mk_scheme()
1626 return scheme; in damon_sysfs_mk_scheme()
1629 static void damon_sysfs_update_scheme(struct damos *scheme, in damon_sysfs_update_scheme() argument
1639 scheme->pattern.min_sz_region = access_pattern->sz->min; in damon_sysfs_update_scheme()
1640 scheme->pattern.max_sz_region = access_pattern->sz->max; in damon_sysfs_update_scheme()
1641 scheme->pattern.min_nr_accesses = access_pattern->nr_accesses->min; in damon_sysfs_update_scheme()
1642 scheme->pattern.max_nr_accesses = access_pattern->nr_accesses->max; in damon_sysfs_update_scheme()
1643 scheme->pattern.min_age_region = access_pattern->age->min; in damon_sysfs_update_scheme()
1644 scheme->pattern.max_age_region = access_pattern->age->max; in damon_sysfs_update_scheme()
1646 scheme->action = sysfs_scheme->action; in damon_sysfs_update_scheme()
1648 scheme->quota.ms = sysfs_quotas->ms; in damon_sysfs_update_scheme()
1649 scheme->quota.sz = sysfs_quotas->sz; in damon_sysfs_update_scheme()
1650 scheme->quota.reset_interval = sysfs_quotas->reset_interval_ms; in damon_sysfs_update_scheme()
1651 scheme->quota.weight_sz = sysfs_weights->sz; in damon_sysfs_update_scheme()
1652 scheme->quota.weight_nr_accesses = sysfs_weights->nr_accesses; in damon_sysfs_update_scheme()
1653 scheme->quota.weight_age = sysfs_weights->age; in damon_sysfs_update_scheme()
1655 scheme->wmarks.metric = sysfs_wmarks->metric; in damon_sysfs_update_scheme()
1656 scheme->wmarks.interval = sysfs_wmarks->interval_us; in damon_sysfs_update_scheme()
1657 scheme->wmarks.high = sysfs_wmarks->high; in damon_sysfs_update_scheme()
1658 scheme->wmarks.mid = sysfs_wmarks->mid; in damon_sysfs_update_scheme()
1659 scheme->wmarks.low = sysfs_wmarks->low; in damon_sysfs_update_scheme()
1661 err = damon_sysfs_set_scheme_filters(scheme, sysfs_scheme->filters); in damon_sysfs_update_scheme()
1663 damon_destroy_scheme(scheme); in damon_sysfs_update_scheme()
1669 struct damos *scheme, *next; in damon_sysfs_set_schemes() local
1672 damon_for_each_scheme_safe(scheme, next, ctx) { in damon_sysfs_set_schemes()
1674 damon_sysfs_update_scheme(scheme, in damon_sysfs_set_schemes()
1677 damon_destroy_scheme(scheme); in damon_sysfs_set_schemes()
1682 struct damos *scheme, *next; in damon_sysfs_set_schemes() local
1684 scheme = damon_sysfs_mk_scheme(sysfs_schemes->schemes_arr[i]); in damon_sysfs_set_schemes()
1685 if (!scheme) { in damon_sysfs_set_schemes()
1686 damon_for_each_scheme_safe(scheme, next, ctx) in damon_sysfs_set_schemes()
1687 damon_destroy_scheme(scheme); in damon_sysfs_set_schemes()
1690 damon_add_scheme(ctx, scheme); in damon_sysfs_set_schemes()
1699 struct damos *scheme; in damon_sysfs_schemes_update_stats() local
1702 damon_for_each_scheme(scheme, ctx) { in damon_sysfs_schemes_update_stats()
1705 /* user could have removed the scheme sysfs dir */ in damon_sysfs_schemes_update_stats()
1710 sysfs_stats->nr_tried = scheme->stat.nr_tried; in damon_sysfs_schemes_update_stats()
1711 sysfs_stats->sz_tried = scheme->stat.sz_tried; in damon_sysfs_schemes_update_stats()
1712 sysfs_stats->nr_applied = scheme->stat.nr_applied; in damon_sysfs_schemes_update_stats()
1713 sysfs_stats->sz_applied = scheme->stat.sz_applied; in damon_sysfs_schemes_update_stats()
1714 sysfs_stats->qt_exceeds = scheme->stat.qt_exceeds; in damon_sysfs_schemes_update_stats()
1735 struct damos *scheme; in damon_sysfs_before_damos_apply() local
1742 damon_for_each_scheme(scheme, ctx) { in damon_sysfs_before_damos_apply()
1743 if (scheme == s) in damon_sysfs_before_damos_apply()
1748 /* user could have removed the scheme sysfs dir */ in damon_sysfs_before_damos_apply()
1776 struct damos *scheme; in damon_sysfs_schemes_clear_regions() local
1779 damon_for_each_scheme(scheme, ctx) { in damon_sysfs_schemes_clear_regions()
1782 /* user could have removed the scheme sysfs dir */ in damon_sysfs_schemes_clear_regions()