NetBSD/sys/dev/biovar.h
xtraeme 59a09b45c9 Improve the bio(4) API for incoming changes to arcmsr(4) (and perhaps
other drivers in the future):

- Added BIOC_SVCHECKING to the BIOCVOL ioctl, to know if a volume is
  running a consistency check.
- Added three more volume levels for the BIOCVOL ioctl.
- Added BIOC_SDPASSTHRU to the BIOCDISK ioctl, to know if a disk is
  in pass-through mode.
- Added BIOCDISK_NOVOL; it's used with the same reason than BIOCDISK,
  but it's used only to get information about the physical disks connected
  in a controller (regardless if they are in a volume set or not).
- Added BIOC_SSDELHOTSPARE, BIOC_SSPASTHRU, BIOC_SSDELPASSTHRU,
  BIOC_SSCHECKSTART_VOL and BIOC_SSCHECKSTOPVOL; to remove a hot-spare,
  add and remove a pass-through disk and to start/stop a consistency
  check in a volume.
- Added the BIOC_VOLOPS ioctl; to create/remove a volume set.
- Removed the BIOCCREATERAID ioctl, it was too limited for my needs.
- Added compatibility ioctls for BIOCDISK and BIOCVOL, enabled via COMPAT_30.
2008-01-02 23:45:03 +00:00

257 lines
7.6 KiB
C

