1 /* 2 * (C) Copyright 2017 Rockchip Electronics Co., Ltd 3 * 4 * SPDX-License-Identifier: GPL-2.0+ 5 */ 6 7 #include <common.h> 8 #include <command.h> 9 #include "test-rockchip.h" 10 11 typedef struct board_module { 12 char *name; 13 int (*test)(int argc, char * const argv[]); 14 } board_module_t; 15 16 static board_module_t g_board_modules[] = { 17 { .name = "timer", .test = board_timer_test }, 18 { .name = "key", .test = board_key_test }, 19 { .name = "emmc", .test = board_emmc_test }, 20 { .name = "regulator", .test = board_regulator_test }, 21 { .name = "rknand", .test = board_rknand_test }, 22 }; 23 24 static int do_rockchip_test(cmd_tbl_t *cmdtp, int flag, 25 int argc, char * const argv[]) 26 { 27 ulong ms_start = 0, ms = 0, sec = 0; 28 board_module_t *module = NULL; 29 char *module_name = NULL; 30 int index = 0, err = 0; 31 32 if (argc >= 2) { 33 module_name = argv[1]; 34 } else { 35 printf("cmd format: test_rockchip [module_name] [args...]\n"); 36 return 0; 37 } 38 39 if (!module_name) 40 return 0; 41 42 printf("***********************************************************\n"); 43 printf("Rockchip Board Module [%s] Test start.\n", module_name); 44 printf("***********************************************************\n"); 45 46 for (index = 0; index < ARRAY_SIZE(g_board_modules); index++) { 47 module = &g_board_modules[index]; 48 if (module && !strcmp(module->name, module_name)) { 49 ms_start = get_timer(0); 50 51 err = module->test(argc, argv); 52 53 ms = get_timer(ms_start); 54 if (ms >= 1000) { 55 sec = ms / 1000; 56 ms = ms % 1000; 57 } 58 } 59 } 60 61 printf("-----------------------------------------------------------\n"); 62 printf("Rockchip Board Module [%s] Test end <%s>.. Total: %lu.%lus\n", 63 module->name, err ? "FAILED" : "PASS", sec, ms); 64 printf("-----------------------------------------------------------\n\n\n"); 65 66 return 0; 67 } 68 69 U_BOOT_CMD( 70 rktest, 10, 0, do_rockchip_test, 71 "Rockchip Board Module Test", 72 "" 73 ); 74