xref: /freebsd/sys/dev/firewire/firewire_phy.h (revision 95ee2897e98f5d444f26ed2334cc7c439f9c16c6)
1 /*-
2  * SPDX-License-Identifier: BSD-4-Clause
3  *
4  * Copyright (c) 1998-2002 Katsushi Kobayashi and Hidetoshi Shimokawa
5  * All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  * 1. Redistributions of source code must retain the above copyright
11  *    notice, this list of conditions and the following disclaimer.
12  * 2. Redistributions in binary form must reproduce the above copyright
13  *    notice, this list of conditions and the following disclaimer in the
14  *    documentation and/or other materials provided with the distribution.
15  * 3. All advertising materials mentioning features or use of this software
16  *    must display the acknowledgement as bellow:
17  *
18  *    This product includes software developed by K. Kobayashi and H. Shimokawa
19  *
20  * 4. The name of the author may not be used to endorse or promote products
21  *    derived from this software without specific prior written permission.
22  *
23  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
24  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
25  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
26  * DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
27  * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
28  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
29  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
31  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
32  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
33  * POSSIBILITY OF SUCH DAMAGE.
34  *
35  */
36 
37 #define	FW_PHY_PHYSID_REG		0x00
38 #define	FW_PHY_PHYSID			(63<<2)
39 #define	FW_PHY_ROOT_REG			0x00
40 #define	FW_PHY_ROOT			(1<<1)
41 #define	FW_PHY_CPS_REG			0x00
42 #define	FW_PHY_CPS			(1<<0)
43 
44 #define	FW_PHY_RHB_REG			0x01
45 #define	FW_PHY_RHB			(1<<7)
46 #define	FW_PHY_IBR_REG			0x01
47 #define	FW_PHY_IBR			(1<<6)
48 #define	FW_PHY_ISBR_REG			0x05
49 #define	FW_PHY_ISBR			(1<<6)
50 #define	FW_PHY_GC_REG			0x01
51 
52 #define	FW_PHY_SPD_REG			0x02
53 #define	FW_PHY_SPD			(3<<6)
54 #define	FW_PHY_REV_REG			0x02
55 #define	FW_PHY_REV			(3<<4)
56 #define	FW_PHY_NP_REG			0x02
57 #define	FW_PHY_NP			(15<<0)
58 
59 #define	FW_PHY_P1_REG			0x03
60 #define	FW_PHY_P2_REG			0x04
61 #define	FW_PHY_P3_REG			0x05
62 
63 #define	FW_PHY_P_ASTAT			(3<<6)
64 #define	FW_PHY_P_BSTAT			(3<<4)
65 #define	FW_PHY_P_CH			(1<<3)
66 #define	FW_PHY_P_CON			(1<<2)
67 
68 #define FW_PHY_LOOPINT_REG		0x06
69 #define FW_PHY_LOOPINT			(1<<7)
70 #define FW_PHY_CPSINT_REG		0x06
71 #define FW_PHY_CPSNT			(1<<6)
72 /*
73 #define FW_PHY_CPS_REG			0x06
74 #define FW_PHY_CPS			(1<<5)
75 */
76 #define FW_PHY_IR_REG			0x06
77 #define FW_PHY_IR			(1<<4)
78 #define FW_PHY_C_REG			0x06
79 #define FW_PHY_C			(1<<0)
80 
81 #define FW_PHY_ESPD_REG			0x03
82 #define	FW_PHY_ESPD			(7<<5)
83 
84 #define FW_PHY_EDEL_REG			0x03
85 #define FW_PHY_EDEL			15<<0
86