1*6ecef65dSmsaitoh /* $NetBSD: sbp.h,v 1.7 2021/12/05 02:21:08 msaitoh Exp $ */ 2c1a84a4dSkiyohara /*- 3c1a84a4dSkiyohara * Copyright (c) 2003 Hidetoshi Shimokawa 4c1a84a4dSkiyohara * Copyright (c) 1998-2002 Katsushi Kobayashi and Hidetoshi Shimokawa 5c1a84a4dSkiyohara * All rights reserved. 6c1a84a4dSkiyohara * 7c1a84a4dSkiyohara * Redistribution and use in source and binary forms, with or without 8c1a84a4dSkiyohara * modification, are permitted provided that the following conditions 9c1a84a4dSkiyohara * are met: 10c1a84a4dSkiyohara * 1. Redistributions of source code must retain the above copyright 11c1a84a4dSkiyohara * notice, this list of conditions and the following disclaimer. 12c1a84a4dSkiyohara * 2. Redistributions in binary form must reproduce the above copyright 13c1a84a4dSkiyohara * notice, this list of conditions and the following disclaimer in the 14c1a84a4dSkiyohara * documentation and/or other materials provided with the distribution. 15c1a84a4dSkiyohara * 3. All advertising materials mentioning features or use of this software 16c1a84a4dSkiyohara * must display the acknowledgement as bellow: 17c1a84a4dSkiyohara * 18c1a84a4dSkiyohara * This product includes software developed by K. Kobayashi and H. Shimokawa 19c1a84a4dSkiyohara * 20c1a84a4dSkiyohara * 4. The name of the author may not be used to endorse or promote products 21c1a84a4dSkiyohara * derived from this software without specific prior written permission. 22c1a84a4dSkiyohara * 23c1a84a4dSkiyohara * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 24c1a84a4dSkiyohara * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 25c1a84a4dSkiyohara * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 26c1a84a4dSkiyohara * DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, 27c1a84a4dSkiyohara * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 28c1a84a4dSkiyohara * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR 29c1a84a4dSkiyohara * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 30c1a84a4dSkiyohara * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, 31c1a84a4dSkiyohara * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN 32c1a84a4dSkiyohara * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 33c1a84a4dSkiyohara * POSSIBILITY OF SUCH DAMAGE. 34c1a84a4dSkiyohara * 35af09db11Skiyohara * $FreeBSD: src/sys/dev/firewire/sbp.h,v 1.6 2009/04/07 02:33:46 sbruno Exp $ 36c1a84a4dSkiyohara * 37c1a84a4dSkiyohara */ 38af09db11Skiyohara #ifndef _SBP_H_ 39af09db11Skiyohara #define _SBP_H_ 40c1a84a4dSkiyohara 41c1a84a4dSkiyohara #define ORB_NOTIFY (1 << 31) 42c1a84a4dSkiyohara #define ORB_FMT_STD (0 << 29) 43c1a84a4dSkiyohara #define ORB_FMT_VED (2 << 29) 44c1a84a4dSkiyohara #define ORB_FMT_NOP (3 << 29) 45c1a84a4dSkiyohara #define ORB_FMT_MSK (3 << 29) 46c1a84a4dSkiyohara #define ORB_EXV (1 << 28) 47c1a84a4dSkiyohara /* */ 48c1a84a4dSkiyohara #define ORB_CMD_IN (1 << 27) 49c1a84a4dSkiyohara /* */ 50c1a84a4dSkiyohara #define ORB_CMD_SPD(x) ((x) << 24) 51c1a84a4dSkiyohara #define ORB_CMD_MAXP(x) ((x) << 20) 52c1a84a4dSkiyohara #define ORB_RCN_TMO(x) ((x) << 20) 53c1a84a4dSkiyohara #define ORB_CMD_PTBL (1 << 19) 54c1a84a4dSkiyohara #define ORB_CMD_PSZ(x) ((x) << 16) 55c1a84a4dSkiyohara 56c1a84a4dSkiyohara #define ORB_FUN_LGI (0 << 16) 57c1a84a4dSkiyohara #define ORB_FUN_QLG (1 << 16) 58c1a84a4dSkiyohara #define ORB_FUN_RCN (3 << 16) 59c1a84a4dSkiyohara #define ORB_FUN_LGO (7 << 16) 60c1a84a4dSkiyohara #define ORB_FUN_ATA (0xb << 16) 61c1a84a4dSkiyohara #define ORB_FUN_ATS (0xc << 16) 62c1a84a4dSkiyohara #define ORB_FUN_LUR (0xe << 16) 63c1a84a4dSkiyohara #define ORB_FUN_RST (0xf << 16) 64c1a84a4dSkiyohara #define ORB_FUN_MSK (0xf << 16) 65c1a84a4dSkiyohara #define ORB_FUN_RUNQUEUE 0xffff 66c1a84a4dSkiyohara 67c1a84a4dSkiyohara #define SBP_DEBUG(x) if (debug > x) { 68c1a84a4dSkiyohara #define END_DEBUG } 69c1a84a4dSkiyohara 70c1a84a4dSkiyohara struct ind_ptr { 71c1a84a4dSkiyohara uint32_t hi,lo; 72c1a84a4dSkiyohara }; 73c1a84a4dSkiyohara 74c1a84a4dSkiyohara 75c1a84a4dSkiyohara #define SBP_RECV_LEN 32 76c1a84a4dSkiyohara 77c1a84a4dSkiyohara struct sbp_login_res{ 78c1a84a4dSkiyohara uint16_t len; 79c1a84a4dSkiyohara uint16_t id; 80c1a84a4dSkiyohara uint16_t res0; 81c1a84a4dSkiyohara uint16_t cmd_hi; 82c1a84a4dSkiyohara uint32_t cmd_lo; 83c1a84a4dSkiyohara uint16_t res1; 84c1a84a4dSkiyohara uint16_t recon_hold; 85c1a84a4dSkiyohara }; 86c1a84a4dSkiyohara 87c1a84a4dSkiyohara struct sbp_status{ 88c1a84a4dSkiyohara #if BYTE_ORDER == BIG_ENDIAN 89c1a84a4dSkiyohara uint8_t src:2, 90c1a84a4dSkiyohara resp:2, 91c1a84a4dSkiyohara dead:1, 92c1a84a4dSkiyohara len:3; 93c1a84a4dSkiyohara #else 94c1a84a4dSkiyohara uint8_t len:3, 95c1a84a4dSkiyohara dead:1, 96c1a84a4dSkiyohara resp:2, 97c1a84a4dSkiyohara src:2; 98c1a84a4dSkiyohara #endif 99c1a84a4dSkiyohara uint8_t status; 100c1a84a4dSkiyohara uint16_t orb_hi; 101c1a84a4dSkiyohara uint32_t orb_lo; 102c1a84a4dSkiyohara uint32_t data[6]; 103c1a84a4dSkiyohara }; 104c1a84a4dSkiyohara /* src */ 105c1a84a4dSkiyohara #define SRC_NEXT_EXISTS 0 106c1a84a4dSkiyohara #define SRC_NO_NEXT 1 107c1a84a4dSkiyohara #define SRC_UNSOL 2 108c1a84a4dSkiyohara 109c1a84a4dSkiyohara /* resp */ 110c1a84a4dSkiyohara #define SBP_REQ_CMP 0 /* request complete */ 111c1a84a4dSkiyohara #define SBP_TRANS_FAIL 1 /* transport failure */ 112c1a84a4dSkiyohara #define SBP_ILLE_REQ 2 /* illegal request */ 113c1a84a4dSkiyohara #define SBP_VEND_DEP 3 /* vendor dependent */ 114c1a84a4dSkiyohara 115c1a84a4dSkiyohara /* status (resp == 0) */ 116c1a84a4dSkiyohara /* 0: No additional Information to report */ 117c1a84a4dSkiyohara /* 1: Request Type not supported */ 118c1a84a4dSkiyohara /* 2: Speed not supported */ 119c1a84a4dSkiyohara /* 3: Page size not supported */ 120c1a84a4dSkiyohara /* 4: Access denied */ 121c1a84a4dSkiyohara #define STATUS_ACCESS_DENY 4 122af09db11Skiyohara #define STATUS_LUR 5 123c1a84a4dSkiyohara /* 6: Maximum payload too small */ 124c1a84a4dSkiyohara /* 7: Reserved for future standardization */ 125*6ecef65dSmsaitoh /* 8: Resource unavailable */ 126c1a84a4dSkiyohara #define STATUS_RES_UNAVAIL 8 127c1a84a4dSkiyohara /* 9: Function Rejected */ 128c1a84a4dSkiyohara /* 10: Login ID not recognized */ 129c1a84a4dSkiyohara /* 11: Dummy ORB completed */ 130c1a84a4dSkiyohara /* 12: Request aborted */ 131c1a84a4dSkiyohara /* 255: Unspecified error */ 132c1a84a4dSkiyohara 133c1a84a4dSkiyohara /* status (resp == 1) */ 134c1a84a4dSkiyohara /* Referenced object */ 135c1a84a4dSkiyohara #define OBJ_ORB (0 << 6) /* 0: ORB */ 136c1a84a4dSkiyohara #define OBJ_DATA (1 << 6) /* 1: Data buffer */ 137c1a84a4dSkiyohara #define OBJ_PT (2 << 6) /* 2: Page table */ 138c1a84a4dSkiyohara #define OBJ_UNSPEC (3 << 6) /* 3: Unable to specify */ 139c1a84a4dSkiyohara /* Serial bus error */ 140c1a84a4dSkiyohara /* 0: Missing acknowledge */ 141c1a84a4dSkiyohara /* 1: Reserved; not to be used */ 142c1a84a4dSkiyohara /* 2: Time-out error */ 143c1a84a4dSkiyohara #define SBE_TIMEOUT 2 144c1a84a4dSkiyohara /* 3: Reserved; not to be used */ 145c1a84a4dSkiyohara /* 4: Busy retry limit exceeded: ack_busy_X */ 146c1a84a4dSkiyohara /* 5: Busy retry limit exceeded: ack_busy_A */ 147c1a84a4dSkiyohara /* 6: Busy retry limit exceeded: ack_busy_B */ 148c1a84a4dSkiyohara /* 7-A: Reserved for future standardization */ 149c1a84a4dSkiyohara /* B: Tardy retry limit exceeded */ 1506bb3ec6dScegger /* C: Conflict error */ 151c1a84a4dSkiyohara /* D: Data error */ 152c1a84a4dSkiyohara /* E: Type error */ 153c1a84a4dSkiyohara /* F: Address error */ 154c1a84a4dSkiyohara 155c1a84a4dSkiyohara 156c1a84a4dSkiyohara struct sbp_cmd_status{ 157c1a84a4dSkiyohara #define SBP_SFMT_CURR 0 158c1a84a4dSkiyohara #define SBP_SFMT_DEFER 1 159c1a84a4dSkiyohara #if BYTE_ORDER == BIG_ENDIAN 160c1a84a4dSkiyohara uint8_t sfmt:2, 161c1a84a4dSkiyohara status:6; 162c1a84a4dSkiyohara uint8_t valid:1, 163c1a84a4dSkiyohara mark:1, 164c1a84a4dSkiyohara eom:1, 165c1a84a4dSkiyohara ill_len:1, 166c1a84a4dSkiyohara s_key:4; 167c1a84a4dSkiyohara #else 168c1a84a4dSkiyohara uint8_t status:6, 169c1a84a4dSkiyohara sfmt:2; 170c1a84a4dSkiyohara uint8_t s_key:4, 171c1a84a4dSkiyohara ill_len:1, 172c1a84a4dSkiyohara eom:1, 173c1a84a4dSkiyohara mark:1, 174c1a84a4dSkiyohara valid:1; 175c1a84a4dSkiyohara #endif 176c1a84a4dSkiyohara uint8_t s_code; 177c1a84a4dSkiyohara uint8_t s_qlfr; 178c1a84a4dSkiyohara uint32_t info; 179c1a84a4dSkiyohara uint32_t cdb; 180c1a84a4dSkiyohara uint8_t fru; 181c1a84a4dSkiyohara uint8_t s_keydep[3]; 182c1a84a4dSkiyohara uint32_t vend[2]; 183c1a84a4dSkiyohara }; 184c1a84a4dSkiyohara 185c1a84a4dSkiyohara #define ORB_FUN_NAMES \ 186c1a84a4dSkiyohara /* 0 */ "LOGIN", \ 187c1a84a4dSkiyohara /* 1 */ "QUERY LOGINS", \ 188c1a84a4dSkiyohara /* 2 */ "Reserved", \ 189c1a84a4dSkiyohara /* 3 */ "RECONNECT", \ 190c1a84a4dSkiyohara /* 4 */ "SET PASSWORD", \ 191c1a84a4dSkiyohara /* 5 */ "Reserved", \ 192c1a84a4dSkiyohara /* 6 */ "Reserved", \ 193c1a84a4dSkiyohara /* 7 */ "LOGOUT", \ 194c1a84a4dSkiyohara /* 8 */ "Reserved", \ 195c1a84a4dSkiyohara /* 9 */ "Reserved", \ 196c1a84a4dSkiyohara /* A */ "Reserved", \ 197c1a84a4dSkiyohara /* B */ "ABORT TASK", \ 198c1a84a4dSkiyohara /* C */ "ABORT TASK SET", \ 199c1a84a4dSkiyohara /* D */ "Reserved", \ 200c1a84a4dSkiyohara /* E */ "LOGICAL UNIT RESET", \ 201c1a84a4dSkiyohara /* F */ "TARGET RESET" 202c1a84a4dSkiyohara 203af09db11Skiyohara #endif /* _SBP_H_ */ 204