source: mainline/uspace/app/hdisk/func_gpt.c@ c3cbbb2

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

more libgpt fixes

  • Property mode set to 100644
File size: 5.2 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 *);
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);
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 != EOK) {
83 printf("Warning: running low on memory, not resizing...\n");
84 return rc;
85 }
86
87 return EOK;
88}
89
90int destroy_gpt_label(label_t *this)
91{
92 gpt_free_label(this->data.gpt);
93 return EOK;
94}
95
96int new_gpt_label(label_t *this)
97{
98 this->data.gpt = gpt_alloc_label();
99 return EOK;
100}
101
102int print_gpt_parts(label_t *this)
103{
104 //int rc;
105 printf("Current partition scheme (GPT):\n");
106 printf("\t\tStart:\tEnd:\tLength:\tType:\tName:\n");
107
108 size_t i = 0;
109
110 gpt_part_foreach(this->data.gpt, iter) {
111 i++;
112
113 if (gpt_get_part_type(iter) == GPT_PTE_UNUSED)
114 continue;
115
116 if (i % 20 == 0)
117 printf("%15s %10s %10s Type: Name:\n", "Start:", "End:", "Length:");
118
119 //printf("\t%10u %10u %10u %3d\n", iter->start_addr, iter->start_addr + iter->length,
120 // iter->length, gpt_get_part_type(iter), gpt_get_part_name(iter));
121 printf("%3u %10llu %10llu %10llu %3d %s\n", i-1, gpt_get_start_lba(iter), gpt_get_end_lba(iter),
122 gpt_get_end_lba(iter) - gpt_get_start_lba(iter), gpt_get_part_type(iter),
123 gpt_get_part_name(iter));
124
125 }
126
127 //return rc;
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)
176{
177 int rc;
178
179 uint64_t sa, ea;
180
181 printf("Set starting address (number): ");
182 sa = get_input_uint64(in);
183
184 printf("Set end addres (number): ");
185 ea = get_input_uint64(in);
186
187 if (ea <= sa) {
188 printf("Invalid value.\n");
189 return EINVAL;
190 }
191
192 gpt_set_start_lba(p, sa);
193 gpt_set_end_lba(p, ea);
194
195 //printf("Set type : ");
196 //size_t idx = get_input_size_t(in);
197 //gpt_set_part_type(p, idx);
198
199 gpt_set_random_uuid(p->part_type);
200 gpt_set_random_uuid(p->part_id);
201
202 char *name;
203 printf("Name the partition: ");
204 rc = get_input_line(in, &name);
205 if (rc != EOK) {
206 printf("Error reading name: %d (%s)\n", rc, str_error(rc));
207 return rc;
208 }
209
210 gpt_set_part_name(p, name, str_size(name));
211
212 return EOK;
213}
214
Note: See TracBrowser for help on using the repository browser.