int damon_sysfs_schemes_update_regions_stop(struct damon_ctx *ctx);
 
+void damos_sysfs_populate_region_dir(struct damon_sysfs_schemes *sysfs_schemes,
+               struct damon_ctx *ctx, struct damon_target *t,
+               struct damon_region *r, struct damos *s,
+               bool total_bytes_only);
+
 int damon_sysfs_schemes_clear_regions(
                struct damon_sysfs_schemes *sysfs_schemes);
 
 
        return 0;
 }
 
+/**
+ * damos_sysfs_populate_region_dir() - Populate a schemes tried region dir.
+ * @sysfs_schemes:     Schemes directory to populate regions directory.
+ * @ctx:               Corresponding DAMON context.
+ * @t:                 DAMON target of @r.
+ * @r:                 DAMON region to populate the directory for.
+ * @s:                 Corresponding scheme.
+ * @total_bytes_only:  Whether the request is for bytes update only.
+ *
+ * Called from DAMOS walk callback while holding damon_sysfs_lock.
+ */
+void damos_sysfs_populate_region_dir(struct damon_sysfs_schemes *sysfs_schemes,
+               struct damon_ctx *ctx, struct damon_target *t,
+               struct damon_region *r, struct damos *s, bool total_bytes_only)
+{
+       struct damos *scheme;
+       struct damon_sysfs_scheme_regions *sysfs_regions;
+       struct damon_sysfs_scheme_region *region;
+       int schemes_idx = 0;
+
+       damon_for_each_scheme(scheme, ctx) {
+               if (scheme == s)
+                       break;
+               schemes_idx++;
+       }
+
+       /* user could have removed the scheme sysfs dir */
+       if (schemes_idx >= sysfs_schemes->nr)
+               return;
+
+       sysfs_regions = sysfs_schemes->schemes_arr[schemes_idx]->tried_regions;
+       sysfs_regions->total_bytes += r->ar.end - r->ar.start;
+       if (total_bytes_only)
+               return;
+
+       region = damon_sysfs_scheme_region_alloc(r);
+       if (!region)
+               return;
+       list_add_tail(®ion->list, &sysfs_regions->regions_list);
+       sysfs_regions->nr_regions++;
+       if (kobject_init_and_add(®ion->kobj,
+                               &damon_sysfs_scheme_region_ktype,
+                               &sysfs_regions->kobj, "%d",
+                               sysfs_regions->nr_regions++)) {
+               kobject_put(®ion->kobj);
+       }
+}
+
 /*
  * DAMON callback that called after each accesses sampling.  While this
  * callback is registered, damon_sysfs_lock should be held to ensure the
 
        return damon_call(kdamond->damon_ctx, &call_control);
 }
 
+struct damon_sysfs_schemes_walk_data {
+       struct damon_sysfs_kdamond *sysfs_kdamond;
+       bool total_bytes_only;
+};
+
+/* populate the region directory */
+static void damon_sysfs_schemes_tried_regions_upd_one(void *data, struct damon_ctx *ctx,
+               struct damon_target *t, struct damon_region *r,
+               struct damos *s)
+{
+       struct damon_sysfs_schemes_walk_data *walk_data = data;
+       struct damon_sysfs_kdamond *sysfs_kdamond = walk_data->sysfs_kdamond;
+
+       damos_sysfs_populate_region_dir(
+                       sysfs_kdamond->contexts->contexts_arr[0]->schemes,
+                       ctx, t, r, s, walk_data->total_bytes_only);
+}
+
+static int damon_sysfs_update_schemes_tried_regions(
+               struct damon_sysfs_kdamond *sysfs_kdamond, bool total_bytes_only)
+{
+       struct damon_sysfs_schemes_walk_data walk_data = {
+               .sysfs_kdamond = sysfs_kdamond,
+               .total_bytes_only = total_bytes_only,
+       };
+       struct damos_walk_control control = {
+               .walk_fn = damon_sysfs_schemes_tried_regions_upd_one,
+               .data = &walk_data,
+       };
+       struct damon_ctx *ctx = sysfs_kdamond->damon_ctx;
+
+       if (!ctx)
+               return -EINVAL;
+
+       damon_sysfs_schemes_clear_regions(
+                       sysfs_kdamond->contexts->contexts_arr[0]->schemes);
+       return damos_walk(ctx, &control);
+}
+
 /*
  * damon_sysfs_handle_cmd() - Handle a command for a specific kdamond.
  * @cmd:       The command to handle.
        case DAMON_SYSFS_CMD_UPDATE_SCHEMES_STATS:
                return damon_sysfs_damon_call(
                                damon_sysfs_upd_schemes_stats, kdamond);
+       case DAMON_SYSFS_CMD_UPDATE_SCHEMES_TRIED_BYTES:
+               return damon_sysfs_update_schemes_tried_regions(kdamond, true);
+       case DAMON_SYSFS_CMD_UPDATE_SCHEMES_TRIED_REGIONS:
+               return damon_sysfs_update_schemes_tried_regions(kdamond, false);
        case DAMON_SYSFS_CMD_CLEAR_SCHEMES_TRIED_REGIONS:
                return damon_sysfs_schemes_clear_regions(
                        kdamond->contexts->contexts_arr[0]->schemes);