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