/* $NetBSD: biovar.h,v 1.6 2008/01/02 23:45:03 xtraeme Exp $ */
/* $OpenBSD: biovar.h,v 1.26 2007/03/19 03:02:08 marco Exp $ */
/*
* Copyright (c) 2002 Niklas Hallqvist. All rights reserved.
* Copyright (c) 2005 Marco Peereboom. 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.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, 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 DAMAGE.
*/
/*
* Devices getting ioctls through this interface should use ioctl class 'B'
* and command numbers starting from 32, lower ones are reserved for generic
* ioctls. All ioctl data must be structures which start with a void *
* cookie.
*/
#ifndef _DEV_BIOVAR_H_
#define _DEV_BIOVAR_H_
#include <sys/types.h>
#ifndef _KERNEL
#include <stdbool.h>
#endif
struct bio_common {
void *bc_cookie;
};
/* convert name to a cookie */
#define BIOCLOCATE _IOWR('B', 0, struct bio_locate)
struct bio_locate {
void *bl_cookie;
char *bl_name;
};
#ifdef _KERNEL
int bio_register(struct device *, int (*)(struct device *, u_long, void *));
void bio_unregister(struct device *);
#endif
#define BIOCINQ _IOWR('B', 32, struct bioc_inq)
struct bioc_inq {
void *bi_cookie;
char bi_dev[16]; /* controller device */
int bi_novol; /* nr of volumes */
int bi_nodisk; /* nr of total disks */
};
#define BIOCDISK_NOVOL _IOWR('b', 38, struct bioc_disk)
#define BIOCDISK _IOWR('B', 33, struct bioc_disk)
/* structure that represents a disk in a RAID volume */
struct bioc_disk {
void *bd_cookie;
uint16_t bd_channel;
uint16_t bd_target;
uint16_t bd_lun;
uint16_t bd_other_id; /* unused for now */
int bd_volid; /* associate with volume */
int bd_diskid; /* virtual disk */
int bd_status; /* current status */
#define BIOC_SDONLINE 0x00
#define BIOC_SDONLINE_S "Online"
#define BIOC_SDOFFLINE 0x01
#define BIOC_SDOFFLINE_S "Offline"
#define BIOC_SDFAILED 0x02
#define BIOC_SDFAILED_S "Failed"
#define BIOC_SDREBUILD 0x03
#define BIOC_SDREBUILD_S "Rebuild"
#define BIOC_SDHOTSPARE 0x04
#define BIOC_SDHOTSPARE_S "Hot spare"
#define BIOC_SDUNUSED 0x05
#define BIOC_SDUNUSED_S "Unused"
#define BIOC_SDSCRUB 0x06
#define BIOC_SDSCRUB_S "Scrubbing"
#define BIOC_SDPASSTHRU 0x07
#define BIOC_SDPASSTHRU_S "Pass through"
#define BIOC_SDINVALID 0xff
#define BIOC_SDINVALID_S "Invalid"
uint64_t bd_size; /* size of the disk */
char bd_vendor[32]; /* scsi string */
char bd_serial[32]; /* serial number */
char bd_procdev[16]; /* processor device */
bool bd_disknovol; /* disk not associated with volumes */
};
/* COMPATIBILITY */
#ifdef _KERNEL
#define OBIOCDISK _IOWR('B', 33, struct obioc_disk)
/* structure that represents a disk in a RAID volume (compat) */
struct obioc_disk {
void *bd_cookie;
uint16_t bd_channel;
uint16_t bd_target;
uint16_t bd_lun;
uint16_t bd_other_id;
int bd_volid;
int bd_diskid;
int bd_status;
uint64_t bd_size;
char bd_vendor[32];
char bd_serial[32];
char bd_procdev[16];
};
#endif
#define BIOCVOL _IOWR('B', 34, struct bioc_vol)
/* structure that represents a RAID volume */
struct bioc_vol {
void *bv_cookie;
int bv_volid; /* volume id */
int16_t bv_percent; /* percent done operation */
uint16_t bv_seconds; /* seconds of progress so far */
int bv_status; /* current status */
#define BIOC_SVONLINE 0x00
#define BIOC_SVONLINE_S "Online"
#define BIOC_SVOFFLINE 0x01
#define BIOC_SVOFFLINE_S "Offline"
#define BIOC_SVDEGRADED 0x02
#define BIOC_SVDEGRADED_S "Degraded"
#define BIOC_SVBUILDING 0x03
#define BIOC_SVBUILDING_S "Building"
#define BIOC_SVSCRUB 0x04
#define BIOC_SVSCRUB_S "Scrubbing"
#define BIOC_SVREBUILD 0x05
#define BIOC_SVREBUILD_S "Rebuild"
#define BIOC_SVMIGRATING 0x06
#define BIOC_SVMIGRATING_S "Migrating"
#define BIOC_SVCHECKING 0x07
#define BIOC_SVCHECKING_S "Checking"
#define BIOC_SVINVALID 0xff
#define BIOC_SVINVALID_S "Invalid"
uint64_t bv_size; /* size of the disk */
int bv_level; /* raid level */
#define BIOC_SVOL_UNUSED 0xaa
#define BIOC_SVOL_HOTSPARE 0xbb
#define BIOC_SVOL_PASSTHRU 0xcc
int bv_nodisk; /* nr of drives */
char bv_dev[16]; /* device */
char bv_vendor[32]; /* scsi string */
uint16_t bv_stripe_size; /* stripe size */
};
/* COMPATIBILITY */
#ifdef _KERNEL
#define OBIOCVOL _IOWR('B', 34, struct obioc_vol)
/* structure that represents a RAID volume */
struct obioc_vol {
void *bv_cookie;
int bv_volid;
int16_t bv_percent;
uint16_t bv_seconds;
int bv_status;
uint64_t bv_size;
int bv_level;
int bv_nodisk;
char bv_dev[16];
char bv_vendor[32];
};
#endif
#define BIOCALARM _IOWR('B', 35, struct bioc_alarm)
struct bioc_alarm {
void *ba_cookie;
int ba_opcode;
int ba_status; /* only used with get state */
#define BIOC_SADISABLE 0x00 /* disable alarm */
#define BIOC_SAENABLE 0x01 /* enable alarm */
#define BIOC_SASILENCE 0x02 /* silence alarm */
#define BIOC_GASTATUS 0x03 /* get status */
#define BIOC_SATEST 0x04 /* test alarm */
};
#define BIOCBLINK _IOWR('B', 36, struct bioc_blink)
struct bioc_blink {
void *bb_cookie;
uint16_t bb_channel;
uint16_t bb_target;
int bb_status; /* current status */
#define BIOC_SBUNBLINK 0x00 /* disable blinking */
#define BIOC_SBBLINK 0x01 /* enable blink */
#define BIOC_SBALARM 0x02 /* enable alarm blink */
};
#define BIOCSETSTATE _IOWR('B', 37, struct bioc_setstate)
struct bioc_setstate {
void *bs_cookie;
uint16_t bs_channel;
uint16_t bs_target;
uint16_t bs_lun;
uint16_t bs_other_id; /* unused for now */
int bs_status; /* change to this status */
#define BIOC_SSONLINE 0x00 /* online disk */
#define BIOC_SSOFFLINE 0x01 /* offline disk */
#define BIOC_SSHOTSPARE 0x02 /* mark as hotspare */
#define BIOC_SSREBUILD 0x03 /* rebuild on this disk */
#define BIOC_SSDELHOTSPARE 0x04 /* unmark as hotspare */
#define BIOC_SSPASSTHRU 0x05 /* mark as pass-through */
#define BIOC_SSDELPASSTHRU 0x06 /* unmark as pass-through */
#define BIOC_SSCHECKSTART_VOL 0x07 /* start consistency check in vol# */
#define BIOC_SSCHECKSTOP_VOL 0x08 /* stop consistency check in vol# */
int bs_volid; /* volume id for rebuild */
};
#define BIOCVOLOPS _IOWR('B', 39, struct bioc_volops)
struct bioc_volops {
void *bc_cookie;
uint64_t bc_size; /* size of the volume set */
uint64_t bc_other_id; /* unused for now */
uint32_t bc_devmask; /* device mask for the volume set */
uint16_t bc_channel;
uint16_t bc_target;
uint16_t bc_lun;
uint16_t bc_stripe; /* stripe size */
uint16_t bc_level; /* RAID level requested */
int bc_opcode;
#define BIOC_VCREATE_VOLUME 0x00 /* create new volume */
#define BIOC_VREMOVE_VOLUME 0x01 /* remove volume */
int bc_volid; /* volume id to be created/removed */
};
#endif /* ! _DEV_BIOVAR_H_ */