1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
|
/*
* lib/part/create.c
*
* Copyright (C) 1997,1998 Russell King
*/
#include <assert.h>
#include <stdlib.h>
#include <string.h>
#include "util/debug.h"
#include "util/error.h"
#include "part/part.h"
/* Prototype: u_int part_create(part_t *part, partinfo_t *pinfo)
* Function : Allocate a new partition slot `parn' and kernel partition number.
* Params : part - partitionable device
* : parn - partition number, or PARN_ALLOCATE to use first slot
* : pinfo - partition info structure to set new partition as
* Returns : FALSE on error
* Notes : Do not alter any structures on disk.
*/
u_int part_allocate(part_t *part, partinfo_t *pinfo)
{
u_int parn;
assert(part != NULL);
assert(part->scheme != NULL);
assert(pinfo != NULL);
dbg_printf("part_allocate(pinfo=[bs=0x%X, be=0x%X, type=0x%X])",
pinfo->blk_start, pinfo->blk_end, pinfo->type);
dbg_level_up();
clear_error();
do {
parn = part->scheme->allocate(part, pinfo);
if (parn == PARN_ERROR) {
if (!is_error_set())
set_error("unable to allocate slot for partition");
break;
}
if (part->scheme->validate_partno(part, parn)) {
if (part->nr_partitions == 0 || parn >= part->nr_partitions) {
partinfo_i_t **p;
u_int new_nr = parn + 1;
p = malloc(new_nr * sizeof(*p));
if (p) {
memset(p, 0, new_nr * sizeof(*p));
memcpy(p, part->partinfo, part->nr_partitions * sizeof(*p));
free(part->partinfo);
part->partinfo = p;
part->nr_partitions = new_nr;
} else {
set_error("out of memory");
break;
}
}
} else if (!is_error_set())
set_error("part_allocate: invalid partition number %d", parn);
} while (0);
dbg_level_down();
dbg_printf("ret=%d (kern_part_no=%d)", parn, pinfo->kern_part_no);
return parn;
}
|