xref: /illumos-gate/usr/src/uts/common/fs/zfs/sys/arc.h (revision 9253d63df408bb48584e0b1abfcc24ef2472382e)
1 /*
2  * CDDL HEADER START
3  *
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.
7  *
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.
12  *
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]
18  *
19  * CDDL HEADER END
20  */
21 /*
22  * Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.
23  * Copyright (c) 2012 by Delphix. All rights reserved.
24  */
25 
26 #ifndef	_SYS_ARC_H
27 #define	_SYS_ARC_H
28 
29 #include <sys/zfs_context.h>
30 
31 #ifdef	__cplusplus
32 extern "C" {
33 #endif
34 
35 #include <sys/zio.h>
36 #include <sys/dmu.h>
37 #include <sys/spa.h>
38 
39 typedef struct arc_buf_hdr arc_buf_hdr_t;
40 typedef struct arc_buf arc_buf_t;
41 typedef void arc_done_func_t(zio_t *zio, arc_buf_t *buf, void *private);
42 typedef int arc_evict_func_t(void *private);
43 
44 /* generic arc_done_func_t's which you can use */
45 arc_done_func_t arc_bcopy_func;
46 arc_done_func_t arc_getbuf_func;
47 
48 struct arc_buf {
49 	arc_buf_hdr_t		*b_hdr;
50 	arc_buf_t		*b_next;
51 	kmutex_t		b_evict_lock;
52 	krwlock_t		b_data_lock;
53 	void			*b_data;
54 	arc_evict_func_t	*b_efunc;
55 	void			*b_private;
56 };
57 
58 typedef enum arc_buf_contents {
59 	ARC_BUFC_DATA,				/* buffer contains data */
60 	ARC_BUFC_METADATA,			/* buffer contains metadata */
61 	ARC_BUFC_NUMTYPES
62 } arc_buf_contents_t;
63 /*
64  * These are the flags we pass into calls to the arc
65  */
66 #define	ARC_WAIT	(1 << 1)	/* perform I/O synchronously */
67 #define	ARC_NOWAIT	(1 << 2)	/* perform I/O asynchronously */
68 #define	ARC_PREFETCH	(1 << 3)	/* I/O is a prefetch */
69 #define	ARC_CACHED	(1 << 4)	/* I/O was already in cache */
70 #define	ARC_L2CACHE	(1 << 5)	/* cache in L2ARC */
71 
72 /*
73  * The following breakdows of arc_size exist for kstat only.
74  */
75 typedef enum arc_space_type {
76 	ARC_SPACE_DATA,
77 	ARC_SPACE_HDRS,
78 	ARC_SPACE_L2HDRS,
79 	ARC_SPACE_OTHER,
80 	ARC_SPACE_NUMTYPES
81 } arc_space_type_t;
82 
83 void arc_space_consume(uint64_t space, arc_space_type_t type);
84 void arc_space_return(uint64_t space, arc_space_type_t type);
85 void *arc_data_buf_alloc(uint64_t space);
86 void arc_data_buf_free(void *buf, uint64_t space);
87 arc_buf_t *arc_buf_alloc(spa_t *spa, int size, void *tag,
88     arc_buf_contents_t type);
89 arc_buf_t *arc_loan_buf(spa_t *spa, int size);
90 void arc_return_buf(arc_buf_t *buf, void *tag);
91 void arc_loan_inuse_buf(arc_buf_t *buf, void *tag);
92 void arc_buf_add_ref(arc_buf_t *buf, void *tag);
93 int arc_buf_remove_ref(arc_buf_t *buf, void *tag);
94 int arc_buf_size(arc_buf_t *buf);
95 void arc_release(arc_buf_t *buf, void *tag);
96 int arc_release_bp(arc_buf_t *buf, void *tag, blkptr_t *bp, spa_t *spa,
97     zbookmark_t *zb);
98 int arc_released(arc_buf_t *buf);
99 int arc_has_callback(arc_buf_t *buf);
100 void arc_buf_freeze(arc_buf_t *buf);
101 void arc_buf_thaw(arc_buf_t *buf);
102 boolean_t arc_buf_eviction_needed(arc_buf_t *buf);
103 #ifdef ZFS_DEBUG
104 int arc_referenced(arc_buf_t *buf);
105 #endif
106 
107 int arc_read(zio_t *pio, spa_t *spa, const blkptr_t *bp, arc_buf_t *pbuf,
108     arc_done_func_t *done, void *private, int priority, int zio_flags,
109     uint32_t *arc_flags, const zbookmark_t *zb);
110 int arc_read_nolock(zio_t *pio, spa_t *spa, const blkptr_t *bp,
111     arc_done_func_t *done, void *private, int priority, int flags,
112     uint32_t *arc_flags, const zbookmark_t *zb);
113 zio_t *arc_write(zio_t *pio, spa_t *spa, uint64_t txg,
114     blkptr_t *bp, arc_buf_t *buf, boolean_t l2arc, const zio_prop_t *zp,
115     arc_done_func_t *ready, arc_done_func_t *done, void *private,
116     int priority, int zio_flags, const zbookmark_t *zb);
117 
118 void arc_set_callback(arc_buf_t *buf, arc_evict_func_t *func, void *private);
119 int arc_buf_evict(arc_buf_t *buf);
120 
121 void arc_flush(spa_t *spa);
122 void arc_tempreserve_clear(uint64_t reserve);
123 int arc_tempreserve_space(uint64_t reserve, uint64_t txg);
124 
125 void arc_init(void);
126 void arc_fini(void);
127 
128 /*
129  * Level 2 ARC
130  */
131 
132 void l2arc_add_vdev(spa_t *spa, vdev_t *vd);
133 void l2arc_remove_vdev(vdev_t *vd);
134 boolean_t l2arc_vdev_present(vdev_t *vd);
135 void l2arc_init(void);
136 void l2arc_fini(void);
137 void l2arc_start(void);
138 void l2arc_stop(void);
139 
140 #ifndef _KERNEL
141 extern boolean_t arc_watch;
142 extern int arc_procfd;
143 #endif
144 
145 #ifdef	__cplusplus
146 }
147 #endif
148 
149 #endif /* _SYS_ARC_H */
150