1167050Smjacob/*-
2167050Smjacob * Copyright (c) 2006-2007 Matthew Jacob <mjacob@FreeBSD.org>
3167050Smjacob * All rights reserved.
4167050Smjacob *
5167050Smjacob * Redistribution and use in source and binary forms, with or without
6167050Smjacob * modification, are permitted provided that the following conditions
7167050Smjacob * are met:
8167050Smjacob * 1. Redistributions of source code must retain the above copyright
9167050Smjacob *    notice, this list of conditions and the following disclaimer.
10167050Smjacob * 2. Redistributions in binary form must reproduce the above copyright
11167050Smjacob *    notice, this list of conditions and the following disclaimer in the
12167050Smjacob *    documentation and/or other materials provided with the distribution.
13167050Smjacob *
14167050Smjacob * THIS SOFTWARE IS PROVIDED BY THE AUTHORS AND CONTRIBUTORS ``AS IS'' AND
15167050Smjacob * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16167050Smjacob * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17167050Smjacob * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE
18167050Smjacob * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19167050Smjacob * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20167050Smjacob * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21167050Smjacob * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22167050Smjacob * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23167050Smjacob * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
24167050Smjacob * SUCH DAMAGE.
25167050Smjacob *
26167050Smjacob * $FreeBSD$
27167050Smjacob */
28167050Smjacob/*
29167050Smjacob * Based upon work by Pawel Jakub Dawidek <pjd@FreeBSD.org> for all of the
30167050Smjacob * fine geom examples, and by Poul Henning Kamp <phk@FreeBSD.org> for GEOM
31167050Smjacob * itself, all of which is most gratefully acknowledged.
32167050Smjacob */
33167050Smjacob
34167050Smjacob#ifndef	_G_MULTIPATH_H_
35167050Smjacob#define	_G_MULTIPATH_H_
36167050Smjacob
37167050Smjacob#define	G_MULTIPATH_CLASS_NAME	"MULTIPATH"
38167050Smjacob#define	G_MULTIPATH_VERSION	1
39167050Smjacob#define	G_MULTIPATH_MAGIC	"GEOM::MULTIPATH"
40167050Smjacob
41167050Smjacob#include <sys/endian.h>
42167050Smjacob
43167050Smjacob#ifdef	_KERNEL
44167050Smjacob
45167050Smjacobstruct g_multipath_softc {
46227464Smav	struct g_provider *	sc_pp;
47227464Smav	struct g_consumer *	sc_active;
48227464Smav	struct mtx		sc_mtx;
49167050Smjacob	char			sc_name[16];
50167050Smjacob	char			sc_uuid[40];
51227464Smav	int			sc_opened;
52227464Smav	int			sc_stopping;
53227464Smav	int			sc_ndisks;
54227464Smav	int			sc_active_active; /* Active/Active mode */
55167050Smjacob};
56167050Smjacob#endif	/* _KERNEL */
57167050Smjacob
58167050Smjacobstruct g_multipath_metadata {
59167050Smjacob	char		md_magic[16];	/* Magic Value */
60167050Smjacob	char 		md_uuid[40];	/* more magic */
61167050Smjacob	char		md_name[16];	/* a friendly name */
62167050Smjacob	uint32_t	md_version;	/* version */
63167050Smjacob	uint32_t	md_sectorsize;	/* sectorsize of provider */
64167050Smjacob	uint64_t	md_size;	/* absolute size of provider */
65227464Smav	uint8_t		md_active_active; /* Active/Active mode */
66167050Smjacob};
67167050Smjacob
68167050Smjacobstatic __inline void
69167050Smjacobmultipath_metadata_encode(const struct g_multipath_metadata *, u_char *);
70167050Smjacob
71167050Smjacobstatic __inline void
72167050Smjacobmultipath_metadata_decode(u_char *, struct g_multipath_metadata *);
73167050Smjacob
74167050Smjacobstatic __inline void
75167050Smjacobmultipath_metadata_encode(const struct g_multipath_metadata *md, u_char *data)
76167050Smjacob{
77167050Smjacob	bcopy(md->md_magic, data, sizeof(md->md_magic));
78167050Smjacob	data += sizeof(md->md_magic);
79167050Smjacob	bcopy(md->md_uuid, data, sizeof(md->md_uuid));
80167050Smjacob	data += sizeof(md->md_uuid);
81167050Smjacob	bcopy(md->md_name, data, sizeof(md->md_name));
82167050Smjacob	data += sizeof(md->md_name);
83167050Smjacob	le32enc(data, md->md_version);
84167050Smjacob	data += sizeof(md->md_version);
85167050Smjacob	le32enc(data, md->md_sectorsize);
86167050Smjacob	data += sizeof(md->md_sectorsize);
87167050Smjacob	le64enc(data, md->md_size);
88227464Smav	data += sizeof(md->md_size);
89227464Smav	*data = md->md_active_active;
90167050Smjacob}
91167050Smjacob
92167050Smjacobstatic __inline void
93167050Smjacobmultipath_metadata_decode(u_char *data, struct g_multipath_metadata *md)
94167050Smjacob{
95167050Smjacob	bcopy(data, md->md_magic, sizeof(md->md_magic));
96167050Smjacob	data += sizeof(md->md_magic);
97167050Smjacob	bcopy(data, md->md_uuid, sizeof(md->md_uuid));
98167050Smjacob	data += sizeof(md->md_uuid);
99167050Smjacob	bcopy(data, md->md_name, sizeof(md->md_name));
100167050Smjacob	data += sizeof(md->md_name);
101167050Smjacob	md->md_version = le32dec(data);
102167050Smjacob	data += sizeof(md->md_version);
103167050Smjacob	md->md_sectorsize = le32dec(data);
104167050Smjacob	data += sizeof(md->md_sectorsize);
105167050Smjacob	md->md_size = le64dec(data);
106227464Smav	data += sizeof(md->md_size);
107227464Smav	md->md_active_active = *data;
108167050Smjacob}
109167050Smjacob#endif	/* _G_MULTIPATH_H_ */
110