Lines Matching refs:md

226     struct g_mirror_metadata *md);
227 int g_mirror_read_metadata(struct g_consumer *cp, struct g_mirror_metadata *md);
229 struct g_mirror_disk *disk, struct g_mirror_metadata *md);
258 mirror_metadata_encode(struct g_mirror_metadata *md, u_char *data)
262 bcopy(md->md_magic, data, 16);
263 le32enc(data + 16, md->md_version);
264 bcopy(md->md_name, data + 20, 16);
265 le32enc(data + 36, md->md_mid);
266 le32enc(data + 40, md->md_did);
267 *(data + 44) = md->md_all;
268 le32enc(data + 45, md->md_genid);
269 le32enc(data + 49, md->md_syncid);
270 *(data + 53) = md->md_priority;
271 le32enc(data + 54, md->md_slice);
272 *(data + 58) = md->md_balance;
273 le64enc(data + 59, md->md_mediasize);
274 le32enc(data + 67, md->md_sectorsize);
275 le64enc(data + 71, md->md_sync_offset);
276 le64enc(data + 79, md->md_mflags);
277 le64enc(data + 87, md->md_dflags);
278 bcopy(md->md_provider, data + 95, 16);
279 le64enc(data + 111, md->md_provsize);
282 MD5Final(md->md_hash, &ctx);
283 bcopy(md->md_hash, data + 119, 16);
286 mirror_metadata_decode_v0v1(const u_char *data, struct g_mirror_metadata *md)
290 bcopy(data + 20, md->md_name, 16);
291 md->md_mid = le32dec(data + 36);
292 md->md_did = le32dec(data + 40);
293 md->md_all = *(data + 44);
294 md->md_syncid = le32dec(data + 45);
295 md->md_priority = *(data + 49);
296 md->md_slice = le32dec(data + 50);
297 md->md_balance = *(data + 54);
298 md->md_mediasize = le64dec(data + 55);
299 md->md_sectorsize = le32dec(data + 63);
300 md->md_sync_offset = le64dec(data + 67);
301 md->md_mflags = le64dec(data + 75);
302 md->md_dflags = le64dec(data + 83);
303 bcopy(data + 91, md->md_provider, 16);
304 bcopy(data + 107, md->md_hash, 16);
307 MD5Final(md->md_hash, &ctx);
308 if (bcmp(md->md_hash, data + 107, 16) != 0)
312 md->md_genid = 0;
313 md->md_provsize = 0;
318 mirror_metadata_decode_v2(const u_char *data, struct g_mirror_metadata *md)
322 bcopy(data + 20, md->md_name, 16);
323 md->md_mid = le32dec(data + 36);
324 md->md_did = le32dec(data + 40);
325 md->md_all = *(data + 44);
326 md->md_genid = le32dec(data + 45);
327 md->md_syncid = le32dec(data + 49);
328 md->md_priority = *(data + 53);
329 md->md_slice = le32dec(data + 54);
330 md->md_balance = *(data + 58);
331 md->md_mediasize = le64dec(data + 59);
332 md->md_sectorsize = le32dec(data + 67);
333 md->md_sync_offset = le64dec(data + 71);
334 md->md_mflags = le64dec(data + 79);
335 md->md_dflags = le64dec(data + 87);
336 bcopy(data + 95, md->md_provider, 16);
337 bcopy(data + 111, md->md_hash, 16);
340 MD5Final(md->md_hash, &ctx);
341 if (bcmp(md->md_hash, data + 111, 16) != 0)
345 md->md_provsize = 0;
350 mirror_metadata_decode_v3v4(const u_char *data, struct g_mirror_metadata *md)
354 bcopy(data + 20, md->md_name, 16);
355 md->md_mid = le32dec(data + 36);
356 md->md_did = le32dec(data + 40);
357 md->md_all = *(data + 44);
358 md->md_genid = le32dec(data + 45);
359 md->md_syncid = le32dec(data + 49);
360 md->md_priority = *(data + 53);
361 md->md_slice = le32dec(data + 54);
362 md->md_balance = *(data + 58);
363 md->md_mediasize = le64dec(data + 59);
364 md->md_sectorsize = le32dec(data + 67);
365 md->md_sync_offset = le64dec(data + 71);
366 md->md_mflags = le64dec(data + 79);
367 md->md_dflags = le64dec(data + 87);
368 bcopy(data + 95, md->md_provider, 16);
369 md->md_provsize = le64dec(data + 111);
370 bcopy(data + 119, md->md_hash, 16);
373 MD5Final(md->md_hash, &ctx);
374 if (bcmp(md->md_hash, data + 119, 16) != 0)
379 mirror_metadata_decode(const u_char *data, struct g_mirror_metadata *md)
383 bcopy(data, md->md_magic, 16);
384 md->md_version = le32dec(data + 16);
385 switch (md->md_version) {
388 error = mirror_metadata_decode_v0v1(data, md);
391 error = mirror_metadata_decode_v2(data, md);
395 error = mirror_metadata_decode_v3v4(data, md);
442 mirror_metadata_dump(const struct g_mirror_metadata *md)
448 printf(" magic: %s\n", md->md_magic);
449 printf(" version: %u\n", (u_int)md->md_version);
450 printf(" name: %s\n", md->md_name);
451 printf(" mid: %u\n", (u_int)md->md_mid);
452 printf(" did: %u\n", (u_int)md->md_did);
453 printf(" all: %u\n", (u_int)md->md_all);
454 printf(" genid: %u\n", (u_int)md->md_genid);
455 printf(" syncid: %u\n", (u_int)md->md_syncid);
456 printf(" priority: %u\n", (u_int)md->md_priority);
457 printf(" slice: %u\n", (u_int)md->md_slice);
458 printf(" balance: %s\n", balance_name((u_int)md->md_balance));
459 printf(" mediasize: %jd\n", (intmax_t)md->md_mediasize);
460 printf("sectorsize: %u\n", (u_int)md->md_sectorsize);
461 printf("syncoffset: %jd\n", (intmax_t)md->md_sync_offset);
463 if (md->md_mflags == 0)
466 if ((md->md_mflags & G_MIRROR_DEVICE_FLAG_NOFAILSYNC) != 0)
468 if ((md->md_mflags & G_MIRROR_DEVICE_FLAG_NOAUTOSYNC) != 0)
473 if (md->md_dflags == 0)
476 if ((md->md_dflags & G_MIRROR_DISK_FLAG_DIRTY) != 0)
478 if ((md->md_dflags & G_MIRROR_DISK_FLAG_SYNCHRONIZING) != 0)
480 if ((md->md_dflags & G_MIRROR_DISK_FLAG_FORCE_SYNC) != 0)
482 if ((md->md_dflags & G_MIRROR_DISK_FLAG_INACTIVE) != 0)
486 printf("hcprovider: %s\n", md->md_provider);
487 printf(" provsize: %ju\n", (uintmax_t)md->md_provsize);
490 hash[i * 2] = hex[md->md_hash[i] >> 4];
491 hash[i * 2 + 1] = hex[md->md_hash[i] & 0x0f];