source: mainline/uspace/app/hdisk/func_gpt.c@ 283ea3d

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 283ea3d was dc76f4a, checked in by Dominik Taborsky (AT DOT) <brembyseznamcz>, 12 years ago

libmbr, libgpt polishing

  • Property mode set to 100644
File size: 5.3 KB
Line 
1/*
2 * Copyright (c) 2012, 2013 Dominik Taborsky
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 /** @addtogroup hdisk
30 * @{
31 */
32/** @file
33 */
34
35#include <stdio.h>
36#include <str.h>
37#include <errno.h>
38#include <str_error.h>
39#include <sys/types.h>
40
41#include "func_gpt.h"
42#include "input.h"
43
44static int set_gpt_partition(tinput_t *, gpt_part_t *, unsigned int);
45
46int construct_gpt_label(label_t *this)
47{
48 this->layout = LYT_GPT;
49 this->alignment = 1;
50
51 this->add_part = add_gpt_part;
52 this->delete_part = delete_gpt_part;
53 this->destroy_label = destroy_gpt_label;
54 this->new_label = new_gpt_label;
55 this->print_parts = print_gpt_parts;
56 this->read_parts = read_gpt_parts;
57 this->write_parts = write_gpt_parts;
58 this->extra_funcs = extra_gpt_funcs;
59
60 return this->new_label(this);
61}
62
63int add_gpt_part(label_t *this, tinput_t *in)
64{
65 gpt_part_t * p = gpt_get_partition(this->data.gpt);
66 if (p == NULL) {
67 return ENOMEM;
68 }
69
70 return set_gpt_partition(in, p, this->alignment);
71}
72
73int delete_gpt_part(label_t *this, tinput_t *in)
74{
75 int rc;
76 size_t idx;
77
78 printf("Number of the partition to delete (counted from 0): ");
79 idx = get_input_size_t(in);
80
81 rc = gpt_remove_partition(this->data.gpt, idx);
82 if (rc == ENOMEM) {
83 printf("Warning: running low on memory, not resizing...\n");
84 return rc;
85 } else if (rc == EINVAL) {
86 printf("Invalid index.\n");
87 return rc;
88 }
89
90 return EOK;
91}
92
93int destroy_gpt_label(label_t *this)
94{
95 gpt_free_label(this->data.gpt);
96 return EOK;
97}
98
99int new_gpt_label(label_t *this)
100{
101 this->data.gpt = gpt_alloc_label();
102 return EOK;
103}
104
105int print_gpt_parts(label_t *this)
106{
107 printf("Current partition scheme (GPT):\n");
108 printf("%15s %10s %10s Type: Name:\n", "Start:", "End:", "Length:");
109
110 size_t i = 0;
111
112 gpt_part_foreach(this->data.gpt, iter) {
113 i++;
114
115 if (gpt_get_part_type(iter) == GPT_PTE_UNUSED)
116 continue;
117
118 if (i % 20 == 0)
119 printf("%15s %10s %10s Type: Name:\n", "Start:", "End:", "Length:");
120
121
122 printf("%3u %10llu %10llu %10llu %3d %s\n", i-1, gpt_get_start_lba(iter), gpt_get_end_lba(iter),
123 gpt_get_end_lba(iter) - gpt_get_start_lba(iter), gpt_get_part_type(iter),
124 gpt_get_part_name(iter));
125
126 }
127
128 return EOK;
129}
130
131int read_gpt_parts(label_t *this, service_id_t dev_handle)
132{
133 int rc;
134
135 rc = gpt_read_header(this->data.gpt, dev_handle);
136 if (rc != EOK) {
137 printf("Error: Reading header failed: %d (%s)\n", rc, str_error(rc));
138 return rc;
139 }
140
141 rc = gpt_read_partitions(this->data.gpt);
142 if (rc != EOK) {
143 printf("Error: Reading partitions failed: %d (%s)\n", rc, str_error(rc));
144 return rc;
145 }
146
147 return EOK;
148}
149
150int write_gpt_parts(label_t *this, service_id_t dev_handle)
151{
152 int rc;
153
154 rc = gpt_write_partitions(this->data.gpt, dev_handle);
155 if (rc != EOK) {
156 printf("Error: Writing partitions failed: %d (%s)\n", rc, str_error(rc));
157 return rc;
158 }
159
160 rc = gpt_write_header(this->data.gpt, dev_handle);
161 if (rc != EOK) {
162 printf("Error: Writing header failed: %d (%s)\n", rc, str_error(rc));
163 return rc;
164 }
165
166 return EOK;
167}
168
169int extra_gpt_funcs(label_t *this, tinput_t *in, service_id_t dev_handle)
170{
171 printf("Not implemented.\n");
172 return EOK;
173}
174
175static int set_gpt_partition(tinput_t *in, gpt_part_t *p, unsigned int alignment)
176{
177 int rc;
178
179 uint64_t sa, ea;
180
181 printf("Set starting address (number): ");
182 sa = get_input_uint64(in);
183 if (sa % alignment != 0)
184 sa = gpt_get_next_aligned(sa, alignment);
185
186 printf("Set end addres (number): ");
187 ea = get_input_uint64(in);
188
189 if (ea <= sa) {
190 printf("Invalid value.\n");
191 return EINVAL;
192 }
193
194 gpt_set_start_lba(p, sa);
195 gpt_set_end_lba(p, ea);
196
197 //printf("Set type : ");
198 //size_t idx = get_input_size_t(in);
199 //gpt_set_part_type(p, idx);
200
201 gpt_set_random_uuid(p->part_type);
202 gpt_set_random_uuid(p->part_id);
203
204 char *name;
205 printf("Name the partition: ");
206 rc = get_input_line(in, &name);
207 if (rc != EOK) {
208 printf("Error reading name: %d (%s)\n", rc, str_error(rc));
209 return rc;
210 }
211
212 gpt_set_part_name(p, name, str_size(name));
213
214 return EOK;
215}
216
Note: See TracBrowser for help on using the repository browser.