master
1/*-
2 * SPDX-License-Identifier: BSD-2-Clause
3 *
4 * Copyright (c) 2015 Spectra Logic Corporation
5 * All rights reserved.
6 *
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
9 * are met:
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions, and the following disclaimer,
12 * without modification.
13 * 2. Redistributions in binary form must reproduce at minimum a disclaimer
14 * substantially similar to the "NO WARRANTY" disclaimer below
15 * ("Disclaimer") and any redistribution must be conditioned upon
16 * including a substantially similar Disclaimer requirement for further
17 * binary redistribution.
18 *
19 * NO WARRANTY
20 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
23 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
24 * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
26 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
28 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
29 * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30 * POSSIBILITY OF SUCH DAMAGES.
31 *
32 * Authors: Ken Merry (Spectra Logic Corporation)
33 */
34
35#ifndef _SYS_DISK_ZONE_H_
36#define _SYS_DISK_ZONE_H_
37
38/*
39 * Interface for Zone-based disks. This allows managing devices that
40 * conform to the SCSI Zoned Block Commands (ZBC) and ATA Zoned ATA Command
41 * Set (ZAC) specifications. Devices using these command sets are
42 * currently (October 2015) hard drives using Shingled Magnetic Recording
43 * (SMR).
44 */
45
46/*
47 * There are currently three types of zoned devices:
48 *
49 * Drive Managed:
50 * Drive Managed drives look and act just like a standard random access
51 * block device, but underneath, the drive reads and writes the bulk of
52 * its capacity using SMR zones. Sequential writes will yield better
53 * performance, but writing sequentially is not required.
54 *
55 * Host Aware:
56 * Host Aware drives expose the underlying zone layout via SCSI or ATA
57 * commands and allow the host to manage the zone conditions. The host
58 * is not required to manage the zones on the drive, though. Sequential
59 * writes will yield better performance in Sequential Write Preferred
60 * zones, but the host can write randomly in those zones.
61 *
62 * Host Managed:
63 * Host Managed drives expose the underlying zone layout via SCSI or ATA
64 * commands. The host is required to access the zones according to the
65 * rules described by the zone layout. Any commands that violate the
66 * rules will be returned with an error.
67 */
68struct disk_zone_disk_params {
69 uint32_t zone_mode;
70#define DISK_ZONE_MODE_NONE 0x00
71#define DISK_ZONE_MODE_HOST_AWARE 0x01
72#define DISK_ZONE_MODE_DRIVE_MANAGED 0x02
73#define DISK_ZONE_MODE_HOST_MANAGED 0x04
74 uint64_t flags;
75#define DISK_ZONE_DISK_URSWRZ 0x001
76#define DISK_ZONE_OPT_SEQ_SET 0x002
77#define DISK_ZONE_OPT_NONSEQ_SET 0x004
78#define DISK_ZONE_MAX_SEQ_SET 0x008
79#define DISK_ZONE_RZ_SUP 0x010
80#define DISK_ZONE_OPEN_SUP 0x020
81#define DISK_ZONE_CLOSE_SUP 0x040
82#define DISK_ZONE_FINISH_SUP 0x080
83#define DISK_ZONE_RWP_SUP 0x100
84#define DISK_ZONE_CMD_SUP_MASK 0x1f0
85 uint64_t optimal_seq_zones;
86 uint64_t optimal_nonseq_zones;
87 uint64_t max_seq_zones;
88};
89
90/*
91 * Used for reset write pointer, open, close and finish.
92 */
93struct disk_zone_rwp {
94 uint64_t id;
95 uint8_t flags;
96#define DISK_ZONE_RWP_FLAG_NONE 0x00
97#define DISK_ZONE_RWP_FLAG_ALL 0x01
98};
99
100/*
101 * Report Zones header. All of these values are passed out.
102 */
103struct disk_zone_rep_header {
104 uint8_t same;
105#define DISK_ZONE_SAME_ALL_DIFFERENT 0x0 /* Lengths and types vary */
106#define DISK_ZONE_SAME_ALL_SAME 0x1 /* Lengths and types the same */
107#define DISK_ZONE_SAME_LAST_DIFFERENT 0x2 /* Types same, last len varies */
108#define DISK_ZONE_SAME_TYPES_DIFFERENT 0x3 /* Types vary, length the same */
109 uint64_t maximum_lba;
110 /*
111 * XXX KDM padding space may not be a good idea inside the bio.
112 */
113 uint8_t reserved[64];
114};
115
116/*
117 * Report Zones entry. Note that the zone types, conditions, and flags
118 * are mapped directly from the SCSI/ATA flag values. Any additional
119 * SCSI/ATA zone types or conditions or flags that are defined in the
120 * future could result in additional values that are not yet defined here.
121 */
122struct disk_zone_rep_entry {
123 uint8_t zone_type;
124#define DISK_ZONE_TYPE_CONVENTIONAL 0x01
125#define DISK_ZONE_TYPE_SEQ_REQUIRED 0x02 /* Host Managed */
126#define DISK_ZONE_TYPE_SEQ_PREFERRED 0x03 /* Host Aware */
127 uint8_t zone_condition;
128#define DISK_ZONE_COND_NOT_WP 0x00
129#define DISK_ZONE_COND_EMPTY 0x01
130#define DISK_ZONE_COND_IMPLICIT_OPEN 0x02
131#define DISK_ZONE_COND_EXPLICIT_OPEN 0x03
132#define DISK_ZONE_COND_CLOSED 0x04
133#define DISK_ZONE_COND_READONLY 0x0D
134#define DISK_ZONE_COND_FULL 0x0E
135#define DISK_ZONE_COND_OFFLINE 0x0F
136 uint8_t zone_flags;
137#define DISK_ZONE_FLAG_RESET 0x01 /* Zone needs RWP */
138#define DISK_ZONE_FLAG_NON_SEQ 0x02 /* Zone accssessed nonseq */
139 uint64_t zone_length;
140 uint64_t zone_start_lba;
141 uint64_t write_pointer_lba;
142 /* XXX KDM padding space may not be a good idea inside the bio */
143 uint8_t reserved[32];
144};
145
146struct disk_zone_report {
147 uint64_t starting_id; /* Passed In */
148 uint8_t rep_options; /* Passed In */
149#define DISK_ZONE_REP_ALL 0x00
150#define DISK_ZONE_REP_EMPTY 0x01
151#define DISK_ZONE_REP_IMP_OPEN 0x02
152#define DISK_ZONE_REP_EXP_OPEN 0x03
153#define DISK_ZONE_REP_CLOSED 0x04
154#define DISK_ZONE_REP_FULL 0x05
155#define DISK_ZONE_REP_READONLY 0x06
156#define DISK_ZONE_REP_OFFLINE 0x07
157#define DISK_ZONE_REP_RWP 0x10
158#define DISK_ZONE_REP_NON_SEQ 0x11
159#define DISK_ZONE_REP_NON_WP 0x3F
160 struct disk_zone_rep_header header;
161 uint32_t entries_allocated; /* Passed In */
162 uint32_t entries_filled; /* Passed Out */
163 uint32_t entries_available; /* Passed Out */
164 struct disk_zone_rep_entry *entries;
165};
166
167union disk_zone_params {
168 struct disk_zone_disk_params disk_params;
169 struct disk_zone_rwp rwp;
170 struct disk_zone_report report;
171};
172
173struct disk_zone_args {
174 uint8_t zone_cmd;
175#define DISK_ZONE_OPEN 0x00
176#define DISK_ZONE_CLOSE 0x01
177#define DISK_ZONE_FINISH 0x02
178#define DISK_ZONE_REPORT_ZONES 0x03
179#define DISK_ZONE_RWP 0x04
180#define DISK_ZONE_GET_PARAMS 0x05
181 union disk_zone_params zone_params;
182};
183
184#endif /* _SYS_DISK_ZONE_H_ */