mirror of https://github.com/F-Stack/f-stack.git
187 lines
6.5 KiB
C
187 lines
6.5 KiB
C
/*-
|
|
* SPDX-License-Identifier: BSD-2-Clause-FreeBSD
|
|
*
|
|
* Copyright (c) 2015 Spectra Logic Corporation
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions
|
|
* are met:
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions, and the following disclaimer,
|
|
* without modification.
|
|
* 2. Redistributions in binary form must reproduce at minimum a disclaimer
|
|
* substantially similar to the "NO WARRANTY" disclaimer below
|
|
* ("Disclaimer") and any redistribution must be conditioned upon
|
|
* including a substantially similar Disclaimer requirement for further
|
|
* binary redistribution.
|
|
*
|
|
* NO WARRANTY
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
|
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
* HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
|
|
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
|
|
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
* POSSIBILITY OF SUCH DAMAGES.
|
|
*
|
|
* Authors: Ken Merry (Spectra Logic Corporation)
|
|
*
|
|
* $FreeBSD$
|
|
*/
|
|
|
|
#ifndef _SYS_DISK_ZONE_H_
|
|
#define _SYS_DISK_ZONE_H_
|
|
|
|
/*
|
|
* Interface for Zone-based disks. This allows managing devices that
|
|
* conform to the SCSI Zoned Block Commands (ZBC) and ATA Zoned ATA Command
|
|
* Set (ZAC) specifications. Devices using these command sets are
|
|
* currently (October 2015) hard drives using Shingled Magnetic Recording
|
|
* (SMR).
|
|
*/
|
|
|
|
/*
|
|
* There are currently three types of zoned devices:
|
|
*
|
|
* Drive Managed:
|
|
* Drive Managed drives look and act just like a standard random access
|
|
* block device, but underneath, the drive reads and writes the bulk of
|
|
* its capacity using SMR zones. Sequential writes will yield better
|
|
* performance, but writing sequentially is not required.
|
|
*
|
|
* Host Aware:
|
|
* Host Aware drives expose the underlying zone layout via SCSI or ATA
|
|
* commands and allow the host to manage the zone conditions. The host
|
|
* is not required to manage the zones on the drive, though. Sequential
|
|
* writes will yield better performance in Sequential Write Preferred
|
|
* zones, but the host can write randomly in those zones.
|
|
*
|
|
* Host Managed:
|
|
* Host Managed drives expose the underlying zone layout via SCSI or ATA
|
|
* commands. The host is required to access the zones according to the
|
|
* rules described by the zone layout. Any commands that violate the
|
|
* rules will be returned with an error.
|
|
*/
|
|
struct disk_zone_disk_params {
|
|
uint32_t zone_mode;
|
|
#define DISK_ZONE_MODE_NONE 0x00
|
|
#define DISK_ZONE_MODE_HOST_AWARE 0x01
|
|
#define DISK_ZONE_MODE_DRIVE_MANAGED 0x02
|
|
#define DISK_ZONE_MODE_HOST_MANAGED 0x04
|
|
uint64_t flags;
|
|
#define DISK_ZONE_DISK_URSWRZ 0x001
|
|
#define DISK_ZONE_OPT_SEQ_SET 0x002
|
|
#define DISK_ZONE_OPT_NONSEQ_SET 0x004
|
|
#define DISK_ZONE_MAX_SEQ_SET 0x008
|
|
#define DISK_ZONE_RZ_SUP 0x010
|
|
#define DISK_ZONE_OPEN_SUP 0x020
|
|
#define DISK_ZONE_CLOSE_SUP 0x040
|
|
#define DISK_ZONE_FINISH_SUP 0x080
|
|
#define DISK_ZONE_RWP_SUP 0x100
|
|
#define DISK_ZONE_CMD_SUP_MASK 0x1f0
|
|
uint64_t optimal_seq_zones;
|
|
uint64_t optimal_nonseq_zones;
|
|
uint64_t max_seq_zones;
|
|
};
|
|
|
|
/*
|
|
* Used for reset write pointer, open, close and finish.
|
|
*/
|
|
struct disk_zone_rwp {
|
|
uint64_t id;
|
|
uint8_t flags;
|
|
#define DISK_ZONE_RWP_FLAG_NONE 0x00
|
|
#define DISK_ZONE_RWP_FLAG_ALL 0x01
|
|
};
|
|
|
|
/*
|
|
* Report Zones header. All of these values are passed out.
|
|
*/
|
|
struct disk_zone_rep_header {
|
|
uint8_t same;
|
|
#define DISK_ZONE_SAME_ALL_DIFFERENT 0x0 /* Lengths and types vary */
|
|
#define DISK_ZONE_SAME_ALL_SAME 0x1 /* Lengths and types the same */
|
|
#define DISK_ZONE_SAME_LAST_DIFFERENT 0x2 /* Types same, last len varies */
|
|
#define DISK_ZONE_SAME_TYPES_DIFFERENT 0x3 /* Types vary, length the same */
|
|
uint64_t maximum_lba;
|
|
/*
|
|
* XXX KDM padding space may not be a good idea inside the bio.
|
|
*/
|
|
uint8_t reserved[64];
|
|
};
|
|
|
|
/*
|
|
* Report Zones entry. Note that the zone types, conditions, and flags
|
|
* are mapped directly from the SCSI/ATA flag values. Any additional
|
|
* SCSI/ATA zone types or conditions or flags that are defined in the
|
|
* future could result in additional values that are not yet defined here.
|
|
*/
|
|
struct disk_zone_rep_entry {
|
|
uint8_t zone_type;
|
|
#define DISK_ZONE_TYPE_CONVENTIONAL 0x01
|
|
#define DISK_ZONE_TYPE_SEQ_REQUIRED 0x02 /* Host Managed */
|
|
#define DISK_ZONE_TYPE_SEQ_PREFERRED 0x03 /* Host Aware */
|
|
uint8_t zone_condition;
|
|
#define DISK_ZONE_COND_NOT_WP 0x00
|
|
#define DISK_ZONE_COND_EMPTY 0x01
|
|
#define DISK_ZONE_COND_IMPLICIT_OPEN 0x02
|
|
#define DISK_ZONE_COND_EXPLICIT_OPEN 0x03
|
|
#define DISK_ZONE_COND_CLOSED 0x04
|
|
#define DISK_ZONE_COND_READONLY 0x0D
|
|
#define DISK_ZONE_COND_FULL 0x0E
|
|
#define DISK_ZONE_COND_OFFLINE 0x0F
|
|
uint8_t zone_flags;
|
|
#define DISK_ZONE_FLAG_RESET 0x01 /* Zone needs RWP */
|
|
#define DISK_ZONE_FLAG_NON_SEQ 0x02 /* Zone accssessed nonseq */
|
|
uint64_t zone_length;
|
|
uint64_t zone_start_lba;
|
|
uint64_t write_pointer_lba;
|
|
/* XXX KDM padding space may not be a good idea inside the bio */
|
|
uint8_t reserved[32];
|
|
};
|
|
|
|
struct disk_zone_report {
|
|
uint64_t starting_id; /* Passed In */
|
|
uint8_t rep_options; /* Passed In */
|
|
#define DISK_ZONE_REP_ALL 0x00
|
|
#define DISK_ZONE_REP_EMPTY 0x01
|
|
#define DISK_ZONE_REP_IMP_OPEN 0x02
|
|
#define DISK_ZONE_REP_EXP_OPEN 0x03
|
|
#define DISK_ZONE_REP_CLOSED 0x04
|
|
#define DISK_ZONE_REP_FULL 0x05
|
|
#define DISK_ZONE_REP_READONLY 0x06
|
|
#define DISK_ZONE_REP_OFFLINE 0x07
|
|
#define DISK_ZONE_REP_RWP 0x10
|
|
#define DISK_ZONE_REP_NON_SEQ 0x11
|
|
#define DISK_ZONE_REP_NON_WP 0x3F
|
|
struct disk_zone_rep_header header;
|
|
uint32_t entries_allocated; /* Passed In */
|
|
uint32_t entries_filled; /* Passed Out */
|
|
uint32_t entries_available; /* Passed Out */
|
|
struct disk_zone_rep_entry *entries;
|
|
};
|
|
|
|
union disk_zone_params {
|
|
struct disk_zone_disk_params disk_params;
|
|
struct disk_zone_rwp rwp;
|
|
struct disk_zone_report report;
|
|
};
|
|
|
|
struct disk_zone_args {
|
|
uint8_t zone_cmd;
|
|
#define DISK_ZONE_OPEN 0x00
|
|
#define DISK_ZONE_CLOSE 0x01
|
|
#define DISK_ZONE_FINISH 0x02
|
|
#define DISK_ZONE_REPORT_ZONES 0x03
|
|
#define DISK_ZONE_RWP 0x04
|
|
#define DISK_ZONE_GET_PARAMS 0x05
|
|
union disk_zone_params zone_params;
|
|
};
|
|
|
|
#endif /* _SYS_DISK_ZONE_H_ */
|