source: mainline/uspace/app/bdsh/cmds/modules/mount/mount.c@ 5a6cc679

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 5a6cc679 was 5a6cc679, checked in by Jenda <jenda.jzqk73@…>, 8 years ago

Merge commit '50f19b7ee8e94570b5c63896736c4eb49cfa18db' into forwardport

Not all ints are converted to errno_t in xhci tree yet, however it compiles and works :)

  • Property mode set to 100644
File size: 4.7 KB
Line 
1/*
2 * Copyright (c) 2009 Jakub Jermar
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29#include <loc.h>
30#include <stdio.h>
31#include <stdlib.h>
32#include <str_error.h>
33#include <vfs/vfs.h>
34#include <vfs/vfs_mtab.h>
35#include <adt/list.h>
36#include <errno.h>
37#include <getopt.h>
38#include <inttypes.h>
39#include "config.h"
40#include "util.h"
41#include "errors.h"
42#include "entry.h"
43#include "mount.h"
44#include "cmds.h"
45
46static const char *cmdname = "mount";
47
48static struct option const long_options[] = {
49 { "help", no_argument, 0, 'h' },
50 { "instance", required_argument, 0, 'i' },
51 { "types", no_argument, 0, 't' },
52 { 0, 0, 0, 0 }
53};
54
55
56/* Displays help for mount in various levels */
57void help_cmd_mount(unsigned int level)
58{
59 static char helpfmt[] =
60 "Usage: %s <fstype> <mp> [dev] [<moptions>]\n"
61 "Options:\n"
62 " -h, --help A short option summary\n"
63 " -i, --instance ## Mount a specific instance\n"
64 " -t, --types List available file system types\n";
65
66 if (level == HELP_SHORT) {
67 printf("'%s' mounts a file system.\n", cmdname);
68 } else {
69 help_cmd_mount(HELP_SHORT);
70 printf(helpfmt, cmdname);
71 }
72 return;
73}
74
75static void print_mtab_list(void)
76{
77 LIST_INITIALIZE(mtab_list);
78 mtab_ent_t *old_ent = NULL;
79 char *svc_name;
80 errno_t rc;
81
82 vfs_get_mtab_list(&mtab_list);
83
84 list_foreach(mtab_list, link, mtab_ent_t, mtab_ent) {
85 if (old_ent)
86 free(old_ent);
87
88 old_ent = mtab_ent;
89
90 printf("%s", mtab_ent->fs_name);
91
92 printf(" %s", mtab_ent->mp);
93
94 rc = loc_service_get_name(mtab_ent->service_id, &svc_name);
95 if (rc == EOK) {
96 printf(" %s", svc_name);
97 free(svc_name);
98 } else {
99 printf(" (%" PRIun ")", mtab_ent->service_id);
100 }
101
102 putchar('\n');
103 }
104
105 if (old_ent)
106 free(old_ent);
107}
108
109static void print_fstypes(void)
110{
111 errno_t rc;
112 vfs_fstypes_t fstypes;
113 char **p;
114
115 rc = vfs_fstypes(&fstypes);
116 if (rc != EOK) {
117 printf("Error getting list of available file system types.\n");
118 return;
119 }
120
121 printf("Available file system types:\n");
122 p = fstypes.fstypes;
123 while (*p != NULL)
124 printf("\t%s\n", *p++);
125 vfs_fstypes_free(&fstypes);
126}
127
128/* Main entry point for mount, accepts an array of arguments */
129int cmd_mount(char **argv)
130{
131 unsigned int argc;
132 const char *mopts = "";
133 const char *dev = "";
134 errno_t rc;
135 int c, opt_ind;
136 unsigned int instance = 0;
137 bool instance_set = false;
138 char **t_argv;
139
140 argc = cli_count_args(argv);
141
142 for (c = 0, optreset = 1, optind = 0, opt_ind = 0; c != -1;) {
143 c = getopt_long(argc, argv, "i:ht", long_options, &opt_ind);
144 switch (c) {
145 case 'h':
146 help_cmd_mount(HELP_LONG);
147 return CMD_SUCCESS;
148 case 'i':
149 instance = (unsigned int) strtol(optarg, NULL, 10);
150 instance_set = true;
151 break;
152 case 't':
153 print_fstypes();
154 return CMD_SUCCESS;
155 }
156 }
157
158 if (instance_set) {
159 argc -= 2;
160 t_argv = &argv[2];
161 } else
162 t_argv = &argv[0];
163
164 if ((argc == 2) || (argc > 5)) {
165 printf("%s: invalid number of arguments. Try `mount --help'\n",
166 cmdname);
167 return CMD_FAILURE;
168 }
169 if (argc == 1) {
170 print_mtab_list();
171 return CMD_SUCCESS;
172 }
173 if (argc > 3)
174 dev = t_argv[3];
175 if (argc == 5)
176 mopts = t_argv[4];
177
178 rc = vfs_mount_path(t_argv[2], t_argv[1], dev, mopts, 0, instance);
179 if (rc != EOK) {
180 printf("Unable to mount %s filesystem to %s on %s (rc=%s)\n",
181 t_argv[2], t_argv[1], t_argv[3], str_error(rc));
182 if (rc == ENOFS)
183 print_fstypes();
184 return CMD_FAILURE;
185 }
186
187 return CMD_SUCCESS;
188}
189
Note: See TracBrowser for help on using the repository browser.