1fa9e4066Sahrens /* 2fa9e4066Sahrens * CDDL HEADER START 3fa9e4066Sahrens * 4fa9e4066Sahrens * The contents of this file are subject to the terms of the 5ea8dc4b6Seschrock * Common Development and Distribution License (the "License"). 6ea8dc4b6Seschrock * 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 */ 21fa9e4066Sahrens /* 223f9d6ad7SLin Ling * Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved. 23cd1c8b85SMatthew Ahrens * Copyright (c) 2012 by Delphix. All rights reserved. 24*aad02571SSaso Kiselkov * Copyright (c) 2013 by Saso Kiselkov. All rights reserved. 25fa9e4066Sahrens */ 26fa9e4066Sahrens 27fa9e4066Sahrens #ifndef _SYS_ARC_H 28fa9e4066Sahrens #define _SYS_ARC_H 29fa9e4066Sahrens 30fa9e4066Sahrens #include <sys/zfs_context.h> 31fa9e4066Sahrens 32fa9e4066Sahrens #ifdef __cplusplus 33fa9e4066Sahrens extern "C" { 34fa9e4066Sahrens #endif 35fa9e4066Sahrens 36fa9e4066Sahrens #include <sys/zio.h> 37e45ce728Sahrens #include <sys/dmu.h> 38fa94a07fSbrendan #include <sys/spa.h> 39fa9e4066Sahrens 40fa9e4066Sahrens typedef struct arc_buf_hdr arc_buf_hdr_t; 41fa9e4066Sahrens typedef struct arc_buf arc_buf_t; 42fa9e4066Sahrens typedef void arc_done_func_t(zio_t *zio, arc_buf_t *buf, void *private); 43ea8dc4b6Seschrock typedef int arc_evict_func_t(void *private); 44fa9e4066Sahrens 45fa9e4066Sahrens /* generic arc_done_func_t's which you can use */ 46fa9e4066Sahrens arc_done_func_t arc_bcopy_func; 47fa9e4066Sahrens arc_done_func_t arc_getbuf_func; 48fa9e4066Sahrens 49fa9e4066Sahrens struct arc_buf { 50fa9e4066Sahrens arc_buf_hdr_t *b_hdr; 51fa9e4066Sahrens arc_buf_t *b_next; 523f9d6ad7SLin Ling kmutex_t b_evict_lock; 53fa9e4066Sahrens void *b_data; 54ea8dc4b6Seschrock arc_evict_func_t *b_efunc; 55ea8dc4b6Seschrock void *b_private; 56fa9e4066Sahrens }; 57fa9e4066Sahrens 58ad23a2dbSjohansen typedef enum arc_buf_contents { 59ad23a2dbSjohansen ARC_BUFC_DATA, /* buffer contains data */ 600e8c6158Smaybee ARC_BUFC_METADATA, /* buffer contains metadata */ 610e8c6158Smaybee ARC_BUFC_NUMTYPES 62ad23a2dbSjohansen } arc_buf_contents_t; 63fa9e4066Sahrens /* 64fa9e4066Sahrens * These are the flags we pass into calls to the arc 65fa9e4066Sahrens */ 66fa9e4066Sahrens #define ARC_WAIT (1 << 1) /* perform I/O synchronously */ 67fa9e4066Sahrens #define ARC_NOWAIT (1 << 2) /* perform I/O asynchronously */ 68fa9e4066Sahrens #define ARC_PREFETCH (1 << 3) /* I/O is a prefetch */ 6913506d1eSmaybee #define ARC_CACHED (1 << 4) /* I/O was already in cache */ 703baa08fcSek #define ARC_L2CACHE (1 << 5) /* cache in L2ARC */ 71*aad02571SSaso Kiselkov #define ARC_L2COMPRESS (1 << 6) /* compress in L2ARC */ 72fa9e4066Sahrens 735a98e54bSBrendan Gregg - Sun Microsystems /* 745a98e54bSBrendan Gregg - Sun Microsystems * The following breakdows of arc_size exist for kstat only. 755a98e54bSBrendan Gregg - Sun Microsystems */ 765a98e54bSBrendan Gregg - Sun Microsystems typedef enum arc_space_type { 775a98e54bSBrendan Gregg - Sun Microsystems ARC_SPACE_DATA, 785a98e54bSBrendan Gregg - Sun Microsystems ARC_SPACE_HDRS, 795a98e54bSBrendan Gregg - Sun Microsystems ARC_SPACE_L2HDRS, 805a98e54bSBrendan Gregg - Sun Microsystems ARC_SPACE_OTHER, 815a98e54bSBrendan Gregg - Sun Microsystems ARC_SPACE_NUMTYPES 825a98e54bSBrendan Gregg - Sun Microsystems } arc_space_type_t; 835a98e54bSBrendan Gregg - Sun Microsystems 845a98e54bSBrendan Gregg - Sun Microsystems void arc_space_consume(uint64_t space, arc_space_type_t type); 855a98e54bSBrendan Gregg - Sun Microsystems void arc_space_return(uint64_t space, arc_space_type_t type); 860e8c6158Smaybee void *arc_data_buf_alloc(uint64_t space); 870e8c6158Smaybee void arc_data_buf_free(void *buf, uint64_t space); 88ad23a2dbSjohansen arc_buf_t *arc_buf_alloc(spa_t *spa, int size, void *tag, 89ad23a2dbSjohansen arc_buf_contents_t type); 902fdbea25SAleksandr Guzovskiy arc_buf_t *arc_loan_buf(spa_t *spa, int size); 912fdbea25SAleksandr Guzovskiy void arc_return_buf(arc_buf_t *buf, void *tag); 92c242f9a0Schunli zhang - Sun Microsystems - Irvine United States void arc_loan_inuse_buf(arc_buf_t *buf, void *tag); 93ea8dc4b6Seschrock void arc_buf_add_ref(arc_buf_t *buf, void *tag); 943b2aab18SMatthew Ahrens boolean_t arc_buf_remove_ref(arc_buf_t *buf, void *tag); 95fa9e4066Sahrens int arc_buf_size(arc_buf_t *buf); 96fa9e4066Sahrens void arc_release(arc_buf_t *buf, void *tag); 97fa9e4066Sahrens int arc_released(arc_buf_t *buf); 98ea8dc4b6Seschrock int arc_has_callback(arc_buf_t *buf); 996b4acc8bSahrens void arc_buf_freeze(arc_buf_t *buf); 1006b4acc8bSahrens void arc_buf_thaw(arc_buf_t *buf); 1019253d63dSGeorge Wilson boolean_t arc_buf_eviction_needed(arc_buf_t *buf); 102ea8dc4b6Seschrock #ifdef ZFS_DEBUG 103ea8dc4b6Seschrock int arc_referenced(arc_buf_t *buf); 104ea8dc4b6Seschrock #endif 105fa9e4066Sahrens 1061b912ec7SGeorge Wilson int arc_read(zio_t *pio, spa_t *spa, const blkptr_t *bp, 107088f3894Sahrens arc_done_func_t *done, void *private, int priority, int flags, 108088f3894Sahrens uint32_t *arc_flags, const zbookmark_t *zb); 109b24ab676SJeff Bonwick zio_t *arc_write(zio_t *pio, spa_t *spa, uint64_t txg, 110*aad02571SSaso Kiselkov blkptr_t *bp, arc_buf_t *buf, boolean_t l2arc, boolean_t l2arc_compress, 111*aad02571SSaso Kiselkov const zio_prop_t *zp, arc_done_func_t *ready, arc_done_func_t *done, 112*aad02571SSaso Kiselkov void *private, int priority, int zio_flags, const zbookmark_t *zb); 113fa9e4066Sahrens 114ea8dc4b6Seschrock void arc_set_callback(arc_buf_t *buf, arc_evict_func_t *func, void *private); 115ea8dc4b6Seschrock int arc_buf_evict(arc_buf_t *buf); 116ea8dc4b6Seschrock 117874395d5Smaybee void arc_flush(spa_t *spa); 1181ab7f2deSmaybee void arc_tempreserve_clear(uint64_t reserve); 1191ab7f2deSmaybee int arc_tempreserve_space(uint64_t reserve, uint64_t txg); 120fa9e4066Sahrens 121fa9e4066Sahrens void arc_init(void); 122fa9e4066Sahrens void arc_fini(void); 123fa9e4066Sahrens 124fa94a07fSbrendan /* 125fa94a07fSbrendan * Level 2 ARC 126fa94a07fSbrendan */ 127fa94a07fSbrendan 128573ca77eSGeorge Wilson void l2arc_add_vdev(spa_t *spa, vdev_t *vd); 129fa94a07fSbrendan void l2arc_remove_vdev(vdev_t *vd); 130c5904d13Seschrock boolean_t l2arc_vdev_present(vdev_t *vd); 131fa94a07fSbrendan void l2arc_init(void); 132fa94a07fSbrendan void l2arc_fini(void); 133e14bb325SJeff Bonwick void l2arc_start(void); 134e14bb325SJeff Bonwick void l2arc_stop(void); 135fa94a07fSbrendan 136cd1c8b85SMatthew Ahrens #ifndef _KERNEL 137cd1c8b85SMatthew Ahrens extern boolean_t arc_watch; 138cd1c8b85SMatthew Ahrens extern int arc_procfd; 139cd1c8b85SMatthew Ahrens #endif 140cd1c8b85SMatthew Ahrens 141fa9e4066Sahrens #ifdef __cplusplus 142fa9e4066Sahrens } 143fa9e4066Sahrens #endif 144fa9e4066Sahrens 145fa9e4066Sahrens #endif /* _SYS_ARC_H */ 146