blob: b551e8b8030083ab7cfec975d64fd494ae0d329e [file] [log] [blame]
Christopher Ferris48af7cb2017-02-21 12:35:09 -08001/****************************************************************************
2 ****************************************************************************
3 ***
4 *** This header was automatically generated from a Linux kernel header
5 *** of the same name, to make information necessary for userspace to
6 *** call into the kernel available to libc. It contains only constants,
7 *** structures, and macros generated from the original header, and thus,
8 *** contains no copyrightable information.
9 ***
10 *** To edit the content of this header, modify the corresponding
11 *** source file (e.g. under external/kernel-headers/original/) then
12 *** run bionic/libc/kernel/tools/update_all.py
13 ***
14 *** Any manual change here will be lost the next time this script will
15 *** be run. You've been warned!
16 ***
17 ****************************************************************************
18 ****************************************************************************/
19#ifndef _UAPI_BLKZONED_H
20#define _UAPI_BLKZONED_H
21#include <linux/types.h>
22#include <linux/ioctl.h>
Christopher Ferris48af7cb2017-02-21 12:35:09 -080023enum blk_zone_type {
24 BLK_ZONE_TYPE_CONVENTIONAL = 0x1,
25 BLK_ZONE_TYPE_SEQWRITE_REQ = 0x2,
26 BLK_ZONE_TYPE_SEQWRITE_PREF = 0x3,
Christopher Ferris48af7cb2017-02-21 12:35:09 -080027};
28enum blk_zone_cond {
29 BLK_ZONE_COND_NOT_WP = 0x0,
30 BLK_ZONE_COND_EMPTY = 0x1,
Christopher Ferris48af7cb2017-02-21 12:35:09 -080031 BLK_ZONE_COND_IMP_OPEN = 0x2,
32 BLK_ZONE_COND_EXP_OPEN = 0x3,
33 BLK_ZONE_COND_CLOSED = 0x4,
34 BLK_ZONE_COND_READONLY = 0xD,
Christopher Ferris48af7cb2017-02-21 12:35:09 -080035 BLK_ZONE_COND_FULL = 0xE,
36 BLK_ZONE_COND_OFFLINE = 0xF,
37};
Christopher Ferris25c18d42020-10-14 17:42:58 -070038enum blk_zone_report_flags {
39 BLK_ZONE_REP_CAPACITY = (1 << 0),
40};
Christopher Ferris48af7cb2017-02-21 12:35:09 -080041struct blk_zone {
Christopher Ferris48af7cb2017-02-21 12:35:09 -080042 __u64 start;
43 __u64 len;
44 __u64 wp;
45 __u8 type;
Christopher Ferris48af7cb2017-02-21 12:35:09 -080046 __u8 cond;
47 __u8 non_seq;
48 __u8 reset;
Christopher Ferris25c18d42020-10-14 17:42:58 -070049 __u8 resv[4];
50 __u64 capacity;
51 __u8 reserved[24];
Christopher Ferris48af7cb2017-02-21 12:35:09 -080052};
53struct blk_zone_report {
54 __u64 sector;
55 __u32 nr_zones;
Christopher Ferris25c18d42020-10-14 17:42:58 -070056 __u32 flags;
Christopher Ferris48af7cb2017-02-21 12:35:09 -080057 struct blk_zone zones[0];
Christopher Ferris9ce28842018-10-25 12:11:39 -070058};
Christopher Ferris48af7cb2017-02-21 12:35:09 -080059struct blk_zone_range {
Christopher Ferris48af7cb2017-02-21 12:35:09 -080060 __u64 sector;
61 __u64 nr_sectors;
62};
63#define BLKREPORTZONE _IOWR(0x12, 130, struct blk_zone_report)
Christopher Ferris48af7cb2017-02-21 12:35:09 -080064#define BLKRESETZONE _IOW(0x12, 131, struct blk_zone_range)
Christopher Ferris86a48372019-01-10 14:14:59 -080065#define BLKGETZONESZ _IOR(0x12, 132, __u32)
66#define BLKGETNRZONES _IOR(0x12, 133, __u32)
Christopher Ferrisd32ca142020-02-04 16:16:51 -080067#define BLKOPENZONE _IOW(0x12, 134, struct blk_zone_range)
68#define BLKCLOSEZONE _IOW(0x12, 135, struct blk_zone_range)
69#define BLKFINISHZONE _IOW(0x12, 136, struct blk_zone_range)
Christopher Ferris48af7cb2017-02-21 12:35:09 -080070#endif