xref: /illumos-gate/usr/src/lib/libzfs_jni/common/libzfs_jni_pool.c (revision b87f3af36bb994656da117319f5129ddfd05ed21)
1fa9e4066Sahrens /*
2fa9e4066Sahrens  * CDDL HEADER START
3fa9e4066Sahrens  *
4fa9e4066Sahrens  * The contents of this file are subject to the terms of the
5bfe5f5a4Stalley  * Common Development and Distribution License (the "License").
6bfe5f5a4Stalley  * You may not use this file except in compliance with the License.
7fa9e4066Sahrens  *
8fa9e4066Sahrens  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9fa9e4066Sahrens  * or http://www.opensolaris.org/os/licensing.
10fa9e4066Sahrens  * See the License for the specific language governing permissions
11fa9e4066Sahrens  * and limitations under the License.
12fa9e4066Sahrens  *
13fa9e4066Sahrens  * When distributing Covered Code, include this CDDL HEADER in each
14fa9e4066Sahrens  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15fa9e4066Sahrens  * If applicable, add the following below this CDDL HEADER, with the
16fa9e4066Sahrens  * fields enclosed by brackets "[]" replaced with your own identifying
17fa9e4066Sahrens  * information: Portions Copyright [yyyy] [name of copyright owner]
18fa9e4066Sahrens  *
19fa9e4066Sahrens  * CDDL HEADER END
20fa9e4066Sahrens  */
21bfe5f5a4Stalley 
22fa9e4066Sahrens /*
233a57275aSck  * Copyright 2008 Sun Microsystems, Inc.  All rights reserved.
24fa9e4066Sahrens  * Use is subject to license terms.
25fa9e4066Sahrens  */
26fa9e4066Sahrens 
27fa9e4066Sahrens #pragma ident	"%Z%%M%	%I%	%E% SMI"
28fa9e4066Sahrens 
2999653d4eSeschrock #include "libzfs_jni_util.h"
30fa9e4066Sahrens #include "libzfs_jni_pool.h"
31fa9e4066Sahrens #include <strings.h>
32fa9e4066Sahrens 
33fa9e4066Sahrens /*
34fa9e4066Sahrens  * Types
35fa9e4066Sahrens  */
36fa9e4066Sahrens 
37c8e9ed14Stalley typedef struct ImportablePoolBean {
38c8e9ed14Stalley 	zjni_Object_t super;
39fbfd10ffStalley 	PoolStatsBean_t interface_PoolStats;
40c8e9ed14Stalley 
41c8e9ed14Stalley 	jmethodID method_setName;
42c8e9ed14Stalley 	jmethodID method_setId;
43c8e9ed14Stalley } ImportablePoolBean_t;
44c8e9ed14Stalley 
45fa9e4066Sahrens typedef struct VirtualDeviceBean {
46fa9e4066Sahrens 	zjni_Object_t super;
47fbfd10ffStalley 	DeviceStatsBean_t interface_DeviceStats;
48fa9e4066Sahrens 
49fa9e4066Sahrens 	jmethodID method_setPoolName;
50bfe5f5a4Stalley 	jmethodID method_setParentIndex;
51fa9e4066Sahrens 	jmethodID method_setIndex;
52fa9e4066Sahrens } VirtualDeviceBean_t;
53fa9e4066Sahrens 
54a1a659aeStalley typedef struct LeafVirtualDeviceBean {
55fa9e4066Sahrens 	VirtualDeviceBean_t super;
56fa9e4066Sahrens 
57a1a659aeStalley 	jmethodID method_setName;
58a1a659aeStalley } LeafVirtualDeviceBean_t;
59a1a659aeStalley 
60a1a659aeStalley typedef struct DiskVirtualDeviceBean {
61a1a659aeStalley 	LeafVirtualDeviceBean_t super;
62fa9e4066Sahrens } DiskVirtualDeviceBean_t;
63fa9e4066Sahrens 
64a1a659aeStalley typedef struct SliceVirtualDeviceBean {
65a1a659aeStalley 	LeafVirtualDeviceBean_t super;
66a1a659aeStalley } SliceVirtualDeviceBean_t;
67fa9e4066Sahrens 
68a1a659aeStalley typedef struct FileVirtualDeviceBean {
69a1a659aeStalley 	LeafVirtualDeviceBean_t super;
70fa9e4066Sahrens } FileVirtualDeviceBean_t;
71fa9e4066Sahrens 
72fa9e4066Sahrens typedef struct RAIDVirtualDeviceBean {
73fa9e4066Sahrens 	VirtualDeviceBean_t super;
741e995cfcSrl 
751e995cfcSrl 	jmethodID method_setParity;
76fa9e4066Sahrens } RAIDVirtualDeviceBean_t;
77fa9e4066Sahrens 
78fa9e4066Sahrens typedef struct MirrorVirtualDeviceBean {
79fa9e4066Sahrens 	VirtualDeviceBean_t super;
80fa9e4066Sahrens } MirrorVirtualDeviceBean_t;
81fa9e4066Sahrens 
82fbfd10ffStalley /*
83fbfd10ffStalley  * Data
84fbfd10ffStalley  */
85fbfd10ffStalley 
86fbfd10ffStalley /* vdev_state_t to DeviceStats$DeviceState map */
87fbfd10ffStalley static zjni_field_mapping_t vdev_state_map[] = {
88fbfd10ffStalley 	{ VDEV_STATE_CANT_OPEN, "VDEV_STATE_CANT_OPEN" },
89fbfd10ffStalley 	{ VDEV_STATE_CLOSED, "VDEV_STATE_CLOSED" },
90fbfd10ffStalley 	{ VDEV_STATE_DEGRADED, "VDEV_STATE_DEGRADED" },
91fbfd10ffStalley 	{ VDEV_STATE_HEALTHY, "VDEV_STATE_HEALTHY" },
92fbfd10ffStalley 	{ VDEV_STATE_OFFLINE, "VDEV_STATE_OFFLINE" },
93fbfd10ffStalley 	{ VDEV_STATE_UNKNOWN, "VDEV_STATE_UNKNOWN" },
94fbfd10ffStalley 	{ -1, NULL },
95fbfd10ffStalley };
96fbfd10ffStalley 
97fbfd10ffStalley /* vdev_aux_t to DeviceStats$DeviceStatus map */
98fbfd10ffStalley static zjni_field_mapping_t vdev_aux_map[] = {
99fbfd10ffStalley 	{ VDEV_AUX_NONE, "VDEV_AUX_NONE" },
100fbfd10ffStalley 	{ VDEV_AUX_OPEN_FAILED, "VDEV_AUX_OPEN_FAILED" },
101fbfd10ffStalley 	{ VDEV_AUX_CORRUPT_DATA, "VDEV_AUX_CORRUPT_DATA" },
102fbfd10ffStalley 	{ VDEV_AUX_NO_REPLICAS, "VDEV_AUX_NO_REPLICAS" },
103fbfd10ffStalley 	{ VDEV_AUX_BAD_GUID_SUM, "VDEV_AUX_BAD_GUID_SUM" },
104fbfd10ffStalley 	{ VDEV_AUX_TOO_SMALL, "VDEV_AUX_TOO_SMALL" },
105fbfd10ffStalley 	{ VDEV_AUX_BAD_LABEL, "VDEV_AUX_BAD_LABEL" },
106fbfd10ffStalley 	{ -1, NULL },
107fbfd10ffStalley };
108fbfd10ffStalley 
109fbfd10ffStalley /* zpool_state_t to PoolStats$PoolState map */
110fbfd10ffStalley static zjni_field_mapping_t pool_state_map[] = {
111fbfd10ffStalley 	{ POOL_STATE_ACTIVE, "POOL_STATE_ACTIVE" },
112fbfd10ffStalley 	{ POOL_STATE_EXPORTED, "POOL_STATE_EXPORTED" },
113fbfd10ffStalley 	{ POOL_STATE_DESTROYED, "POOL_STATE_DESTROYED" },
114a55b6846Scristian 	{ POOL_STATE_SPARE, "POOL_STATE_SPARE" },
115fbfd10ffStalley 	{ POOL_STATE_UNINITIALIZED, "POOL_STATE_UNINITIALIZED" },
116fbfd10ffStalley 	{ POOL_STATE_UNAVAIL, "POOL_STATE_UNAVAIL" },
117a55b6846Scristian 	{ POOL_STATE_POTENTIALLY_ACTIVE, "POOL_STATE_POTENTIALLY_ACTIVE" },
118fbfd10ffStalley 	{ -1, NULL },
119fbfd10ffStalley };
120fbfd10ffStalley 
121fbfd10ffStalley /* zpool_status_t to PoolStats$PoolStatus map */
122fbfd10ffStalley static zjni_field_mapping_t zpool_status_map[] = {
123a55b6846Scristian 	{ ZPOOL_STATUS_CORRUPT_CACHE, "ZPOOL_STATUS_CORRUPT_CACHE" },
124a55b6846Scristian 	{ ZPOOL_STATUS_MISSING_DEV_R, "ZPOOL_STATUS_MISSING_DEV_R" },
125a55b6846Scristian 	{ ZPOOL_STATUS_MISSING_DEV_NR, "ZPOOL_STATUS_MISSING_DEV_NR" },
126a55b6846Scristian 	{ ZPOOL_STATUS_CORRUPT_LABEL_R, "ZPOOL_STATUS_CORRUPT_LABEL_R" },
127a55b6846Scristian 	{ ZPOOL_STATUS_CORRUPT_LABEL_NR, "ZPOOL_STATUS_CORRUPT_LABEL_NR" },
128fbfd10ffStalley 	{ ZPOOL_STATUS_BAD_GUID_SUM, "ZPOOL_STATUS_BAD_GUID_SUM" },
129fbfd10ffStalley 	{ ZPOOL_STATUS_CORRUPT_POOL, "ZPOOL_STATUS_CORRUPT_POOL" },
130fbfd10ffStalley 	{ ZPOOL_STATUS_CORRUPT_DATA, "ZPOOL_STATUS_CORRUPT_DATA" },
131fbfd10ffStalley 	{ ZPOOL_STATUS_FAILING_DEV, "ZPOOL_STATUS_FAILING_DEV" },
132a55b6846Scristian 	{ ZPOOL_STATUS_VERSION_NEWER, "ZPOOL_STATUS_VERSION_NEWER" },
133a55b6846Scristian 	{ ZPOOL_STATUS_HOSTID_MISMATCH, "ZPOOL_STATUS_HOSTID_MISMATCH" },
134a55b6846Scristian 	{ ZPOOL_STATUS_FAULTED_DEV_R, "ZPOOL_STATUS_FAULTED_DEV_R" },
135a55b6846Scristian 	{ ZPOOL_STATUS_FAULTED_DEV_NR, "ZPOOL_STATUS_FAULTED_DEV_NR" },
136*b87f3af3Sperrin 	{ ZPOOL_STATUS_BAD_LOG, "ZPOOL_STATUS_BAD_LOG" },
137a55b6846Scristian 	{ ZPOOL_STATUS_VERSION_OLDER, "ZPOOL_STATUS_VERSION_OLDER" },
138fbfd10ffStalley 	{ ZPOOL_STATUS_RESILVERING, "ZPOOL_STATUS_RESILVERING" },
139fbfd10ffStalley 	{ ZPOOL_STATUS_OFFLINE_DEV, "ZPOOL_STATUS_OFFLINE_DEV" },
140fbfd10ffStalley 	{ ZPOOL_STATUS_OK, "ZPOOL_STATUS_OK" },
141a55b6846Scristian 	{ -1, NULL }
142fbfd10ffStalley };
143fbfd10ffStalley 
144fa9e4066Sahrens /*
145fa9e4066Sahrens  * Function prototypes
146fa9e4066Sahrens  */
147fa9e4066Sahrens 
148c8e9ed14Stalley static void new_ImportablePoolBean(JNIEnv *, ImportablePoolBean_t *);
149fa9e4066Sahrens static void new_VirtualDevice(JNIEnv *, VirtualDeviceBean_t *);
150a1a659aeStalley static void new_LeafVirtualDevice(JNIEnv *, LeafVirtualDeviceBean_t *);
151fa9e4066Sahrens static void new_DiskVirtualDeviceBean(JNIEnv *, DiskVirtualDeviceBean_t *);
152a1a659aeStalley static void new_SliceVirtualDeviceBean(JNIEnv *, SliceVirtualDeviceBean_t *);
153fa9e4066Sahrens static void new_FileVirtualDeviceBean(JNIEnv *, FileVirtualDeviceBean_t *);
154fa9e4066Sahrens static void new_RAIDVirtualDeviceBean(JNIEnv *, RAIDVirtualDeviceBean_t *);
155fa9e4066Sahrens static void new_MirrorVirtualDeviceBean(JNIEnv *, MirrorVirtualDeviceBean_t *);
156c8e9ed14Stalley static int populate_ImportablePoolBean(
157fbfd10ffStalley     JNIEnv *, ImportablePoolBean_t *, nvlist_t *);
158bfe5f5a4Stalley static int populate_VirtualDeviceBean(JNIEnv *, zpool_handle_t *,
159bfe5f5a4Stalley     nvlist_t *, uint64_t *p_vdev_id, VirtualDeviceBean_t *);
160bfe5f5a4Stalley static int populate_LeafVirtualDeviceBean(JNIEnv *, zpool_handle_t *,
161bfe5f5a4Stalley     nvlist_t *, uint64_t *p_vdev_id, LeafVirtualDeviceBean_t *);
162bfe5f5a4Stalley static int populate_DiskVirtualDeviceBean(JNIEnv *, zpool_handle_t *,
163bfe5f5a4Stalley     nvlist_t *, uint64_t *p_vdev_id, DiskVirtualDeviceBean_t *);
164bfe5f5a4Stalley static int populate_SliceVirtualDeviceBean(JNIEnv *, zpool_handle_t *,
165bfe5f5a4Stalley     nvlist_t *, uint64_t *p_vdev_id, SliceVirtualDeviceBean_t *);
166bfe5f5a4Stalley static int populate_FileVirtualDeviceBean(JNIEnv *, zpool_handle_t *,
167bfe5f5a4Stalley     nvlist_t *, uint64_t *p_vdev_id, FileVirtualDeviceBean_t *);
168bfe5f5a4Stalley static int populate_RAIDVirtualDeviceBean(JNIEnv *, zpool_handle_t *,
169bfe5f5a4Stalley     nvlist_t *, uint64_t *p_vdev_id, RAIDVirtualDeviceBean_t *);
170bfe5f5a4Stalley static int populate_MirrorVirtualDeviceBean(JNIEnv *, zpool_handle_t *,
171bfe5f5a4Stalley     nvlist_t *, uint64_t *p_vdev_id, MirrorVirtualDeviceBean_t *);
172fbfd10ffStalley static jobject create_ImportablePoolBean(JNIEnv *, nvlist_t *);
173fa9e4066Sahrens static jobject create_DiskVirtualDeviceBean(
174bfe5f5a4Stalley     JNIEnv *, zpool_handle_t *, nvlist_t *, uint64_t *p_vdev_id);
175a1a659aeStalley static jobject create_SliceVirtualDeviceBean(
176bfe5f5a4Stalley     JNIEnv *, zpool_handle_t *, nvlist_t *, uint64_t *p_vdev_id);
177fa9e4066Sahrens static jobject create_FileVirtualDeviceBean(
178bfe5f5a4Stalley     JNIEnv *, zpool_handle_t *, nvlist_t *, uint64_t *p_vdev_id);
179fa9e4066Sahrens static jobject create_RAIDVirtualDeviceBean(
180bfe5f5a4Stalley     JNIEnv *, zpool_handle_t *, nvlist_t *, uint64_t *p_vdev_id);
181fa9e4066Sahrens static jobject create_MirrorVirtualDeviceBean(
182bfe5f5a4Stalley     JNIEnv *, zpool_handle_t *, nvlist_t *, uint64_t *p_vdev_id);
183fbfd10ffStalley static char *find_field(const zjni_field_mapping_t *, int);
184fbfd10ffStalley static jobject zjni_vdev_state_to_obj(JNIEnv *, vdev_state_t);
185fbfd10ffStalley static jobject zjni_vdev_aux_to_obj(JNIEnv *, vdev_aux_t);
186fa9e4066Sahrens 
187fa9e4066Sahrens /*
188fa9e4066Sahrens  * Static functions
189fa9e4066Sahrens  */
190fa9e4066Sahrens 
191c8e9ed14Stalley /* Create a ImportablePoolBean */
192c8e9ed14Stalley static void
193c8e9ed14Stalley new_ImportablePoolBean(JNIEnv *env, ImportablePoolBean_t *bean)
194c8e9ed14Stalley {
195c8e9ed14Stalley 	zjni_Object_t *object = (zjni_Object_t *)bean;
196c8e9ed14Stalley 
197c8e9ed14Stalley 	if (object->object == NULL) {
198c8e9ed14Stalley 		object->class =
199c8e9ed14Stalley 		    (*env)->FindClass(env,
2001e995cfcSrl 		    ZFSJNI_PACKAGE_DATA "ImportablePoolBean");
201c8e9ed14Stalley 
202c8e9ed14Stalley 		object->constructor =
203c8e9ed14Stalley 		    (*env)->GetMethodID(env, object->class, "<init>", "()V");
204c8e9ed14Stalley 
205c8e9ed14Stalley 		object->object =
206c8e9ed14Stalley 		    (*env)->NewObject(env, object->class, object->constructor);
207c8e9ed14Stalley 	}
208c8e9ed14Stalley 
209fbfd10ffStalley 	new_PoolStats(env, &(bean->interface_PoolStats), object);
210fbfd10ffStalley 
211c8e9ed14Stalley 	bean->method_setName = (*env)->GetMethodID(
212c8e9ed14Stalley 	    env, object->class, "setName", "(Ljava/lang/String;)V");
213c8e9ed14Stalley 
214c8e9ed14Stalley 	bean->method_setId = (*env)->GetMethodID(
215c8e9ed14Stalley 	    env, object->class, "setId", "(J)V");
216c8e9ed14Stalley }
217c8e9ed14Stalley 
218fa9e4066Sahrens /* Create a VirtualDeviceBean */
219fa9e4066Sahrens static void
220fa9e4066Sahrens new_VirtualDevice(JNIEnv *env, VirtualDeviceBean_t *bean)
221fa9e4066Sahrens {
222fa9e4066Sahrens 	zjni_Object_t *object = (zjni_Object_t *)bean;
223fa9e4066Sahrens 
224fa9e4066Sahrens 	if (object->object == NULL) {
225fa9e4066Sahrens 		object->class =
226fa9e4066Sahrens 		    (*env)->FindClass(env,
2271e995cfcSrl 		    ZFSJNI_PACKAGE_DATA "VirtualDeviceBean");
228fa9e4066Sahrens 
229fa9e4066Sahrens 		object->constructor =
230fa9e4066Sahrens 		    (*env)->GetMethodID(env, object->class, "<init>", "()V");
231fa9e4066Sahrens 
232fa9e4066Sahrens 		object->object =
233fa9e4066Sahrens 		    (*env)->NewObject(env, object->class, object->constructor);
234fa9e4066Sahrens 	}
235fa9e4066Sahrens 
236fbfd10ffStalley 	new_DeviceStats(env, &(bean->interface_DeviceStats), object);
237fbfd10ffStalley 
238fa9e4066Sahrens 	bean->method_setPoolName = (*env)->GetMethodID(
239fa9e4066Sahrens 	    env, object->class, "setPoolName", "(Ljava/lang/String;)V");
240fa9e4066Sahrens 
241bfe5f5a4Stalley 	bean->method_setParentIndex = (*env)->GetMethodID(
242bfe5f5a4Stalley 	    env, object->class, "setParentIndex", "(Ljava/lang/Long;)V");
243bfe5f5a4Stalley 
244fa9e4066Sahrens 	bean->method_setIndex = (*env)->GetMethodID(
245fa9e4066Sahrens 	    env, object->class, "setIndex", "(J)V");
246fa9e4066Sahrens }
247fa9e4066Sahrens 
248a1a659aeStalley /* Create a LeafVirtualDeviceBean */
249a1a659aeStalley static void
250a1a659aeStalley new_LeafVirtualDevice(JNIEnv *env, LeafVirtualDeviceBean_t *bean)
251a1a659aeStalley {
252a1a659aeStalley 	zjni_Object_t *object = (zjni_Object_t *)bean;
253a1a659aeStalley 
254a1a659aeStalley 	if (object->object == NULL) {
255a1a659aeStalley 		object->class =
256a1a659aeStalley 		    (*env)->FindClass(env,
2571e995cfcSrl 		    ZFSJNI_PACKAGE_DATA "LeafVirtualDeviceBean");
258a1a659aeStalley 
259a1a659aeStalley 		object->constructor =
260a1a659aeStalley 		    (*env)->GetMethodID(env, object->class, "<init>", "()V");
261a1a659aeStalley 
262a1a659aeStalley 		object->object =
263a1a659aeStalley 		    (*env)->NewObject(env, object->class, object->constructor);
264a1a659aeStalley 	}
265a1a659aeStalley 
266a1a659aeStalley 	new_VirtualDevice(env, (VirtualDeviceBean_t *)bean);
267a1a659aeStalley 
268a1a659aeStalley 	bean->method_setName = (*env)->GetMethodID(
269a1a659aeStalley 	    env, object->class, "setName", "(Ljava/lang/String;)V");
270a1a659aeStalley }
271a1a659aeStalley 
272fa9e4066Sahrens /* Create a DiskVirtualDeviceBean */
273fa9e4066Sahrens static void
274fa9e4066Sahrens new_DiskVirtualDeviceBean(JNIEnv *env, DiskVirtualDeviceBean_t *bean)
275fa9e4066Sahrens {
276fa9e4066Sahrens 	zjni_Object_t *object = (zjni_Object_t *)bean;
277fa9e4066Sahrens 
278fa9e4066Sahrens 	if (object->object == NULL) {
279fa9e4066Sahrens 		object->class = (*env)->FindClass(
280fa9e4066Sahrens 		    env, ZFSJNI_PACKAGE_DATA "DiskVirtualDeviceBean");
281fa9e4066Sahrens 
282fa9e4066Sahrens 		object->constructor =
283fa9e4066Sahrens 		    (*env)->GetMethodID(env, object->class, "<init>", "()V");
284fa9e4066Sahrens 
285fa9e4066Sahrens 		object->object =
286fa9e4066Sahrens 		    (*env)->NewObject(env, object->class, object->constructor);
287fa9e4066Sahrens 	}
288fa9e4066Sahrens 
289a1a659aeStalley 	new_LeafVirtualDevice(env, (LeafVirtualDeviceBean_t *)bean);
290a1a659aeStalley }
291fa9e4066Sahrens 
292a1a659aeStalley /* Create a SliceVirtualDeviceBean */
293a1a659aeStalley static void
294a1a659aeStalley new_SliceVirtualDeviceBean(JNIEnv *env, SliceVirtualDeviceBean_t *bean)
295a1a659aeStalley {
296a1a659aeStalley 	zjni_Object_t *object = (zjni_Object_t *)bean;
297fa9e4066Sahrens 
298a1a659aeStalley 	if (object->object == NULL) {
299a1a659aeStalley 		object->class = (*env)->FindClass(
300a1a659aeStalley 		    env, ZFSJNI_PACKAGE_DATA "SliceVirtualDeviceBean");
301a1a659aeStalley 
302a1a659aeStalley 		object->constructor =
303a1a659aeStalley 		    (*env)->GetMethodID(env, object->class, "<init>", "()V");
304a1a659aeStalley 
305a1a659aeStalley 		object->object =
306a1a659aeStalley 		    (*env)->NewObject(env, object->class, object->constructor);
307a1a659aeStalley 	}
308a1a659aeStalley 
309a1a659aeStalley 	new_LeafVirtualDevice(env, (LeafVirtualDeviceBean_t *)bean);
310fa9e4066Sahrens }
311fa9e4066Sahrens 
312fa9e4066Sahrens /* Create a FileVirtualDeviceBean */
313fa9e4066Sahrens static void
314fa9e4066Sahrens new_FileVirtualDeviceBean(JNIEnv *env, FileVirtualDeviceBean_t *bean)
315fa9e4066Sahrens {
316fa9e4066Sahrens 	zjni_Object_t *object = (zjni_Object_t *)bean;
317fa9e4066Sahrens 
318fa9e4066Sahrens 	if (object->object == NULL) {
319fa9e4066Sahrens 		object->class = (*env)->FindClass(
320fa9e4066Sahrens 		    env, ZFSJNI_PACKAGE_DATA "FileVirtualDeviceBean");
321fa9e4066Sahrens 
322fa9e4066Sahrens 		object->constructor =
323fa9e4066Sahrens 		    (*env)->GetMethodID(env, object->class, "<init>", "()V");
324fa9e4066Sahrens 
325fa9e4066Sahrens 		object->object =
326fa9e4066Sahrens 		    (*env)->NewObject(env, object->class, object->constructor);
327fa9e4066Sahrens 	}
328fa9e4066Sahrens 
329a1a659aeStalley 	new_LeafVirtualDevice(env, (LeafVirtualDeviceBean_t *)bean);
330fa9e4066Sahrens }
331fa9e4066Sahrens 
332fa9e4066Sahrens /* Create a RAIDVirtualDeviceBean */
333fa9e4066Sahrens static void
334fa9e4066Sahrens new_RAIDVirtualDeviceBean(JNIEnv *env, RAIDVirtualDeviceBean_t *bean)
335fa9e4066Sahrens {
336fa9e4066Sahrens 	zjni_Object_t *object = (zjni_Object_t *)bean;
337fa9e4066Sahrens 
338fa9e4066Sahrens 	if (object->object == NULL) {
339fa9e4066Sahrens 
340fa9e4066Sahrens 		object->class = (*env)->FindClass(
341fa9e4066Sahrens 		    env, ZFSJNI_PACKAGE_DATA "RAIDVirtualDeviceBean");
342fa9e4066Sahrens 
343fa9e4066Sahrens 		object->constructor =
344fa9e4066Sahrens 		    (*env)->GetMethodID(env, object->class, "<init>", "()V");
345fa9e4066Sahrens 
346fa9e4066Sahrens 		object->object =
347fa9e4066Sahrens 		    (*env)->NewObject(env, object->class, object->constructor);
348fa9e4066Sahrens 	}
349fa9e4066Sahrens 
350fa9e4066Sahrens 	new_VirtualDevice(env, (VirtualDeviceBean_t *)bean);
3511e995cfcSrl 
3521e995cfcSrl 	bean->method_setParity = (*env)->GetMethodID(
3531e995cfcSrl 	    env, object->class, "setParity", "(J)V");
354fa9e4066Sahrens }
355fa9e4066Sahrens 
356fa9e4066Sahrens /* Create a MirrorVirtualDeviceBean */
357fa9e4066Sahrens static void
358fa9e4066Sahrens new_MirrorVirtualDeviceBean(JNIEnv *env, MirrorVirtualDeviceBean_t *bean)
359fa9e4066Sahrens {
360fa9e4066Sahrens 	zjni_Object_t *object = (zjni_Object_t *)bean;
361fa9e4066Sahrens 
362fa9e4066Sahrens 	if (object->object == NULL) {
363fa9e4066Sahrens 		object->class = (*env)->FindClass(
364fa9e4066Sahrens 		    env, ZFSJNI_PACKAGE_DATA "MirrorVirtualDeviceBean");
365fa9e4066Sahrens 
366fa9e4066Sahrens 		object->constructor =
367fa9e4066Sahrens 		    (*env)->GetMethodID(env, object->class, "<init>", "()V");
368fa9e4066Sahrens 
369fa9e4066Sahrens 		object->object =
370fa9e4066Sahrens 		    (*env)->NewObject(env, object->class, object->constructor);
371fa9e4066Sahrens 	}
372fa9e4066Sahrens 
373fa9e4066Sahrens 	new_VirtualDevice(env, (VirtualDeviceBean_t *)bean);
374fa9e4066Sahrens }
375fa9e4066Sahrens 
376c8e9ed14Stalley static int
377c8e9ed14Stalley populate_ImportablePoolBean(JNIEnv *env, ImportablePoolBean_t *bean,
378fbfd10ffStalley     nvlist_t *config)
379c8e9ed14Stalley {
380fbfd10ffStalley 	char *c;
381fbfd10ffStalley 	char *name;
382fbfd10ffStalley 	uint64_t guid;
383fbfd10ffStalley 	uint64_t state;
384a55b6846Scristian 	uint64_t version;
385fbfd10ffStalley 	nvlist_t *devices;
386fbfd10ffStalley 
387c8e9ed14Stalley 	zjni_Object_t *object = (zjni_Object_t *)bean;
388fbfd10ffStalley 	PoolStatsBean_t *pool_stats = &(bean->interface_PoolStats);
389fbfd10ffStalley 	DeviceStatsBean_t *dev_stats = (DeviceStatsBean_t *)pool_stats;
390fbfd10ffStalley 
391fbfd10ffStalley 	if (nvlist_lookup_string(config, ZPOOL_CONFIG_POOL_NAME, &name) ||
392fbfd10ffStalley 	    nvlist_lookup_uint64(config, ZPOOL_CONFIG_POOL_GUID, &guid) ||
393fbfd10ffStalley 	    nvlist_lookup_uint64(config, ZPOOL_CONFIG_POOL_STATE, &state) ||
394a55b6846Scristian 	    nvlist_lookup_uint64(config, ZPOOL_CONFIG_VERSION, &version) ||
395fbfd10ffStalley 	    nvlist_lookup_nvlist(config, ZPOOL_CONFIG_VDEV_TREE, &devices) ||
396fbfd10ffStalley 	    populate_DeviceStatsBean(env, devices, dev_stats, object)) {
397fbfd10ffStalley 		return (-1);
398fbfd10ffStalley 	}
399c8e9ed14Stalley 
400fbfd10ffStalley 	(*env)->CallVoidMethod(env, object->object,
401fbfd10ffStalley 	    bean->method_setName, (*env)->NewStringUTF(env, name));
402c8e9ed14Stalley 
403fbfd10ffStalley 	(*env)->CallVoidMethod(env, object->object,
404fbfd10ffStalley 	    bean->method_setId, (jlong)guid);
405c8e9ed14Stalley 
406fbfd10ffStalley 	(*env)->CallVoidMethod(env, object->object,
407fbfd10ffStalley 	    pool_stats->method_setPoolState,
408fbfd10ffStalley 	    zjni_pool_state_to_obj(env, (pool_state_t)state));
409c8e9ed14Stalley 
410fbfd10ffStalley 	(*env)->CallVoidMethod(env, object->object,
411fbfd10ffStalley 	    pool_stats->method_setPoolStatus,
412fbfd10ffStalley 	    zjni_pool_status_to_obj(env, zpool_import_status(config, &c)));
413c8e9ed14Stalley 
414a55b6846Scristian 	(*env)->CallVoidMethod(env, object->object,
415a55b6846Scristian 	    pool_stats->method_setPoolVersion, (jlong)version);
416a55b6846Scristian 
417c8e9ed14Stalley 	return (0);
418c8e9ed14Stalley }
419c8e9ed14Stalley 
420fa9e4066Sahrens static int
421fa9e4066Sahrens populate_VirtualDeviceBean(JNIEnv *env, zpool_handle_t *zhp,
422bfe5f5a4Stalley     nvlist_t *vdev, uint64_t *p_vdev_id, VirtualDeviceBean_t *bean)
423fa9e4066Sahrens {
424fa9e4066Sahrens 	int result;
425fa9e4066Sahrens 	uint64_t vdev_id;
426fbfd10ffStalley 	jstring poolUTF;
427fbfd10ffStalley 
428fa9e4066Sahrens 	zjni_Object_t *object = (zjni_Object_t *)bean;
429fbfd10ffStalley 	DeviceStatsBean_t *stats = &(bean->interface_DeviceStats);
430fbfd10ffStalley 
431fbfd10ffStalley 	result = populate_DeviceStatsBean(env, vdev, stats, object);
432fbfd10ffStalley 	if (result != 0) {
433fbfd10ffStalley 		return (1);
434fbfd10ffStalley 	}
435fa9e4066Sahrens 
436fa9e4066Sahrens 	/* Set pool name */
437fbfd10ffStalley 	poolUTF = (*env)->NewStringUTF(env, zpool_get_name(zhp));
438fa9e4066Sahrens 	(*env)->CallVoidMethod(
439fa9e4066Sahrens 	    env, object->object, bean->method_setPoolName, poolUTF);
440fa9e4066Sahrens 
441bfe5f5a4Stalley 	/* Set parent vdev index */
442bfe5f5a4Stalley 	(*env)->CallVoidMethod(
443bfe5f5a4Stalley 	    env, object->object, bean->method_setParentIndex,
444bfe5f5a4Stalley 	    p_vdev_id == NULL ? NULL :
445bfe5f5a4Stalley 	    zjni_long_to_Long(env, *p_vdev_id));
446bfe5f5a4Stalley 
447fa9e4066Sahrens 	/* Get index */
448fa9e4066Sahrens 	result = nvlist_lookup_uint64(vdev, ZPOOL_CONFIG_GUID, &vdev_id);
449fa9e4066Sahrens 	if (result != 0) {
450fa9e4066Sahrens 		zjni_throw_exception(env,
451fa9e4066Sahrens 		    "could not retrieve virtual device ID (pool %s)",
452fa9e4066Sahrens 		    zpool_get_name(zhp));
453fbfd10ffStalley 		return (1);
454fa9e4066Sahrens 	}
455fa9e4066Sahrens 
456fbfd10ffStalley 	(*env)->CallVoidMethod(
457fbfd10ffStalley 	    env, object->object, bean->method_setIndex, (jlong)vdev_id);
458fbfd10ffStalley 
459fbfd10ffStalley 	return (0);
460fa9e4066Sahrens }
461fa9e4066Sahrens 
462a1a659aeStalley static int
463a1a659aeStalley populate_LeafVirtualDeviceBean(JNIEnv *env, zpool_handle_t *zhp,
464bfe5f5a4Stalley     nvlist_t *vdev, uint64_t *p_vdev_id, LeafVirtualDeviceBean_t *bean)
465a1a659aeStalley {
466a1a659aeStalley 	return (populate_VirtualDeviceBean(
467bfe5f5a4Stalley 	    env, zhp, vdev, p_vdev_id, (VirtualDeviceBean_t *)bean));
468a1a659aeStalley }
469a1a659aeStalley 
470fa9e4066Sahrens static int
471fa9e4066Sahrens populate_DiskVirtualDeviceBean(JNIEnv *env, zpool_handle_t *zhp,
472bfe5f5a4Stalley     nvlist_t *vdev, uint64_t *p_vdev_id, DiskVirtualDeviceBean_t *bean)
473fa9e4066Sahrens {
474fa9e4066Sahrens 	char *path;
475a1a659aeStalley 	int result = populate_LeafVirtualDeviceBean(
476bfe5f5a4Stalley 	    env, zhp, vdev, p_vdev_id, (LeafVirtualDeviceBean_t *)bean);
477fa9e4066Sahrens 
478fa9e4066Sahrens 	if (result) {
479fa9e4066Sahrens 		/* Must not call any more Java methods to preserve exception */
480fa9e4066Sahrens 		return (-1);
481fa9e4066Sahrens 	}
482fa9e4066Sahrens 
483fa9e4066Sahrens 	/* Set path */
484fa9e4066Sahrens 	result = nvlist_lookup_string(vdev, ZPOOL_CONFIG_PATH, &path);
485fa9e4066Sahrens 	if (result != 0) {
486fa9e4066Sahrens 		zjni_throw_exception(env,
487d7d4af51Smmusante 		    "could not retrieve path from disk virtual device "
488d7d4af51Smmusante 		    "(pool %s)", zpool_get_name(zhp));
489fa9e4066Sahrens 	} else {
490fa9e4066Sahrens 
491a1a659aeStalley 		regex_t re;
492a1a659aeStalley 		regmatch_t matches[2];
493a1a659aeStalley 		jstring pathUTF = NULL;
494a1a659aeStalley 
495a1a659aeStalley 		/* Strip off slice portion of name, if applicable */
496a1a659aeStalley 		if (regcomp(&re, "^(/dev/dsk/.*)s[0-9]+$", REG_EXTENDED) == 0) {
497a1a659aeStalley 			if (regexec(&re, path, 2, matches, 0) == 0) {
498a1a659aeStalley 				regmatch_t *match = matches + 1;
499a1a659aeStalley 				if (match->rm_so != -1 && match->rm_eo != -1) {
500a1a659aeStalley 					char *tmp = strdup(path);
501a1a659aeStalley 					if (tmp != NULL) {
502a1a659aeStalley 						char *end = tmp + match->rm_eo;
503a1a659aeStalley 						*end = '\0';
504a1a659aeStalley 						pathUTF = (*env)->NewStringUTF(
505a1a659aeStalley 						    env, tmp);
506a1a659aeStalley 						free(tmp);
507a1a659aeStalley 					}
508a1a659aeStalley 				}
509a1a659aeStalley 			}
510a1a659aeStalley 			regfree(&re);
511a1a659aeStalley 		}
512a1a659aeStalley 
513a1a659aeStalley 		if (pathUTF == NULL) {
5141e995cfcSrl 			pathUTF = (*env)->NewStringUTF(env, path);
515a1a659aeStalley 		}
516a1a659aeStalley 
517a1a659aeStalley 		(*env)->CallVoidMethod(env, ((zjni_Object_t *)bean)->object,
518a1a659aeStalley 		    ((LeafVirtualDeviceBean_t *)bean)->method_setName, pathUTF);
519a1a659aeStalley 	}
520a1a659aeStalley 
521a1a659aeStalley 	return (result != 0);
522a1a659aeStalley }
523a1a659aeStalley 
524a1a659aeStalley static int
525a1a659aeStalley populate_SliceVirtualDeviceBean(JNIEnv *env, zpool_handle_t *zhp,
526bfe5f5a4Stalley     nvlist_t *vdev, uint64_t *p_vdev_id, SliceVirtualDeviceBean_t *bean)
527a1a659aeStalley {
528a1a659aeStalley 	char *path;
529a1a659aeStalley 	int result = populate_LeafVirtualDeviceBean(
530bfe5f5a4Stalley 	    env, zhp, vdev, p_vdev_id, (LeafVirtualDeviceBean_t *)bean);
531a1a659aeStalley 
532a1a659aeStalley 	if (result) {
533a1a659aeStalley 		/* Must not call any more Java methods to preserve exception */
534a1a659aeStalley 		return (-1);
535a1a659aeStalley 	}
536a1a659aeStalley 
537a1a659aeStalley 	/* Set path */
538a1a659aeStalley 	result = nvlist_lookup_string(vdev, ZPOOL_CONFIG_PATH, &path);
539a1a659aeStalley 	if (result != 0) {
540a1a659aeStalley 		zjni_throw_exception(env,
541d7d4af51Smmusante 		    "could not retrieve path from slice virtual device (pool "
542a1a659aeStalley 		    "%s)", zpool_get_name(zhp));
543a1a659aeStalley 	} else {
544a1a659aeStalley 
545fa9e4066Sahrens 		jstring pathUTF = (*env)->NewStringUTF(env, path);
546fa9e4066Sahrens 		(*env)->CallVoidMethod(env, ((zjni_Object_t *)bean)->object,
547bfe5f5a4Stalley 		    ((LeafVirtualDeviceBean_t *)bean)->method_setName,
548bfe5f5a4Stalley 		    pathUTF);
549fa9e4066Sahrens 	}
550fa9e4066Sahrens 
551fa9e4066Sahrens 	return (result != 0);
552fa9e4066Sahrens }
553fa9e4066Sahrens 
554fa9e4066Sahrens static int
555fa9e4066Sahrens populate_FileVirtualDeviceBean(JNIEnv *env, zpool_handle_t *zhp,
556bfe5f5a4Stalley     nvlist_t *vdev, uint64_t *p_vdev_id, FileVirtualDeviceBean_t *bean)
557fa9e4066Sahrens {
558fa9e4066Sahrens 	char *path;
559a1a659aeStalley 	int result = populate_LeafVirtualDeviceBean(
560bfe5f5a4Stalley 	    env, zhp, vdev, p_vdev_id, (LeafVirtualDeviceBean_t *)bean);
561fa9e4066Sahrens 
562fa9e4066Sahrens 	if (result) {
563fa9e4066Sahrens 		/* Must not call any more Java methods to preserve exception */
564fa9e4066Sahrens 		return (-1);
565fa9e4066Sahrens 	}
566fa9e4066Sahrens 
567fa9e4066Sahrens 	/* Set path */
568fa9e4066Sahrens 	result = nvlist_lookup_string(vdev, ZPOOL_CONFIG_PATH, &path);
569fa9e4066Sahrens 	if (result != 0) {
570fa9e4066Sahrens 		zjni_throw_exception(env,
571d7d4af51Smmusante 		    "could not retrieve path from disk virtual device "
572d7d4af51Smmusante 		    "(pool %s)", zpool_get_name(zhp));
573fa9e4066Sahrens 	} else {
574fa9e4066Sahrens 
575fa9e4066Sahrens 		jstring pathUTF = (*env)->NewStringUTF(env, path);
576fa9e4066Sahrens 		(*env)->CallVoidMethod(env, ((zjni_Object_t *)bean)->object,
577a1a659aeStalley 		    ((LeafVirtualDeviceBean_t *)bean)->method_setName, pathUTF);
578fa9e4066Sahrens 	}
579fa9e4066Sahrens 
580fa9e4066Sahrens 	return (result != 0);
581fa9e4066Sahrens }
582fa9e4066Sahrens 
583fa9e4066Sahrens static int
584fa9e4066Sahrens populate_RAIDVirtualDeviceBean(JNIEnv *env, zpool_handle_t *zhp,
585bfe5f5a4Stalley     nvlist_t *vdev, uint64_t *p_vdev_id, RAIDVirtualDeviceBean_t *bean)
586fa9e4066Sahrens {
587bfe5f5a4Stalley 	return (populate_VirtualDeviceBean(env, zhp, vdev, p_vdev_id,
588fa9e4066Sahrens 	    (VirtualDeviceBean_t *)bean));
589fa9e4066Sahrens }
590fa9e4066Sahrens 
591fa9e4066Sahrens static int
592fa9e4066Sahrens populate_MirrorVirtualDeviceBean(JNIEnv *env, zpool_handle_t *zhp,
593bfe5f5a4Stalley     nvlist_t *vdev, uint64_t *p_vdev_id, MirrorVirtualDeviceBean_t *bean)
594fa9e4066Sahrens {
595bfe5f5a4Stalley 	return (populate_VirtualDeviceBean(env, zhp, vdev, p_vdev_id,
596fa9e4066Sahrens 	    (VirtualDeviceBean_t *)bean));
597fa9e4066Sahrens }
598fa9e4066Sahrens 
599c8e9ed14Stalley static jobject
600fbfd10ffStalley create_ImportablePoolBean(JNIEnv *env, nvlist_t *config)
601c8e9ed14Stalley {
602c8e9ed14Stalley 	int result;
603c8e9ed14Stalley 	ImportablePoolBean_t bean_obj = {0};
604c8e9ed14Stalley 	ImportablePoolBean_t *bean = &bean_obj;
605c8e9ed14Stalley 
606c8e9ed14Stalley 	/* Construct ImportablePoolBean */
607c8e9ed14Stalley 	new_ImportablePoolBean(env, bean);
608c8e9ed14Stalley 
609fbfd10ffStalley 	result = populate_ImportablePoolBean(env, bean, config);
610c8e9ed14Stalley 	if (result) {
611c8e9ed14Stalley 		/* Must not call any more Java methods to preserve exception */
612c8e9ed14Stalley 		return (NULL);
613c8e9ed14Stalley 	}
614c8e9ed14Stalley 
615c8e9ed14Stalley 	return (((zjni_Object_t *)bean)->object);
616c8e9ed14Stalley }
617c8e9ed14Stalley 
618fa9e4066Sahrens static jobject
619bfe5f5a4Stalley create_DiskVirtualDeviceBean(JNIEnv *env, zpool_handle_t *zhp,
620bfe5f5a4Stalley     nvlist_t *vdev, uint64_t *p_vdev_id)
621fa9e4066Sahrens {
622fa9e4066Sahrens 	int result;
623fa9e4066Sahrens 	DiskVirtualDeviceBean_t bean_obj = {0};
624fa9e4066Sahrens 	DiskVirtualDeviceBean_t *bean = &bean_obj;
625fa9e4066Sahrens 
626fa9e4066Sahrens 	/* Construct DiskVirtualDeviceBean */
627fa9e4066Sahrens 	new_DiskVirtualDeviceBean(env, bean);
628fa9e4066Sahrens 
629bfe5f5a4Stalley 	result = populate_DiskVirtualDeviceBean(
630bfe5f5a4Stalley 	    env, zhp, vdev, p_vdev_id, bean);
631fa9e4066Sahrens 	if (result) {
632fa9e4066Sahrens 		/* Must not call any more Java methods to preserve exception */
633fa9e4066Sahrens 		return (NULL);
634fa9e4066Sahrens 	}
635fa9e4066Sahrens 
636fa9e4066Sahrens 	return (((zjni_Object_t *)bean)->object);
637fa9e4066Sahrens }
638fa9e4066Sahrens 
639a1a659aeStalley static jobject
640bfe5f5a4Stalley create_SliceVirtualDeviceBean(JNIEnv *env, zpool_handle_t *zhp,
641bfe5f5a4Stalley     nvlist_t *vdev, uint64_t *p_vdev_id)
642a1a659aeStalley {
643a1a659aeStalley 	int result;
644a1a659aeStalley 	SliceVirtualDeviceBean_t bean_obj = {0};
645a1a659aeStalley 	SliceVirtualDeviceBean_t *bean = &bean_obj;
646a1a659aeStalley 
647a1a659aeStalley 	/* Construct SliceVirtualDeviceBean */
648a1a659aeStalley 	new_SliceVirtualDeviceBean(env, bean);
649a1a659aeStalley 
650bfe5f5a4Stalley 	result = populate_SliceVirtualDeviceBean(
651bfe5f5a4Stalley 	    env, zhp, vdev, p_vdev_id, bean);
652a1a659aeStalley 	if (result) {
653a1a659aeStalley 		/* Must not call any more Java methods to preserve exception */
654a1a659aeStalley 		return (NULL);
655a1a659aeStalley 	}
656a1a659aeStalley 
657a1a659aeStalley 	return (((zjni_Object_t *)bean)->object);
658a1a659aeStalley }
659a1a659aeStalley 
660fa9e4066Sahrens static jobject
661bfe5f5a4Stalley create_FileVirtualDeviceBean(JNIEnv *env, zpool_handle_t *zhp,
662bfe5f5a4Stalley     nvlist_t *vdev, uint64_t *p_vdev_id)
663fa9e4066Sahrens {
664fa9e4066Sahrens 	int result;
665fa9e4066Sahrens 	FileVirtualDeviceBean_t bean_obj = {0};
666fa9e4066Sahrens 	FileVirtualDeviceBean_t *bean = &bean_obj;
667fa9e4066Sahrens 
668fa9e4066Sahrens 	/* Construct FileVirtualDeviceBean */
669fa9e4066Sahrens 	new_FileVirtualDeviceBean(env, bean);
670fa9e4066Sahrens 
671bfe5f5a4Stalley 	result = populate_FileVirtualDeviceBean(
672bfe5f5a4Stalley 	    env, zhp, vdev, p_vdev_id, bean);
673fa9e4066Sahrens 	if (result) {
674fa9e4066Sahrens 		/* Must not call any more Java methods to preserve exception */
675fa9e4066Sahrens 		return (NULL);
676fa9e4066Sahrens 	}
677fa9e4066Sahrens 
678fa9e4066Sahrens 	return (((zjni_Object_t *)bean)->object);
679fa9e4066Sahrens }
680fa9e4066Sahrens 
681fa9e4066Sahrens static jobject
682bfe5f5a4Stalley create_RAIDVirtualDeviceBean(JNIEnv *env, zpool_handle_t *zhp,
683bfe5f5a4Stalley     nvlist_t *vdev, uint64_t *p_vdev_id)
684fa9e4066Sahrens {
685fa9e4066Sahrens 	int result;
6861e995cfcSrl 	uint64_t parity;
687fa9e4066Sahrens 	RAIDVirtualDeviceBean_t bean_obj = {0};
688fa9e4066Sahrens 	RAIDVirtualDeviceBean_t *bean = &bean_obj;
689fa9e4066Sahrens 
690fa9e4066Sahrens 	((zjni_Object_t *)bean)->object = NULL;
691fa9e4066Sahrens 
692fa9e4066Sahrens 	/* Construct RAIDVirtualDeviceBean */
693fa9e4066Sahrens 	new_RAIDVirtualDeviceBean(env, bean);
694fa9e4066Sahrens 
6951e995cfcSrl 	/* Set parity bit */
6961e995cfcSrl 	result = nvlist_lookup_uint64(vdev, ZPOOL_CONFIG_NPARITY,
6971e995cfcSrl 	    &parity);
6981e995cfcSrl 	if (result) {
6991e995cfcSrl 		/* Default to RAID-Z1 in case of error */
7001e995cfcSrl 		parity = 1;
7011e995cfcSrl 	}
7021e995cfcSrl 
7031e995cfcSrl 	(*env)->CallVoidMethod(
7041e995cfcSrl 	    env, ((zjni_Object_t *)bean)->object, bean->method_setParity,
7051e995cfcSrl 	    (jlong)parity);
7061e995cfcSrl 
7071e995cfcSrl 
708bfe5f5a4Stalley 	result = populate_RAIDVirtualDeviceBean(
709bfe5f5a4Stalley 	    env, zhp, vdev, p_vdev_id, bean);
710fa9e4066Sahrens 	if (result) {
711fa9e4066Sahrens 		/* Must not call any more Java methods to preserve exception */
712fa9e4066Sahrens 		return (NULL);
713fa9e4066Sahrens 	}
714fa9e4066Sahrens 
715fa9e4066Sahrens 	return (((zjni_Object_t *)bean)->object);
716fa9e4066Sahrens }
717fa9e4066Sahrens 
718fa9e4066Sahrens static jobject
719bfe5f5a4Stalley create_MirrorVirtualDeviceBean(JNIEnv *env, zpool_handle_t *zhp,
720bfe5f5a4Stalley     nvlist_t *vdev, uint64_t *p_vdev_id)
721fa9e4066Sahrens {
722fa9e4066Sahrens 	int result;
723fa9e4066Sahrens 	MirrorVirtualDeviceBean_t bean_obj = {0};
724fa9e4066Sahrens 	MirrorVirtualDeviceBean_t *bean = &bean_obj;
725fa9e4066Sahrens 
726fa9e4066Sahrens 	/* Construct MirrorVirtualDeviceBean */
727fa9e4066Sahrens 	new_MirrorVirtualDeviceBean(env, bean);
728fa9e4066Sahrens 
729bfe5f5a4Stalley 	result = populate_MirrorVirtualDeviceBean(
730bfe5f5a4Stalley 	    env, zhp, vdev, p_vdev_id, bean);
731fa9e4066Sahrens 	if (result) {
732fa9e4066Sahrens 		/* Must not call any more Java methods to preserve exception */
733fa9e4066Sahrens 		return (NULL);
734fa9e4066Sahrens 	}
735fa9e4066Sahrens 
736fa9e4066Sahrens 	return (((zjni_Object_t *)bean)->object);
737fa9e4066Sahrens }
738fa9e4066Sahrens 
739fbfd10ffStalley static char *
740fbfd10ffStalley find_field(const zjni_field_mapping_t *mapping, int value) {
741fbfd10ffStalley 	int i;
742fbfd10ffStalley 	for (i = 0; mapping[i].name != NULL; i++) {
743fbfd10ffStalley 		if (value == mapping[i].value) {
744fbfd10ffStalley 			return (mapping[i].name);
745fbfd10ffStalley 		}
746fbfd10ffStalley 	}
747fbfd10ffStalley 	return (NULL);
748fbfd10ffStalley }
749fbfd10ffStalley 
750fbfd10ffStalley /*
751fbfd10ffStalley  * Converts a vdev_state_t to a Java DeviceStats$DeviceState object.
752fbfd10ffStalley  */
753fbfd10ffStalley static jobject
754fbfd10ffStalley zjni_vdev_state_to_obj(JNIEnv *env, vdev_state_t state)
755fbfd10ffStalley {
756fbfd10ffStalley 	return (zjni_int_to_enum(env, state,
757fbfd10ffStalley 	    ZFSJNI_PACKAGE_DATA "DeviceStats$DeviceState",
758fbfd10ffStalley 	    "VDEV_STATE_UNKNOWN", vdev_state_map));
759fbfd10ffStalley }
760fbfd10ffStalley 
761fbfd10ffStalley /*
762fbfd10ffStalley  * Converts a vdev_aux_t to a Java DeviceStats$DeviceStatus object.
763fbfd10ffStalley  */
764fbfd10ffStalley static jobject
765fbfd10ffStalley zjni_vdev_aux_to_obj(JNIEnv *env, vdev_aux_t aux)
766fbfd10ffStalley {
767fbfd10ffStalley 	return (zjni_int_to_enum(env, aux,
768fbfd10ffStalley 	    ZFSJNI_PACKAGE_DATA "DeviceStats$DeviceStatus",
769fbfd10ffStalley 	    "VDEV_AUX_NONE", vdev_aux_map));
770fbfd10ffStalley }
771fbfd10ffStalley 
772fa9e4066Sahrens /*
773fa9e4066Sahrens  * Package-private functions
774fa9e4066Sahrens  */
775fa9e4066Sahrens 
776fbfd10ffStalley /* Create a DeviceStatsBean */
777fbfd10ffStalley void
778fbfd10ffStalley new_DeviceStats(JNIEnv *env, DeviceStatsBean_t *bean, zjni_Object_t *object)
779fbfd10ffStalley {
780fbfd10ffStalley 	bean->method_setSize = (*env)->GetMethodID(
781fbfd10ffStalley 	    env, object->class, "setSize", "(J)V");
782fbfd10ffStalley 
783a1a659aeStalley 	bean->method_setReplacementSize = (*env)->GetMethodID(
784a1a659aeStalley 	    env, object->class, "setReplacementSize", "(J)V");
785a1a659aeStalley 
786fbfd10ffStalley 	bean->method_setUsed = (*env)->GetMethodID(
787fbfd10ffStalley 	    env, object->class, "setUsed", "(J)V");
788fbfd10ffStalley 
789fbfd10ffStalley 	bean->method_setReadBytes = (*env)->GetMethodID(
790fbfd10ffStalley 	    env, object->class, "setReadBytes", "(J)V");
791fbfd10ffStalley 
792fbfd10ffStalley 	bean->method_setWriteBytes = (*env)->GetMethodID(
793fbfd10ffStalley 	    env, object->class, "setWriteBytes", "(J)V");
794fbfd10ffStalley 
795fbfd10ffStalley 	bean->method_setReadOperations = (*env)->GetMethodID(
796fbfd10ffStalley 	    env, object->class, "setReadOperations", "(J)V");
797fbfd10ffStalley 
798fbfd10ffStalley 	bean->method_setWriteOperations = (*env)->GetMethodID(
799fbfd10ffStalley 	    env, object->class, "setWriteOperations", "(J)V");
800fbfd10ffStalley 
801fbfd10ffStalley 	bean->method_setReadErrors = (*env)->GetMethodID(
802fbfd10ffStalley 	    env, object->class, "setReadErrors", "(J)V");
803fbfd10ffStalley 
804fbfd10ffStalley 	bean->method_setWriteErrors = (*env)->GetMethodID(
805fbfd10ffStalley 	    env, object->class, "setWriteErrors", "(J)V");
806fbfd10ffStalley 
807fbfd10ffStalley 	bean->method_setChecksumErrors = (*env)->GetMethodID(
808fbfd10ffStalley 	    env, object->class, "setChecksumErrors", "(J)V");
809fbfd10ffStalley 
810fbfd10ffStalley 	bean->method_setDeviceState = (*env)->GetMethodID(
811fbfd10ffStalley 	    env, object->class, "setDeviceState",
812fbfd10ffStalley 	    "(L" ZFSJNI_PACKAGE_DATA "DeviceStats$DeviceState;)V");
813fbfd10ffStalley 
814fbfd10ffStalley 	bean->method_setDeviceStatus = (*env)->GetMethodID(
815fbfd10ffStalley 	    env, object->class, "setDeviceStatus",
816fbfd10ffStalley 	    "(L" ZFSJNI_PACKAGE_DATA "DeviceStats$DeviceStatus;)V");
817fbfd10ffStalley }
818fbfd10ffStalley 
819fbfd10ffStalley /* Create a PoolStatsBean */
820fbfd10ffStalley void
821fbfd10ffStalley new_PoolStats(JNIEnv *env, PoolStatsBean_t *bean, zjni_Object_t *object)
822fbfd10ffStalley {
823fbfd10ffStalley 	new_DeviceStats(env, (DeviceStatsBean_t *)bean, object);
824fbfd10ffStalley 
825fbfd10ffStalley 	bean->method_setPoolState = (*env)->GetMethodID(
826fbfd10ffStalley 	    env, object->class, "setPoolState",
827fbfd10ffStalley 	    "(L" ZFSJNI_PACKAGE_DATA "PoolStats$PoolState;)V");
828fbfd10ffStalley 
829fbfd10ffStalley 	bean->method_setPoolStatus = (*env)->GetMethodID(
830fbfd10ffStalley 	    env, object->class, "setPoolStatus",
831fbfd10ffStalley 	    "(L" ZFSJNI_PACKAGE_DATA "PoolStats$PoolStatus;)V");
832a55b6846Scristian 
833a55b6846Scristian 	bean->method_setPoolVersion = (*env)->GetMethodID(
834a55b6846Scristian 	    env, object->class, "setPoolVersion", "(J)V");
835fbfd10ffStalley }
836fbfd10ffStalley 
837fa9e4066Sahrens /*
838fa9e4066Sahrens  * Gets the root vdev (an nvlist_t *) for the given pool.
839fa9e4066Sahrens  */
840fa9e4066Sahrens nvlist_t *
841fa9e4066Sahrens zjni_get_root_vdev(zpool_handle_t *zhp)
842fa9e4066Sahrens {
843fa9e4066Sahrens 	nvlist_t *root = NULL;
844fa9e4066Sahrens 
845fa9e4066Sahrens 	if (zhp != NULL) {
846088e9d47Seschrock 		nvlist_t *attrs = zpool_get_config(zhp, NULL);
847fa9e4066Sahrens 
848fa9e4066Sahrens 		if (attrs != NULL) {
849fa9e4066Sahrens 			int result = nvlist_lookup_nvlist(
850fa9e4066Sahrens 			    attrs, ZPOOL_CONFIG_VDEV_TREE, &root);
851fa9e4066Sahrens 			if (result != 0) {
852fa9e4066Sahrens 				root = NULL;
853fa9e4066Sahrens 			}
854fa9e4066Sahrens 		}
855fa9e4066Sahrens 	}
856fa9e4066Sahrens 
857fa9e4066Sahrens 	return (root);
858fa9e4066Sahrens }
859fa9e4066Sahrens 
860fa9e4066Sahrens /*
861fa9e4066Sahrens  * Gets the vdev (an nvlist_t *) with the given vdev_id, below the
862fa9e4066Sahrens  * given vdev.  If the given vdev is NULL, all vdevs within the given
863fa9e4066Sahrens  * pool are searched.
864bfe5f5a4Stalley  *
865bfe5f5a4Stalley  * If p_vdev_id is not NULL, it will be set to the ID of the parent
866bfe5f5a4Stalley  * vdev, if any, or to vdev_id_to_find if the searched-for vdev is a
867bfe5f5a4Stalley  * toplevel vdev.
868fa9e4066Sahrens  */
869fa9e4066Sahrens nvlist_t *
870fa9e4066Sahrens zjni_get_vdev(zpool_handle_t *zhp, nvlist_t *vdev_parent,
871bfe5f5a4Stalley     uint64_t vdev_id_to_find, uint64_t *p_vdev_id)
872fa9e4066Sahrens {
873fa9e4066Sahrens 	int result;
874bfe5f5a4Stalley 	uint64_t id = vdev_id_to_find;
875fa9e4066Sahrens 
876fa9e4066Sahrens 	/* Was a vdev specified? */
877fa9e4066Sahrens 	if (vdev_parent == NULL) {
878fa9e4066Sahrens 		/* No -- retrieve the top-level pool vdev */
879fa9e4066Sahrens 		vdev_parent = zjni_get_root_vdev(zhp);
880fa9e4066Sahrens 	} else {
881fa9e4066Sahrens 		/* Get index of this vdev and compare with vdev_id_to_find */
882fa9e4066Sahrens 		result = nvlist_lookup_uint64(
883fa9e4066Sahrens 		    vdev_parent, ZPOOL_CONFIG_GUID, &id);
884fa9e4066Sahrens 		if (result == 0 && id == vdev_id_to_find) {
885fa9e4066Sahrens 			return (vdev_parent);
886fa9e4066Sahrens 		}
887fa9e4066Sahrens 	}
888fa9e4066Sahrens 
889fa9e4066Sahrens 	if (vdev_parent != NULL) {
890fa9e4066Sahrens 
891fa9e4066Sahrens 		nvlist_t **children;
892fa9e4066Sahrens 		uint_t nelem = 0;
893fa9e4066Sahrens 
894fa9e4066Sahrens 		/* Get the vdevs under this vdev */
895fa9e4066Sahrens 		result = nvlist_lookup_nvlist_array(
896fa9e4066Sahrens 		    vdev_parent, ZPOOL_CONFIG_CHILDREN, &children, &nelem);
897fa9e4066Sahrens 
898fa9e4066Sahrens 		if (result == 0) {
899fa9e4066Sahrens 
900fa9e4066Sahrens 			int i;
901fa9e4066Sahrens 			nvlist_t *child;
902fa9e4066Sahrens 
903fa9e4066Sahrens 			/* For each vdev child... */
904fa9e4066Sahrens 			for (i = 0; i < nelem; i++) {
905bfe5f5a4Stalley 				if (p_vdev_id != NULL) {
906bfe5f5a4Stalley 					/* Save parent vdev id */
907bfe5f5a4Stalley 					*p_vdev_id = id;
908bfe5f5a4Stalley 				}
909bfe5f5a4Stalley 
910fa9e4066Sahrens 				child = zjni_get_vdev(zhp, children[i],
911bfe5f5a4Stalley 				    vdev_id_to_find, p_vdev_id);
912fa9e4066Sahrens 				if (child != NULL) {
913fa9e4066Sahrens 					return (child);
914fa9e4066Sahrens 				}
915fa9e4066Sahrens 			}
916fa9e4066Sahrens 		}
917fa9e4066Sahrens 	}
918fa9e4066Sahrens 
919fa9e4066Sahrens 	return (NULL);
920fa9e4066Sahrens }
921fa9e4066Sahrens 
922fa9e4066Sahrens jobject
923fa9e4066Sahrens zjni_get_VirtualDevice_from_vdev(JNIEnv *env, zpool_handle_t *zhp,
924bfe5f5a4Stalley     nvlist_t *vdev, uint64_t *p_vdev_id)
925fa9e4066Sahrens {
926fa9e4066Sahrens 	jobject obj = NULL;
927fa9e4066Sahrens 	char *type = NULL;
928fa9e4066Sahrens 	int result = nvlist_lookup_string(vdev, ZPOOL_CONFIG_TYPE, &type);
929fa9e4066Sahrens 
930fa9e4066Sahrens 	if (result == 0) {
931fa9e4066Sahrens 		if (strcmp(type, VDEV_TYPE_DISK) == 0) {
932a1a659aeStalley 			uint64_t wholedisk;
933a1a659aeStalley 			if (nvlist_lookup_uint64(vdev, ZPOOL_CONFIG_WHOLE_DISK,
934a1a659aeStalley 			    &wholedisk) == 0 && wholedisk) {
935a1a659aeStalley 				obj = create_DiskVirtualDeviceBean(
936bfe5f5a4Stalley 				    env, zhp, vdev, p_vdev_id);
937a1a659aeStalley 			} else {
938a1a659aeStalley 				obj = create_SliceVirtualDeviceBean(
939bfe5f5a4Stalley 				    env, zhp, vdev, p_vdev_id);
940a1a659aeStalley 			}
941fa9e4066Sahrens 		} else if (strcmp(type, VDEV_TYPE_FILE) == 0) {
942bfe5f5a4Stalley 			obj = create_FileVirtualDeviceBean(
943bfe5f5a4Stalley 			    env, zhp, vdev, p_vdev_id);
944fa9e4066Sahrens 		} else if (strcmp(type, VDEV_TYPE_RAIDZ) == 0) {
945bfe5f5a4Stalley 			obj = create_RAIDVirtualDeviceBean(
946bfe5f5a4Stalley 			    env, zhp, vdev, p_vdev_id);
947fa9e4066Sahrens 		} else if (strcmp(type, VDEV_TYPE_MIRROR) == 0) {
948bfe5f5a4Stalley 			obj = create_MirrorVirtualDeviceBean(
949bfe5f5a4Stalley 			    env, zhp, vdev, p_vdev_id);
950c8e9ed14Stalley 		} else if (strcmp(type, VDEV_TYPE_REPLACING) == 0) {
951c8e9ed14Stalley 
952c8e9ed14Stalley 			/* Get the vdevs under this vdev */
953c8e9ed14Stalley 			nvlist_t **children;
954c8e9ed14Stalley 			uint_t nelem = 0;
955c8e9ed14Stalley 			int result = nvlist_lookup_nvlist_array(
956c8e9ed14Stalley 			    vdev, ZPOOL_CONFIG_CHILDREN, &children, &nelem);
957c8e9ed14Stalley 
958c8e9ed14Stalley 			if (result == 0 && nelem > 0) {
959c8e9ed14Stalley 
960c8e9ed14Stalley 				/* Get last vdev child (replacement device) */
961c8e9ed14Stalley 				nvlist_t *child = children[nelem - 1];
962c8e9ed14Stalley 
963c8e9ed14Stalley 				obj = zjni_get_VirtualDevice_from_vdev(env,
964bfe5f5a4Stalley 				    zhp, child, p_vdev_id);
965c8e9ed14Stalley 			}
966fa9e4066Sahrens 		}
967fa9e4066Sahrens 	}
968fa9e4066Sahrens 
969fa9e4066Sahrens 	return (obj);
970fa9e4066Sahrens }
971fa9e4066Sahrens 
972fa9e4066Sahrens jobject
973fa9e4066Sahrens zjni_get_VirtualDevices_from_vdev(JNIEnv *env, zpool_handle_t *zhp,
974bfe5f5a4Stalley     nvlist_t *vdev_parent, uint64_t *p_vdev_id)
975fa9e4066Sahrens {
976fa9e4066Sahrens 	/* Create an array list for the vdevs */
977fa9e4066Sahrens 	zjni_ArrayList_t list_class = {0};
978fa9e4066Sahrens 	zjni_ArrayList_t *list_class_p = &list_class;
979fa9e4066Sahrens 	zjni_new_ArrayList(env, list_class_p);
980fa9e4066Sahrens 
981fa9e4066Sahrens 	/* Was a vdev specified? */
982fa9e4066Sahrens 	if (vdev_parent == NULL) {
983fa9e4066Sahrens 		/* No -- retrieve the top-level pool vdev */
984fa9e4066Sahrens 		vdev_parent = zjni_get_root_vdev(zhp);
985fa9e4066Sahrens 	}
986fa9e4066Sahrens 
987fa9e4066Sahrens 	if (vdev_parent != NULL) {
988fa9e4066Sahrens 
989fa9e4066Sahrens 		/* Get the vdevs under this vdev */
990fa9e4066Sahrens 		nvlist_t **children;
991fa9e4066Sahrens 		uint_t nelem = 0;
992fa9e4066Sahrens 		int result = nvlist_lookup_nvlist_array(
993fa9e4066Sahrens 		    vdev_parent, ZPOOL_CONFIG_CHILDREN, &children, &nelem);
994fa9e4066Sahrens 
995fa9e4066Sahrens 		if (result == 0) {
996fa9e4066Sahrens 
997fa9e4066Sahrens 			/* For each vdev child... */
998fa9e4066Sahrens 			int i;
999fa9e4066Sahrens 			for (i = 0; i < nelem; i++) {
1000fa9e4066Sahrens 				nvlist_t *child = children[i];
1001fa9e4066Sahrens 
1002fa9e4066Sahrens 				/* Create a Java object from this vdev */
1003fa9e4066Sahrens 				jobject obj =
1004fa9e4066Sahrens 				    zjni_get_VirtualDevice_from_vdev(env,
10051e995cfcSrl 				    zhp, child, p_vdev_id);
1006fa9e4066Sahrens 
1007c8e9ed14Stalley 				if ((*env)->ExceptionOccurred(env) != NULL) {
1008fa9e4066Sahrens 					/*
1009fa9e4066Sahrens 					 * Must not call any more Java methods
1010fa9e4066Sahrens 					 * to preserve exception
1011fa9e4066Sahrens 					 */
1012fa9e4066Sahrens 					return (NULL);
1013fa9e4066Sahrens 				}
1014fa9e4066Sahrens 
1015c8e9ed14Stalley 				if (obj != NULL) {
1016c8e9ed14Stalley 				    /* Add child to child vdev list */
10171e995cfcSrl 					(*env)->CallBooleanMethod(env,
10181e995cfcSrl 					    ((zjni_Object_t *)
10191e995cfcSrl 					    list_class_p)->object,
10201e995cfcSrl 					    ((zjni_Collection_t *)
10211e995cfcSrl 					    list_class_p)->method_add, obj);
1022c8e9ed14Stalley 				}
1023fa9e4066Sahrens 			}
1024fa9e4066Sahrens 		}
1025fa9e4066Sahrens 	}
1026fa9e4066Sahrens 
1027fa9e4066Sahrens 	return (zjni_Collection_to_array(
1028fa9e4066Sahrens 	    env, (zjni_Collection_t *)list_class_p,
1029fa9e4066Sahrens 	    ZFSJNI_PACKAGE_DATA "VirtualDevice"));
1030fa9e4066Sahrens }
1031c8e9ed14Stalley 
1032c8e9ed14Stalley int
1033fbfd10ffStalley zjni_create_add_ImportablePool(nvlist_t *config, void *data) {
1034c8e9ed14Stalley 
1035c8e9ed14Stalley 	JNIEnv *env = ((zjni_ArrayCallbackData_t *)data)->env;
1036c8e9ed14Stalley 	zjni_Collection_t *list = ((zjni_ArrayCallbackData_t *)data)->list;
1037c8e9ed14Stalley 
1038c8e9ed14Stalley 	/* Construct ImportablePool object */
1039fbfd10ffStalley 	jobject bean = create_ImportablePoolBean(env, config);
1040c8e9ed14Stalley 	if (bean == NULL) {
1041c8e9ed14Stalley 		return (-1);
1042c8e9ed14Stalley 	}
1043c8e9ed14Stalley 
1044c8e9ed14Stalley 	/* Add bean to list */
1045c8e9ed14Stalley 	(*env)->CallBooleanMethod(env, ((zjni_Object_t *)list)->object,
1046c8e9ed14Stalley 	    ((zjni_Collection_t *)list)->method_add, bean);
1047c8e9ed14Stalley 
1048c8e9ed14Stalley 	return (0);
1049c8e9ed14Stalley }
1050c8e9ed14Stalley 
1051fbfd10ffStalley int
1052fbfd10ffStalley populate_DeviceStatsBean(JNIEnv *env, nvlist_t *vdev,
1053fbfd10ffStalley     DeviceStatsBean_t *bean, zjni_Object_t *object)
1054fbfd10ffStalley {
1055fbfd10ffStalley 	uint_t c;
1056fbfd10ffStalley 	vdev_stat_t *vs;
1057fbfd10ffStalley 
1058fbfd10ffStalley 	int result = nvlist_lookup_uint64_array(
1059fbfd10ffStalley 	    vdev, ZPOOL_CONFIG_STATS, (uint64_t **)&vs, &c);
1060fbfd10ffStalley 	if (result != 0) {
1061fbfd10ffStalley 		zjni_throw_exception(env,
1062fbfd10ffStalley 		    "could not retrieve virtual device statistics");
1063fbfd10ffStalley 		return (1);
1064fbfd10ffStalley 	}
1065fbfd10ffStalley 
1066fbfd10ffStalley 	(*env)->CallVoidMethod(env, object->object,
1067fbfd10ffStalley 	    bean->method_setUsed, (jlong)vs->vs_alloc);
1068fbfd10ffStalley 
1069fbfd10ffStalley 	(*env)->CallVoidMethod(env, object->object,
1070fbfd10ffStalley 	    bean->method_setSize, (jlong)vs->vs_space);
1071fbfd10ffStalley 
1072a1a659aeStalley 	(*env)->CallVoidMethod(env, object->object,
1073a1a659aeStalley 	    bean->method_setReplacementSize, (jlong)vs->vs_rsize);
1074a1a659aeStalley 
1075fbfd10ffStalley 	(*env)->CallVoidMethod(env, object->object,
1076fbfd10ffStalley 	    bean->method_setReadBytes, (jlong)vs->vs_bytes[ZIO_TYPE_READ]);
1077fbfd10ffStalley 
1078fbfd10ffStalley 	(*env)->CallVoidMethod(env, object->object,
1079fbfd10ffStalley 	    bean->method_setWriteBytes, (jlong)vs->vs_bytes[ZIO_TYPE_WRITE]);
1080fbfd10ffStalley 
1081fbfd10ffStalley 	(*env)->CallVoidMethod(env, object->object,
1082fbfd10ffStalley 	    bean->method_setReadOperations, (jlong)vs->vs_ops[ZIO_TYPE_READ]);
1083fbfd10ffStalley 
1084fbfd10ffStalley 	(*env)->CallVoidMethod(env, object->object,
1085fbfd10ffStalley 	    bean->method_setWriteOperations, (jlong)vs->vs_ops[ZIO_TYPE_WRITE]);
1086fbfd10ffStalley 
1087fbfd10ffStalley 	(*env)->CallVoidMethod(env, object->object,
1088fbfd10ffStalley 	    bean->method_setReadErrors, (jlong)vs->vs_read_errors);
1089fbfd10ffStalley 
1090fbfd10ffStalley 	(*env)->CallVoidMethod(env, object->object,
1091fbfd10ffStalley 	    bean->method_setWriteErrors, (jlong)vs->vs_write_errors);
1092fbfd10ffStalley 
1093fbfd10ffStalley 	(*env)->CallVoidMethod(env, object->object,
1094fbfd10ffStalley 	    bean->method_setChecksumErrors, (jlong)vs->vs_checksum_errors);
1095fbfd10ffStalley 
1096fbfd10ffStalley 	(*env)->CallVoidMethod(env, object->object,
1097fbfd10ffStalley 	    bean->method_setDeviceState,
1098fbfd10ffStalley 	    zjni_vdev_state_to_obj(env, vs->vs_state));
1099fbfd10ffStalley 
1100fbfd10ffStalley 	(*env)->CallVoidMethod(env, object->object,
1101fbfd10ffStalley 	    bean->method_setDeviceStatus,
1102fbfd10ffStalley 	    zjni_vdev_aux_to_obj(env, vs->vs_aux));
1103fbfd10ffStalley 
1104fbfd10ffStalley 	return (0);
1105fbfd10ffStalley }
1106fbfd10ffStalley 
1107fbfd10ffStalley /*
1108fbfd10ffStalley  * Converts a pool_state_t to a Java PoolStats$PoolState object.
1109fbfd10ffStalley  */
1110fbfd10ffStalley jobject
1111fbfd10ffStalley zjni_pool_state_to_obj(JNIEnv *env, pool_state_t state)
1112fbfd10ffStalley {
1113fbfd10ffStalley 	return (zjni_int_to_enum(env, state,
1114fbfd10ffStalley 	    ZFSJNI_PACKAGE_DATA "PoolStats$PoolState",
1115fbfd10ffStalley 	    "POOL_STATE_ACTIVE", pool_state_map));
1116fbfd10ffStalley }
1117fbfd10ffStalley 
1118fbfd10ffStalley /*
1119fbfd10ffStalley  * Converts a zpool_status_t to a Java PoolStats$PoolStatus object.
1120fbfd10ffStalley  */
1121fbfd10ffStalley jobject
1122fbfd10ffStalley zjni_pool_status_to_obj(JNIEnv *env, zpool_status_t status)
1123fbfd10ffStalley {
1124fbfd10ffStalley 	return (zjni_int_to_enum(env, status,
1125fbfd10ffStalley 	    ZFSJNI_PACKAGE_DATA "PoolStats$PoolStatus",
1126fbfd10ffStalley 	    "ZPOOL_STATUS_OK", zpool_status_map));
1127fbfd10ffStalley }
1128fbfd10ffStalley 
1129c8e9ed14Stalley /*
1130c8e9ed14Stalley  * Extern functions
1131c8e9ed14Stalley  */
1132c8e9ed14Stalley 
1133c8e9ed14Stalley /*
1134c8e9ed14Stalley  * Iterates through each importable pool on the system.  For each
1135c8e9ed14Stalley  * importable pool, runs the given function with the given void as the
1136c8e9ed14Stalley  * last arg.
1137c8e9ed14Stalley  */
1138c8e9ed14Stalley int
1139c8e9ed14Stalley zjni_ipool_iter(int argc, char **argv, zjni_ipool_iter_f func, void *data)
1140c8e9ed14Stalley {
114124e697d4Sck 	nvlist_t *pools = zpool_find_import(g_zfs, argc, argv);
1142c8e9ed14Stalley 
1143c8e9ed14Stalley 	if (pools != NULL) {
1144c8e9ed14Stalley 		nvpair_t *elem = NULL;
1145fbfd10ffStalley 
1146c8e9ed14Stalley 		while ((elem = nvlist_next_nvpair(pools, elem)) != NULL) {
1147c8e9ed14Stalley 			nvlist_t *config;
1148c8e9ed14Stalley 
1149c8e9ed14Stalley 			if (nvpair_value_nvlist(elem, &config) != 0 ||
1150fbfd10ffStalley 			    func(config, data)) {
1151c8e9ed14Stalley 				return (-1);
1152c8e9ed14Stalley 			}
1153c8e9ed14Stalley 		}
1154c8e9ed14Stalley 	}
1155c8e9ed14Stalley 
1156c8e9ed14Stalley 	return (0);
1157c8e9ed14Stalley }
1158c8e9ed14Stalley 
1159c8e9ed14Stalley char *
1160fbfd10ffStalley zjni_vdev_state_to_str(vdev_state_t state) {
1161fbfd10ffStalley 	return (find_field(vdev_state_map, state));
1162fbfd10ffStalley }
1163fbfd10ffStalley 
1164fbfd10ffStalley char *
1165fbfd10ffStalley zjni_vdev_aux_to_str(vdev_aux_t aux) {
1166fbfd10ffStalley 	return (find_field(vdev_aux_map, aux));
1167fbfd10ffStalley }
1168c8e9ed14Stalley 
1169fbfd10ffStalley char *
1170fbfd10ffStalley zjni_pool_state_to_str(pool_state_t state) {
1171fbfd10ffStalley 	return (find_field(pool_state_map, state));
1172fbfd10ffStalley }
1173fbfd10ffStalley 
1174fbfd10ffStalley char *
1175fbfd10ffStalley zjni_pool_status_to_str(zpool_status_t status) {
1176fbfd10ffStalley 	return (find_field(zpool_status_map, status));
1177c8e9ed14Stalley }
1178