struct cmd_tbl;
 struct unit_test;
+struct unit_test_state;
 
 /* 'command' functions normally called do_xxx where xxx is the command name */
-typedef int (*ut_cmd_func)(struct cmd_tbl *cmd, int flags, int argc,
-                          char *const argv[]);
+typedef int (*ut_cmd_func)(struct unit_test_state *uts, struct cmd_tbl *cmd,
+                          int flags, int argc, char *const argv[]);
 
 /**
  * cmd_ut_category() - Run a category of unit tests
  *
+ * @uts: Unit-test state, which must be ready for use, i.e. ut_init_state()
+ *     has been called. The caller is responsible for calling
+ *     ut_uninit_state() after this function returns
  * @name:      Category name
  * @prefix:    Prefix of test name
  * @tests:     List of tests to run
  * @argv:      Arguments: argv[1] is the test to run (if @argc >= 2)
  * Return: 0 if OK, CMD_RET_FAILURE on failure
  */
-int cmd_ut_category(const char *name, const char *prefix,
-                   struct unit_test *tests, int n_ents,
+int cmd_ut_category(struct unit_test_state *uts, const char *name,
+                   const char *prefix, struct unit_test *tests, int n_ents,
                    int argc, char *const argv[]);
 
-int do_ut_bootstd(struct cmd_tbl *cmdtp, int flag, int argc,
-                 char *const argv[]);
+int do_ut_bootstd(struct unit_test_state *uts, struct cmd_tbl *cmdtp, int flag,
+                 int argc, char *const argv[]);
 int do_ut_optee(struct cmd_tbl *cmdtp, int flag, int argc, char *const argv[]);
-int do_ut_overlay(struct cmd_tbl *cmdtp, int flag, int argc,
-                 char *const argv[]);
+int do_ut_overlay(struct unit_test_state *uts, struct cmd_tbl *cmdtp, int flag,
+                 int argc, char *const argv[]);
 
 #endif /* __TEST_SUITES_H__ */
 
        ut_cmd_func cmd;
 };
 
-static int do_ut_all(struct cmd_tbl *cmdtp, int flag, int argc,
-                    char *const argv[]);
+static int do_ut_all(struct unit_test_state *uts, struct cmd_tbl *cmdtp,
+                    int flag, int argc, char *const argv[]);
 
 static int do_ut_info(struct cmd_tbl *cmdtp, int flag, int argc,
                      char *const argv[]);
 
-int cmd_ut_category(const char *name, const char *prefix,
-                   struct unit_test *tests, int n_ents,
+int cmd_ut_category(struct unit_test_state *uts, const char *name,
+                   const char *prefix, struct unit_test *tests, int n_ents,
                    int argc, char *const argv[])
 {
-       struct unit_test_state uts;
        const char *test_insert = NULL;
        int runs_per_text = 1;
        bool force_run = false;
                argc--;
        }
 
-       ut_init_state(&uts);
-       ret = ut_run_list(&uts, name, prefix, tests, n_ents,
+       ret = ut_run_list(uts, name, prefix, tests, n_ents,
                          cmd_arg1(argc, argv), runs_per_text, force_run,
                          test_insert);
-       ut_uninit_state(&uts);
 
        return ret ? CMD_RET_FAILURE : 0;
 }
 }
 
 /** run_suite() - Run a suite of tests */
-static int run_suite(struct suite *ste, struct cmd_tbl *cmdtp, int flag,
-                    int argc, char *const argv[])
+static int run_suite(struct unit_test_state *uts, struct suite *ste,
+                    struct cmd_tbl *cmdtp, int flag, int argc,
+                    char *const argv[])
 {
        int ret;
 
        if (ste->cmd) {
-               ret = ste->cmd(cmdtp, flag, argc, argv);
+               ret = ste->cmd(uts, cmdtp, flag, argc, argv);
        } else {
                int n_ents = ste->end - ste->start;
                char prefix[30];
 
                /* use a standard prefix */
                snprintf(prefix, sizeof(prefix), "%s_test", ste->name);
-               ret = cmd_ut_category(ste->name, prefix, ste->start, n_ents,
-                                     argc, argv);
+               ret = cmd_ut_category(uts, ste->name, prefix, ste->start,
+                                     n_ents, argc, argv);
        }
 
        return ret;
 }
 
-static int do_ut_all(struct cmd_tbl *cmdtp, int flag, int argc,
-                    char *const argv[])
+static int do_ut_all(struct unit_test_state *uts, struct cmd_tbl *cmdtp,
+                    int flag, int argc, char *const argv[])
 {
        int i;
        int retval;
 
                if (has_tests(ste)) {
                        printf("----Running %s tests----\n", ste->name);
-                       retval = run_suite(ste, cmdtp, flag, 1, argv);
+                       retval = run_suite(uts, ste, cmdtp, flag, 1, argv);
                        if (!any_fail)
                                any_fail = retval;
                }
 
 static int do_ut(struct cmd_tbl *cmdtp, int flag, int argc, char *const argv[])
 {
+       struct unit_test_state uts;
        struct suite *ste;
        const char *name;
        int ret;
        argc--;
        argv++;
 
+       ut_init_state(&uts);
        name = argv[0];
        if (!strcmp(name, "all")) {
-               ret = do_ut_all(cmdtp, flag, argc, argv);
+               ret = do_ut_all(&uts, cmdtp, flag, argc, argv);
        } else if (!strcmp(name, "info")) {
                ret = do_ut_info(cmdtp, flag, argc, argv);
        } else {
                        return CMD_RET_FAILURE;
                }
 
-               ret = run_suite(ste, cmdtp, flag, argc, argv);
+               ret = run_suite(&uts, ste, cmdtp, flag, argc, argv);
        }
        if (ret)
                return ret;
+       ut_uninit_state(&uts);
 
        return 0;
 }
 
 }
 OVERLAY_TEST(fdt_overlay_stacked, 0);
 
-int do_ut_overlay(struct cmd_tbl *cmdtp, int flag, int argc, char *const argv[])
+int do_ut_overlay(struct unit_test_state *uts, struct cmd_tbl *cmdtp, int flag,
+                 int argc, char *const argv[])
 {
        struct unit_test *tests = UNIT_TEST_SUITE_START(overlay);
        const int n_ents = UNIT_TEST_SUITE_COUNT(overlay);
-       struct unit_test_state *uts;
        void *fdt_base = &__dtb_test_fdt_base_begin;
        void *fdt_overlay = &__dtbo_test_fdt_overlay_begin;
        void *fdt_overlay_stacked = &__dtbo_test_fdt_overlay_stacked_begin;
        void *fdt_overlay_copy, *fdt_overlay_stacked_copy;
        int ret = -ENOMEM;
 
-       uts = calloc(1, sizeof(*uts));
-       if (!uts)
-               return -ENOMEM;
-
        ut_assertok(fdt_check_header(fdt_base));
        ut_assertok(fdt_check_header(fdt_overlay));
 
        /* Apply the stacked overlay */
        ut_assertok(fdt_overlay_apply(fdt, fdt_overlay_stacked_copy));
 
-       ret = cmd_ut_category("overlay", "", tests, n_ents, argc, argv);
+       ret = cmd_ut_category(uts, "overlay", "", tests, n_ents, argc, argv);
 
        free(fdt_overlay_stacked_copy);
 err3: