2011-06-21 02:02:55 +04:00
|
|
|
/* $NetBSD: arcmsr.c,v 1.30 2011/06/20 22:03:16 pgoyette Exp $ */
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
/* $OpenBSD: arc.c,v 1.68 2007/10/27 03:28:27 dlg Exp $ */
|
|
|
|
|
|
|
|
/*
|
2008-02-28 19:47:53 +03:00
|
|
|
* Copyright (c) 2007, 2008 Juan Romero Pardines <xtraeme@netbsd.org>
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
* Copyright (c) 2006 David Gwynne <dlg@openbsd.org>
|
|
|
|
*
|
|
|
|
* Permission to use, copy, modify, and distribute this software for any
|
|
|
|
* purpose with or without fee is hereby granted, provided that the above
|
|
|
|
* copyright notice and this permission notice appear in all copies.
|
|
|
|
*
|
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
|
|
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
|
|
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
|
|
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
|
|
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
|
|
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
|
|
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "bio.h"
|
|
|
|
|
|
|
|
#include <sys/cdefs.h>
|
2011-06-21 02:02:55 +04:00
|
|
|
__KERNEL_RCSID(0, "$NetBSD: arcmsr.c,v 1.30 2011/06/20 22:03:16 pgoyette Exp $");
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
#include <sys/param.h>
|
|
|
|
#include <sys/buf.h>
|
|
|
|
#include <sys/kernel.h>
|
|
|
|
#include <sys/malloc.h>
|
|
|
|
#include <sys/device.h>
|
2007-12-07 11:50:36 +03:00
|
|
|
#include <sys/kmem.h>
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
#include <sys/kthread.h>
|
2007-12-05 21:07:34 +03:00
|
|
|
#include <sys/mutex.h>
|
|
|
|
#include <sys/condvar.h>
|
2007-12-05 21:58:00 +03:00
|
|
|
#include <sys/rwlock.h>
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
#if NBIO > 0
|
|
|
|
#include <sys/ioctl.h>
|
|
|
|
#include <dev/biovar.h>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include <dev/pci/pcireg.h>
|
|
|
|
#include <dev/pci/pcivar.h>
|
|
|
|
#include <dev/pci/pcidevs.h>
|
|
|
|
|
|
|
|
#include <dev/scsipi/scsipi_all.h>
|
|
|
|
#include <dev/scsipi/scsi_all.h>
|
|
|
|
#include <dev/scsipi/scsiconf.h>
|
|
|
|
|
|
|
|
#include <dev/sysmon/sysmonvar.h>
|
|
|
|
|
|
|
|
#include <sys/bus.h>
|
|
|
|
|
2007-12-05 03:18:06 +03:00
|
|
|
#include <dev/pci/arcmsrvar.h>
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
/* #define ARC_DEBUG */
|
|
|
|
#ifdef ARC_DEBUG
|
|
|
|
#define ARC_D_INIT (1<<0)
|
|
|
|
#define ARC_D_RW (1<<1)
|
|
|
|
#define ARC_D_DB (1<<2)
|
|
|
|
|
|
|
|
int arcdebug = 0;
|
|
|
|
|
|
|
|
#define DPRINTF(p...) do { if (arcdebug) printf(p); } while (0)
|
|
|
|
#define DNPRINTF(n, p...) do { if ((n) & arcdebug) printf(p); } while (0)
|
|
|
|
|
|
|
|
#else
|
2008-06-24 14:14:41 +04:00
|
|
|
#define DPRINTF(p, ...) /* p */
|
|
|
|
#define DNPRINTF(n, p, ...) /* n, p */
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/*
|
|
|
|
* the fw header must always equal this.
|
|
|
|
*/
|
|
|
|
static struct arc_fw_hdr arc_fw_hdr = { 0x5e, 0x01, 0x61 };
|
|
|
|
|
|
|
|
/*
|
|
|
|
* autoconf(9) glue.
|
|
|
|
*/
|
2008-03-05 18:03:36 +03:00
|
|
|
static int arc_match(device_t, cfdata_t, void *);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
static void arc_attach(device_t, device_t, void *);
|
|
|
|
static int arc_detach(device_t, int);
|
2008-02-28 19:47:53 +03:00
|
|
|
static bool arc_shutdown(device_t, int);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
static int arc_intr(void *);
|
|
|
|
static void arc_minphys(struct buf *);
|
|
|
|
|
2008-03-05 18:03:36 +03:00
|
|
|
CFATTACH_DECL_NEW(arcmsr, sizeof(struct arc_softc),
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
arc_match, arc_attach, arc_detach, NULL);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* bio(4) and sysmon_envsys(9) glue.
|
|
|
|
*/
|
|
|
|
#if NBIO > 0
|
2008-03-05 18:03:36 +03:00
|
|
|
static int arc_bioctl(device_t, u_long, void *);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
static int arc_bio_inq(struct arc_softc *, struct bioc_inq *);
|
|
|
|
static int arc_bio_vol(struct arc_softc *, struct bioc_vol *);
|
2008-01-03 02:48:05 +03:00
|
|
|
static int arc_bio_disk_volume(struct arc_softc *, struct bioc_disk *);
|
|
|
|
static int arc_bio_disk_novol(struct arc_softc *, struct bioc_disk *);
|
|
|
|
static void arc_bio_disk_filldata(struct arc_softc *, struct bioc_disk *,
|
|
|
|
struct arc_fw_diskinfo *, int);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
static int arc_bio_alarm(struct arc_softc *, struct bioc_alarm *);
|
|
|
|
static int arc_bio_alarm_state(struct arc_softc *, struct bioc_alarm *);
|
|
|
|
static int arc_bio_getvol(struct arc_softc *, int,
|
|
|
|
struct arc_fw_volinfo *);
|
2008-01-03 02:48:05 +03:00
|
|
|
static int arc_bio_setstate(struct arc_softc *, struct bioc_setstate *);
|
|
|
|
static int arc_bio_volops(struct arc_softc *, struct bioc_volops *);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
static void arc_create_sensors(void *);
|
2007-12-05 19:02:25 +03:00
|
|
|
static void arc_refresh_sensors(struct sysmon_envsys *, envsys_data_t *);
|
2008-01-03 02:48:05 +03:00
|
|
|
static int arc_fw_parse_status_code(struct arc_softc *, uint8_t *);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
#endif
|
|
|
|
|
|
|
|
static int
|
2008-03-05 18:03:36 +03:00
|
|
|
arc_match(device_t parent, cfdata_t match, void *aux)
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
{
|
|
|
|
struct pci_attach_args *pa = aux;
|
|
|
|
|
|
|
|
if (PCI_VENDOR(pa->pa_id) == PCI_VENDOR_ARECA) {
|
|
|
|
switch (PCI_PRODUCT(pa->pa_id)) {
|
|
|
|
case PCI_PRODUCT_ARECA_ARC1110:
|
|
|
|
case PCI_PRODUCT_ARECA_ARC1120:
|
|
|
|
case PCI_PRODUCT_ARECA_ARC1130:
|
|
|
|
case PCI_PRODUCT_ARECA_ARC1160:
|
|
|
|
case PCI_PRODUCT_ARECA_ARC1170:
|
|
|
|
case PCI_PRODUCT_ARECA_ARC1200:
|
|
|
|
case PCI_PRODUCT_ARECA_ARC1202:
|
|
|
|
case PCI_PRODUCT_ARECA_ARC1210:
|
|
|
|
case PCI_PRODUCT_ARECA_ARC1220:
|
|
|
|
case PCI_PRODUCT_ARECA_ARC1230:
|
|
|
|
case PCI_PRODUCT_ARECA_ARC1260:
|
|
|
|
case PCI_PRODUCT_ARECA_ARC1270:
|
|
|
|
case PCI_PRODUCT_ARECA_ARC1280:
|
|
|
|
case PCI_PRODUCT_ARECA_ARC1380:
|
|
|
|
case PCI_PRODUCT_ARECA_ARC1381:
|
|
|
|
case PCI_PRODUCT_ARECA_ARC1680:
|
|
|
|
case PCI_PRODUCT_ARECA_ARC1681:
|
|
|
|
return 1;
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
arc_attach(device_t parent, device_t self, void *aux)
|
|
|
|
{
|
|
|
|
struct arc_softc *sc = device_private(self);
|
|
|
|
struct pci_attach_args *pa = aux;
|
|
|
|
struct scsipi_adapter *adapt = &sc->sc_adapter;
|
|
|
|
struct scsipi_channel *chan = &sc->sc_chan;
|
|
|
|
|
2008-03-05 18:03:36 +03:00
|
|
|
sc->sc_dev = self;
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
sc->sc_talking = 0;
|
2007-12-05 21:58:00 +03:00
|
|
|
rw_init(&sc->sc_rwlock);
|
2007-12-05 21:07:34 +03:00
|
|
|
mutex_init(&sc->sc_mutex, MUTEX_DEFAULT, IPL_BIO);
|
|
|
|
cv_init(&sc->sc_condvar, "arcdb");
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
2008-03-05 18:03:36 +03:00
|
|
|
if (arc_map_pci_resources(self, pa) != 0) {
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
/* error message printed by arc_map_pci_resources */
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2008-03-05 18:03:36 +03:00
|
|
|
if (arc_query_firmware(self) != 0) {
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
/* error message printed by arc_query_firmware */
|
|
|
|
goto unmap_pci;
|
|
|
|
}
|
|
|
|
|
2008-03-05 18:03:36 +03:00
|
|
|
if (arc_alloc_ccbs(self) != 0) {
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
/* error message printed by arc_alloc_ccbs */
|
|
|
|
goto unmap_pci;
|
|
|
|
}
|
|
|
|
|
2008-02-28 19:47:53 +03:00
|
|
|
if (!pmf_device_register1(self, NULL, NULL, arc_shutdown))
|
2008-02-29 00:08:45 +03:00
|
|
|
panic("%s: couldn't establish shutdown handler\n",
|
|
|
|
device_xname(self));
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
memset(adapt, 0, sizeof(*adapt));
|
|
|
|
adapt->adapt_dev = self;
|
|
|
|
adapt->adapt_nchannels = 1;
|
|
|
|
adapt->adapt_openings = sc->sc_req_count / ARC_MAX_TARGET;
|
|
|
|
adapt->adapt_max_periph = adapt->adapt_openings;
|
|
|
|
adapt->adapt_minphys = arc_minphys;
|
|
|
|
adapt->adapt_request = arc_scsi_cmd;
|
|
|
|
|
|
|
|
memset(chan, 0, sizeof(*chan));
|
|
|
|
chan->chan_adapter = adapt;
|
|
|
|
chan->chan_bustype = &scsi_bustype;
|
|
|
|
chan->chan_nluns = ARC_MAX_LUN;
|
|
|
|
chan->chan_ntargets = ARC_MAX_TARGET;
|
|
|
|
chan->chan_id = ARC_MAX_TARGET;
|
2007-12-05 21:25:53 +03:00
|
|
|
chan->chan_flags = SCSIPI_CHAN_NOSETTLE;
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
2008-01-03 02:48:05 +03:00
|
|
|
/*
|
|
|
|
* Save the device_t returned, because we could to attach
|
|
|
|
* devices via the management interface.
|
|
|
|
*/
|
|
|
|
sc->sc_scsibus_dv = config_found(self, &sc->sc_chan, scsiprint);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
/* enable interrupts */
|
|
|
|
arc_write(sc, ARC_REG_INTRMASK,
|
|
|
|
~(ARC_REG_INTRMASK_POSTQUEUE|ARC_REG_INTRSTAT_DOORBELL));
|
|
|
|
|
|
|
|
#if NBIO > 0
|
2007-12-07 11:50:36 +03:00
|
|
|
/*
|
|
|
|
* Register the driver to bio(4) and setup the sensors.
|
|
|
|
*/
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
if (bio_register(self, arc_bioctl) != 0)
|
|
|
|
panic("%s: bioctl registration failed\n", device_xname(self));
|
2007-12-07 11:50:36 +03:00
|
|
|
|
|
|
|
/*
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
* you need to talk to the firmware to get volume info. our firmware
|
|
|
|
* interface relies on being able to sleep, so we need to use a thread
|
|
|
|
* to do the work.
|
|
|
|
*/
|
|
|
|
if (kthread_create(PRI_NONE, KTHREAD_MPSAFE, NULL,
|
|
|
|
arc_create_sensors, sc, &sc->sc_lwp, "arcmsr_sensors") != 0)
|
|
|
|
panic("%s: unable to create a kernel thread for sensors\n",
|
|
|
|
device_xname(self));
|
|
|
|
#endif
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
unmap_pci:
|
|
|
|
arc_unmap_pci_resources(sc);
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
arc_detach(device_t self, int flags)
|
|
|
|
{
|
|
|
|
struct arc_softc *sc = device_private(self);
|
|
|
|
|
|
|
|
if (arc_msg0(sc, ARC_REG_INB_MSG0_STOP_BGRB) != 0)
|
2008-03-05 18:03:36 +03:00
|
|
|
aprint_error_dev(self, "timeout waiting to stop bg rebuild\n");
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
if (arc_msg0(sc, ARC_REG_INB_MSG0_FLUSH_CACHE) != 0)
|
2008-03-05 18:03:36 +03:00
|
|
|
aprint_error_dev(self, "timeout waiting to flush cache\n");
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
2010-04-03 21:54:24 +04:00
|
|
|
if (sc->sc_sme != NULL)
|
|
|
|
sysmon_envsys_unregister(sc->sc_sme);
|
|
|
|
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2008-02-28 19:47:53 +03:00
|
|
|
static bool
|
|
|
|
arc_shutdown(device_t self, int how)
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
{
|
2008-02-28 19:47:53 +03:00
|
|
|
struct arc_softc *sc = device_private(self);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
if (arc_msg0(sc, ARC_REG_INB_MSG0_STOP_BGRB) != 0)
|
2008-03-05 18:03:36 +03:00
|
|
|
aprint_error_dev(self, "timeout waiting to stop bg rebuild\n");
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
if (arc_msg0(sc, ARC_REG_INB_MSG0_FLUSH_CACHE) != 0)
|
2008-03-05 18:03:36 +03:00
|
|
|
aprint_error_dev(self, "timeout waiting to flush cache\n");
|
2008-02-28 19:47:53 +03:00
|
|
|
|
|
|
|
return true;
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
arc_minphys(struct buf *bp)
|
|
|
|
{
|
|
|
|
if (bp->b_bcount > MAXPHYS)
|
|
|
|
bp->b_bcount = MAXPHYS;
|
|
|
|
minphys(bp);
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
arc_intr(void *arg)
|
|
|
|
{
|
|
|
|
struct arc_softc *sc = arg;
|
|
|
|
struct arc_ccb *ccb = NULL;
|
|
|
|
char *kva = ARC_DMA_KVA(sc->sc_requests);
|
|
|
|
struct arc_io_cmd *cmd;
|
|
|
|
uint32_t reg, intrstat;
|
|
|
|
|
2007-12-07 11:50:36 +03:00
|
|
|
mutex_spin_enter(&sc->sc_mutex);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
intrstat = arc_read(sc, ARC_REG_INTRSTAT);
|
2007-12-05 21:07:34 +03:00
|
|
|
if (intrstat == 0x0) {
|
2007-12-07 11:50:36 +03:00
|
|
|
mutex_spin_exit(&sc->sc_mutex);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
return 0;
|
2007-12-05 21:07:34 +03:00
|
|
|
}
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
intrstat &= ARC_REG_INTRSTAT_POSTQUEUE | ARC_REG_INTRSTAT_DOORBELL;
|
|
|
|
arc_write(sc, ARC_REG_INTRSTAT, intrstat);
|
|
|
|
|
|
|
|
if (intrstat & ARC_REG_INTRSTAT_DOORBELL) {
|
|
|
|
if (sc->sc_talking) {
|
|
|
|
arc_write(sc, ARC_REG_INTRMASK,
|
|
|
|
~ARC_REG_INTRMASK_POSTQUEUE);
|
2007-12-05 21:07:34 +03:00
|
|
|
cv_broadcast(&sc->sc_condvar);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
} else {
|
|
|
|
/* otherwise drop it */
|
|
|
|
reg = arc_read(sc, ARC_REG_OUTB_DOORBELL);
|
|
|
|
arc_write(sc, ARC_REG_OUTB_DOORBELL, reg);
|
|
|
|
if (reg & ARC_REG_OUTB_DOORBELL_WRITE_OK)
|
|
|
|
arc_write(sc, ARC_REG_INB_DOORBELL,
|
|
|
|
ARC_REG_INB_DOORBELL_READ_OK);
|
|
|
|
}
|
|
|
|
}
|
2007-12-07 11:50:36 +03:00
|
|
|
mutex_spin_exit(&sc->sc_mutex);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
while ((reg = arc_pop(sc)) != 0xffffffff) {
|
|
|
|
cmd = (struct arc_io_cmd *)(kva +
|
|
|
|
((reg << ARC_REG_REPLY_QUEUE_ADDR_SHIFT) -
|
|
|
|
(uint32_t)ARC_DMA_DVA(sc->sc_requests)));
|
|
|
|
ccb = &sc->sc_ccbs[htole32(cmd->cmd.context)];
|
|
|
|
|
|
|
|
bus_dmamap_sync(sc->sc_dmat, ARC_DMA_MAP(sc->sc_requests),
|
|
|
|
ccb->ccb_offset, ARC_MAX_IOCMDLEN,
|
|
|
|
BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE);
|
|
|
|
|
|
|
|
arc_scsi_cmd_done(sc, ccb, reg);
|
|
|
|
}
|
|
|
|
|
2008-01-03 02:48:05 +03:00
|
|
|
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
arc_scsi_cmd(struct scsipi_channel *chan, scsipi_adapter_req_t req, void *arg)
|
|
|
|
{
|
|
|
|
struct scsipi_periph *periph;
|
|
|
|
struct scsipi_xfer *xs;
|
|
|
|
struct scsipi_adapter *adapt = chan->chan_adapter;
|
|
|
|
struct arc_softc *sc = device_private(adapt->adapt_dev);
|
|
|
|
struct arc_ccb *ccb;
|
|
|
|
struct arc_msg_scsicmd *cmd;
|
|
|
|
uint32_t reg;
|
|
|
|
uint8_t target;
|
|
|
|
|
|
|
|
switch (req) {
|
|
|
|
case ADAPTER_REQ_GROW_RESOURCES:
|
|
|
|
/* Not supported. */
|
|
|
|
return;
|
|
|
|
case ADAPTER_REQ_SET_XFER_MODE:
|
|
|
|
/* Not supported. */
|
|
|
|
return;
|
|
|
|
case ADAPTER_REQ_RUN_XFER:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2007-12-07 11:50:36 +03:00
|
|
|
mutex_spin_enter(&sc->sc_mutex);
|
|
|
|
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
xs = arg;
|
|
|
|
periph = xs->xs_periph;
|
|
|
|
target = periph->periph_target;
|
|
|
|
|
|
|
|
if (xs->cmdlen > ARC_MSG_CDBLEN) {
|
|
|
|
memset(&xs->sense, 0, sizeof(xs->sense));
|
|
|
|
xs->sense.scsi_sense.response_code = SSD_RCODE_VALID | 0x70;
|
|
|
|
xs->sense.scsi_sense.flags = SKEY_ILLEGAL_REQUEST;
|
|
|
|
xs->sense.scsi_sense.asc = 0x20;
|
|
|
|
xs->error = XS_SENSE;
|
|
|
|
xs->status = SCSI_CHECK;
|
2007-12-07 11:50:36 +03:00
|
|
|
mutex_spin_exit(&sc->sc_mutex);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
scsipi_done(xs);
|
2007-12-05 21:07:34 +03:00
|
|
|
return;
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
ccb = arc_get_ccb(sc);
|
|
|
|
if (ccb == NULL) {
|
|
|
|
xs->error = XS_RESOURCE_SHORTAGE;
|
2007-12-07 11:50:36 +03:00
|
|
|
mutex_spin_exit(&sc->sc_mutex);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
scsipi_done(xs);
|
2007-12-05 21:07:34 +03:00
|
|
|
return;
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
ccb->ccb_xs = xs;
|
|
|
|
|
|
|
|
if (arc_load_xs(ccb) != 0) {
|
|
|
|
xs->error = XS_DRIVER_STUFFUP;
|
|
|
|
arc_put_ccb(sc, ccb);
|
2007-12-07 11:50:36 +03:00
|
|
|
mutex_spin_exit(&sc->sc_mutex);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
scsipi_done(xs);
|
2007-12-05 21:07:34 +03:00
|
|
|
return;
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
cmd = &ccb->ccb_cmd->cmd;
|
|
|
|
reg = ccb->ccb_cmd_post;
|
|
|
|
|
|
|
|
/* bus is always 0 */
|
|
|
|
cmd->target = target;
|
|
|
|
cmd->lun = periph->periph_lun;
|
|
|
|
cmd->function = 1; /* XXX magic number */
|
|
|
|
|
|
|
|
cmd->cdb_len = xs->cmdlen;
|
|
|
|
cmd->sgl_len = ccb->ccb_dmamap->dm_nsegs;
|
|
|
|
if (xs->xs_control & XS_CTL_DATA_OUT)
|
|
|
|
cmd->flags = ARC_MSG_SCSICMD_FLAG_WRITE;
|
|
|
|
if (ccb->ccb_dmamap->dm_nsegs > ARC_SGL_256LEN) {
|
|
|
|
cmd->flags |= ARC_MSG_SCSICMD_FLAG_SGL_BSIZE_512;
|
|
|
|
reg |= ARC_REG_POST_QUEUE_BIGFRAME;
|
|
|
|
}
|
|
|
|
|
|
|
|
cmd->context = htole32(ccb->ccb_id);
|
|
|
|
cmd->data_len = htole32(xs->datalen);
|
|
|
|
|
|
|
|
memcpy(cmd->cdb, xs->cmd, xs->cmdlen);
|
|
|
|
|
|
|
|
/* we've built the command, let's put it on the hw */
|
|
|
|
bus_dmamap_sync(sc->sc_dmat, ARC_DMA_MAP(sc->sc_requests),
|
|
|
|
ccb->ccb_offset, ARC_MAX_IOCMDLEN,
|
|
|
|
BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE);
|
|
|
|
|
|
|
|
arc_push(sc, reg);
|
|
|
|
if (xs->xs_control & XS_CTL_POLL) {
|
|
|
|
if (arc_complete(sc, ccb, xs->timeout) != 0) {
|
|
|
|
xs->error = XS_DRIVER_STUFFUP;
|
2007-12-07 11:50:36 +03:00
|
|
|
mutex_spin_exit(&sc->sc_mutex);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
scsipi_done(xs);
|
2007-12-07 11:50:36 +03:00
|
|
|
return;
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
}
|
|
|
|
}
|
2007-12-07 11:50:36 +03:00
|
|
|
|
|
|
|
mutex_spin_exit(&sc->sc_mutex);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
arc_load_xs(struct arc_ccb *ccb)
|
|
|
|
{
|
|
|
|
struct arc_softc *sc = ccb->ccb_sc;
|
|
|
|
struct scsipi_xfer *xs = ccb->ccb_xs;
|
|
|
|
bus_dmamap_t dmap = ccb->ccb_dmamap;
|
|
|
|
struct arc_sge *sgl = ccb->ccb_cmd->sgl, *sge;
|
|
|
|
uint64_t addr;
|
|
|
|
int i, error;
|
|
|
|
|
|
|
|
if (xs->datalen == 0)
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
error = bus_dmamap_load(sc->sc_dmat, dmap,
|
|
|
|
xs->data, xs->datalen, NULL,
|
|
|
|
(xs->xs_control & XS_CTL_NOSLEEP) ?
|
|
|
|
BUS_DMA_NOWAIT : BUS_DMA_WAITOK);
|
|
|
|
if (error != 0) {
|
|
|
|
aprint_error("%s: error %d loading dmamap\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev), error);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i = 0; i < dmap->dm_nsegs; i++) {
|
|
|
|
sge = &sgl[i];
|
|
|
|
|
|
|
|
sge->sg_hdr = htole32(ARC_SGE_64BIT | dmap->dm_segs[i].ds_len);
|
|
|
|
addr = dmap->dm_segs[i].ds_addr;
|
|
|
|
sge->sg_hi_addr = htole32((uint32_t)(addr >> 32));
|
|
|
|
sge->sg_lo_addr = htole32((uint32_t)addr);
|
|
|
|
}
|
|
|
|
|
|
|
|
bus_dmamap_sync(sc->sc_dmat, dmap, 0, dmap->dm_mapsize,
|
|
|
|
(xs->xs_control & XS_CTL_DATA_IN) ? BUS_DMASYNC_PREREAD :
|
|
|
|
BUS_DMASYNC_PREWRITE);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
arc_scsi_cmd_done(struct arc_softc *sc, struct arc_ccb *ccb, uint32_t reg)
|
|
|
|
{
|
|
|
|
struct scsipi_xfer *xs = ccb->ccb_xs;
|
|
|
|
struct arc_msg_scsicmd *cmd;
|
|
|
|
|
|
|
|
if (xs->datalen != 0) {
|
|
|
|
bus_dmamap_sync(sc->sc_dmat, ccb->ccb_dmamap, 0,
|
|
|
|
ccb->ccb_dmamap->dm_mapsize,
|
|
|
|
(xs->xs_control & XS_CTL_DATA_IN) ?
|
|
|
|
BUS_DMASYNC_POSTREAD : BUS_DMASYNC_POSTWRITE);
|
|
|
|
bus_dmamap_unload(sc->sc_dmat, ccb->ccb_dmamap);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* timeout_del */
|
|
|
|
xs->status |= XS_STS_DONE;
|
|
|
|
|
|
|
|
if (reg & ARC_REG_REPLY_QUEUE_ERR) {
|
|
|
|
cmd = &ccb->ccb_cmd->cmd;
|
|
|
|
|
|
|
|
switch (cmd->status) {
|
|
|
|
case ARC_MSG_STATUS_SELTIMEOUT:
|
|
|
|
case ARC_MSG_STATUS_ABORTED:
|
|
|
|
case ARC_MSG_STATUS_INIT_FAIL:
|
|
|
|
xs->status = SCSI_OK;
|
|
|
|
xs->error = XS_SELTIMEOUT;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case SCSI_CHECK:
|
|
|
|
memset(&xs->sense, 0, sizeof(xs->sense));
|
|
|
|
memcpy(&xs->sense, cmd->sense_data,
|
|
|
|
min(ARC_MSG_SENSELEN, sizeof(xs->sense)));
|
|
|
|
xs->sense.scsi_sense.response_code =
|
|
|
|
SSD_RCODE_VALID | 0x70;
|
|
|
|
xs->status = SCSI_CHECK;
|
|
|
|
xs->error = XS_SENSE;
|
|
|
|
xs->resid = 0;
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
/* unknown device status */
|
|
|
|
xs->error = XS_BUSY; /* try again later? */
|
|
|
|
xs->status = SCSI_BUSY;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
xs->status = SCSI_OK;
|
|
|
|
xs->error = XS_NOERROR;
|
|
|
|
xs->resid = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
arc_put_ccb(sc, ccb);
|
|
|
|
scsipi_done(xs);
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
arc_complete(struct arc_softc *sc, struct arc_ccb *nccb, int timeout)
|
|
|
|
{
|
|
|
|
struct arc_ccb *ccb = NULL;
|
|
|
|
char *kva = ARC_DMA_KVA(sc->sc_requests);
|
|
|
|
struct arc_io_cmd *cmd;
|
|
|
|
uint32_t reg;
|
|
|
|
|
|
|
|
do {
|
|
|
|
reg = arc_pop(sc);
|
|
|
|
if (reg == 0xffffffff) {
|
|
|
|
if (timeout-- == 0)
|
|
|
|
return 1;
|
|
|
|
|
|
|
|
delay(1000);
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
cmd = (struct arc_io_cmd *)(kva +
|
|
|
|
((reg << ARC_REG_REPLY_QUEUE_ADDR_SHIFT) -
|
|
|
|
ARC_DMA_DVA(sc->sc_requests)));
|
|
|
|
ccb = &sc->sc_ccbs[htole32(cmd->cmd.context)];
|
|
|
|
|
|
|
|
bus_dmamap_sync(sc->sc_dmat, ARC_DMA_MAP(sc->sc_requests),
|
|
|
|
ccb->ccb_offset, ARC_MAX_IOCMDLEN,
|
|
|
|
BUS_DMASYNC_PREREAD | BUS_DMASYNC_PREWRITE);
|
|
|
|
|
|
|
|
arc_scsi_cmd_done(sc, ccb, reg);
|
|
|
|
} while (nccb != ccb);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
2008-03-05 18:03:36 +03:00
|
|
|
arc_map_pci_resources(device_t self, struct pci_attach_args *pa)
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
{
|
2008-03-05 18:03:36 +03:00
|
|
|
struct arc_softc *sc = device_private(self);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
pcireg_t memtype;
|
|
|
|
pci_intr_handle_t ih;
|
|
|
|
|
|
|
|
sc->sc_pc = pa->pa_pc;
|
|
|
|
sc->sc_tag = pa->pa_tag;
|
|
|
|
sc->sc_dmat = pa->pa_dmat;
|
|
|
|
|
|
|
|
memtype = pci_mapreg_type(sc->sc_pc, sc->sc_tag, ARC_PCI_BAR);
|
|
|
|
if (pci_mapreg_map(pa, ARC_PCI_BAR, memtype, 0, &sc->sc_iot,
|
|
|
|
&sc->sc_ioh, NULL, &sc->sc_ios) != 0) {
|
|
|
|
aprint_error(": unable to map system interface register\n");
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (pci_intr_map(pa, &ih) != 0) {
|
|
|
|
aprint_error(": unable to map interrupt\n");
|
|
|
|
goto unmap;
|
|
|
|
}
|
|
|
|
|
|
|
|
sc->sc_ih = pci_intr_establish(pa->pa_pc, ih, IPL_BIO,
|
|
|
|
arc_intr, sc);
|
|
|
|
if (sc->sc_ih == NULL) {
|
|
|
|
aprint_error(": unable to map interrupt [2]\n");
|
|
|
|
goto unmap;
|
|
|
|
}
|
2008-02-28 19:47:53 +03:00
|
|
|
|
|
|
|
aprint_normal("\n");
|
2008-03-05 18:03:36 +03:00
|
|
|
aprint_normal_dev(self, "interrupting at %s\n",
|
|
|
|
pci_intr_string(pa->pa_pc, ih));
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
unmap:
|
|
|
|
bus_space_unmap(sc->sc_iot, sc->sc_ioh, sc->sc_ios);
|
|
|
|
sc->sc_ios = 0;
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
arc_unmap_pci_resources(struct arc_softc *sc)
|
|
|
|
{
|
|
|
|
pci_intr_disestablish(sc->sc_pc, sc->sc_ih);
|
|
|
|
bus_space_unmap(sc->sc_iot, sc->sc_ioh, sc->sc_ios);
|
|
|
|
sc->sc_ios = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
2008-03-05 18:03:36 +03:00
|
|
|
arc_query_firmware(device_t self)
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
{
|
2008-03-05 18:03:36 +03:00
|
|
|
struct arc_softc *sc = device_private(self);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
struct arc_msg_firmware_info fwinfo;
|
|
|
|
char string[81]; /* sizeof(vendor)*2+1 */
|
|
|
|
|
|
|
|
if (arc_wait_eq(sc, ARC_REG_OUTB_ADDR1, ARC_REG_OUTB_ADDR1_FIRMWARE_OK,
|
|
|
|
ARC_REG_OUTB_ADDR1_FIRMWARE_OK) != 0) {
|
2008-03-05 18:03:36 +03:00
|
|
|
aprint_debug_dev(self, "timeout waiting for firmware ok\n");
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (arc_msg0(sc, ARC_REG_INB_MSG0_GET_CONFIG) != 0) {
|
2008-03-05 18:03:36 +03:00
|
|
|
aprint_debug_dev(self, "timeout waiting for get config\n");
|
2007-12-05 21:07:34 +03:00
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (arc_msg0(sc, ARC_REG_INB_MSG0_START_BGRB) != 0) {
|
2008-03-05 18:03:36 +03:00
|
|
|
aprint_debug_dev(self, "timeout waiting to start bg rebuild\n");
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
arc_read_region(sc, ARC_REG_MSGBUF, &fwinfo, sizeof(fwinfo));
|
|
|
|
|
|
|
|
DNPRINTF(ARC_D_INIT, "%s: signature: 0x%08x\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(self), htole32(fwinfo.signature));
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
if (htole32(fwinfo.signature) != ARC_FWINFO_SIGNATURE_GET_CONFIG) {
|
2008-03-05 18:03:36 +03:00
|
|
|
aprint_error_dev(self, "invalid firmware info from iop\n");
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
DNPRINTF(ARC_D_INIT, "%s: request_len: %d\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(self), htole32(fwinfo.request_len));
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
DNPRINTF(ARC_D_INIT, "%s: queue_len: %d\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(self), htole32(fwinfo.queue_len));
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
DNPRINTF(ARC_D_INIT, "%s: sdram_size: %d\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(self), htole32(fwinfo.sdram_size));
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
DNPRINTF(ARC_D_INIT, "%s: sata_ports: %d\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(self), htole32(fwinfo.sata_ports));
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
scsipi_strvis(string, 81, fwinfo.vendor, sizeof(fwinfo.vendor));
|
|
|
|
DNPRINTF(ARC_D_INIT, "%s: vendor: \"%s\"\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(self), string);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
scsipi_strvis(string, 17, fwinfo.model, sizeof(fwinfo.model));
|
2008-03-05 18:03:36 +03:00
|
|
|
aprint_normal_dev(self, "Areca %s Host Adapter RAID controller\n",
|
|
|
|
string);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
scsipi_strvis(string, 33, fwinfo.fw_version, sizeof(fwinfo.fw_version));
|
|
|
|
DNPRINTF(ARC_D_INIT, "%s: version: \"%s\"\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(self), string);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
2008-03-05 18:03:36 +03:00
|
|
|
aprint_normal_dev(self, "%d ports, %dMB SDRAM, firmware <%s>\n",
|
|
|
|
htole32(fwinfo.sata_ports), htole32(fwinfo.sdram_size), string);
|
2008-01-03 02:48:05 +03:00
|
|
|
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
if (htole32(fwinfo.request_len) != ARC_MAX_IOCMDLEN) {
|
2008-03-05 18:03:36 +03:00
|
|
|
aprint_error_dev(self,
|
|
|
|
"unexpected request frame size (%d != %d)\n",
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
htole32(fwinfo.request_len), ARC_MAX_IOCMDLEN);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
sc->sc_req_count = htole32(fwinfo.queue_len);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
#if NBIO > 0
|
|
|
|
static int
|
2008-03-05 18:03:36 +03:00
|
|
|
arc_bioctl(device_t self, u_long cmd, void *addr)
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
{
|
|
|
|
struct arc_softc *sc = device_private(self);
|
|
|
|
int error = 0;
|
|
|
|
|
|
|
|
switch (cmd) {
|
|
|
|
case BIOCINQ:
|
|
|
|
error = arc_bio_inq(sc, (struct bioc_inq *)addr);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case BIOCVOL:
|
|
|
|
error = arc_bio_vol(sc, (struct bioc_vol *)addr);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case BIOCDISK:
|
2008-01-03 02:48:05 +03:00
|
|
|
error = arc_bio_disk_volume(sc, (struct bioc_disk *)addr);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case BIOCDISK_NOVOL:
|
|
|
|
error = arc_bio_disk_novol(sc, (struct bioc_disk *)addr);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
break;
|
|
|
|
|
|
|
|
case BIOCALARM:
|
|
|
|
error = arc_bio_alarm(sc, (struct bioc_alarm *)addr);
|
|
|
|
break;
|
|
|
|
|
2008-01-03 02:48:05 +03:00
|
|
|
case BIOCSETSTATE:
|
|
|
|
error = arc_bio_setstate(sc, (struct bioc_setstate *)addr);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case BIOCVOLOPS:
|
|
|
|
error = arc_bio_volops(sc, (struct bioc_volops *)addr);
|
|
|
|
break;
|
|
|
|
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
default:
|
|
|
|
error = ENOTTY;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
return error;
|
|
|
|
}
|
|
|
|
|
2008-01-03 02:48:05 +03:00
|
|
|
static int
|
|
|
|
arc_fw_parse_status_code(struct arc_softc *sc, uint8_t *reply)
|
|
|
|
{
|
|
|
|
switch (*reply) {
|
|
|
|
case ARC_FW_CMD_RAIDINVAL:
|
|
|
|
printf("%s: firmware error (invalid raid set)\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev));
|
2008-01-03 02:48:05 +03:00
|
|
|
return EINVAL;
|
|
|
|
case ARC_FW_CMD_VOLINVAL:
|
|
|
|
printf("%s: firmware error (invalid volume set)\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev));
|
2008-01-03 02:48:05 +03:00
|
|
|
return EINVAL;
|
|
|
|
case ARC_FW_CMD_NORAID:
|
|
|
|
printf("%s: firmware error (unexistent raid set)\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev));
|
2008-01-03 02:48:05 +03:00
|
|
|
return ENODEV;
|
|
|
|
case ARC_FW_CMD_NOVOLUME:
|
|
|
|
printf("%s: firmware error (unexistent volume set)\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev));
|
2008-01-03 02:48:05 +03:00
|
|
|
return ENODEV;
|
|
|
|
case ARC_FW_CMD_NOPHYSDRV:
|
|
|
|
printf("%s: firmware error (unexistent physical drive)\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev));
|
2008-01-03 02:48:05 +03:00
|
|
|
return ENODEV;
|
|
|
|
case ARC_FW_CMD_PARAM_ERR:
|
|
|
|
printf("%s: firmware error (parameter error)\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev));
|
2008-01-03 02:48:05 +03:00
|
|
|
return EINVAL;
|
|
|
|
case ARC_FW_CMD_UNSUPPORTED:
|
|
|
|
printf("%s: firmware error (unsupported command)\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev));
|
2008-01-03 02:48:05 +03:00
|
|
|
return EOPNOTSUPP;
|
|
|
|
case ARC_FW_CMD_DISKCFG_CHGD:
|
|
|
|
printf("%s: firmware error (disk configuration changed)\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev));
|
2008-01-03 02:48:05 +03:00
|
|
|
return EINVAL;
|
|
|
|
case ARC_FW_CMD_PASS_INVAL:
|
|
|
|
printf("%s: firmware error (invalid password)\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev));
|
2008-01-03 02:48:05 +03:00
|
|
|
return EINVAL;
|
|
|
|
case ARC_FW_CMD_NODISKSPACE:
|
|
|
|
printf("%s: firmware error (no disk space available)\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev));
|
2008-01-03 02:48:05 +03:00
|
|
|
return EOPNOTSUPP;
|
|
|
|
case ARC_FW_CMD_CHECKSUM_ERR:
|
|
|
|
printf("%s: firmware error (checksum error)\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev));
|
2008-01-03 02:48:05 +03:00
|
|
|
return EINVAL;
|
|
|
|
case ARC_FW_CMD_PASS_REQD:
|
|
|
|
printf("%s: firmware error (password required)\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev));
|
2008-01-03 02:48:05 +03:00
|
|
|
return EPERM;
|
|
|
|
case ARC_FW_CMD_OK:
|
|
|
|
default:
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
static int
|
|
|
|
arc_bio_alarm(struct arc_softc *sc, struct bioc_alarm *ba)
|
|
|
|
{
|
|
|
|
uint8_t request[2], reply[1];
|
|
|
|
size_t len;
|
|
|
|
int error = 0;
|
|
|
|
|
|
|
|
switch (ba->ba_opcode) {
|
|
|
|
case BIOC_SAENABLE:
|
|
|
|
case BIOC_SADISABLE:
|
|
|
|
request[0] = ARC_FW_SET_ALARM;
|
|
|
|
request[1] = (ba->ba_opcode == BIOC_SAENABLE) ?
|
|
|
|
ARC_FW_SET_ALARM_ENABLE : ARC_FW_SET_ALARM_DISABLE;
|
|
|
|
len = sizeof(request);
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
case BIOC_SASILENCE:
|
|
|
|
request[0] = ARC_FW_MUTE_ALARM;
|
|
|
|
len = 1;
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
case BIOC_GASTATUS:
|
|
|
|
/* system info is too big/ugly to deal with here */
|
|
|
|
return arc_bio_alarm_state(sc, ba);
|
|
|
|
|
|
|
|
default:
|
|
|
|
return EOPNOTSUPP;
|
|
|
|
}
|
|
|
|
|
|
|
|
error = arc_msgbuf(sc, request, len, reply, sizeof(reply));
|
|
|
|
if (error != 0)
|
|
|
|
return error;
|
|
|
|
|
2008-01-03 02:48:05 +03:00
|
|
|
return arc_fw_parse_status_code(sc, &reply[0]);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
arc_bio_alarm_state(struct arc_softc *sc, struct bioc_alarm *ba)
|
|
|
|
{
|
|
|
|
struct arc_fw_sysinfo *sysinfo;
|
2008-01-03 02:48:05 +03:00
|
|
|
uint8_t request;
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
int error = 0;
|
|
|
|
|
2008-02-28 19:47:53 +03:00
|
|
|
sysinfo = kmem_zalloc(sizeof(*sysinfo), KM_SLEEP);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
request = ARC_FW_SYSINFO;
|
|
|
|
error = arc_msgbuf(sc, &request, sizeof(request),
|
|
|
|
sysinfo, sizeof(struct arc_fw_sysinfo));
|
|
|
|
|
|
|
|
if (error != 0)
|
|
|
|
goto out;
|
|
|
|
|
|
|
|
ba->ba_status = sysinfo->alarm;
|
|
|
|
|
|
|
|
out:
|
2007-12-07 11:50:36 +03:00
|
|
|
kmem_free(sysinfo, sizeof(*sysinfo));
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
return error;
|
|
|
|
}
|
|
|
|
|
2008-01-03 02:48:05 +03:00
|
|
|
static int
|
|
|
|
arc_bio_volops(struct arc_softc *sc, struct bioc_volops *bc)
|
|
|
|
{
|
|
|
|
/* to create a raid set */
|
|
|
|
struct req_craidset {
|
|
|
|
uint8_t cmdcode;
|
|
|
|
uint32_t devmask;
|
|
|
|
uint8_t raidset_name[16];
|
|
|
|
} __packed;
|
|
|
|
|
|
|
|
/* to create a volume set */
|
|
|
|
struct req_cvolset {
|
|
|
|
uint8_t cmdcode;
|
|
|
|
uint8_t raidset;
|
|
|
|
uint8_t volset_name[16];
|
|
|
|
uint64_t capacity;
|
|
|
|
uint8_t raidlevel;
|
|
|
|
uint8_t stripe;
|
|
|
|
uint8_t scsi_chan;
|
|
|
|
uint8_t scsi_target;
|
|
|
|
uint8_t scsi_lun;
|
|
|
|
uint8_t tagqueue;
|
|
|
|
uint8_t cache;
|
|
|
|
uint8_t speed;
|
|
|
|
uint8_t quick_init;
|
|
|
|
} __packed;
|
|
|
|
|
|
|
|
struct scsibus_softc *scsibus_sc = NULL;
|
|
|
|
struct req_craidset req_craidset;
|
|
|
|
struct req_cvolset req_cvolset;
|
|
|
|
uint8_t request[2];
|
|
|
|
uint8_t reply[1];
|
|
|
|
int error = 0;
|
|
|
|
|
|
|
|
switch (bc->bc_opcode) {
|
|
|
|
case BIOC_VCREATE_VOLUME:
|
|
|
|
{
|
|
|
|
/*
|
|
|
|
* Zero out the structs so that we use some defaults
|
|
|
|
* in raid and volume sets.
|
|
|
|
*/
|
|
|
|
memset(&req_craidset, 0, sizeof(req_craidset));
|
|
|
|
memset(&req_cvolset, 0, sizeof(req_cvolset));
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Firstly we have to create the raid set and
|
|
|
|
* use the default name for all them.
|
|
|
|
*/
|
|
|
|
req_craidset.cmdcode = ARC_FW_CREATE_RAIDSET;
|
|
|
|
req_craidset.devmask = bc->bc_devmask;
|
|
|
|
error = arc_msgbuf(sc, &req_craidset, sizeof(req_craidset),
|
|
|
|
reply, sizeof(reply));
|
|
|
|
if (error != 0)
|
|
|
|
return error;
|
|
|
|
|
|
|
|
error = arc_fw_parse_status_code(sc, &reply[0]);
|
|
|
|
if (error) {
|
|
|
|
printf("%s: create raidset%d failed\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev), bc->bc_volid);
|
2008-01-03 02:48:05 +03:00
|
|
|
return error;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* At this point the raid set was created, so it's
|
|
|
|
* time to create the volume set.
|
|
|
|
*/
|
|
|
|
req_cvolset.cmdcode = ARC_FW_CREATE_VOLUME;
|
|
|
|
req_cvolset.raidset = bc->bc_volid;
|
|
|
|
req_cvolset.capacity = bc->bc_size * ARC_BLOCKSIZE;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Set the RAID level.
|
|
|
|
*/
|
|
|
|
switch (bc->bc_level) {
|
|
|
|
case 0:
|
|
|
|
case 1:
|
|
|
|
req_cvolset.raidlevel = bc->bc_level;
|
|
|
|
break;
|
2008-03-03 17:57:22 +03:00
|
|
|
case BIOC_SVOL_RAID10:
|
|
|
|
req_cvolset.raidlevel = 1;
|
|
|
|
break;
|
2008-01-03 02:48:05 +03:00
|
|
|
case 3:
|
|
|
|
req_cvolset.raidlevel = ARC_FW_VOL_RAIDLEVEL_3;
|
|
|
|
break;
|
|
|
|
case 5:
|
|
|
|
req_cvolset.raidlevel = ARC_FW_VOL_RAIDLEVEL_5;
|
|
|
|
break;
|
|
|
|
case 6:
|
|
|
|
req_cvolset.raidlevel = ARC_FW_VOL_RAIDLEVEL_6;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
return EOPNOTSUPP;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Set the stripe size.
|
|
|
|
*/
|
|
|
|
switch (bc->bc_stripe) {
|
|
|
|
case 4:
|
|
|
|
req_cvolset.stripe = 0;
|
|
|
|
break;
|
|
|
|
case 8:
|
|
|
|
req_cvolset.stripe = 1;
|
|
|
|
break;
|
|
|
|
case 16:
|
|
|
|
req_cvolset.stripe = 2;
|
|
|
|
break;
|
|
|
|
case 32:
|
|
|
|
req_cvolset.stripe = 3;
|
|
|
|
break;
|
|
|
|
case 64:
|
|
|
|
req_cvolset.stripe = 4;
|
|
|
|
break;
|
|
|
|
case 128:
|
|
|
|
req_cvolset.stripe = 5;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
req_cvolset.stripe = 4; /* by default 64K */
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
req_cvolset.scsi_chan = bc->bc_channel;
|
|
|
|
req_cvolset.scsi_target = bc->bc_target;
|
|
|
|
req_cvolset.scsi_lun = bc->bc_lun;
|
|
|
|
req_cvolset.tagqueue = 1; /* always enabled */
|
|
|
|
req_cvolset.cache = 1; /* always enabled */
|
|
|
|
req_cvolset.speed = 4; /* always max speed */
|
|
|
|
|
2008-03-03 17:57:22 +03:00
|
|
|
/* RAID 1 and 1+0 levels need foreground initialization */
|
|
|
|
if (bc->bc_level == 1 || bc->bc_level == BIOC_SVOL_RAID10)
|
2008-03-01 19:33:29 +03:00
|
|
|
req_cvolset.quick_init = 1; /* foreground init */
|
|
|
|
|
2008-01-03 02:48:05 +03:00
|
|
|
error = arc_msgbuf(sc, &req_cvolset, sizeof(req_cvolset),
|
|
|
|
reply, sizeof(reply));
|
|
|
|
if (error != 0)
|
|
|
|
return error;
|
|
|
|
|
|
|
|
error = arc_fw_parse_status_code(sc, &reply[0]);
|
|
|
|
if (error) {
|
|
|
|
printf("%s: create volumeset%d failed\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev), bc->bc_volid);
|
2008-01-03 02:48:05 +03:00
|
|
|
return error;
|
|
|
|
}
|
|
|
|
|
2008-03-01 19:33:29 +03:00
|
|
|
/*
|
|
|
|
* If we are creating a RAID 1 or RAID 1+0 volume,
|
|
|
|
* the volume will be created immediately but it won't
|
|
|
|
* be available until the initialization is done... so
|
|
|
|
* don't bother attaching the sd(4) device.
|
|
|
|
*/
|
2008-03-03 17:57:22 +03:00
|
|
|
if (bc->bc_level == 1 || bc->bc_level == BIOC_SVOL_RAID10)
|
2008-03-01 19:33:29 +03:00
|
|
|
break;
|
|
|
|
|
2008-01-03 02:48:05 +03:00
|
|
|
/*
|
|
|
|
* Do a rescan on the bus to attach the device associated
|
|
|
|
* with the new volume.
|
|
|
|
*/
|
|
|
|
scsibus_sc = device_private(sc->sc_scsibus_dv);
|
|
|
|
(void)scsi_probe_bus(scsibus_sc, bc->bc_target, bc->bc_lun);
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case BIOC_VREMOVE_VOLUME:
|
|
|
|
{
|
|
|
|
/*
|
|
|
|
* Remove the volume set specified in bc_volid.
|
|
|
|
*/
|
|
|
|
request[0] = ARC_FW_DELETE_VOLUME;
|
|
|
|
request[1] = bc->bc_volid;
|
|
|
|
error = arc_msgbuf(sc, request, sizeof(request),
|
|
|
|
reply, sizeof(reply));
|
|
|
|
if (error != 0)
|
|
|
|
return error;
|
|
|
|
|
|
|
|
error = arc_fw_parse_status_code(sc, &reply[0]);
|
|
|
|
if (error) {
|
|
|
|
printf("%s: delete volumeset%d failed\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev), bc->bc_volid);
|
2008-01-03 02:48:05 +03:00
|
|
|
return error;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Detach the sd(4) device associated with the volume,
|
|
|
|
* but if there's an error don't make it a priority.
|
|
|
|
*/
|
|
|
|
error = scsipi_target_detach(&sc->sc_chan, bc->bc_target,
|
|
|
|
bc->bc_lun, 0);
|
|
|
|
if (error)
|
|
|
|
printf("%s: couldn't detach sd device for volume %d "
|
|
|
|
"at %u:%u.%u (error=%d)\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev), bc->bc_volid,
|
2008-01-03 02:48:05 +03:00
|
|
|
bc->bc_channel, bc->bc_target, bc->bc_lun, error);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* and remove the raid set specified in bc_volid,
|
|
|
|
* we only care about volumes.
|
|
|
|
*/
|
|
|
|
request[0] = ARC_FW_DELETE_RAIDSET;
|
|
|
|
request[1] = bc->bc_volid;
|
|
|
|
error = arc_msgbuf(sc, request, sizeof(request),
|
|
|
|
reply, sizeof(reply));
|
|
|
|
if (error != 0)
|
|
|
|
return error;
|
|
|
|
|
|
|
|
error = arc_fw_parse_status_code(sc, &reply[0]);
|
|
|
|
if (error) {
|
|
|
|
printf("%s: delete raidset%d failed\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev), bc->bc_volid);
|
2008-01-03 02:48:05 +03:00
|
|
|
return error;
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
return EOPNOTSUPP;
|
|
|
|
}
|
|
|
|
|
|
|
|
return error;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
arc_bio_setstate(struct arc_softc *sc, struct bioc_setstate *bs)
|
|
|
|
{
|
|
|
|
/* for a hotspare disk */
|
|
|
|
struct request_hs {
|
|
|
|
uint8_t cmdcode;
|
|
|
|
uint32_t devmask;
|
|
|
|
} __packed;
|
|
|
|
|
|
|
|
/* for a pass-through disk */
|
|
|
|
struct request_pt {
|
|
|
|
uint8_t cmdcode;
|
|
|
|
uint8_t devid;
|
|
|
|
uint8_t scsi_chan;
|
|
|
|
uint8_t scsi_id;
|
|
|
|
uint8_t scsi_lun;
|
|
|
|
uint8_t tagged_queue;
|
|
|
|
uint8_t cache_mode;
|
|
|
|
uint8_t max_speed;
|
|
|
|
} __packed;
|
|
|
|
|
|
|
|
struct scsibus_softc *scsibus_sc = NULL;
|
|
|
|
struct request_hs req_hs; /* to add/remove hotspare */
|
|
|
|
struct request_pt req_pt; /* to add a pass-through */
|
|
|
|
uint8_t req_gen[2];
|
|
|
|
uint8_t reply[1];
|
|
|
|
int error = 0;
|
|
|
|
|
|
|
|
switch (bs->bs_status) {
|
|
|
|
case BIOC_SSHOTSPARE:
|
|
|
|
{
|
|
|
|
req_hs.cmdcode = ARC_FW_CREATE_HOTSPARE;
|
|
|
|
req_hs.devmask = (1 << bs->bs_target);
|
|
|
|
goto hotspare;
|
|
|
|
}
|
|
|
|
case BIOC_SSDELHOTSPARE:
|
|
|
|
{
|
|
|
|
req_hs.cmdcode = ARC_FW_DELETE_HOTSPARE;
|
|
|
|
req_hs.devmask = (1 << bs->bs_target);
|
|
|
|
goto hotspare;
|
|
|
|
}
|
|
|
|
case BIOC_SSPASSTHRU:
|
|
|
|
{
|
|
|
|
req_pt.cmdcode = ARC_FW_CREATE_PASSTHRU;
|
|
|
|
req_pt.devid = bs->bs_other_id; /* this wants device# */
|
|
|
|
req_pt.scsi_chan = bs->bs_channel;
|
|
|
|
req_pt.scsi_id = bs->bs_target;
|
|
|
|
req_pt.scsi_lun = bs->bs_lun;
|
|
|
|
req_pt.tagged_queue = 1; /* always enabled */
|
|
|
|
req_pt.cache_mode = 1; /* always enabled */
|
|
|
|
req_pt.max_speed = 4; /* always max speed */
|
|
|
|
|
|
|
|
error = arc_msgbuf(sc, &req_pt, sizeof(req_pt),
|
|
|
|
reply, sizeof(reply));
|
|
|
|
if (error != 0)
|
|
|
|
return error;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Do a rescan on the bus to attach the new device
|
|
|
|
* associated with the pass-through disk.
|
|
|
|
*/
|
|
|
|
scsibus_sc = device_private(sc->sc_scsibus_dv);
|
|
|
|
(void)scsi_probe_bus(scsibus_sc, bs->bs_target, bs->bs_lun);
|
|
|
|
|
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
case BIOC_SSDELPASSTHRU:
|
|
|
|
{
|
|
|
|
req_gen[0] = ARC_FW_DELETE_PASSTHRU;
|
|
|
|
req_gen[1] = bs->bs_target;
|
|
|
|
error = arc_msgbuf(sc, &req_gen, sizeof(req_gen),
|
|
|
|
reply, sizeof(reply));
|
|
|
|
if (error != 0)
|
|
|
|
return error;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Detach the sd device associated with this pass-through disk.
|
|
|
|
*/
|
|
|
|
error = scsipi_target_detach(&sc->sc_chan, bs->bs_target,
|
|
|
|
bs->bs_lun, 0);
|
|
|
|
if (error)
|
|
|
|
printf("%s: couldn't detach sd device for the "
|
|
|
|
"pass-through disk at %u:%u.%u (error=%d)\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev),
|
2008-01-03 02:48:05 +03:00
|
|
|
bs->bs_channel, bs->bs_target, bs->bs_lun, error);
|
|
|
|
|
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
case BIOC_SSCHECKSTART_VOL:
|
|
|
|
{
|
|
|
|
req_gen[0] = ARC_FW_START_CHECKVOL;
|
|
|
|
req_gen[1] = bs->bs_volid;
|
|
|
|
error = arc_msgbuf(sc, &req_gen, sizeof(req_gen),
|
|
|
|
reply, sizeof(reply));
|
|
|
|
if (error != 0)
|
|
|
|
return error;
|
|
|
|
|
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
case BIOC_SSCHECKSTOP_VOL:
|
|
|
|
{
|
|
|
|
uint8_t req = ARC_FW_STOP_CHECKVOL;
|
|
|
|
error = arc_msgbuf(sc, &req, 1, reply, sizeof(reply));
|
|
|
|
if (error != 0)
|
|
|
|
return error;
|
|
|
|
|
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
return EOPNOTSUPP;
|
|
|
|
}
|
|
|
|
|
|
|
|
hotspare:
|
|
|
|
error = arc_msgbuf(sc, &req_hs, sizeof(req_hs),
|
|
|
|
reply, sizeof(reply));
|
|
|
|
if (error != 0)
|
|
|
|
return error;
|
|
|
|
|
|
|
|
out:
|
|
|
|
return arc_fw_parse_status_code(sc, &reply[0]);
|
|
|
|
}
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
static int
|
|
|
|
arc_bio_inq(struct arc_softc *sc, struct bioc_inq *bi)
|
|
|
|
{
|
|
|
|
uint8_t request[2];
|
2008-02-29 21:15:41 +03:00
|
|
|
struct arc_fw_sysinfo *sysinfo = NULL;
|
2008-01-03 02:48:05 +03:00
|
|
|
struct arc_fw_raidinfo *raidinfo;
|
2008-02-29 20:45:04 +03:00
|
|
|
int nvols = 0, i;
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
int error = 0;
|
|
|
|
|
2008-02-28 19:47:53 +03:00
|
|
|
raidinfo = kmem_zalloc(sizeof(*raidinfo), KM_SLEEP);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
2008-02-29 21:15:41 +03:00
|
|
|
if (!sc->sc_maxraidset || !sc->sc_maxvolset || !sc->sc_cchans) {
|
|
|
|
sysinfo = kmem_zalloc(sizeof(*sysinfo), KM_SLEEP);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
2008-02-29 21:15:41 +03:00
|
|
|
request[0] = ARC_FW_SYSINFO;
|
|
|
|
error = arc_msgbuf(sc, request, 1, sysinfo,
|
|
|
|
sizeof(struct arc_fw_sysinfo));
|
|
|
|
if (error != 0)
|
|
|
|
goto out;
|
|
|
|
|
|
|
|
sc->sc_maxraidset = sysinfo->max_raid_set;
|
|
|
|
sc->sc_maxvolset = sysinfo->max_volume_set;
|
|
|
|
sc->sc_cchans = sysinfo->ide_channels;
|
|
|
|
}
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
2008-01-03 02:48:05 +03:00
|
|
|
request[0] = ARC_FW_RAIDINFO;
|
2008-02-29 20:45:04 +03:00
|
|
|
for (i = 0; i < sc->sc_maxraidset; i++) {
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
request[1] = i;
|
2008-01-03 02:48:05 +03:00
|
|
|
error = arc_msgbuf(sc, request, sizeof(request), raidinfo,
|
|
|
|
sizeof(struct arc_fw_raidinfo));
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
if (error != 0)
|
|
|
|
goto out;
|
|
|
|
|
2008-09-24 02:22:41 +04:00
|
|
|
nvols += raidinfo->volumes;
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
}
|
|
|
|
|
2008-03-05 18:03:36 +03:00
|
|
|
strlcpy(bi->bi_dev, device_xname(sc->sc_dev), sizeof(bi->bi_dev));
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
bi->bi_novol = nvols;
|
2008-02-29 20:45:04 +03:00
|
|
|
bi->bi_nodisk = sc->sc_cchans;
|
2008-01-03 02:48:05 +03:00
|
|
|
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
out:
|
2008-02-29 21:15:41 +03:00
|
|
|
if (sysinfo)
|
|
|
|
kmem_free(sysinfo, sizeof(*sysinfo));
|
2008-01-03 02:48:05 +03:00
|
|
|
kmem_free(raidinfo, sizeof(*raidinfo));
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
return error;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
arc_bio_getvol(struct arc_softc *sc, int vol, struct arc_fw_volinfo *volinfo)
|
|
|
|
{
|
|
|
|
uint8_t request[2];
|
|
|
|
int error = 0;
|
2008-02-29 20:45:04 +03:00
|
|
|
int nvols = 0, i;
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
request[0] = ARC_FW_VOLINFO;
|
2008-02-29 20:45:04 +03:00
|
|
|
for (i = 0; i < sc->sc_maxvolset; i++) {
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
request[1] = i;
|
|
|
|
error = arc_msgbuf(sc, request, sizeof(request), volinfo,
|
|
|
|
sizeof(struct arc_fw_volinfo));
|
|
|
|
if (error != 0)
|
|
|
|
goto out;
|
|
|
|
|
2008-01-03 02:48:05 +03:00
|
|
|
if (volinfo->capacity == 0 && volinfo->capacity2 == 0)
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
continue;
|
|
|
|
|
|
|
|
if (nvols == vol)
|
|
|
|
break;
|
|
|
|
|
|
|
|
nvols++;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (nvols != vol ||
|
2008-01-03 02:48:05 +03:00
|
|
|
(volinfo->capacity == 0 && volinfo->capacity2 == 0)) {
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
error = ENODEV;
|
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
|
|
|
|
out:
|
|
|
|
return error;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
arc_bio_vol(struct arc_softc *sc, struct bioc_vol *bv)
|
|
|
|
{
|
|
|
|
struct arc_fw_volinfo *volinfo;
|
|
|
|
uint64_t blocks;
|
|
|
|
uint32_t status;
|
|
|
|
int error = 0;
|
|
|
|
|
2008-02-28 19:47:53 +03:00
|
|
|
volinfo = kmem_zalloc(sizeof(*volinfo), KM_SLEEP);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
error = arc_bio_getvol(sc, bv->bv_volid, volinfo);
|
|
|
|
if (error != 0)
|
|
|
|
goto out;
|
|
|
|
|
|
|
|
bv->bv_percent = -1;
|
|
|
|
bv->bv_seconds = 0;
|
|
|
|
|
|
|
|
status = htole32(volinfo->volume_status);
|
|
|
|
if (status == 0x0) {
|
|
|
|
if (htole32(volinfo->fail_mask) == 0x0)
|
|
|
|
bv->bv_status = BIOC_SVONLINE;
|
|
|
|
else
|
|
|
|
bv->bv_status = BIOC_SVDEGRADED;
|
|
|
|
} else if (status & ARC_FW_VOL_STATUS_NEED_REGEN) {
|
|
|
|
bv->bv_status = BIOC_SVDEGRADED;
|
|
|
|
} else if (status & ARC_FW_VOL_STATUS_FAILED) {
|
|
|
|
bv->bv_status = BIOC_SVOFFLINE;
|
|
|
|
} else if (status & ARC_FW_VOL_STATUS_INITTING) {
|
|
|
|
bv->bv_status = BIOC_SVBUILDING;
|
2008-01-03 02:48:05 +03:00
|
|
|
bv->bv_percent = htole32(volinfo->progress);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
} else if (status & ARC_FW_VOL_STATUS_REBUILDING) {
|
|
|
|
bv->bv_status = BIOC_SVREBUILD;
|
2008-01-03 02:48:05 +03:00
|
|
|
bv->bv_percent = htole32(volinfo->progress);
|
2007-12-07 14:51:21 +03:00
|
|
|
} else if (status & ARC_FW_VOL_STATUS_MIGRATING) {
|
|
|
|
bv->bv_status = BIOC_SVMIGRATING;
|
2008-01-03 02:48:05 +03:00
|
|
|
bv->bv_percent = htole32(volinfo->progress);
|
|
|
|
} else if (status & ARC_FW_VOL_STATUS_CHECKING) {
|
|
|
|
bv->bv_status = BIOC_SVCHECKING;
|
|
|
|
bv->bv_percent = htole32(volinfo->progress);
|
2008-03-01 19:33:29 +03:00
|
|
|
} else if (status & ARC_FW_VOL_STATUS_NEED_INIT) {
|
|
|
|
bv->bv_status = BIOC_SVOFFLINE;
|
|
|
|
} else {
|
|
|
|
printf("%s: volume %d status 0x%x\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev), bv->bv_volid, status);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
blocks = (uint64_t)htole32(volinfo->capacity2) << 32;
|
|
|
|
blocks += (uint64_t)htole32(volinfo->capacity);
|
|
|
|
bv->bv_size = blocks * ARC_BLOCKSIZE; /* XXX */
|
|
|
|
|
|
|
|
switch (volinfo->raid_level) {
|
|
|
|
case ARC_FW_VOL_RAIDLEVEL_0:
|
|
|
|
bv->bv_level = 0;
|
|
|
|
break;
|
|
|
|
case ARC_FW_VOL_RAIDLEVEL_1:
|
2008-03-03 17:57:22 +03:00
|
|
|
if (volinfo->member_disks > 2)
|
|
|
|
bv->bv_level = BIOC_SVOL_RAID10;
|
|
|
|
else
|
|
|
|
bv->bv_level = 1;
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
break;
|
|
|
|
case ARC_FW_VOL_RAIDLEVEL_3:
|
|
|
|
bv->bv_level = 3;
|
|
|
|
break;
|
|
|
|
case ARC_FW_VOL_RAIDLEVEL_5:
|
|
|
|
bv->bv_level = 5;
|
|
|
|
break;
|
|
|
|
case ARC_FW_VOL_RAIDLEVEL_6:
|
|
|
|
bv->bv_level = 6;
|
|
|
|
break;
|
|
|
|
case ARC_FW_VOL_RAIDLEVEL_PASSTHRU:
|
2008-01-03 02:48:05 +03:00
|
|
|
bv->bv_level = BIOC_SVOL_PASSTHRU;
|
|
|
|
break;
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
default:
|
|
|
|
bv->bv_level = -1;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
bv->bv_nodisk = volinfo->member_disks;
|
2008-01-03 02:48:05 +03:00
|
|
|
bv->bv_stripe_size = volinfo->stripe_size / 2;
|
|
|
|
snprintf(bv->bv_dev, sizeof(bv->bv_dev), "sd%d", bv->bv_volid);
|
|
|
|
scsipi_strvis(bv->bv_vendor, sizeof(bv->bv_vendor), volinfo->set_name,
|
|
|
|
sizeof(volinfo->set_name));
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
out:
|
2007-12-07 11:50:36 +03:00
|
|
|
kmem_free(volinfo, sizeof(*volinfo));
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
return error;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
2008-01-03 02:48:05 +03:00
|
|
|
arc_bio_disk_novol(struct arc_softc *sc, struct bioc_disk *bd)
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
{
|
|
|
|
struct arc_fw_diskinfo *diskinfo;
|
2008-01-03 02:48:05 +03:00
|
|
|
uint8_t request[2];
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
int error = 0;
|
2008-01-03 02:48:05 +03:00
|
|
|
|
2008-02-28 19:47:53 +03:00
|
|
|
diskinfo = kmem_zalloc(sizeof(*diskinfo), KM_SLEEP);
|
2008-01-03 02:48:05 +03:00
|
|
|
|
2008-02-29 20:45:04 +03:00
|
|
|
if (bd->bd_diskid >= sc->sc_cchans) {
|
2008-01-03 02:48:05 +03:00
|
|
|
error = ENODEV;
|
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
|
|
|
|
request[0] = ARC_FW_DISKINFO;
|
|
|
|
request[1] = bd->bd_diskid;
|
|
|
|
error = arc_msgbuf(sc, request, sizeof(request),
|
|
|
|
diskinfo, sizeof(struct arc_fw_diskinfo));
|
|
|
|
if (error != 0)
|
2008-02-29 15:37:43 +03:00
|
|
|
goto out;
|
2008-01-03 02:48:05 +03:00
|
|
|
|
|
|
|
/* skip disks with no capacity */
|
|
|
|
if (htole32(diskinfo->capacity) == 0 &&
|
|
|
|
htole32(diskinfo->capacity2) == 0)
|
|
|
|
goto out;
|
|
|
|
|
|
|
|
bd->bd_disknovol = true;
|
|
|
|
arc_bio_disk_filldata(sc, bd, diskinfo, bd->bd_diskid);
|
|
|
|
|
|
|
|
out:
|
|
|
|
kmem_free(diskinfo, sizeof(*diskinfo));
|
|
|
|
return error;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
arc_bio_disk_filldata(struct arc_softc *sc, struct bioc_disk *bd,
|
|
|
|
struct arc_fw_diskinfo *diskinfo, int diskid)
|
|
|
|
{
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
uint64_t blocks;
|
|
|
|
char model[81];
|
|
|
|
char serial[41];
|
|
|
|
char rev[17];
|
|
|
|
|
2008-09-24 02:22:41 +04:00
|
|
|
/* Ignore bit zero for now, we don't know what it means */
|
|
|
|
diskinfo->device_state &= ~0x1;
|
|
|
|
|
2008-04-03 17:59:00 +04:00
|
|
|
switch (diskinfo->device_state) {
|
2008-09-24 02:22:41 +04:00
|
|
|
case ARC_FW_DISK_FAILED:
|
|
|
|
bd->bd_status = BIOC_SDFAILED;
|
|
|
|
break;
|
2008-01-03 02:48:05 +03:00
|
|
|
case ARC_FW_DISK_PASSTHRU:
|
|
|
|
bd->bd_status = BIOC_SDPASSTHRU;
|
|
|
|
break;
|
2008-09-24 02:22:41 +04:00
|
|
|
case ARC_FW_DISK_NORMAL:
|
2008-01-03 02:48:05 +03:00
|
|
|
bd->bd_status = BIOC_SDONLINE;
|
|
|
|
break;
|
|
|
|
case ARC_FW_DISK_HOTSPARE:
|
|
|
|
bd->bd_status = BIOC_SDHOTSPARE;
|
|
|
|
break;
|
|
|
|
case ARC_FW_DISK_UNUSED:
|
|
|
|
bd->bd_status = BIOC_SDUNUSED;
|
|
|
|
break;
|
2008-02-29 20:45:04 +03:00
|
|
|
case 0:
|
|
|
|
/* disk has been disconnected */
|
|
|
|
bd->bd_status = BIOC_SDOFFLINE;
|
|
|
|
bd->bd_channel = 1;
|
|
|
|
bd->bd_target = 0;
|
|
|
|
bd->bd_lun = 0;
|
|
|
|
strlcpy(bd->bd_vendor, "disk missing", sizeof(bd->bd_vendor));
|
|
|
|
break;
|
2008-01-03 02:48:05 +03:00
|
|
|
default:
|
|
|
|
printf("%s: unknown disk device_state: 0x%x\n", __func__,
|
2008-04-03 17:59:00 +04:00
|
|
|
diskinfo->device_state);
|
2008-01-03 02:48:05 +03:00
|
|
|
bd->bd_status = BIOC_SDINVALID;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
blocks = (uint64_t)htole32(diskinfo->capacity2) << 32;
|
|
|
|
blocks += (uint64_t)htole32(diskinfo->capacity);
|
|
|
|
bd->bd_size = blocks * ARC_BLOCKSIZE; /* XXX */
|
|
|
|
|
|
|
|
scsipi_strvis(model, 81, diskinfo->model, sizeof(diskinfo->model));
|
|
|
|
scsipi_strvis(serial, 41, diskinfo->serial, sizeof(diskinfo->serial));
|
|
|
|
scsipi_strvis(rev, 17, diskinfo->firmware_rev,
|
|
|
|
sizeof(diskinfo->firmware_rev));
|
|
|
|
|
|
|
|
snprintf(bd->bd_vendor, sizeof(bd->bd_vendor), "%s %s", model, rev);
|
|
|
|
strlcpy(bd->bd_serial, serial, sizeof(bd->bd_serial));
|
|
|
|
|
|
|
|
#if 0
|
|
|
|
bd->bd_channel = diskinfo->scsi_attr.channel;
|
|
|
|
bd->bd_target = diskinfo->scsi_attr.target;
|
|
|
|
bd->bd_lun = diskinfo->scsi_attr.lun;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/*
|
|
|
|
* the firwmare doesnt seem to fill scsi_attr in, so fake it with
|
|
|
|
* the diskid.
|
|
|
|
*/
|
|
|
|
bd->bd_channel = 0;
|
|
|
|
bd->bd_target = diskid;
|
|
|
|
bd->bd_lun = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
arc_bio_disk_volume(struct arc_softc *sc, struct bioc_disk *bd)
|
|
|
|
{
|
|
|
|
struct arc_fw_raidinfo *raidinfo;
|
|
|
|
struct arc_fw_volinfo *volinfo;
|
|
|
|
struct arc_fw_diskinfo *diskinfo;
|
2008-02-29 20:45:04 +03:00
|
|
|
uint8_t request[2];
|
2008-01-03 02:48:05 +03:00
|
|
|
int error = 0;
|
|
|
|
|
2008-02-28 19:47:53 +03:00
|
|
|
volinfo = kmem_zalloc(sizeof(*volinfo), KM_SLEEP);
|
|
|
|
raidinfo = kmem_zalloc(sizeof(*raidinfo), KM_SLEEP);
|
|
|
|
diskinfo = kmem_zalloc(sizeof(*diskinfo), KM_SLEEP);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
error = arc_bio_getvol(sc, bd->bd_volid, volinfo);
|
|
|
|
if (error != 0)
|
|
|
|
goto out;
|
|
|
|
|
|
|
|
request[0] = ARC_FW_RAIDINFO;
|
|
|
|
request[1] = volinfo->raid_set_number;
|
2007-12-07 11:50:36 +03:00
|
|
|
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
error = arc_msgbuf(sc, request, sizeof(request), raidinfo,
|
|
|
|
sizeof(struct arc_fw_raidinfo));
|
|
|
|
if (error != 0)
|
|
|
|
goto out;
|
|
|
|
|
2008-02-29 20:45:04 +03:00
|
|
|
if (bd->bd_diskid >= sc->sc_cchans ||
|
|
|
|
bd->bd_diskid >= raidinfo->member_devices) {
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
error = ENODEV;
|
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
|
2008-02-29 20:45:04 +03:00
|
|
|
if (raidinfo->device_array[bd->bd_diskid] == 0xff) {
|
|
|
|
/*
|
|
|
|
* The disk has been disconnected, mark it offline
|
|
|
|
* and put it on another bus.
|
|
|
|
*/
|
|
|
|
bd->bd_channel = 1;
|
|
|
|
bd->bd_target = 0;
|
|
|
|
bd->bd_lun = 0;
|
|
|
|
bd->bd_status = BIOC_SDOFFLINE;
|
|
|
|
strlcpy(bd->bd_vendor, "disk missing", sizeof(bd->bd_vendor));
|
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
request[0] = ARC_FW_DISKINFO;
|
|
|
|
request[1] = raidinfo->device_array[bd->bd_diskid];
|
|
|
|
error = arc_msgbuf(sc, request, sizeof(request), diskinfo,
|
|
|
|
sizeof(struct arc_fw_diskinfo));
|
|
|
|
if (error != 0)
|
|
|
|
goto out;
|
|
|
|
|
2008-01-03 02:48:05 +03:00
|
|
|
/* now fill our bio disk with data from the firmware */
|
|
|
|
arc_bio_disk_filldata(sc, bd, diskinfo,
|
|
|
|
raidinfo->device_array[bd->bd_diskid]);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
out:
|
2007-12-07 11:50:36 +03:00
|
|
|
kmem_free(raidinfo, sizeof(*raidinfo));
|
|
|
|
kmem_free(volinfo, sizeof(*volinfo));
|
2008-01-03 02:48:05 +03:00
|
|
|
kmem_free(diskinfo, sizeof(*diskinfo));
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
return error;
|
|
|
|
}
|
|
|
|
#endif /* NBIO > 0 */
|
|
|
|
|
|
|
|
uint8_t
|
|
|
|
arc_msg_cksum(void *cmd, uint16_t len)
|
|
|
|
{
|
|
|
|
uint8_t *buf = cmd;
|
|
|
|
uint8_t cksum;
|
|
|
|
int i;
|
|
|
|
|
|
|
|
cksum = (uint8_t)(len >> 8) + (uint8_t)len;
|
|
|
|
for (i = 0; i < len; i++)
|
|
|
|
cksum += buf[i];
|
|
|
|
|
|
|
|
return cksum;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
int
|
|
|
|
arc_msgbuf(struct arc_softc *sc, void *wptr, size_t wbuflen, void *rptr,
|
|
|
|
size_t rbuflen)
|
|
|
|
{
|
|
|
|
uint8_t rwbuf[ARC_REG_IOC_RWBUF_MAXLEN];
|
|
|
|
uint8_t *wbuf, *rbuf;
|
|
|
|
int wlen, wdone = 0, rlen, rdone = 0;
|
|
|
|
struct arc_fw_bufhdr *bufhdr;
|
|
|
|
uint32_t reg, rwlen;
|
|
|
|
int error = 0;
|
|
|
|
#ifdef ARC_DEBUG
|
|
|
|
int i;
|
|
|
|
#endif
|
|
|
|
|
2007-12-07 11:50:36 +03:00
|
|
|
wbuf = rbuf = NULL;
|
|
|
|
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
DNPRINTF(ARC_D_DB, "%s: arc_msgbuf wbuflen: %d rbuflen: %d\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev), wbuflen, rbuflen);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
wlen = sizeof(struct arc_fw_bufhdr) + wbuflen + 1; /* 1 for cksum */
|
2007-12-07 11:50:36 +03:00
|
|
|
wbuf = kmem_alloc(wlen, KM_SLEEP);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
rlen = sizeof(struct arc_fw_bufhdr) + rbuflen + 1; /* 1 for cksum */
|
2007-12-07 11:50:36 +03:00
|
|
|
rbuf = kmem_alloc(rlen, KM_SLEEP);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
DNPRINTF(ARC_D_DB, "%s: arc_msgbuf wlen: %d rlen: %d\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev), wlen, rlen);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
bufhdr = (struct arc_fw_bufhdr *)wbuf;
|
|
|
|
bufhdr->hdr = arc_fw_hdr;
|
|
|
|
bufhdr->len = htole16(wbuflen);
|
|
|
|
memcpy(wbuf + sizeof(struct arc_fw_bufhdr), wptr, wbuflen);
|
|
|
|
wbuf[wlen - 1] = arc_msg_cksum(wptr, wbuflen);
|
|
|
|
|
2007-12-07 11:50:36 +03:00
|
|
|
arc_lock(sc);
|
|
|
|
if (arc_read(sc, ARC_REG_OUTB_DOORBELL) != 0) {
|
|
|
|
error = EBUSY;
|
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
reg = ARC_REG_OUTB_DOORBELL_READ_OK;
|
|
|
|
|
|
|
|
do {
|
|
|
|
if ((reg & ARC_REG_OUTB_DOORBELL_READ_OK) && wdone < wlen) {
|
|
|
|
memset(rwbuf, 0, sizeof(rwbuf));
|
|
|
|
rwlen = (wlen - wdone) % sizeof(rwbuf);
|
|
|
|
memcpy(rwbuf, &wbuf[wdone], rwlen);
|
|
|
|
|
|
|
|
#ifdef ARC_DEBUG
|
|
|
|
if (arcdebug & ARC_D_DB) {
|
|
|
|
printf("%s: write %d:",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev), rwlen);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
for (i = 0; i < rwlen; i++)
|
|
|
|
printf(" 0x%02x", rwbuf[i]);
|
|
|
|
printf("\n");
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* copy the chunk to the hw */
|
|
|
|
arc_write(sc, ARC_REG_IOC_WBUF_LEN, rwlen);
|
|
|
|
arc_write_region(sc, ARC_REG_IOC_WBUF, rwbuf,
|
|
|
|
sizeof(rwbuf));
|
|
|
|
|
|
|
|
/* say we have a buffer for the hw */
|
|
|
|
arc_write(sc, ARC_REG_INB_DOORBELL,
|
|
|
|
ARC_REG_INB_DOORBELL_WRITE_OK);
|
|
|
|
|
|
|
|
wdone += rwlen;
|
|
|
|
}
|
|
|
|
|
|
|
|
while ((reg = arc_read(sc, ARC_REG_OUTB_DOORBELL)) == 0)
|
|
|
|
arc_wait(sc);
|
2008-01-03 02:48:05 +03:00
|
|
|
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
arc_write(sc, ARC_REG_OUTB_DOORBELL, reg);
|
|
|
|
|
|
|
|
DNPRINTF(ARC_D_DB, "%s: reg: 0x%08x\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev), reg);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
if ((reg & ARC_REG_OUTB_DOORBELL_WRITE_OK) && rdone < rlen) {
|
|
|
|
rwlen = arc_read(sc, ARC_REG_IOC_RBUF_LEN);
|
|
|
|
if (rwlen > sizeof(rwbuf)) {
|
|
|
|
DNPRINTF(ARC_D_DB, "%s: rwlen too big\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev));
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
error = EIO;
|
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
|
|
|
|
arc_read_region(sc, ARC_REG_IOC_RBUF, rwbuf,
|
|
|
|
sizeof(rwbuf));
|
|
|
|
|
|
|
|
arc_write(sc, ARC_REG_INB_DOORBELL,
|
|
|
|
ARC_REG_INB_DOORBELL_READ_OK);
|
|
|
|
|
|
|
|
#ifdef ARC_DEBUG
|
|
|
|
printf("%s: len: %d+%d=%d/%d\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev),
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
rwlen, rdone, rwlen + rdone, rlen);
|
|
|
|
if (arcdebug & ARC_D_DB) {
|
|
|
|
printf("%s: read:",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev));
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
for (i = 0; i < rwlen; i++)
|
|
|
|
printf(" 0x%02x", rwbuf[i]);
|
|
|
|
printf("\n");
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
if ((rdone + rwlen) > rlen) {
|
|
|
|
DNPRINTF(ARC_D_DB, "%s: rwbuf too big\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev));
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
error = EIO;
|
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
|
|
|
|
memcpy(&rbuf[rdone], rwbuf, rwlen);
|
|
|
|
rdone += rwlen;
|
|
|
|
}
|
|
|
|
} while (rdone != rlen);
|
|
|
|
|
|
|
|
bufhdr = (struct arc_fw_bufhdr *)rbuf;
|
|
|
|
if (memcmp(&bufhdr->hdr, &arc_fw_hdr, sizeof(bufhdr->hdr)) != 0 ||
|
|
|
|
bufhdr->len != htole16(rbuflen)) {
|
|
|
|
DNPRINTF(ARC_D_DB, "%s: rbuf hdr is wrong\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev));
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
error = EIO;
|
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
|
|
|
|
memcpy(rptr, rbuf + sizeof(struct arc_fw_bufhdr), rbuflen);
|
|
|
|
|
|
|
|
if (rbuf[rlen - 1] != arc_msg_cksum(rptr, rbuflen)) {
|
|
|
|
DNPRINTF(ARC_D_DB, "%s: invalid cksum\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev));
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
error = EIO;
|
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
|
|
|
|
out:
|
2007-12-07 11:50:36 +03:00
|
|
|
arc_unlock(sc);
|
|
|
|
kmem_free(wbuf, wlen);
|
|
|
|
kmem_free(rbuf, rlen);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
return error;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
arc_lock(struct arc_softc *sc)
|
2007-12-05 21:58:00 +03:00
|
|
|
{
|
|
|
|
rw_enter(&sc->sc_rwlock, RW_WRITER);
|
2007-12-07 11:50:36 +03:00
|
|
|
mutex_spin_enter(&sc->sc_mutex);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
arc_write(sc, ARC_REG_INTRMASK, ~ARC_REG_INTRMASK_POSTQUEUE);
|
|
|
|
sc->sc_talking = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
arc_unlock(struct arc_softc *sc)
|
|
|
|
{
|
2007-12-05 21:07:34 +03:00
|
|
|
KASSERT(mutex_owned(&sc->sc_mutex));
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
arc_write(sc, ARC_REG_INTRMASK,
|
|
|
|
~(ARC_REG_INTRMASK_POSTQUEUE|ARC_REG_INTRMASK_DOORBELL));
|
2008-01-03 02:48:05 +03:00
|
|
|
sc->sc_talking = 0;
|
2007-12-07 11:50:36 +03:00
|
|
|
mutex_spin_exit(&sc->sc_mutex);
|
2007-12-05 21:58:00 +03:00
|
|
|
rw_exit(&sc->sc_rwlock);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
arc_wait(struct arc_softc *sc)
|
|
|
|
{
|
2007-12-05 21:07:34 +03:00
|
|
|
KASSERT(mutex_owned(&sc->sc_mutex));
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
arc_write(sc, ARC_REG_INTRMASK,
|
|
|
|
~(ARC_REG_INTRMASK_POSTQUEUE|ARC_REG_INTRMASK_DOORBELL));
|
2008-01-03 02:48:05 +03:00
|
|
|
if (cv_timedwait(&sc->sc_condvar, &sc->sc_mutex, hz) == EWOULDBLOCK)
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
arc_write(sc, ARC_REG_INTRMASK, ~ARC_REG_INTRMASK_POSTQUEUE);
|
|
|
|
}
|
|
|
|
|
|
|
|
#if NBIO > 0
|
|
|
|
static void
|
|
|
|
arc_create_sensors(void *arg)
|
|
|
|
{
|
|
|
|
struct arc_softc *sc = arg;
|
|
|
|
struct bioc_inq bi;
|
|
|
|
struct bioc_vol bv;
|
2008-02-28 19:47:53 +03:00
|
|
|
int i, j;
|
|
|
|
size_t slen, count = 0;
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
memset(&bi, 0, sizeof(bi));
|
|
|
|
if (arc_bio_inq(sc, &bi) != 0) {
|
|
|
|
aprint_error("%s: unable to query firmware for sensor info\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev));
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
kthread_exit(0);
|
|
|
|
}
|
|
|
|
|
2008-02-28 19:47:53 +03:00
|
|
|
/* There's no point to continue if there are no volumes */
|
|
|
|
if (!bi.bi_novol)
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
kthread_exit(0);
|
|
|
|
|
2008-02-28 19:47:53 +03:00
|
|
|
for (i = 0; i < bi.bi_novol; i++) {
|
|
|
|
memset(&bv, 0, sizeof(bv));
|
|
|
|
bv.bv_volid = i;
|
|
|
|
if (arc_bio_vol(sc, &bv) != 0)
|
|
|
|
kthread_exit(0);
|
|
|
|
|
|
|
|
/* Skip passthrough volumes */
|
|
|
|
if (bv.bv_level == BIOC_SVOL_PASSTHRU)
|
|
|
|
continue;
|
|
|
|
|
|
|
|
/* new volume found */
|
|
|
|
sc->sc_nsensors++;
|
|
|
|
/* new disk in a volume found */
|
|
|
|
sc->sc_nsensors+= bv.bv_nodisk;
|
|
|
|
}
|
|
|
|
|
2008-03-01 16:56:46 +03:00
|
|
|
/* No valid volumes */
|
|
|
|
if (!sc->sc_nsensors)
|
|
|
|
kthread_exit(0);
|
|
|
|
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
sc->sc_sme = sysmon_envsys_create();
|
2011-06-20 17:26:58 +04:00
|
|
|
slen = sizeof(arc_edata_t) * sc->sc_nsensors;
|
|
|
|
sc->sc_arc_sensors = kmem_zalloc(slen, KM_SLEEP);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
2008-02-28 19:47:53 +03:00
|
|
|
/* Attach sensors for volumes and disks */
|
|
|
|
for (i = 0; i < bi.bi_novol; i++) {
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
memset(&bv, 0, sizeof(bv));
|
|
|
|
bv.bv_volid = i;
|
|
|
|
if (arc_bio_vol(sc, &bv) != 0)
|
|
|
|
goto bad;
|
|
|
|
|
2011-06-20 17:26:58 +04:00
|
|
|
sc->sc_arc_sensors[count].arc_sensor.units = ENVSYS_DRIVE;
|
2011-06-20 21:29:06 +04:00
|
|
|
sc->sc_arc_sensors[count].arc_sensor.state = ENVSYS_SINVALID;
|
2011-06-21 02:02:55 +04:00
|
|
|
sc->sc_arc_sensors[count].arc_sensor.value_cur =
|
|
|
|
ENVSYS_DRIVE_EMPTY;
|
2011-06-20 17:26:58 +04:00
|
|
|
sc->sc_arc_sensors[count].arc_sensor.flags =
|
|
|
|
ENVSYS_FMONSTCHANGED;
|
2008-02-28 19:47:53 +03:00
|
|
|
|
|
|
|
/* Skip passthrough volumes */
|
|
|
|
if (bv.bv_level == BIOC_SVOL_PASSTHRU)
|
|
|
|
continue;
|
|
|
|
|
2008-03-03 17:57:22 +03:00
|
|
|
if (bv.bv_level == BIOC_SVOL_RAID10)
|
2011-06-20 17:26:58 +04:00
|
|
|
snprintf(sc->sc_arc_sensors[count].arc_sensor.desc,
|
|
|
|
sizeof(sc->sc_arc_sensors[count].arc_sensor.desc),
|
2008-03-03 17:57:22 +03:00
|
|
|
"RAID 1+0 volume%d (%s)", i, bv.bv_dev);
|
|
|
|
else
|
2011-06-20 17:26:58 +04:00
|
|
|
snprintf(sc->sc_arc_sensors[count].arc_sensor.desc,
|
|
|
|
sizeof(sc->sc_arc_sensors[count].arc_sensor.desc),
|
2008-03-03 17:57:22 +03:00
|
|
|
"RAID %d volume%d (%s)", bv.bv_level, i,
|
|
|
|
bv.bv_dev);
|
|
|
|
|
2011-06-20 17:26:58 +04:00
|
|
|
sc->sc_arc_sensors[count].arc_volid = i;
|
2008-02-28 19:47:53 +03:00
|
|
|
|
|
|
|
if (sysmon_envsys_sensor_attach(sc->sc_sme,
|
2011-06-20 17:26:58 +04:00
|
|
|
&sc->sc_arc_sensors[count].arc_sensor))
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
goto bad;
|
2008-02-28 19:47:53 +03:00
|
|
|
|
|
|
|
count++;
|
|
|
|
|
|
|
|
/* Attach disk sensors for this volume */
|
|
|
|
for (j = 0; j < bv.bv_nodisk; j++) {
|
2011-06-20 21:29:06 +04:00
|
|
|
sc->sc_arc_sensors[count].arc_sensor.state =
|
|
|
|
ENVSYS_SINVALID;
|
2011-06-20 17:26:58 +04:00
|
|
|
sc->sc_arc_sensors[count].arc_sensor.units =
|
|
|
|
ENVSYS_DRIVE;
|
2011-06-21 02:02:55 +04:00
|
|
|
sc->sc_arc_sensors[count].arc_sensor.value_cur =
|
|
|
|
ENVSYS_DRIVE_EMPTY;
|
2011-06-20 17:26:58 +04:00
|
|
|
sc->sc_arc_sensors[count].arc_sensor.flags =
|
|
|
|
ENVSYS_FMONSTCHANGED;
|
2008-02-28 19:47:53 +03:00
|
|
|
|
2011-06-20 17:26:58 +04:00
|
|
|
snprintf(sc->sc_arc_sensors[count].arc_sensor.desc,
|
|
|
|
sizeof(sc->sc_arc_sensors[count].arc_sensor.desc),
|
2008-02-28 19:47:53 +03:00
|
|
|
"disk%d volume%d (%s)", j, i, bv.bv_dev);
|
2011-06-20 17:26:58 +04:00
|
|
|
sc->sc_arc_sensors[count].arc_volid = i;
|
|
|
|
sc->sc_arc_sensors[count].arc_diskid = j + 10;
|
2008-02-28 19:47:53 +03:00
|
|
|
|
|
|
|
if (sysmon_envsys_sensor_attach(sc->sc_sme,
|
2011-06-20 17:26:58 +04:00
|
|
|
&sc->sc_arc_sensors[count].arc_sensor))
|
2008-02-28 19:47:53 +03:00
|
|
|
goto bad;
|
|
|
|
|
|
|
|
count++;
|
|
|
|
}
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
}
|
|
|
|
|
2008-02-28 19:47:53 +03:00
|
|
|
/*
|
|
|
|
* Register our envsys driver with the framework now that the
|
|
|
|
* sensors were all attached.
|
|
|
|
*/
|
2008-03-05 18:03:36 +03:00
|
|
|
sc->sc_sme->sme_name = device_xname(sc->sc_dev);
|
2007-12-05 19:02:25 +03:00
|
|
|
sc->sc_sme->sme_cookie = sc;
|
|
|
|
sc->sc_sme->sme_refresh = arc_refresh_sensors;
|
2008-02-28 19:47:53 +03:00
|
|
|
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
if (sysmon_envsys_register(sc->sc_sme)) {
|
|
|
|
aprint_debug("%s: unable to register with sysmon\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev));
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
goto bad;
|
|
|
|
}
|
|
|
|
kthread_exit(0);
|
|
|
|
|
|
|
|
bad:
|
|
|
|
sysmon_envsys_destroy(sc->sc_sme);
|
2011-06-20 17:26:58 +04:00
|
|
|
kmem_free(sc->sc_arc_sensors, slen);
|
2010-04-03 21:54:24 +04:00
|
|
|
|
|
|
|
sc->sc_sme = NULL;
|
2011-06-20 17:26:58 +04:00
|
|
|
sc->sc_arc_sensors = NULL;
|
2010-04-03 21:54:24 +04:00
|
|
|
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
kthread_exit(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
2007-12-05 19:02:25 +03:00
|
|
|
arc_refresh_sensors(struct sysmon_envsys *sme, envsys_data_t *edata)
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
{
|
2007-12-05 19:02:25 +03:00
|
|
|
struct arc_softc *sc = sme->sme_cookie;
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
struct bioc_vol bv;
|
2008-02-28 19:47:53 +03:00
|
|
|
struct bioc_disk bd;
|
2011-06-20 17:26:58 +04:00
|
|
|
arc_edata_t *arcdata = (arc_edata_t *)edata;
|
2008-02-28 19:47:53 +03:00
|
|
|
|
|
|
|
/* sanity check */
|
|
|
|
if (edata->units != ENVSYS_DRIVE)
|
|
|
|
return;
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
memset(&bv, 0, sizeof(bv));
|
2011-06-20 17:26:58 +04:00
|
|
|
bv.bv_volid = arcdata->arc_volid;
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
2007-12-05 19:02:25 +03:00
|
|
|
if (arc_bio_vol(sc, &bv)) {
|
|
|
|
edata->value_cur = ENVSYS_DRIVE_EMPTY;
|
|
|
|
edata->state = ENVSYS_SINVALID;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2008-02-28 19:47:53 +03:00
|
|
|
/* Current sensor is handling a disk volume member */
|
2011-06-20 17:26:58 +04:00
|
|
|
if (arcdata->arc_diskid) {
|
2008-02-28 19:47:53 +03:00
|
|
|
memset(&bd, 0, sizeof(bd));
|
2011-06-20 17:26:58 +04:00
|
|
|
bd.bd_volid = arcdata->arc_volid;
|
|
|
|
bd.bd_diskid = arcdata->arc_diskid - 10;
|
2008-02-28 19:47:53 +03:00
|
|
|
|
|
|
|
if (arc_bio_disk_volume(sc, &bd)) {
|
2008-02-29 20:45:04 +03:00
|
|
|
edata->value_cur = ENVSYS_DRIVE_OFFLINE;
|
|
|
|
edata->state = ENVSYS_SCRITICAL;
|
2008-02-28 19:47:53 +03:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
switch (bd.bd_status) {
|
|
|
|
case BIOC_SDONLINE:
|
|
|
|
edata->value_cur = ENVSYS_DRIVE_ONLINE;
|
|
|
|
edata->state = ENVSYS_SVALID;
|
|
|
|
break;
|
|
|
|
case BIOC_SDOFFLINE:
|
|
|
|
edata->value_cur = ENVSYS_DRIVE_OFFLINE;
|
|
|
|
edata->state = ENVSYS_SCRITICAL;
|
|
|
|
break;
|
|
|
|
default:
|
2008-02-29 20:45:04 +03:00
|
|
|
edata->value_cur = ENVSYS_DRIVE_FAIL;
|
2008-02-28 19:47:53 +03:00
|
|
|
edata->state = ENVSYS_SCRITICAL;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Current sensor is handling a volume */
|
2007-12-05 19:02:25 +03:00
|
|
|
switch (bv.bv_status) {
|
|
|
|
case BIOC_SVOFFLINE:
|
2008-03-01 19:33:29 +03:00
|
|
|
edata->value_cur = ENVSYS_DRIVE_OFFLINE;
|
2007-12-05 19:02:25 +03:00
|
|
|
edata->state = ENVSYS_SCRITICAL;
|
|
|
|
break;
|
|
|
|
case BIOC_SVDEGRADED:
|
|
|
|
edata->value_cur = ENVSYS_DRIVE_PFAIL;
|
|
|
|
edata->state = ENVSYS_SCRITICAL;
|
|
|
|
break;
|
|
|
|
case BIOC_SVBUILDING:
|
2008-02-28 19:47:53 +03:00
|
|
|
edata->value_cur = ENVSYS_DRIVE_BUILD;
|
2007-12-05 19:02:25 +03:00
|
|
|
edata->state = ENVSYS_SVALID;
|
|
|
|
break;
|
2007-12-07 14:51:21 +03:00
|
|
|
case BIOC_SVMIGRATING:
|
|
|
|
edata->value_cur = ENVSYS_DRIVE_MIGRATING;
|
|
|
|
edata->state = ENVSYS_SVALID;
|
|
|
|
break;
|
2008-02-28 19:47:53 +03:00
|
|
|
case BIOC_SVCHECKING:
|
|
|
|
edata->value_cur = ENVSYS_DRIVE_CHECK;
|
|
|
|
edata->state = ENVSYS_SVALID;
|
|
|
|
break;
|
2008-02-29 15:56:03 +03:00
|
|
|
case BIOC_SVREBUILD:
|
|
|
|
edata->value_cur = ENVSYS_DRIVE_REBUILD;
|
|
|
|
edata->state = ENVSYS_SCRITICAL;
|
|
|
|
break;
|
2007-12-05 19:02:25 +03:00
|
|
|
case BIOC_SVSCRUB:
|
|
|
|
case BIOC_SVONLINE:
|
|
|
|
edata->value_cur = ENVSYS_DRIVE_ONLINE;
|
|
|
|
edata->state = ENVSYS_SVALID;
|
|
|
|
break;
|
|
|
|
case BIOC_SVINVALID:
|
2008-02-28 19:47:53 +03:00
|
|
|
/* FALLTHROUGH */
|
2007-12-05 19:02:25 +03:00
|
|
|
default:
|
|
|
|
edata->value_cur = ENVSYS_DRIVE_EMPTY; /* unknown state */
|
|
|
|
edata->state = ENVSYS_SINVALID;
|
|
|
|
break;
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif /* NBIO > 0 */
|
|
|
|
|
|
|
|
uint32_t
|
|
|
|
arc_read(struct arc_softc *sc, bus_size_t r)
|
|
|
|
{
|
|
|
|
uint32_t v;
|
|
|
|
|
|
|
|
bus_space_barrier(sc->sc_iot, sc->sc_ioh, r, 4,
|
|
|
|
BUS_SPACE_BARRIER_READ);
|
|
|
|
v = bus_space_read_4(sc->sc_iot, sc->sc_ioh, r);
|
|
|
|
|
|
|
|
DNPRINTF(ARC_D_RW, "%s: arc_read 0x%lx 0x%08x\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev), r, v);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
return v;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
arc_read_region(struct arc_softc *sc, bus_size_t r, void *buf, size_t len)
|
|
|
|
{
|
|
|
|
bus_space_barrier(sc->sc_iot, sc->sc_ioh, r, len,
|
|
|
|
BUS_SPACE_BARRIER_READ);
|
|
|
|
bus_space_read_region_4(sc->sc_iot, sc->sc_ioh, r,
|
|
|
|
(uint32_t *)buf, len >> 2);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
arc_write(struct arc_softc *sc, bus_size_t r, uint32_t v)
|
|
|
|
{
|
|
|
|
DNPRINTF(ARC_D_RW, "%s: arc_write 0x%lx 0x%08x\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev), r, v);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
bus_space_write_4(sc->sc_iot, sc->sc_ioh, r, v);
|
|
|
|
bus_space_barrier(sc->sc_iot, sc->sc_ioh, r, 4,
|
|
|
|
BUS_SPACE_BARRIER_WRITE);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
arc_write_region(struct arc_softc *sc, bus_size_t r, void *buf, size_t len)
|
|
|
|
{
|
|
|
|
bus_space_write_region_4(sc->sc_iot, sc->sc_ioh, r,
|
|
|
|
(const uint32_t *)buf, len >> 2);
|
|
|
|
bus_space_barrier(sc->sc_iot, sc->sc_ioh, r, len,
|
|
|
|
BUS_SPACE_BARRIER_WRITE);
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
arc_wait_eq(struct arc_softc *sc, bus_size_t r, uint32_t mask,
|
|
|
|
uint32_t target)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
|
|
|
DNPRINTF(ARC_D_RW, "%s: arc_wait_eq 0x%lx 0x%08x 0x%08x\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev), r, mask, target);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
for (i = 0; i < 10000; i++) {
|
|
|
|
if ((arc_read(sc, r) & mask) == target)
|
|
|
|
return 0;
|
|
|
|
delay(1000);
|
|
|
|
}
|
|
|
|
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
arc_wait_ne(struct arc_softc *sc, bus_size_t r, uint32_t mask,
|
|
|
|
uint32_t target)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
|
|
|
DNPRINTF(ARC_D_RW, "%s: arc_wait_ne 0x%lx 0x%08x 0x%08x\n",
|
2008-03-05 18:03:36 +03:00
|
|
|
device_xname(sc->sc_dev), r, mask, target);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
for (i = 0; i < 10000; i++) {
|
|
|
|
if ((arc_read(sc, r) & mask) != target)
|
|
|
|
return 0;
|
|
|
|
delay(1000);
|
|
|
|
}
|
|
|
|
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
arc_msg0(struct arc_softc *sc, uint32_t m)
|
|
|
|
{
|
|
|
|
/* post message */
|
|
|
|
arc_write(sc, ARC_REG_INB_MSG0, m);
|
|
|
|
/* wait for the fw to do it */
|
|
|
|
if (arc_wait_eq(sc, ARC_REG_INTRSTAT, ARC_REG_INTRSTAT_MSG0,
|
|
|
|
ARC_REG_INTRSTAT_MSG0) != 0)
|
|
|
|
return 1;
|
|
|
|
|
|
|
|
/* ack it */
|
|
|
|
arc_write(sc, ARC_REG_INTRSTAT, ARC_REG_INTRSTAT_MSG0);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
struct arc_dmamem *
|
|
|
|
arc_dmamem_alloc(struct arc_softc *sc, size_t size)
|
|
|
|
{
|
|
|
|
struct arc_dmamem *adm;
|
|
|
|
int nsegs;
|
|
|
|
|
2007-12-07 11:50:36 +03:00
|
|
|
adm = kmem_zalloc(sizeof(*adm), KM_NOSLEEP);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
if (adm == NULL)
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
adm->adm_size = size;
|
|
|
|
|
|
|
|
if (bus_dmamap_create(sc->sc_dmat, size, 1, size, 0,
|
|
|
|
BUS_DMA_NOWAIT|BUS_DMA_ALLOCNOW, &adm->adm_map) != 0)
|
|
|
|
goto admfree;
|
|
|
|
|
|
|
|
if (bus_dmamem_alloc(sc->sc_dmat, size, PAGE_SIZE, 0, &adm->adm_seg,
|
|
|
|
1, &nsegs, BUS_DMA_NOWAIT) != 0)
|
|
|
|
goto destroy;
|
|
|
|
|
|
|
|
if (bus_dmamem_map(sc->sc_dmat, &adm->adm_seg, nsegs, size,
|
|
|
|
&adm->adm_kva, BUS_DMA_NOWAIT|BUS_DMA_COHERENT) != 0)
|
|
|
|
goto free;
|
|
|
|
|
|
|
|
if (bus_dmamap_load(sc->sc_dmat, adm->adm_map, adm->adm_kva, size,
|
|
|
|
NULL, BUS_DMA_NOWAIT) != 0)
|
|
|
|
goto unmap;
|
|
|
|
|
|
|
|
memset(adm->adm_kva, 0, size);
|
|
|
|
|
|
|
|
return adm;
|
|
|
|
|
|
|
|
unmap:
|
|
|
|
bus_dmamem_unmap(sc->sc_dmat, adm->adm_kva, size);
|
|
|
|
free:
|
|
|
|
bus_dmamem_free(sc->sc_dmat, &adm->adm_seg, 1);
|
|
|
|
destroy:
|
|
|
|
bus_dmamap_destroy(sc->sc_dmat, adm->adm_map);
|
|
|
|
admfree:
|
2007-12-07 11:50:36 +03:00
|
|
|
kmem_free(adm, sizeof(*adm));
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
arc_dmamem_free(struct arc_softc *sc, struct arc_dmamem *adm)
|
|
|
|
{
|
|
|
|
bus_dmamap_unload(sc->sc_dmat, adm->adm_map);
|
|
|
|
bus_dmamem_unmap(sc->sc_dmat, adm->adm_kva, adm->adm_size);
|
|
|
|
bus_dmamem_free(sc->sc_dmat, &adm->adm_seg, 1);
|
|
|
|
bus_dmamap_destroy(sc->sc_dmat, adm->adm_map);
|
2007-12-07 11:50:36 +03:00
|
|
|
kmem_free(adm, sizeof(*adm));
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
int
|
2008-03-05 18:03:36 +03:00
|
|
|
arc_alloc_ccbs(device_t self)
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
{
|
2008-03-05 18:03:36 +03:00
|
|
|
struct arc_softc *sc = device_private(self);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
struct arc_ccb *ccb;
|
|
|
|
uint8_t *cmd;
|
|
|
|
int i;
|
2007-12-07 11:50:36 +03:00
|
|
|
size_t ccbslen;
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
TAILQ_INIT(&sc->sc_ccb_free);
|
|
|
|
|
2007-12-07 11:50:36 +03:00
|
|
|
ccbslen = sizeof(struct arc_ccb) * sc->sc_req_count;
|
|
|
|
sc->sc_ccbs = kmem_zalloc(ccbslen, KM_SLEEP);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
sc->sc_requests = arc_dmamem_alloc(sc,
|
|
|
|
ARC_MAX_IOCMDLEN * sc->sc_req_count);
|
|
|
|
if (sc->sc_requests == NULL) {
|
2008-03-05 18:03:36 +03:00
|
|
|
aprint_error_dev(self, "unable to allocate ccb dmamem\n");
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
goto free_ccbs;
|
|
|
|
}
|
|
|
|
cmd = ARC_DMA_KVA(sc->sc_requests);
|
|
|
|
|
|
|
|
for (i = 0; i < sc->sc_req_count; i++) {
|
|
|
|
ccb = &sc->sc_ccbs[i];
|
|
|
|
|
|
|
|
if (bus_dmamap_create(sc->sc_dmat, MAXPHYS, ARC_SGL_MAXLEN,
|
|
|
|
MAXPHYS, 0, 0, &ccb->ccb_dmamap) != 0) {
|
2008-03-05 18:03:36 +03:00
|
|
|
aprint_error_dev(self,
|
|
|
|
"unable to create dmamap for ccb %d\n", i);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
goto free_maps;
|
|
|
|
}
|
|
|
|
|
|
|
|
ccb->ccb_sc = sc;
|
|
|
|
ccb->ccb_id = i;
|
|
|
|
ccb->ccb_offset = ARC_MAX_IOCMDLEN * i;
|
|
|
|
|
|
|
|
ccb->ccb_cmd = (struct arc_io_cmd *)&cmd[ccb->ccb_offset];
|
|
|
|
ccb->ccb_cmd_post = (ARC_DMA_DVA(sc->sc_requests) +
|
|
|
|
ccb->ccb_offset) >> ARC_REG_POST_QUEUE_ADDR_SHIFT;
|
|
|
|
|
|
|
|
arc_put_ccb(sc, ccb);
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
free_maps:
|
|
|
|
while ((ccb = arc_get_ccb(sc)) != NULL)
|
|
|
|
bus_dmamap_destroy(sc->sc_dmat, ccb->ccb_dmamap);
|
|
|
|
arc_dmamem_free(sc, sc->sc_requests);
|
|
|
|
|
|
|
|
free_ccbs:
|
2007-12-07 11:50:36 +03:00
|
|
|
kmem_free(sc->sc_ccbs, ccbslen);
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
struct arc_ccb *
|
|
|
|
arc_get_ccb(struct arc_softc *sc)
|
|
|
|
{
|
|
|
|
struct arc_ccb *ccb;
|
|
|
|
|
|
|
|
ccb = TAILQ_FIRST(&sc->sc_ccb_free);
|
|
|
|
if (ccb != NULL)
|
|
|
|
TAILQ_REMOVE(&sc->sc_ccb_free, ccb, ccb_link);
|
2007-12-05 21:07:34 +03:00
|
|
|
|
Areca Technology Corporation SATA RAID controller driver, ported
from OpenBSD.
arc0 at pci2 dev 14 function 0: interrupting at ioapic0 pin 18 (irq 5)
arc0: Areca ARC-1210 Host Adapter RAID controller
arc0: 4 ports, 256MB SDRAM, firmware <V1.43 2007-4-17>
scsibus0 at arc0: 16 targets, 8 luns per target
[...]
scsibus0: waiting 2 seconds for devices to settle...
sd0 at scsibus0 target 0 lun 0: <Areca, ARC-1210-VOL#00, R001> disk fixed
sd0: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
sd1 at scsibus0 target 0 lun 1: <Areca, ARC-1210-VOL#01, R001> disk fixed
sd1: 465 GB, 56514 cyl, 36 head, 480 sec, 512 bytes/sect x 976562176 sectors
bioctl(4) output with two RAID0 volumes:
Volume Status Size Device
arc0 0 Online 466G ARC-1210-VOL#00 RAID0
0 Online 234G 0:0.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:1.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
arc0 1 Online 466G ARC-1210-VOL#01 RAID0
0 Online 234G 0:2.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
1 Online 234G 0:3.0 noencl <WDC WD2500YS-01SHB1 20.06C06>
The driver still needs changes related to locking and talking to the
firmware, which sometimes is unable to answer...
Raid card donated by Areca Technology Corporation via Trent George.
Disks used for testing were contributed by TNF.
Thank you very much.
2007-12-04 21:47:50 +03:00
|
|
|
return ccb;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
arc_put_ccb(struct arc_softc *sc, struct arc_ccb *ccb)
|
|
|
|
{
|
|
|
|
ccb->ccb_xs = NULL;
|
|
|
|
memset(ccb->ccb_cmd, 0, ARC_MAX_IOCMDLEN);
|
|
|
|
TAILQ_INSERT_TAIL(&sc->sc_ccb_free, ccb, ccb_link);
|
|
|
|
}
|