4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
23 * Copyright (c) 2004, 2010, Oracle and/or its affiliates. All rights reserved.
26 #ifndef _SYS_FM_UTIL_H
27 #define _SYS_FM_UTIL_H
33 #include <sys/nvpair.h>
36 * Shared user/kernel definitions for class length, error channel name,
37 * and kernel event publisher string.
39 #define FM_MAX_CLASS 100
40 #define FM_ERROR_CHAN "com.sun:fm:error"
44 * ereport dump device transport support
46 * Ereports are written out to the dump device at a proscribed offset from the
47 * end, similar to in-transit log messages. The ereports are represented as a
48 * erpt_dump_t header followed by ed_size bytes of packed native nvlist data.
50 * NOTE: All of these constants and the header must be defined so they have the
51 * same representation for *both* 32-bit and 64-bit producers and consumers.
53 #define ERPT_MAGIC 0xf00d4eddU
54 #define ERPT_MAX_ERRS 16
55 #define ERPT_DATA_SZ (6 * 1024)
56 #define ERPT_EVCH_MAX 256
59 typedef struct erpt_dump
{
60 uint32_t ed_magic
; /* ERPT_MAGIC or zero to indicate end */
61 uint32_t ed_chksum
; /* checksum32() of packed nvlist data */
62 uint32_t ed_size
; /* ereport (nvl) fixed buf size */
63 uint32_t ed_pad
; /* reserved for future use */
64 hrtime_t ed_hrt_nsec
; /* hrtime of this ereport */
65 hrtime_t ed_hrt_base
; /* hrtime sample corresponding to ed_tod_base */
67 uint64_t sec
; /* seconds since gettimeofday() Epoch */
68 uint64_t nsec
; /* nanoseconds past ed_tod_base.sec */
74 #define ZEVENT_SHUTDOWN 0x1
76 typedef void zevent_cb_t(nvlist_t
*, nvlist_t
*);
78 typedef struct zevent_s
{
79 nvlist_t
*ev_nvl
; /* protected by the zevent_lock */
80 nvlist_t
*ev_detector
; /* " */
81 list_t ev_ze_list
; /* " */
82 list_node_t ev_node
; /* " */
83 zevent_cb_t
*ev_cb
; /* " */
87 typedef struct zfs_zevent
{
88 zevent_t
*ze_zevent
; /* protected by the zevent_lock */
89 list_node_t ze_node
; /* " */
90 uint64_t ze_dropped
; /* " */
93 extern void fm_init(void);
94 extern void fm_fini(void);
95 extern void fm_nvprint(nvlist_t
*);
96 extern void zfs_zevent_post_cb(nvlist_t
*nvl
, nvlist_t
*detector
);
97 extern int zfs_zevent_post(nvlist_t
*, nvlist_t
*, zevent_cb_t
*);
98 extern void zfs_zevent_drain_all(int *);
99 extern int zfs_zevent_fd_hold(int, minor_t
*, zfs_zevent_t
**);
100 extern void zfs_zevent_fd_rele(int);
101 extern int zfs_zevent_next(zfs_zevent_t
*, nvlist_t
**, uint64_t *, uint64_t *);
102 extern int zfs_zevent_wait(zfs_zevent_t
*);
103 extern int zfs_zevent_seek(zfs_zevent_t
*, uint64_t);
104 extern void zfs_zevent_init(zfs_zevent_t
**);
105 extern void zfs_zevent_destroy(zfs_zevent_t
*);
107 extern void zfs_zevent_track_duplicate(void);
108 extern void zfs_ereport_init(void);
109 extern void zfs_ereport_fini(void);
112 static inline void fm_init(void) { }
113 static inline void fm_fini(void) { }
121 #endif /* _SYS_FM_UTIL_H */