xref: /dflybsd-src/contrib/lvm2/dist/lib/format_text/text_label.c (revision 86d7f5d305c6adaa56ff4582ece9859d73106103)
1*86d7f5d3SJohn Marino /*	$NetBSD: text_label.c,v 1.1.1.2 2009/12/02 00:26:28 haad Exp $	*/
2*86d7f5d3SJohn Marino 
3*86d7f5d3SJohn Marino /*
4*86d7f5d3SJohn Marino  * Copyright (C) 2002-2004 Sistina Software, Inc. All rights reserved.
5*86d7f5d3SJohn Marino  * Copyright (C) 2004-2006 Red Hat, Inc. All rights reserved.
6*86d7f5d3SJohn Marino  *
7*86d7f5d3SJohn Marino  * This file is part of LVM2.
8*86d7f5d3SJohn Marino  *
9*86d7f5d3SJohn Marino  * This copyrighted material is made available to anyone wishing to use,
10*86d7f5d3SJohn Marino  * modify, copy, or redistribute it subject to the terms and conditions
11*86d7f5d3SJohn Marino  * of the GNU Lesser General Public License v.2.1.
12*86d7f5d3SJohn Marino  *
13*86d7f5d3SJohn Marino  * You should have received a copy of the GNU Lesser General Public License
14*86d7f5d3SJohn Marino  * along with this program; if not, write to the Free Software Foundation,
15*86d7f5d3SJohn Marino  * Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16*86d7f5d3SJohn Marino  */
17*86d7f5d3SJohn Marino 
18*86d7f5d3SJohn Marino #include "lib.h"
19*86d7f5d3SJohn Marino #include "format-text.h"
20*86d7f5d3SJohn Marino #include "layout.h"
21*86d7f5d3SJohn Marino #include "label.h"
22*86d7f5d3SJohn Marino #include "xlate.h"
23*86d7f5d3SJohn Marino #include "lvmcache.h"
24*86d7f5d3SJohn Marino 
25*86d7f5d3SJohn Marino #include <sys/stat.h>
26*86d7f5d3SJohn Marino #include <fcntl.h>
27*86d7f5d3SJohn Marino 
_text_can_handle(struct labeller * l __attribute ((unused)),void * buf,uint64_t sector __attribute ((unused)))28*86d7f5d3SJohn Marino static int _text_can_handle(struct labeller *l __attribute((unused)),
29*86d7f5d3SJohn Marino 			    void *buf,
30*86d7f5d3SJohn Marino 			    uint64_t sector __attribute((unused)))
31*86d7f5d3SJohn Marino {
32*86d7f5d3SJohn Marino 	struct label_header *lh = (struct label_header *) buf;
33*86d7f5d3SJohn Marino 
34*86d7f5d3SJohn Marino 	if (!strncmp((char *)lh->type, LVM2_LABEL, sizeof(lh->type)))
35*86d7f5d3SJohn Marino 		return 1;
36*86d7f5d3SJohn Marino 
37*86d7f5d3SJohn Marino 	return 0;
38*86d7f5d3SJohn Marino }
39*86d7f5d3SJohn Marino 
_text_write(struct label * label,void * buf)40*86d7f5d3SJohn Marino static int _text_write(struct label *label, void *buf)
41*86d7f5d3SJohn Marino {
42*86d7f5d3SJohn Marino 	struct label_header *lh = (struct label_header *) buf;
43*86d7f5d3SJohn Marino 	struct pv_header *pvhdr;
44*86d7f5d3SJohn Marino 	struct lvmcache_info *info;
45*86d7f5d3SJohn Marino 	struct disk_locn *pvh_dlocn_xl;
46*86d7f5d3SJohn Marino 	struct metadata_area *mda;
47*86d7f5d3SJohn Marino 	struct mda_context *mdac;
48*86d7f5d3SJohn Marino 	struct data_area_list *da;
49*86d7f5d3SJohn Marino 	char buffer[64] __attribute((aligned(8)));
50*86d7f5d3SJohn Marino 	int da1, mda1, mda2;
51*86d7f5d3SJohn Marino 
52*86d7f5d3SJohn Marino 	/* FIXME Move to where label is created */
53*86d7f5d3SJohn Marino 	strncpy(label->type, LVM2_LABEL, sizeof(label->type));
54*86d7f5d3SJohn Marino 
55*86d7f5d3SJohn Marino 	strncpy((char *)lh->type, label->type, sizeof(label->type));
56*86d7f5d3SJohn Marino 
57*86d7f5d3SJohn Marino 	pvhdr = (struct pv_header *) ((void *) buf + xlate32(lh->offset_xl));
58*86d7f5d3SJohn Marino 	info = (struct lvmcache_info *) label->info;
59*86d7f5d3SJohn Marino 	pvhdr->device_size_xl = xlate64(info->device_size);
60*86d7f5d3SJohn Marino 	memcpy(pvhdr->pv_uuid, &info->dev->pvid, sizeof(struct id));
61*86d7f5d3SJohn Marino 	if (!id_write_format((const struct id *)pvhdr->pv_uuid, buffer,
62*86d7f5d3SJohn Marino 			     sizeof(buffer))) {
63*86d7f5d3SJohn Marino 		stack;
64*86d7f5d3SJohn Marino 		buffer[0] = '\0';
65*86d7f5d3SJohn Marino 	}
66*86d7f5d3SJohn Marino 
67*86d7f5d3SJohn Marino 	pvh_dlocn_xl = &pvhdr->disk_areas_xl[0];
68*86d7f5d3SJohn Marino 
69*86d7f5d3SJohn Marino 	/* List of data areas (holding PEs) */
70*86d7f5d3SJohn Marino 	dm_list_iterate_items(da, &info->das) {
71*86d7f5d3SJohn Marino 		pvh_dlocn_xl->offset = xlate64(da->disk_locn.offset);
72*86d7f5d3SJohn Marino 		pvh_dlocn_xl->size = xlate64(da->disk_locn.size);
73*86d7f5d3SJohn Marino 		pvh_dlocn_xl++;
74*86d7f5d3SJohn Marino 	}
75*86d7f5d3SJohn Marino 
76*86d7f5d3SJohn Marino 	/* NULL-termination */
77*86d7f5d3SJohn Marino 	pvh_dlocn_xl->offset = xlate64(UINT64_C(0));
78*86d7f5d3SJohn Marino 	pvh_dlocn_xl->size = xlate64(UINT64_C(0));
79*86d7f5d3SJohn Marino 	pvh_dlocn_xl++;
80*86d7f5d3SJohn Marino 
81*86d7f5d3SJohn Marino 	/* List of metadata area header locations */
82*86d7f5d3SJohn Marino 	dm_list_iterate_items(mda, &info->mdas) {
83*86d7f5d3SJohn Marino 		mdac = (struct mda_context *) mda->metadata_locn;
84*86d7f5d3SJohn Marino 
85*86d7f5d3SJohn Marino 		if (mdac->area.dev != info->dev)
86*86d7f5d3SJohn Marino 			continue;
87*86d7f5d3SJohn Marino 
88*86d7f5d3SJohn Marino 		pvh_dlocn_xl->offset = xlate64(mdac->area.start);
89*86d7f5d3SJohn Marino 		pvh_dlocn_xl->size = xlate64(mdac->area.size);
90*86d7f5d3SJohn Marino 		pvh_dlocn_xl++;
91*86d7f5d3SJohn Marino 	}
92*86d7f5d3SJohn Marino 
93*86d7f5d3SJohn Marino 	/* NULL-termination */
94*86d7f5d3SJohn Marino 	pvh_dlocn_xl->offset = xlate64(UINT64_C(0));
95*86d7f5d3SJohn Marino 	pvh_dlocn_xl->size = xlate64(UINT64_C(0));
96*86d7f5d3SJohn Marino 
97*86d7f5d3SJohn Marino 	/* Create debug message with da and mda locations */
98*86d7f5d3SJohn Marino 	if (xlate64(pvhdr->disk_areas_xl[0].offset) ||
99*86d7f5d3SJohn Marino 	    xlate64(pvhdr->disk_areas_xl[0].size))
100*86d7f5d3SJohn Marino 		da1 = 0;
101*86d7f5d3SJohn Marino 	else
102*86d7f5d3SJohn Marino 		da1 = -1;
103*86d7f5d3SJohn Marino 
104*86d7f5d3SJohn Marino 	mda1 = da1 + 2;
105*86d7f5d3SJohn Marino 	mda2 = mda1 + 1;
106*86d7f5d3SJohn Marino 
107*86d7f5d3SJohn Marino 	if (!xlate64(pvhdr->disk_areas_xl[mda1].offset) &&
108*86d7f5d3SJohn Marino 	    !xlate64(pvhdr->disk_areas_xl[mda1].size))
109*86d7f5d3SJohn Marino 		mda1 = mda2 = 0;
110*86d7f5d3SJohn Marino 	else if (!xlate64(pvhdr->disk_areas_xl[mda2].offset) &&
111*86d7f5d3SJohn Marino 		 !xlate64(pvhdr->disk_areas_xl[mda2].size))
112*86d7f5d3SJohn Marino 		mda2 = 0;
113*86d7f5d3SJohn Marino 
114*86d7f5d3SJohn Marino 	log_debug("%s: Preparing PV label header %s size %" PRIu64 " with"
115*86d7f5d3SJohn Marino 		  "%s%.*" PRIu64 "%s%.*" PRIu64 "%s"
116*86d7f5d3SJohn Marino 		  "%s%.*" PRIu64 "%s%.*" PRIu64 "%s"
117*86d7f5d3SJohn Marino 		  "%s%.*" PRIu64 "%s%.*" PRIu64 "%s",
118*86d7f5d3SJohn Marino 		  dev_name(info->dev), buffer, info->device_size,
119*86d7f5d3SJohn Marino 		  (da1 > -1) ? " da1 (" : "",
120*86d7f5d3SJohn Marino 		  (da1 > -1) ? 1 : 0,
121*86d7f5d3SJohn Marino 		  (da1 > -1) ? xlate64(pvhdr->disk_areas_xl[da1].offset) >> SECTOR_SHIFT : 0,
122*86d7f5d3SJohn Marino 		  (da1 > -1) ? "s, " : "",
123*86d7f5d3SJohn Marino 		  (da1 > -1) ? 1 : 0,
124*86d7f5d3SJohn Marino 		  (da1 > -1) ? xlate64(pvhdr->disk_areas_xl[da1].size) >> SECTOR_SHIFT : 0,
125*86d7f5d3SJohn Marino 		  (da1 > -1) ? "s)" : "",
126*86d7f5d3SJohn Marino 		  mda1 ? " mda1 (" : "",
127*86d7f5d3SJohn Marino 		  mda1 ? 1 : 0,
128*86d7f5d3SJohn Marino 		  mda1 ? xlate64(pvhdr->disk_areas_xl[mda1].offset) >> SECTOR_SHIFT : 0,
129*86d7f5d3SJohn Marino 		  mda1 ? "s, " : "",
130*86d7f5d3SJohn Marino 		  mda1 ? 1 : 0,
131*86d7f5d3SJohn Marino 		  mda1 ? xlate64(pvhdr->disk_areas_xl[mda1].size) >> SECTOR_SHIFT : 0,
132*86d7f5d3SJohn Marino 		  mda1 ? "s)" : "",
133*86d7f5d3SJohn Marino 		  mda2 ? " mda2 (" : "",
134*86d7f5d3SJohn Marino 		  mda2 ? 1 : 0,
135*86d7f5d3SJohn Marino 		  mda2 ? xlate64(pvhdr->disk_areas_xl[mda2].offset) >> SECTOR_SHIFT : 0,
136*86d7f5d3SJohn Marino 		  mda2 ? "s, " : "",
137*86d7f5d3SJohn Marino 		  mda2 ? 1 : 0,
138*86d7f5d3SJohn Marino 		  mda2 ? xlate64(pvhdr->disk_areas_xl[mda2].size) >> SECTOR_SHIFT : 0,
139*86d7f5d3SJohn Marino 		  mda2 ? "s)" : "");
140*86d7f5d3SJohn Marino 
141*86d7f5d3SJohn Marino 	if (da1 < 0) {
142*86d7f5d3SJohn Marino 		log_error("Internal error: %s label header currently requires "
143*86d7f5d3SJohn Marino 			  "a data area.", dev_name(info->dev));
144*86d7f5d3SJohn Marino 		return 0;
145*86d7f5d3SJohn Marino 	}
146*86d7f5d3SJohn Marino 
147*86d7f5d3SJohn Marino 	return 1;
148*86d7f5d3SJohn Marino }
149*86d7f5d3SJohn Marino 
add_da(struct dm_pool * mem,struct dm_list * das,uint64_t start,uint64_t size)150*86d7f5d3SJohn Marino int add_da(struct dm_pool *mem, struct dm_list *das,
151*86d7f5d3SJohn Marino 	   uint64_t start, uint64_t size)
152*86d7f5d3SJohn Marino {
153*86d7f5d3SJohn Marino 	struct data_area_list *dal;
154*86d7f5d3SJohn Marino 
155*86d7f5d3SJohn Marino 	if (!mem) {
156*86d7f5d3SJohn Marino 		if (!(dal = dm_malloc(sizeof(*dal)))) {
157*86d7f5d3SJohn Marino 			log_error("struct data_area_list allocation failed");
158*86d7f5d3SJohn Marino 			return 0;
159*86d7f5d3SJohn Marino 		}
160*86d7f5d3SJohn Marino 	} else {
161*86d7f5d3SJohn Marino 		if (!(dal = dm_pool_alloc(mem, sizeof(*dal)))) {
162*86d7f5d3SJohn Marino 			log_error("struct data_area_list allocation failed");
163*86d7f5d3SJohn Marino 			return 0;
164*86d7f5d3SJohn Marino 		}
165*86d7f5d3SJohn Marino 	}
166*86d7f5d3SJohn Marino 
167*86d7f5d3SJohn Marino 	dal->disk_locn.offset = start;
168*86d7f5d3SJohn Marino 	dal->disk_locn.size = size;
169*86d7f5d3SJohn Marino 
170*86d7f5d3SJohn Marino 	dm_list_add(das, &dal->list);
171*86d7f5d3SJohn Marino 
172*86d7f5d3SJohn Marino 	return 1;
173*86d7f5d3SJohn Marino }
174*86d7f5d3SJohn Marino 
del_das(struct dm_list * das)175*86d7f5d3SJohn Marino void del_das(struct dm_list *das)
176*86d7f5d3SJohn Marino {
177*86d7f5d3SJohn Marino 	struct dm_list *dah, *tmp;
178*86d7f5d3SJohn Marino 	struct data_area_list *da;
179*86d7f5d3SJohn Marino 
180*86d7f5d3SJohn Marino 	dm_list_iterate_safe(dah, tmp, das) {
181*86d7f5d3SJohn Marino 		da = dm_list_item(dah, struct data_area_list);
182*86d7f5d3SJohn Marino 		dm_list_del(&da->list);
183*86d7f5d3SJohn Marino 		dm_free(da);
184*86d7f5d3SJohn Marino 	}
185*86d7f5d3SJohn Marino }
186*86d7f5d3SJohn Marino 
add_mda(const struct format_type * fmt,struct dm_pool * mem,struct dm_list * mdas,struct device * dev,uint64_t start,uint64_t size)187*86d7f5d3SJohn Marino int add_mda(const struct format_type *fmt, struct dm_pool *mem, struct dm_list *mdas,
188*86d7f5d3SJohn Marino 	    struct device *dev, uint64_t start, uint64_t size)
189*86d7f5d3SJohn Marino {
190*86d7f5d3SJohn Marino /* FIXME List size restricted by pv_header SECTOR_SIZE */
191*86d7f5d3SJohn Marino 	struct metadata_area *mdal;
192*86d7f5d3SJohn Marino 	struct mda_lists *mda_lists = (struct mda_lists *) fmt->private;
193*86d7f5d3SJohn Marino 	struct mda_context *mdac;
194*86d7f5d3SJohn Marino 
195*86d7f5d3SJohn Marino 	if (!mem) {
196*86d7f5d3SJohn Marino 		if (!(mdal = dm_malloc(sizeof(struct metadata_area)))) {
197*86d7f5d3SJohn Marino 			log_error("struct mda_list allocation failed");
198*86d7f5d3SJohn Marino 			return 0;
199*86d7f5d3SJohn Marino 		}
200*86d7f5d3SJohn Marino 
201*86d7f5d3SJohn Marino 		if (!(mdac = dm_malloc(sizeof(struct mda_context)))) {
202*86d7f5d3SJohn Marino 			log_error("struct mda_context allocation failed");
203*86d7f5d3SJohn Marino 			dm_free(mdal);
204*86d7f5d3SJohn Marino 			return 0;
205*86d7f5d3SJohn Marino 		}
206*86d7f5d3SJohn Marino 	} else {
207*86d7f5d3SJohn Marino 		if (!(mdal = dm_pool_alloc(mem, sizeof(struct metadata_area)))) {
208*86d7f5d3SJohn Marino 			log_error("struct mda_list allocation failed");
209*86d7f5d3SJohn Marino 			return 0;
210*86d7f5d3SJohn Marino 		}
211*86d7f5d3SJohn Marino 
212*86d7f5d3SJohn Marino 		if (!(mdac = dm_pool_alloc(mem, sizeof(struct mda_context)))) {
213*86d7f5d3SJohn Marino 			log_error("struct mda_context allocation failed");
214*86d7f5d3SJohn Marino 			return 0;
215*86d7f5d3SJohn Marino 		}
216*86d7f5d3SJohn Marino 	}
217*86d7f5d3SJohn Marino 
218*86d7f5d3SJohn Marino 	mdal->ops = mda_lists->raw_ops;
219*86d7f5d3SJohn Marino 	mdal->metadata_locn = mdac;
220*86d7f5d3SJohn Marino 
221*86d7f5d3SJohn Marino 	mdac->area.dev = dev;
222*86d7f5d3SJohn Marino 	mdac->area.start = start;
223*86d7f5d3SJohn Marino 	mdac->area.size = size;
224*86d7f5d3SJohn Marino 	mdac->free_sectors = UINT64_C(0);
225*86d7f5d3SJohn Marino 	memset(&mdac->rlocn, 0, sizeof(mdac->rlocn));
226*86d7f5d3SJohn Marino 
227*86d7f5d3SJohn Marino 	dm_list_add(mdas, &mdal->list);
228*86d7f5d3SJohn Marino 	return 1;
229*86d7f5d3SJohn Marino }
230*86d7f5d3SJohn Marino 
del_mdas(struct dm_list * mdas)231*86d7f5d3SJohn Marino void del_mdas(struct dm_list *mdas)
232*86d7f5d3SJohn Marino {
233*86d7f5d3SJohn Marino 	struct dm_list *mdah, *tmp;
234*86d7f5d3SJohn Marino 	struct metadata_area *mda;
235*86d7f5d3SJohn Marino 
236*86d7f5d3SJohn Marino 	dm_list_iterate_safe(mdah, tmp, mdas) {
237*86d7f5d3SJohn Marino 		mda = dm_list_item(mdah, struct metadata_area);
238*86d7f5d3SJohn Marino 		dm_free(mda->metadata_locn);
239*86d7f5d3SJohn Marino 		dm_list_del(&mda->list);
240*86d7f5d3SJohn Marino 		dm_free(mda);
241*86d7f5d3SJohn Marino 	}
242*86d7f5d3SJohn Marino }
243*86d7f5d3SJohn Marino 
_text_initialise_label(struct labeller * l __attribute ((unused)),struct label * label)244*86d7f5d3SJohn Marino static int _text_initialise_label(struct labeller *l __attribute((unused)),
245*86d7f5d3SJohn Marino 				  struct label *label)
246*86d7f5d3SJohn Marino {
247*86d7f5d3SJohn Marino 	strncpy(label->type, LVM2_LABEL, sizeof(label->type));
248*86d7f5d3SJohn Marino 
249*86d7f5d3SJohn Marino 	return 1;
250*86d7f5d3SJohn Marino }
251*86d7f5d3SJohn Marino 
_text_read(struct labeller * l,struct device * dev,void * buf,struct label ** label)252*86d7f5d3SJohn Marino static int _text_read(struct labeller *l, struct device *dev, void *buf,
253*86d7f5d3SJohn Marino 		 struct label **label)
254*86d7f5d3SJohn Marino {
255*86d7f5d3SJohn Marino 	struct label_header *lh = (struct label_header *) buf;
256*86d7f5d3SJohn Marino 	struct pv_header *pvhdr;
257*86d7f5d3SJohn Marino 	struct lvmcache_info *info;
258*86d7f5d3SJohn Marino 	struct disk_locn *dlocn_xl;
259*86d7f5d3SJohn Marino 	uint64_t offset;
260*86d7f5d3SJohn Marino 	struct metadata_area *mda;
261*86d7f5d3SJohn Marino 	struct id vgid;
262*86d7f5d3SJohn Marino 	struct mda_context *mdac;
263*86d7f5d3SJohn Marino 	const char *vgname;
264*86d7f5d3SJohn Marino 	uint32_t vgstatus;
265*86d7f5d3SJohn Marino 	char *creation_host;
266*86d7f5d3SJohn Marino 
267*86d7f5d3SJohn Marino 	pvhdr = (struct pv_header *) ((void *) buf + xlate32(lh->offset_xl));
268*86d7f5d3SJohn Marino 
269*86d7f5d3SJohn Marino 	if (!(info = lvmcache_add(l, (char *)pvhdr->pv_uuid, dev,
270*86d7f5d3SJohn Marino 				  FMT_TEXT_ORPHAN_VG_NAME,
271*86d7f5d3SJohn Marino 				  FMT_TEXT_ORPHAN_VG_NAME, 0)))
272*86d7f5d3SJohn Marino 		return_0;
273*86d7f5d3SJohn Marino 	*label = info->label;
274*86d7f5d3SJohn Marino 
275*86d7f5d3SJohn Marino 	info->device_size = xlate64(pvhdr->device_size_xl);
276*86d7f5d3SJohn Marino 
277*86d7f5d3SJohn Marino 	if (info->das.n)
278*86d7f5d3SJohn Marino 		del_das(&info->das);
279*86d7f5d3SJohn Marino 	dm_list_init(&info->das);
280*86d7f5d3SJohn Marino 
281*86d7f5d3SJohn Marino 	if (info->mdas.n)
282*86d7f5d3SJohn Marino 		del_mdas(&info->mdas);
283*86d7f5d3SJohn Marino 	dm_list_init(&info->mdas);
284*86d7f5d3SJohn Marino 
285*86d7f5d3SJohn Marino 	/* Data areas holding the PEs */
286*86d7f5d3SJohn Marino 	dlocn_xl = pvhdr->disk_areas_xl;
287*86d7f5d3SJohn Marino 	while ((offset = xlate64(dlocn_xl->offset))) {
288*86d7f5d3SJohn Marino 		add_da(NULL, &info->das, offset,
289*86d7f5d3SJohn Marino 		       xlate64(dlocn_xl->size));
290*86d7f5d3SJohn Marino 		dlocn_xl++;
291*86d7f5d3SJohn Marino 	}
292*86d7f5d3SJohn Marino 
293*86d7f5d3SJohn Marino 	/* Metadata area headers */
294*86d7f5d3SJohn Marino 	dlocn_xl++;
295*86d7f5d3SJohn Marino 	while ((offset = xlate64(dlocn_xl->offset))) {
296*86d7f5d3SJohn Marino 		add_mda(info->fmt, NULL, &info->mdas, dev, offset,
297*86d7f5d3SJohn Marino 			xlate64(dlocn_xl->size));
298*86d7f5d3SJohn Marino 		dlocn_xl++;
299*86d7f5d3SJohn Marino 	}
300*86d7f5d3SJohn Marino 
301*86d7f5d3SJohn Marino 	dm_list_iterate_items(mda, &info->mdas) {
302*86d7f5d3SJohn Marino 		mdac = (struct mda_context *) mda->metadata_locn;
303*86d7f5d3SJohn Marino 		if ((vgname = vgname_from_mda(info->fmt, &mdac->area,
304*86d7f5d3SJohn Marino 					      &vgid, &vgstatus, &creation_host,
305*86d7f5d3SJohn Marino 					      &mdac->free_sectors)) &&
306*86d7f5d3SJohn Marino 		    !lvmcache_update_vgname_and_id(info, vgname,
307*86d7f5d3SJohn Marino 						   (char *) &vgid, vgstatus,
308*86d7f5d3SJohn Marino 						   creation_host))
309*86d7f5d3SJohn Marino 			return_0;
310*86d7f5d3SJohn Marino 	}
311*86d7f5d3SJohn Marino 
312*86d7f5d3SJohn Marino 	info->status &= ~CACHE_INVALID;
313*86d7f5d3SJohn Marino 
314*86d7f5d3SJohn Marino 	return 1;
315*86d7f5d3SJohn Marino }
316*86d7f5d3SJohn Marino 
_text_destroy_label(struct labeller * l __attribute ((unused)),struct label * label)317*86d7f5d3SJohn Marino static void _text_destroy_label(struct labeller *l __attribute((unused)),
318*86d7f5d3SJohn Marino 				struct label *label)
319*86d7f5d3SJohn Marino {
320*86d7f5d3SJohn Marino 	struct lvmcache_info *info = (struct lvmcache_info *) label->info;
321*86d7f5d3SJohn Marino 
322*86d7f5d3SJohn Marino 	if (info->mdas.n)
323*86d7f5d3SJohn Marino 		del_mdas(&info->mdas);
324*86d7f5d3SJohn Marino 	if (info->das.n)
325*86d7f5d3SJohn Marino 		del_das(&info->das);
326*86d7f5d3SJohn Marino }
327*86d7f5d3SJohn Marino 
_fmt_text_destroy(struct labeller * l)328*86d7f5d3SJohn Marino static void _fmt_text_destroy(struct labeller *l)
329*86d7f5d3SJohn Marino {
330*86d7f5d3SJohn Marino 	dm_free(l);
331*86d7f5d3SJohn Marino }
332*86d7f5d3SJohn Marino 
333*86d7f5d3SJohn Marino struct label_ops _text_ops = {
334*86d7f5d3SJohn Marino 	.can_handle = _text_can_handle,
335*86d7f5d3SJohn Marino 	.write = _text_write,
336*86d7f5d3SJohn Marino 	.read = _text_read,
337*86d7f5d3SJohn Marino 	.verify = _text_can_handle,
338*86d7f5d3SJohn Marino 	.initialise_label = _text_initialise_label,
339*86d7f5d3SJohn Marino 	.destroy_label = _text_destroy_label,
340*86d7f5d3SJohn Marino 	.destroy = _fmt_text_destroy,
341*86d7f5d3SJohn Marino };
342*86d7f5d3SJohn Marino 
text_labeller_create(const struct format_type * fmt)343*86d7f5d3SJohn Marino struct labeller *text_labeller_create(const struct format_type *fmt)
344*86d7f5d3SJohn Marino {
345*86d7f5d3SJohn Marino 	struct labeller *l;
346*86d7f5d3SJohn Marino 
347*86d7f5d3SJohn Marino 	if (!(l = dm_malloc(sizeof(*l)))) {
348*86d7f5d3SJohn Marino 		log_error("Couldn't allocate labeller object.");
349*86d7f5d3SJohn Marino 		return NULL;
350*86d7f5d3SJohn Marino 	}
351*86d7f5d3SJohn Marino 
352*86d7f5d3SJohn Marino 	l->ops = &_text_ops;
353*86d7f5d3SJohn Marino 	l->private = (const void *) fmt;
354*86d7f5d3SJohn Marino 
355*86d7f5d3SJohn Marino 	return l;
356*86d7f5d3SJohn Marino }
357