1 /* $NetBSD: ata_raidvar.h,v 1.4 2005/12/11 12:21:14 christos Exp $ */ 2 3 /* 4 * Copyright (c) 2003 Wasabi Systems, Inc. 5 * All rights reserved. 6 * 7 * Written by Jason R. Thorpe for Wasabi Systems, Inc. 8 * 9 * Redistribution and use in source and binary forms, with or without 10 * modification, are permitted provided that the following conditions 11 * are met: 12 * 1. Redistributions of source code must retain the above copyright 13 * notice, this list of conditions and the following disclaimer. 14 * 2. Redistributions in binary form must reproduce the above copyright 15 * notice, this list of conditions and the following disclaimer in the 16 * documentation and/or other materials provided with the distribution. 17 * 3. All advertising materials mentioning features or use of this software 18 * must display the following acknowledgement: 19 * This product includes software developed for the NetBSD Project by 20 * Wasabi Systems, Inc. 21 * 4. The name of Wasabi Systems, Inc. may not be used to endorse 22 * or promote products derived from this software without specific prior 23 * written permission. 24 * 25 * THIS SOFTWARE IS PROVIDED BY WASABI SYSTEMS, INC. ``AS IS'' AND 26 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 27 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 28 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL WASABI SYSTEMS, INC 29 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 30 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 31 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 32 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 33 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 34 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 35 * POSSIBILITY OF SUCH DAMAGE. 36 */ 37 38 #ifndef _DEV_ATA_ATA_RAIDVAR_H_ 39 #define _DEV_ATA_ATA_RAIDVAR_H_ 40 41 #include <sys/queue.h> 42 43 /* 44 * Types of RAID configurations we support. Do not change the order 45 * of this list, as it will change the order in which the arrays are 46 * sorted. 47 * 48 * If this list is updated, ensure the array in 49 * ata_raid.c:ata_raid_type_name() is also updated. 50 */ 51 #define ATA_RAID_TYPE_PROMISE 0 52 #define ATA_RAID_TYPE_ADAPTEC 1 53 #define ATA_RAID_TYPE_MAX 1 54 55 /* 56 * Max # of disks supported by a single array. This is limited by 57 * the number that the individual controller config blocks can support: 58 * 59 * Promise 8 60 */ 61 #define ATA_RAID_MAX_DISKS 8 62 63 struct ataraid_disk_info { 64 struct device *adi_dev; /* disk's device */ 65 int adi_status; /* disk's status */ 66 u_int adi_sectors; 67 u_int adi_compsize; /* in sectors */ 68 }; 69 70 /* adi_status */ 71 #define ADI_S_ONLINE 0x01 72 #define ADI_S_ASSIGNED 0x02 73 #define ADI_S_SPARE 0x04 74 75 struct ataraid_array_info { 76 TAILQ_ENTRY(ataraid_array_info) aai_list; 77 78 struct device *aai_ld; /* associated logical disk */ 79 80 u_int aai_type; /* array type */ 81 u_int aai_arrayno; /* array number */ 82 int aai_level; /* RAID level */ 83 int aai_generation; /* config generaion # */ 84 int aai_status; /* array status */ 85 86 /* Geometry info. */ 87 u_int aai_interleave; /* stripe size */ 88 u_int aai_width; /* array width */ 89 u_int aai_ndisks; /* number of disks */ 90 u_int aai_heads; /* tracks/cyl */ 91 u_int aai_sectors; /* secs/track */ 92 u_int aai_cylinders; /* cyl/unit */ 93 u_int aai_capacity; /* in sectors */ 94 u_int aai_offset; /* component start offset */ 95 u_int aai_reserved; /* component reserved sectors */ 96 97 struct ataraid_disk_info aai_disks[ATA_RAID_MAX_DISKS]; 98 }; 99 100 /* aai_level */ 101 #define AAI_L_SPAN 0x01 102 #define AAI_L_RAID0 0x02 103 #define AAI_L_RAID1 0x04 104 105 /* aai_status */ 106 #define AAI_S_READY 0x01 107 #define AAI_S_DEGRADED 0x02 108 109 struct vnode; 110 struct wd_softc; 111 112 typedef TAILQ_HEAD(, ataraid_array_info) ataraid_array_info_list_t; 113 extern ataraid_array_info_list_t ataraid_array_info_list; 114 115 void ata_raid_check_component(struct device *); 116 const char *ata_raid_type_name(u_int); 117 118 struct ataraid_array_info *ata_raid_get_array_info(u_int, u_int); 119 int ata_raid_config_block_rw(struct vnode *, daddr_t, void *, 120 size_t, int); 121 122 /* Promise RAID support */ 123 int ata_raid_read_config_promise(struct wd_softc *); 124 125 /* Adaptec HostRAID support */ 126 int ata_raid_read_config_adaptec(struct wd_softc *); 127 128 #endif /* _DEV_ATA_ATA_RAIDVAR_H_ */ 129