]>
cloudbase.mooo.com Git - z180-stamp.git/blob - avr/cmd_sd.c
2 * (C) Copyright 2014, 2018 Leo C. <erbl259-lmu@yahoo.de>
4 * SPDX-License-Identifier: GPL-2.0
11 #include "print-utils.h"
16 * status <pd#> - Show socket status
20 command_ret_t
do_status(cmd_tbl_t
*cmdtp
, uint_fast8_t flag
, int argc
, char * const argv
[])
25 (void) cmdtp
; (void) flag
;
30 dev
= (BYTE
) eval_arg(argv
[1], NULL
);
31 res
= disk_status(dev
);
32 printf_P(PSTR("Socket status: %02x\n"), res
);
34 return CMD_RET_SUCCESS
;
38 * init <pd#> - Initialize disk
42 command_ret_t
do_init(cmd_tbl_t
*cmdtp
, uint_fast8_t flag
, int argc
, char * const argv
[])
47 (void) cmdtp
; (void) flag
;
52 dev
= (BYTE
) eval_arg(argv
[1], NULL
);
54 if (disk_status(dev
) & STA_NODISK
)
55 cmd_error(CMD_RET_FAILURE
, 0, PSTR("No disk"));
57 res
= disk_initialize(dev
);
58 printf_P(PSTR("rc=%.2x\n"), res
);
60 if (res
& (STA_NODISK
| STA_NOINIT
))
61 return CMD_RET_FAILURE
;
63 return CMD_RET_SUCCESS
;
67 * info <pd#> - Show disk info
71 command_ret_t
do_info(cmd_tbl_t
*cmdtp
, uint_fast8_t flag
, int argc
, char * const argv
[])
77 unsigned char uca
[64];
82 (void) cmdtp
; (void) flag
;
87 dev
= (BYTE
) eval_arg(argv
[1], NULL
);
89 res
= disk_status(dev
);
90 if (res
& (STA_NODISK
| STA_NOINIT
)) {
91 printf_P(res
& STA_NODISK
?
92 PSTR("No disk\n") : PSTR("Not initialized\n"));
93 return CMD_RET_FAILURE
;
96 if (disk_ioctl(dev
, GET_SECTOR_COUNT
, &dat
.ul
) == RES_OK
)
97 printf_P(PSTR("Drive size: %lu sectors\n"), dat
.ul
);
98 if (disk_ioctl(dev
, GET_BLOCK_SIZE
, &dat
.ul
) == RES_OK
)
99 printf_P(PSTR("Erase block: %lu sectors\n"), dat
.ul
);
100 if (disk_ioctl(dev
, MMC_GET_TYPE
, &dat
.uc
) == RES_OK
)
101 printf_P(PSTR("Card type: %u\n"), dat
.uc
);
102 if (disk_ioctl(dev
, MMC_GET_CSD
, dat
.uca
) == RES_OK
)
103 dump_ram(dat
.uca
, 0, 16, "CSD:");
104 if (disk_ioctl(dev
, MMC_GET_CID
, dat
.uca
) == RES_OK
)
105 dump_ram(dat
.uca
, 0, 16, "CID:");
106 if (disk_ioctl(dev
, MMC_GET_OCR
, dat
.uca
) == RES_OK
)
107 dump_ram(dat
.uca
, 0, 4, "OCR:");
108 if (disk_ioctl(dev
, MMC_GET_SDSTAT
, dat
.uca
) == RES_OK
)
109 dump_ram(dat
.uca
, 0, 64, "SD Status:");
111 return CMD_RET_SUCCESS
;
116 * dump <pd#> [<sector> [count]] - Dump sector
120 command_ret_t
do_dump(cmd_tbl_t
*cmdtp
, uint_fast8_t flag
, int argc
, char * const argv
[])
122 static BYTE dev_last
;
123 static DWORD sec_last
;
124 BYTE buffer
[FF_MAX_SS
];
132 (void) cmdtp
; (void) flag
;
135 return CMD_RET_USAGE
;
137 dev
= (BYTE
) eval_arg(argv
[1], NULL
);
143 if ((flag
& CMD_FLAG_REPEAT
) == 0) {
144 /* If another parameter, it is the sector to dump. */
146 sec
= eval_arg(argv
[2], NULL
);
148 count
= (UINT
) eval_arg(argv
[3], NULL
);
151 for ( ; count
; count
--, sec
++) {
152 res
= disk_read(dev
, buffer
, sec
, 1);
155 cmd_error(CMD_RET_FAILURE
, 0, PSTR("rc=%.2x"), res
);
157 sprintf_P(header
, PSTR("Sector: %lu"), sec
);
158 dump_ram(buffer
, 0, FF_MAX_SS
, header
);
163 return CMD_RET_SUCCESS
;
167 * read drive sector count memaddr - Read disk into memory
171 command_ret_t
do_read(cmd_tbl_t
*cmdtp
, uint_fast8_t flag
, int argc
, char * const argv
[])
178 BYTE buffer
[FF_MAX_SS
];
180 static DWORD sec_last
;
181 static uint32_t addr_last
;
186 return CMD_RET_USAGE
;
188 dev
= (BYTE
) eval_arg(argv
[1], NULL
);
193 if ((flag
& CMD_FLAG_REPEAT
) == 0) {
194 /* If another parameter, it is the sector to dump. */
196 sec
= eval_arg(argv
[2], NULL
);
198 count
= eval_arg(argv
[3], NULL
);
200 addr
= eval_arg(argv
[4], NULL
);
203 for (nr
= 0; nr
< count
;) {
205 if ((res
= disk_read(dev
, buffer
, sec
, 1)) == RES_OK
) {
206 z80_bus_request_or_exit();
207 z80_write_block(buffer
, addr
/*+ base*/, FF_MAX_SS
);
208 z80_bus_cmd(Release
);
209 sec
++; addr
+= FF_MAX_SS
;
214 printf_P(PSTR("Read %d sector(s), rc=%.2x.\n"), nr
, res
);
216 printf_P(PSTR("Last sector not written!\n"));
221 return res
? CMD_RET_FAILURE
: CMD_RET_SUCCESS
;
226 * write <pd#> <sector> <memaddr> [<n>] - Write memory to disk
230 command_ret_t
do_write(cmd_tbl_t
*cmdtp
, uint_fast8_t flag
, int argc
, char * const argv
[])
237 BYTE buffer
[FF_MAX_SS
];
239 static DWORD sec_last
;
240 static uint32_t addr_last
;
245 return CMD_RET_USAGE
;
247 dev
= (BYTE
) eval_arg(argv
[1], NULL
);
252 if ((flag
& CMD_FLAG_REPEAT
) == 0) {
253 /* If another parameter, it is the sector to dump. */
255 sec
= eval_arg(argv
[2], NULL
);
257 count
= eval_arg(argv
[3], NULL
);
259 addr
= eval_arg(argv
[4], NULL
);
262 for (nr
= 0; nr
< count
;) {
264 z80_bus_request_or_exit();
265 z80_read_block(buffer
, addr
/*+ base*/, FF_MAX_SS
);
266 z80_bus_cmd(Release
);
268 res
= disk_write(dev
, buffer
, sec
, 1);
271 sec
++; addr
+= FF_MAX_SS
;
274 printf_P(PSTR("%d sector(s) written, rc=%.2x.\n"), nr
, res
);
279 return res
? CMD_RET_FAILURE
: CMD_RET_SUCCESS
;
286 * sync <pd#> - CTRL_SYNC
290 command_ret_t
do_ioctl_sync(cmd_tbl_t
*cmdtp
, uint_fast8_t flag
, int argc
, char * const argv
[])
294 (void) cmdtp
; (void) flag
;
297 return CMD_RET_USAGE
;
299 dev
= (BYTE
) eval_arg(argv
[1], NULL
);
300 printf_P(PSTR("rc=%.2x\n"), disk_ioctl(dev
, CTRL_SYNC
, 0));
302 return CMD_RET_SUCCESS
;
306 cmd_tbl_t cmd_tbl_sd
[] = {
308 status
, 2, CTBL_RPT
, do_status
,
313 init
, 2, CTBL_RPT
, do_init
,
318 info
, 2, CTBL_RPT
, do_info
,
323 dump
, CONFIG_SYS_MAXARGS
, CTBL_RPT
, do_dump
,
325 "drive [sector [count ]]"
328 read
, 2, CTBL_RPT
, do_read
,
329 "Read disk sector(s) into meomory",
330 "drive [sector [count [memaddr]]]"
333 write
, 2, CTBL_RPT
, do_write
,
334 "Write sector(s) from meomory to disk",
335 "drive [sector [count [memaddr]]]"
338 sync
, 2, CTBL_RPT
, do_ioctl_sync
,
339 "Device control: SYNC",
344 help
, CONFIG_SYS_MAXARGS
, CTBL_RPT
, do_help
,
345 "Print sub command description/usage",
347 " - print brief description of all sub commands\n"
348 "sd help command ...\n"
349 " - print detailed usage of sub cmd 'command'"
352 /* This does not use the CMD_TBL_ITEM macro as ? can't be used in symbol names */
353 {FSTR("?"), CONFIG_SYS_MAXARGS
, 1, do_help
,
355 #ifdef CONFIG_SYS_LONGHELP
357 #endif /* CONFIG_SYS_LONGHELP */
359 #ifdef CONFIG_AUTO_COMPLETE
363 /* Mark end of table */
364 CMD_TBL_END(cmd_tbl_sd
)
368 command_ret_t
do_sd(cmd_tbl_t
*cmdtp UNUSED
, uint_fast8_t flag UNUSED
, int argc UNUSED
, char * const argv
[] UNUSED
)
370 puts_P(PSTR("Huch?"));
371 return CMD_RET_USAGE
;