1 1.6 bouyer /* $NetBSD: satapmpreg.h,v 1.6 2012/07/31 15:50:34 bouyer Exp $ */ 2 1.1 thorpej 3 1.1 thorpej /*- 4 1.1 thorpej * Copyright (c) 2004 The NetBSD Foundation, Inc. 5 1.1 thorpej * All rights reserved. 6 1.1 thorpej * 7 1.1 thorpej * This code is derived from software contributed to The NetBSD Foundation 8 1.1 thorpej * by Frank van der Linden of Wasabi Systems, Inc. 9 1.1 thorpej * 10 1.1 thorpej * Redistribution and use in source and binary forms, with or without 11 1.1 thorpej * modification, are permitted provided that the following conditions 12 1.1 thorpej * are met: 13 1.1 thorpej * 1. Redistributions of source code must retain the above copyright 14 1.1 thorpej * notice, this list of conditions and the following disclaimer. 15 1.1 thorpej * 2. Redistributions in binary form must reproduce the above copyright 16 1.1 thorpej * notice, this list of conditions and the following disclaimer in the 17 1.1 thorpej * documentation and/or other materials provided with the distribution. 18 1.1 thorpej * 19 1.1 thorpej * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 20 1.1 thorpej * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 21 1.1 thorpej * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 22 1.1 thorpej * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 23 1.1 thorpej * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 24 1.1 thorpej * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 25 1.1 thorpej * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 26 1.1 thorpej * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 27 1.1 thorpej * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 28 1.1 thorpej * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 29 1.1 thorpej * POSSIBILITY OF SUCH DAMAGE. 30 1.1 thorpej */ 31 1.1 thorpej 32 1.1 thorpej #ifndef _DEV_ATA_SATAPMPREG_H_ 33 1.1 thorpej #define _DEV_ATA_SATAPMPREG_H_ 34 1.1 thorpej 35 1.1 thorpej /* 36 1.1 thorpej * Global port multiplier registers, accessed through the control port. 37 1.1 thorpej */ 38 1.1 thorpej 39 1.1 thorpej #define PMP_GSCR_ID 0x00 /* product and vendor id */ 40 1.6 bouyer #define PMP_ID_DEV(x) ((x) >> 16) 41 1.1 thorpej #define PMP_ID_VEND(x) ((x) & 0xffff) 42 1.1 thorpej #define PMP_GSCR_REV 0x01 /* revision */ 43 1.1 thorpej #define PMP_REV_SPEC_10 0x02 44 1.1 thorpej #define PMP_REV_SPEC_11 0x04 45 1.1 thorpej #define PMP_REV_LEVEL(x) (((x) >> 8) & 0xff) 46 1.1 thorpej #define PMP_GSCR_INF 0x02 /* info */ 47 1.1 thorpej #define PMP_INF_NPORTS(x) ((x) & 0xf) 48 1.1 thorpej #define PMP_GSCR_ERR 0x20 /* error bit for each port */ 49 1.1 thorpej #define PMP_ERR(p) ((1) << (p)) 50 1.1 thorpej #define PMP_GSCR_ERREN 0x21 /* error bit enable for each port */ 51 1.1 thorpej #define PMP_ERREN(p) ((1) << (p)) 52 1.1 thorpej #define PMP_GSCR_FEAT 0x40 /* features */ 53 1.1 thorpej #define PMP_FEAT_BIST 0x01 54 1.1 thorpej #define PMP_FEAT_PMREQ 0x01 55 1.1 thorpej #define PMP_FEAT_SCC 0x04 56 1.1 thorpej #define PMP_FEAT_ASYNC 0x08 57 1.1 thorpej #define PMP_GSCR_FEATEN 0x60 /* feature enable, bits as above */ 58 1.1 thorpej 59 1.1 thorpej #define PMP_GSCR_VENDSTART 0x80 /* start of vendor unique registers */ 60 1.1 thorpej 61 1.1 thorpej #define PMP_GSCR_NREGS 256 62 1.1 thorpej 63 1.1 thorpej /* 64 1.1 thorpej * Port status and control registers (per port) 65 1.1 thorpej */ 66 1.1 thorpej #define PMP_PSCR_SStatus 0x00 67 1.1 thorpej #define PMP_PSCR_SError 0x01 68 1.1 thorpej #define PMP_PSCR_SControl 0x02 69 1.1 thorpej #define PMP_PSCR_SActive 0x03 70 1.1 thorpej 71 1.1 thorpej /* 72 1.1 thorpej * Control port as defined in the spec. 73 1.1 thorpej */ 74 1.1 thorpej #define PMP_PORT_CTL 0x0f 75 1.1 thorpej 76 1.1 thorpej /* 77 1.1 thorpej * Device commands for port multipliers 78 1.1 thorpej */ 79 1.1 thorpej #define PMPC_READ_PORT 0xe4 80 1.1 thorpej #define PMPC_WRITE_PORT 0xe8 81 1.1 thorpej 82 1.6 bouyer /* max number of drives (last one being the PM itself */ 83 1.6 bouyer #define PMP_MAX_DRIVES 16 84 1.6 bouyer 85 1.1 thorpej #endif /* _DEV_ATA_SATAPMPREG_H_ */ 86