2025-01-04 11:04:27 +11:00
|
|
|
// SPDX-License-Identifier: CDDL-1.0
|
2008-11-20 12:01:55 -08:00
|
|
|
/*
|
|
|
|
|
* CDDL HEADER START
|
|
|
|
|
*
|
|
|
|
|
* The contents of this file are subject to the terms of the
|
|
|
|
|
* Common Development and Distribution License (the "License").
|
|
|
|
|
* You may not use this file except in compliance with the License.
|
|
|
|
|
*
|
|
|
|
|
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
|
2022-07-11 23:16:13 +02:00
|
|
|
* or https://opensource.org/licenses/CDDL-1.0.
|
2008-11-20 12:01:55 -08:00
|
|
|
* See the License for the specific language governing permissions
|
|
|
|
|
* and limitations under the License.
|
|
|
|
|
*
|
|
|
|
|
* When distributing Covered Code, include this CDDL HEADER in each
|
|
|
|
|
* file and include the License file at usr/src/OPENSOLARIS.LICENSE.
|
|
|
|
|
* If applicable, add the following below this CDDL HEADER, with the
|
|
|
|
|
* fields enclosed by brackets "[]" replaced with your own identifying
|
|
|
|
|
* information: Portions Copyright [yyyy] [name of copyright owner]
|
|
|
|
|
*
|
|
|
|
|
* CDDL HEADER END
|
|
|
|
|
*/
|
|
|
|
|
/*
|
2010-05-28 13:45:14 -07:00
|
|
|
* Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.
|
2018-02-12 12:56:06 -08:00
|
|
|
* Copyright (c) 2011, 2018 by Delphix. All rights reserved.
|
2018-09-05 19:33:36 -06:00
|
|
|
* Copyright (c) 2017, Intel Corporation.
|
2008-11-20 12:01:55 -08:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#ifndef _SYS_METASLAB_H
|
|
|
|
|
#define _SYS_METASLAB_H
|
|
|
|
|
|
|
|
|
|
#include <sys/spa.h>
|
|
|
|
|
#include <sys/space_map.h>
|
|
|
|
|
#include <sys/txg.h>
|
|
|
|
|
#include <sys/zio.h>
|
|
|
|
|
#include <sys/avl.h>
|
|
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
|
extern "C" {
|
|
|
|
|
#endif
|
|
|
|
|
|
2017-01-12 12:52:56 -07:00
|
|
|
|
2013-10-01 13:25:53 -08:00
|
|
|
typedef struct metaslab_ops {
|
2023-09-01 19:00:30 -06:00
|
|
|
const char *msop_name;
|
2025-05-02 15:32:18 -07:00
|
|
|
uint64_t (*msop_alloc)(metaslab_t *, uint64_t, uint64_t, uint64_t *);
|
2013-10-01 13:25:53 -08:00
|
|
|
} metaslab_ops_t;
|
2009-07-02 15:44:48 -07:00
|
|
|
|
2017-01-12 12:52:56 -07:00
|
|
|
|
2022-01-15 00:37:55 +01:00
|
|
|
extern const metaslab_ops_t zfs_metaslab_ops;
|
2013-10-01 13:25:53 -08:00
|
|
|
|
2014-10-06 16:32:36 +02:00
|
|
|
int metaslab_init(metaslab_group_t *, uint64_t, uint64_t, uint64_t,
|
|
|
|
|
metaslab_t **);
|
2014-07-19 12:19:24 -08:00
|
|
|
void metaslab_fini(metaslab_t *);
|
2013-10-01 13:25:53 -08:00
|
|
|
|
2022-04-26 13:44:21 -04:00
|
|
|
void metaslab_set_unflushed_dirty(metaslab_t *, boolean_t);
|
2019-07-16 10:11:49 -07:00
|
|
|
void metaslab_set_unflushed_txg(metaslab_t *, uint64_t, dmu_tx_t *);
|
|
|
|
|
void metaslab_set_estimated_condensed_size(metaslab_t *, uint64_t, dmu_tx_t *);
|
2022-04-26 13:44:21 -04:00
|
|
|
boolean_t metaslab_unflushed_dirty(metaslab_t *);
|
2019-07-16 10:11:49 -07:00
|
|
|
uint64_t metaslab_unflushed_txg(metaslab_t *);
|
|
|
|
|
uint64_t metaslab_estimated_condensed_size(metaslab_t *);
|
|
|
|
|
int metaslab_sort_by_flushed(const void *, const void *);
|
2022-04-26 13:44:21 -04:00
|
|
|
void metaslab_unflushed_bump(metaslab_t *, dmu_tx_t *, boolean_t);
|
2019-07-16 10:11:49 -07:00
|
|
|
uint64_t metaslab_unflushed_changes_memused(metaslab_t *);
|
|
|
|
|
|
2014-07-19 12:19:24 -08:00
|
|
|
int metaslab_load(metaslab_t *);
|
|
|
|
|
void metaslab_unload(metaslab_t *);
|
2019-07-16 10:11:49 -07:00
|
|
|
boolean_t metaslab_flush(metaslab_t *, dmu_tx_t *);
|
2019-02-12 10:38:11 -08:00
|
|
|
|
|
|
|
|
uint64_t metaslab_allocated_space(metaslab_t *);
|
2013-10-01 13:25:53 -08:00
|
|
|
|
2014-07-19 12:19:24 -08:00
|
|
|
void metaslab_sync(metaslab_t *, uint64_t);
|
|
|
|
|
void metaslab_sync_done(metaslab_t *, uint64_t);
|
|
|
|
|
void metaslab_sync_reassess(metaslab_group_t *);
|
2019-08-05 14:34:27 -07:00
|
|
|
uint64_t metaslab_largest_allocatable(metaslab_t *);
|
2008-11-20 12:01:55 -08:00
|
|
|
|
2018-09-05 19:33:36 -06:00
|
|
|
/*
|
|
|
|
|
* metaslab alloc flags
|
|
|
|
|
*/
|
2025-03-24 12:25:01 -04:00
|
|
|
#define METASLAB_ZIL 0x1
|
2016-10-13 18:59:18 -06:00
|
|
|
#define METASLAB_GANG_HEADER 0x2
|
|
|
|
|
#define METASLAB_GANG_CHILD 0x4
|
|
|
|
|
#define METASLAB_ASYNC_ALLOC 0x8
|
2008-12-03 12:09:06 -08:00
|
|
|
|
2025-03-24 12:25:01 -04:00
|
|
|
int metaslab_alloc(spa_t *, metaslab_class_t *, uint64_t, blkptr_t *, int,
|
2025-05-13 03:52:46 +10:00
|
|
|
uint64_t, const blkptr_t *, int, zio_alloc_list_t *, int, const void *);
|
2025-05-02 15:32:18 -07:00
|
|
|
int metaslab_alloc_range(spa_t *, metaslab_class_t *, uint64_t, uint64_t,
|
2025-05-13 03:52:46 +10:00
|
|
|
blkptr_t *, int, uint64_t, const blkptr_t *, int, zio_alloc_list_t *,
|
2025-05-02 15:32:18 -07:00
|
|
|
int, const void *, uint64_t *);
|
2016-09-22 09:30:13 -07:00
|
|
|
int metaslab_alloc_dva(spa_t *, metaslab_class_t *, uint64_t,
|
2025-05-13 03:52:46 +10:00
|
|
|
dva_t *, int, const dva_t *, uint64_t, int, zio_alloc_list_t *, int);
|
2014-07-19 12:19:24 -08:00
|
|
|
void metaslab_free(spa_t *, const blkptr_t *, uint64_t, boolean_t);
|
2016-12-16 14:11:29 -08:00
|
|
|
void metaslab_free_concrete(vdev_t *, uint64_t, uint64_t, boolean_t);
|
|
|
|
|
void metaslab_free_dva(spa_t *, const dva_t *, boolean_t);
|
2016-09-22 09:30:13 -07:00
|
|
|
void metaslab_free_impl_cb(uint64_t, vdev_t *, uint64_t, uint64_t, void *);
|
|
|
|
|
void metaslab_unalloc_dva(spa_t *, const dva_t *, uint64_t);
|
2014-07-19 12:19:24 -08:00
|
|
|
int metaslab_claim(spa_t *, const blkptr_t *, uint64_t);
|
2016-09-22 09:30:13 -07:00
|
|
|
int metaslab_claim_impl(vdev_t *, uint64_t, uint64_t, uint64_t);
|
2014-07-19 12:19:24 -08:00
|
|
|
void metaslab_check_free(spa_t *, const blkptr_t *);
|
2008-11-20 12:01:55 -08:00
|
|
|
|
2019-10-09 10:36:03 -07:00
|
|
|
void metaslab_stat_init(void);
|
|
|
|
|
void metaslab_stat_fini(void);
|
2025-05-02 15:32:18 -07:00
|
|
|
void metaslab_trace_move(zio_alloc_list_t *, zio_alloc_list_t *);
|
2017-01-12 12:52:56 -07:00
|
|
|
void metaslab_trace_init(zio_alloc_list_t *);
|
|
|
|
|
void metaslab_trace_fini(zio_alloc_list_t *);
|
|
|
|
|
|
2025-06-03 11:12:59 -04:00
|
|
|
metaslab_class_t *metaslab_class_create(spa_t *, const char *,
|
|
|
|
|
const metaslab_ops_t *, boolean_t);
|
2014-07-19 12:19:24 -08:00
|
|
|
void metaslab_class_destroy(metaslab_class_t *);
|
2025-03-24 12:25:01 -04:00
|
|
|
void metaslab_class_validate(metaslab_class_t *);
|
|
|
|
|
void metaslab_class_balance(metaslab_class_t *mc, boolean_t onsync);
|
2014-07-19 12:19:24 -08:00
|
|
|
void metaslab_class_histogram_verify(metaslab_class_t *);
|
|
|
|
|
uint64_t metaslab_class_fragmentation(metaslab_class_t *);
|
|
|
|
|
uint64_t metaslab_class_expandable_space(metaslab_class_t *);
|
2025-07-05 13:22:22 +10:00
|
|
|
boolean_t metaslab_class_throttle_reserve(metaslab_class_t *, int, int,
|
|
|
|
|
uint64_t, boolean_t, boolean_t *);
|
|
|
|
|
boolean_t metaslab_class_throttle_unreserve(metaslab_class_t *, int, int,
|
|
|
|
|
uint64_t);
|
2019-08-16 08:08:21 -07:00
|
|
|
void metaslab_class_evict_old(metaslab_class_t *, uint64_t);
|
2025-06-03 11:12:59 -04:00
|
|
|
const char *metaslab_class_get_name(metaslab_class_t *);
|
2014-07-19 12:19:24 -08:00
|
|
|
uint64_t metaslab_class_get_alloc(metaslab_class_t *);
|
2026-02-19 13:36:35 -05:00
|
|
|
uint64_t metaslab_class_get_dalloc(metaslab_class_t *);
|
2014-07-19 12:19:24 -08:00
|
|
|
uint64_t metaslab_class_get_space(metaslab_class_t *);
|
|
|
|
|
uint64_t metaslab_class_get_dspace(metaslab_class_t *);
|
|
|
|
|
uint64_t metaslab_class_get_deferred(metaslab_class_t *);
|
2008-11-20 12:01:55 -08:00
|
|
|
|
2026-02-19 13:36:35 -05:00
|
|
|
void metaslab_space_update(metaslab_group_t *, int64_t, int64_t, int64_t);
|
2019-07-16 10:11:49 -07:00
|
|
|
|
2025-03-28 16:11:10 -04:00
|
|
|
metaslab_group_t *metaslab_group_create(metaslab_class_t *, vdev_t *);
|
2014-07-19 12:19:24 -08:00
|
|
|
void metaslab_group_destroy(metaslab_group_t *);
|
|
|
|
|
void metaslab_group_activate(metaslab_group_t *);
|
|
|
|
|
void metaslab_group_passivate(metaslab_group_t *);
|
2016-10-13 18:59:18 -06:00
|
|
|
boolean_t metaslab_group_initialized(metaslab_group_t *);
|
2014-07-19 12:19:24 -08:00
|
|
|
uint64_t metaslab_group_get_space(metaslab_group_t *);
|
|
|
|
|
void metaslab_group_histogram_verify(metaslab_group_t *);
|
|
|
|
|
uint64_t metaslab_group_fragmentation(metaslab_group_t *);
|
|
|
|
|
void metaslab_group_histogram_remove(metaslab_group_t *, metaslab_t *);
|
2025-05-02 15:32:18 -07:00
|
|
|
void metaslab_group_alloc_increment_all(spa_t *, blkptr_t *, int, int,
|
|
|
|
|
uint64_t, const void *);
|
2025-03-24 12:25:01 -04:00
|
|
|
void metaslab_group_alloc_decrement(spa_t *, uint64_t, int, int, uint64_t,
|
|
|
|
|
const void *);
|
2019-02-20 09:59:57 -08:00
|
|
|
void metaslab_recalculate_weight_and_sort(metaslab_t *);
|
2019-03-29 09:13:20 -07:00
|
|
|
void metaslab_disable(metaslab_t *);
|
2019-08-16 08:08:21 -07:00
|
|
|
void metaslab_enable(metaslab_t *, boolean_t, boolean_t);
|
|
|
|
|
void metaslab_set_selected_txg(metaslab_t *, uint64_t);
|
2008-11-20 12:01:55 -08:00
|
|
|
|
2019-07-16 10:11:49 -07:00
|
|
|
extern int metaslab_debug_load;
|
|
|
|
|
|
2025-01-30 21:26:49 +11:00
|
|
|
zfs_range_seg_type_t metaslab_calculate_range_tree_type(vdev_t *vdev,
|
2020-07-14 17:51:05 -07:00
|
|
|
metaslab_t *msp, uint64_t *start, uint64_t *shift);
|
|
|
|
|
|
2008-11-20 12:01:55 -08:00
|
|
|
#ifdef __cplusplus
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#endif /* _SYS_METASLAB_H */
|