xref: /rk3399_rockchip-uboot/cmd/rksfc.c (revision aa16b1f80312183f6bebceb1efe5f9499b9526e5)
1d5f538dcSDingqiang Lin /*
2d5f538dcSDingqiang Lin  * Copyright (c) 2018 Fuzhou Rockchip Electronics Co., Ltd
3d5f538dcSDingqiang Lin  *
4d5f538dcSDingqiang Lin  * SPDX-License-Identifier: (GPL-2.0+ OR MIT)
5d5f538dcSDingqiang Lin  */
6d5f538dcSDingqiang Lin 
7d5f538dcSDingqiang Lin #include <common.h>
8d5f538dcSDingqiang Lin #include <command.h>
9d5f538dcSDingqiang Lin #include <dm.h>
10d5f538dcSDingqiang Lin #include <rksfc.h>
11d5f538dcSDingqiang Lin 
12d5f538dcSDingqiang Lin static int rksfc_curr_dev;
do_rksfc(cmd_tbl_t * cmdtp,int flag,int argc,char * const argv[])13d5f538dcSDingqiang Lin static int do_rksfc(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
14d5f538dcSDingqiang Lin {
15d5f538dcSDingqiang Lin 	int ret;
16*aa16b1f8SDingqiang Lin 	u32 dev_type = IF_TYPE_UNKNOWN;
17*aa16b1f8SDingqiang Lin 
18*aa16b1f8SDingqiang Lin 	if (rksfc_curr_dev == 0)
19*aa16b1f8SDingqiang Lin 		dev_type = IF_TYPE_SPINAND;
20*aa16b1f8SDingqiang Lin 	else if (rksfc_curr_dev == 1)
21*aa16b1f8SDingqiang Lin 		dev_type = IF_TYPE_SPINOR;
22d5f538dcSDingqiang Lin 
23d5f538dcSDingqiang Lin 	if (argc == 2) {
24d5f538dcSDingqiang Lin 		if (strncmp(argv[1], "scan", 4) == 0) {
25d5f538dcSDingqiang Lin 			ret = rksfc_scan_namespace();
26d5f538dcSDingqiang Lin 			if (ret)
27d5f538dcSDingqiang Lin 				return CMD_RET_FAILURE;
28d5f538dcSDingqiang Lin 
29d5f538dcSDingqiang Lin 			return ret;
30d5f538dcSDingqiang Lin 		}
31d5f538dcSDingqiang Lin 	}
32d5f538dcSDingqiang Lin 
33*aa16b1f8SDingqiang Lin 	if (argc == 3) {
34*aa16b1f8SDingqiang Lin 		if (strncmp(argv[1], "dev", 3) == 0) {
35*aa16b1f8SDingqiang Lin 			if ((int)simple_strtoul(argv[2], NULL, 10) == 0)
36*aa16b1f8SDingqiang Lin 				dev_type = IF_TYPE_SPINAND;
37*aa16b1f8SDingqiang Lin 			else
38*aa16b1f8SDingqiang Lin 				dev_type = IF_TYPE_SPINOR;
39*aa16b1f8SDingqiang Lin 		}
40*aa16b1f8SDingqiang Lin 	}
41*aa16b1f8SDingqiang Lin 
42*aa16b1f8SDingqiang Lin 	return blk_common_cmd(argc, argv, dev_type, &rksfc_curr_dev);
43d5f538dcSDingqiang Lin }
44d5f538dcSDingqiang Lin 
45d5f538dcSDingqiang Lin U_BOOT_CMD(
46d5f538dcSDingqiang Lin 	rksfc, 8, 1, do_rksfc,
47d5f538dcSDingqiang Lin 	"rockchip sfc sub-system",
48d5f538dcSDingqiang Lin 	"scan - scan Sfc devices\n"
49d5f538dcSDingqiang Lin 	"rksfc info - show all available Sfc devices\n"
50d5f538dcSDingqiang Lin 	"rksfc device [dev] - show or set current Sfc device\n"
51*aa16b1f8SDingqiang Lin 	"      dev 0 - spinand\n"
52*aa16b1f8SDingqiang Lin 	"      dev 1 - spinor\n"
53d5f538dcSDingqiang Lin 	"rksfc part [dev] - print partition table of one or all Sfc devices\n"
54d5f538dcSDingqiang Lin 	"rksfc read addr blk# cnt - read `cnt' blocks starting at block\n"
55d5f538dcSDingqiang Lin 	"     `blk#' to memory address `addr'\n"
56d5f538dcSDingqiang Lin 	"rksfc write addr blk# cnt - write `cnt' blocks starting at block\n"
57d5f538dcSDingqiang Lin 	"     `blk#' from memory address `addr'"
58d5f538dcSDingqiang Lin );
59