1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00

Merge pull request #18112 from fjmolinas/pr_vfs_rmount_mkdir

sys/shell/vfs: add umount, rmount and mkdir commands
This commit is contained in:
benpicco 2022-05-23 23:33:16 +02:00 committed by GitHub
commit c72d4ccc0e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -60,18 +60,26 @@ static void _vfs_usage(char **argv)
printf("%s ls <path>\n", argv[0]); printf("%s ls <path>\n", argv[0]);
printf("%s cp <src> <dest>\n", argv[0]); printf("%s cp <src> <dest>\n", argv[0]);
printf("%s mv <src> <dest>\n", argv[0]); printf("%s mv <src> <dest>\n", argv[0]);
printf("%s mkdir <path> \n", argv[0]);
printf("%s rm <file>\n", argv[0]); printf("%s rm <file>\n", argv[0]);
printf("%s df [path]\n", argv[0]); printf("%s df [path]\n", argv[0]);
if (MOUNTPOINTS_NUMOF > 0) { if (MOUNTPOINTS_NUMOF > 0) {
printf("%s mount [path]\n", argv[0]); printf("%s mount [path]\n", argv[0]);
} }
if (MOUNTPOINTS_NUMOF > 0) {
printf("%s umount [path]\n", argv[0]);
}
if (MOUNTPOINTS_NUMOF > 0) {
printf("%s remount [path]\n", argv[0]);
}
puts("r: Read [bytes] bytes at [offset] in file <path>"); puts("r: Read [bytes] bytes at [offset] in file <path>");
puts("w: Write (<a>: append, <o> overwrite) <ascii> or <hex> string <data> in file <path>"); puts("w: Write (<a>: append, <o> overwrite) <ascii> or <hex> string <data> in file <path>");
puts("ls: list files in <path>"); puts("ls: List files in <path>");
puts("mv: Move <src> file to <dest>"); puts("mv: Move <src> file to <dest>");
puts("mkdir: Create directory <path> ");
puts("cp: Copy <src> file to <dest>"); puts("cp: Copy <src> file to <dest>");
puts("rm: Unlink (delete) <file>"); puts("rm: Unlink (delete) <file>");
puts("df: show file system space utilization stats"); puts("df: Show file system space utilization stats");
} }
/* Macro used by _errno_string to expand errno labels to string and print it */ /* Macro used by _errno_string to expand errno labels to string and print it */
@ -170,8 +178,39 @@ static int _mount_handler(int argc, char **argv)
return -1; return -1;
} }
uint8_t buf[16];
int res = vfs_mount_by_path(argv[1]); int res = vfs_mount_by_path(argv[1]);
puts(strerror(res)); _errno_string(res, (char *)buf, sizeof(buf));
return res;
}
static int _umount_handler(int argc, char **argv)
{
if (argc < 2) {
printf("usage: %s [path]\n", argv[0]);
puts("umount pre-configured mount point");
return -1;
}
uint8_t buf[16];
int res = vfs_unmount_by_path(argv[1]);
_errno_string(res, (char *)buf, sizeof(buf));
return res;
}
static int _remount_handler(int argc, char **argv)
{
if (argc < 2) {
printf("usage: %s [path]\n", argv[0]);
puts("remount pre-configured mount point");
return -1;
}
uint8_t buf[16];
vfs_unmount_by_path(argv[1]);
int res = vfs_mount_by_path(argv[1]);
_errno_string(res, (char *)buf, sizeof(buf));
return res; return res;
} }
@ -531,6 +570,25 @@ static int _rm_handler(int argc, char **argv)
return 0; return 0;
} }
static int _mkdir_handler(int argc, char **argv)
{
if (argc < 2) {
_vfs_usage(argv);
return 1;
}
char *dir_name = argv[1];
printf("%s: mkdir: %s\n", argv[0], dir_name);
int res = vfs_mkdir(dir_name, 0);
if (res < 0) {
char errbuf[16];
_errno_string(res, (char *)errbuf, sizeof(errbuf));
printf("mkdir ERR: %s\n", errbuf);
return 2;
}
return 0;
}
int _ls_handler(int argc, char **argv) int _ls_handler(int argc, char **argv)
{ {
if (argc < 2) { if (argc < 2) {
@ -623,6 +681,9 @@ int _vfs_handler(int argc, char **argv)
else if (strcmp(argv[1], "mv") == 0) { else if (strcmp(argv[1], "mv") == 0) {
return _mv_handler(argc - 1, &argv[1]); return _mv_handler(argc - 1, &argv[1]);
} }
else if (strcmp(argv[1], "mkdir") == 0) {
return _mkdir_handler(argc - 1, &argv[1]);
}
else if (strcmp(argv[1], "rm") == 0) { else if (strcmp(argv[1], "rm") == 0) {
return _rm_handler(argc - 1, &argv[1]); return _rm_handler(argc - 1, &argv[1]);
} }
@ -632,6 +693,12 @@ int _vfs_handler(int argc, char **argv)
else if (MOUNTPOINTS_NUMOF > 0 && strcmp(argv[1], "mount") == 0) { else if (MOUNTPOINTS_NUMOF > 0 && strcmp(argv[1], "mount") == 0) {
return _mount_handler(argc - 1, &argv[1]); return _mount_handler(argc - 1, &argv[1]);
} }
else if (MOUNTPOINTS_NUMOF > 0 && strcmp(argv[1], "umount") == 0) {
return _umount_handler(argc - 1, &argv[1]);
}
else if (MOUNTPOINTS_NUMOF > 0 && strcmp(argv[1], "remount") == 0) {
return _remount_handler(argc - 1, &argv[1]);
}
else { else {
printf("vfs: unsupported sub-command \"%s\"\n", argv[1]); printf("vfs: unsupported sub-command \"%s\"\n", argv[1]);
return 1; return 1;