diff options
author | Erik van Konijnenburg <ekonijn@xs4all.nl> | 2008-06-11 21:36:57 +0200 |
---|---|---|
committer | Kay Sievers <kay.sievers@vrfy.org> | 2008-06-11 23:54:56 +0200 |
commit | 0c6ecdfd9f7b7247d8f0258b6cb92aac9eccfb9b (patch) | |
tree | 1afd53b833310b000d0bb6ae09e1ef8b32af27a0 /extras/volume_id/lib/oracleasm.c | |
parent | 1ecb0864600073a5d63c2298239cd04e7bf8d527 (diff) |
volume_id: support for oracleasm
Diffstat (limited to 'extras/volume_id/lib/oracleasm.c')
-rw-r--r-- | extras/volume_id/lib/oracleasm.c | 65 |
1 files changed, 65 insertions, 0 deletions
diff --git a/extras/volume_id/lib/oracleasm.c b/extras/volume_id/lib/oracleasm.c new file mode 100644 index 0000000000..0f5ff80cfb --- /dev/null +++ b/extras/volume_id/lib/oracleasm.c @@ -0,0 +1,65 @@ +/* + * volume_id - reads filesystem label and uuid + * + * Copyright (C) 2004 Kay Sievers <kay.sievers@vrfy.org> + * + * This program is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License as published by the + * Free Software Foundation version 2 of the License. + */ + +#ifndef _GNU_SOURCE +#define _GNU_SOURCE 1 +#endif + +#ifdef HAVE_CONFIG_H +# include <config.h> +#endif + +#include <stdio.h> +#include <stdlib.h> +#include <unistd.h> +#include <string.h> +#include <errno.h> +#include <ctype.h> + +#include "libvolume_id.h" +#include "util.h" + +struct oracleasm_super_block { + uint8_t tag[8]; + uint8_t id[24]; +} PACKED; + +#define ASM_SB_OFF 0x20 +#define ASM_MAGIC "ORCLDISK" + +/* + * Detect Oracle Automatic Storage Management (ASM). + * It can do mirroring, but don't consider it RAID in the sense + * that an ext3 filesystem could live inside. Thus, mark it 'other'. + * There also is a magic word 'ORCLCLRD'; like blkid(8), we ignore that. + */ +int volume_id_probe_oracleasm(struct volume_id *id, uint64_t off, uint64_t size) +{ + const uint8_t *buf; + struct oracleasm_super_block *oracleasm; + + info("probing at offset 0x%llx\n", (unsigned long long) off); + + buf = volume_id_get_buffer(id, off + ASM_SB_OFF, 0x800); + if (buf == NULL) + return -1; + + oracleasm = (struct oracleasm_super_block *) buf; + + if (memcmp(oracleasm->tag, ASM_MAGIC, 8) != 0) + return -1; + + volume_id_set_usage(id, VOLUME_ID_OTHER); + volume_id_set_label_raw(id, oracleasm->id, 24); + volume_id_set_label_string(id, oracleasm->id, 24); + id->type = "oracleasm"; + + return 0; +} |