diff options
author | Stefan Richter <stefanr@s5r6.in-berlin.de> | 2010-10-09 18:12:20 -0400 |
---|---|---|
committer | Stefan Richter <stefanr@s5r6.in-berlin.de> | 2010-10-11 08:48:03 -0400 |
commit | 66fa12c571d35e3cd62574c65f1785a460105397 (patch) | |
tree | b4f8de3d5ca827d2b134ed628628a7bff46967ca /drivers/ieee1394/ieee1394.h | |
parent | 1ef5b816c0eaf84f91106cfc0893069c49e86113 (diff) |
ieee1394: remove the old IEEE 1394 driver stack
The drivers
- ohci1394 (controller driver)
- ieee1394 (core)
- dv1394, raw1394, video1394 (userspace ABI)
- eth1394, sbp2 (protocol drivers)
are replaced by
- firewire-ohci (controller driver)
- firewire-core (core and userspace ABI)
- firewire-net, firewire-sbp2 (protocol drivers)
which are more featureful, better performing, and more secure than the older
drivers; all with a smaller and more modern code base.
The driver firedtv in drivers/media/dvb/firewire/ contains backends to both
ieee1394 and firewire-core. Its ieee1394 backend code can be removed in an
independent commit; firedtv as-is builds and works fine without ieee1394.
The driver pcilynx (an incomplete controller driver) is deleted without
replacement since PCILynx cards are extremely rare. Owners of these cards
use them with the stand-alone bus sniffer driver nosy instead.
The drivers nosy and init_ohci1394_dma which do not interact with either of
the two IEEE 1394 stacks are not affected by the ieee1394 subsystem removal.
There are still some issues with the newer firewire subsystem compared to
the older one:
- The rare and quirky controllers ALi M52xx, Apple UniNorth v1, NVIDIA
NForce2 are even less well supported by firewire-ohci than by ohci1394.
I am looking into the M52xx issue.
- The experimental firewire-net is reportedly less stable than its
experimental cousin eth1394.
- Audio playback of a certain group of audio devices (ones based on DICE
chipset with EAP; supported by prerelease FFADO code) does not work yet.
This issue is still under investigation.
- There were some ieee1394 based out-of-the-mainline drivers. Of them,
only lisight, an audio driver for iSight webcams, seems still useful.
Work is underway to reimplement it on top of firewire-core.
All these remainig issues are minor; they should not stand in the way of
overall better user experience of IEEE 1394 on Linux, together with a
reduction in support efforts and maintenance burden. The coexistence of two
IEEE 1394 kernel driver stacks in the mainline since 2.6.22 shall end now,
as announced earlier this year.
Signed-off-by: Stefan Richter <stefanr@s5r6.in-berlin.de>
Diffstat (limited to 'drivers/ieee1394/ieee1394.h')
-rw-r--r-- | drivers/ieee1394/ieee1394.h | 220 |
1 files changed, 0 insertions, 220 deletions
diff --git a/drivers/ieee1394/ieee1394.h b/drivers/ieee1394/ieee1394.h deleted file mode 100644 index af320e2c5079..000000000000 --- a/drivers/ieee1394/ieee1394.h +++ /dev/null | |||
@@ -1,220 +0,0 @@ | |||
1 | /* | ||
2 | * Generic IEEE 1394 definitions | ||
3 | */ | ||
4 | |||
5 | #ifndef _IEEE1394_IEEE1394_H | ||
6 | #define _IEEE1394_IEEE1394_H | ||
7 | |||
8 | #define TCODE_WRITEQ 0x0 | ||
9 | #define TCODE_WRITEB 0x1 | ||
10 | #define TCODE_WRITE_RESPONSE 0x2 | ||
11 | #define TCODE_READQ 0x4 | ||
12 | #define TCODE_READB 0x5 | ||
13 | #define TCODE_READQ_RESPONSE 0x6 | ||
14 | #define TCODE_READB_RESPONSE 0x7 | ||
15 | #define TCODE_CYCLE_START 0x8 | ||
16 | #define TCODE_LOCK_REQUEST 0x9 | ||
17 | #define TCODE_ISO_DATA 0xa | ||
18 | #define TCODE_STREAM_DATA 0xa | ||
19 | #define TCODE_LOCK_RESPONSE 0xb | ||
20 | |||
21 | #define RCODE_COMPLETE 0x0 | ||
22 | #define RCODE_CONFLICT_ERROR 0x4 | ||
23 | #define RCODE_DATA_ERROR 0x5 | ||
24 | #define RCODE_TYPE_ERROR 0x6 | ||
25 | #define RCODE_ADDRESS_ERROR 0x7 | ||
26 | |||
27 | #define EXTCODE_MASK_SWAP 0x1 | ||
28 | #define EXTCODE_COMPARE_SWAP 0x2 | ||
29 | #define EXTCODE_FETCH_ADD 0x3 | ||
30 | #define EXTCODE_LITTLE_ADD 0x4 | ||
31 | #define EXTCODE_BOUNDED_ADD 0x5 | ||
32 | #define EXTCODE_WRAP_ADD 0x6 | ||
33 | |||
34 | #define ACK_COMPLETE 0x1 | ||
35 | #define ACK_PENDING 0x2 | ||
36 | #define ACK_BUSY_X 0x4 | ||
37 | #define ACK_BUSY_A 0x5 | ||
38 | #define ACK_BUSY_B 0x6 | ||
39 | #define ACK_TARDY 0xb | ||
40 | #define ACK_CONFLICT_ERROR 0xc | ||
41 | #define ACK_DATA_ERROR 0xd | ||
42 | #define ACK_TYPE_ERROR 0xe | ||
43 | #define ACK_ADDRESS_ERROR 0xf | ||
44 | |||
45 | /* Non-standard "ACK codes" for internal use */ | ||
46 | #define ACKX_NONE (-1) | ||
47 | #define ACKX_SEND_ERROR (-2) | ||
48 | #define ACKX_ABORTED (-3) | ||
49 | #define ACKX_TIMEOUT (-4) | ||
50 | |||
51 | #define IEEE1394_SPEED_100 0x00 | ||
52 | #define IEEE1394_SPEED_200 0x01 | ||
53 | #define IEEE1394_SPEED_400 0x02 | ||
54 | #define IEEE1394_SPEED_800 0x03 | ||
55 | #define IEEE1394_SPEED_1600 0x04 | ||
56 | #define IEEE1394_SPEED_3200 0x05 | ||
57 | #define IEEE1394_SPEED_MAX IEEE1394_SPEED_3200 | ||
58 | |||
59 | /* Maps speed values above to a string representation */ | ||
60 | extern const char *hpsb_speedto_str[]; | ||
61 | |||
62 | /* 1394a cable PHY packets */ | ||
63 | #define SELFID_PWRCL_NO_POWER 0x0 | ||
64 | #define SELFID_PWRCL_PROVIDE_15W 0x1 | ||
65 | #define SELFID_PWRCL_PROVIDE_30W 0x2 | ||
66 | #define SELFID_PWRCL_PROVIDE_45W 0x3 | ||
67 | #define SELFID_PWRCL_USE_1W 0x4 | ||
68 | #define SELFID_PWRCL_USE_3W 0x5 | ||
69 | #define SELFID_PWRCL_USE_6W 0x6 | ||
70 | #define SELFID_PWRCL_USE_10W 0x7 | ||
71 | |||
72 | #define SELFID_PORT_CHILD 0x3 | ||
73 | #define SELFID_PORT_PARENT 0x2 | ||
74 | #define SELFID_PORT_NCONN 0x1 | ||
75 | #define SELFID_PORT_NONE 0x0 | ||
76 | |||
77 | #define SELFID_SPEED_UNKNOWN 0x3 /* 1394b PHY */ | ||
78 | |||
79 | #define PHYPACKET_LINKON 0x40000000 | ||
80 | #define PHYPACKET_PHYCONFIG_R 0x00800000 | ||
81 | #define PHYPACKET_PHYCONFIG_T 0x00400000 | ||
82 | #define EXTPHYPACKET_TYPE_PING 0x00000000 | ||
83 | #define EXTPHYPACKET_TYPE_REMOTEACCESS_BASE 0x00040000 | ||
84 | #define EXTPHYPACKET_TYPE_REMOTEACCESS_PAGED 0x00140000 | ||
85 | #define EXTPHYPACKET_TYPE_REMOTEREPLY_BASE 0x000C0000 | ||
86 | #define EXTPHYPACKET_TYPE_REMOTEREPLY_PAGED 0x001C0000 | ||
87 | #define EXTPHYPACKET_TYPE_REMOTECOMMAND 0x00200000 | ||
88 | #define EXTPHYPACKET_TYPE_REMOTECONFIRMATION 0x00280000 | ||
89 | #define EXTPHYPACKET_TYPE_RESUME 0x003C0000 | ||
90 | |||
91 | #define EXTPHYPACKET_TYPEMASK 0xC0FC0000 | ||
92 | |||
93 | #define PHYPACKET_PORT_SHIFT 24 | ||
94 | #define PHYPACKET_GAPCOUNT_SHIFT 16 | ||
95 | |||
96 | /* 1394a PHY register map bitmasks */ | ||
97 | #define PHY_00_PHYSICAL_ID 0xFC | ||
98 | #define PHY_00_R 0x02 /* Root */ | ||
99 | #define PHY_00_PS 0x01 /* Power Status*/ | ||
100 | #define PHY_01_RHB 0x80 /* Root Hold-Off */ | ||
101 | #define PHY_01_IBR 0x80 /* Initiate Bus Reset */ | ||
102 | #define PHY_01_GAP_COUNT 0x3F | ||
103 | #define PHY_02_EXTENDED 0xE0 /* 0x7 for 1394a-compliant PHY */ | ||
104 | #define PHY_02_TOTAL_PORTS 0x1F | ||
105 | #define PHY_03_MAX_SPEED 0xE0 | ||
106 | #define PHY_03_DELAY 0x0F | ||
107 | #define PHY_04_LCTRL 0x80 /* Link Active Report Control */ | ||
108 | #define PHY_04_CONTENDER 0x40 | ||
109 | #define PHY_04_JITTER 0x38 | ||
110 | #define PHY_04_PWR_CLASS 0x07 /* Power Class */ | ||
111 | #define PHY_05_WATCHDOG 0x80 | ||
112 | #define PHY_05_ISBR 0x40 /* Initiate Short Bus Reset */ | ||
113 | #define PHY_05_LOOP 0x20 /* Loop Detect */ | ||
114 | #define PHY_05_PWR_FAIL 0x10 /* Cable Power Failure Detect */ | ||
115 | #define PHY_05_TIMEOUT 0x08 /* Arbitration State Machine Timeout */ | ||
116 | #define PHY_05_PORT_EVENT 0x04 /* Port Event Detect */ | ||
117 | #define PHY_05_ENAB_ACCEL 0x02 /* Enable Arbitration Acceleration */ | ||
118 | #define PHY_05_ENAB_MULTI 0x01 /* Ena. Multispeed Packet Concatenation */ | ||
119 | |||
120 | #include <asm/byteorder.h> | ||
121 | |||
122 | /* '1' '3' '9' '4' in ASCII */ | ||
123 | #define IEEE1394_BUSID_MAGIC cpu_to_be32(0x31333934) | ||
124 | |||
125 | #ifdef __BIG_ENDIAN_BITFIELD | ||
126 | |||
127 | struct selfid { | ||
128 | u32 packet_identifier:2; /* always binary 10 */ | ||
129 | u32 phy_id:6; | ||
130 | /* byte */ | ||
131 | u32 extended:1; /* if true is struct ext_selfid */ | ||
132 | u32 link_active:1; | ||
133 | u32 gap_count:6; | ||
134 | /* byte */ | ||
135 | u32 speed:2; | ||
136 | u32 phy_delay:2; | ||
137 | u32 contender:1; | ||
138 | u32 power_class:3; | ||
139 | /* byte */ | ||
140 | u32 port0:2; | ||
141 | u32 port1:2; | ||
142 | u32 port2:2; | ||
143 | u32 initiated_reset:1; | ||
144 | u32 more_packets:1; | ||
145 | } __attribute__((packed)); | ||
146 | |||
147 | struct ext_selfid { | ||
148 | u32 packet_identifier:2; /* always binary 10 */ | ||
149 | u32 phy_id:6; | ||
150 | /* byte */ | ||
151 | u32 extended:1; /* if false is struct selfid */ | ||
152 | u32 seq_nr:3; | ||
153 | u32 reserved:2; | ||
154 | u32 porta:2; | ||
155 | /* byte */ | ||
156 | u32 portb:2; | ||
157 | u32 portc:2; | ||
158 | u32 portd:2; | ||
159 | u32 porte:2; | ||
160 | /* byte */ | ||
161 | u32 portf:2; | ||
162 | u32 portg:2; | ||
163 | u32 porth:2; | ||
164 | u32 reserved2:1; | ||
165 | u32 more_packets:1; | ||
166 | } __attribute__((packed)); | ||
167 | |||
168 | #elif defined __LITTLE_ENDIAN_BITFIELD /* __BIG_ENDIAN_BITFIELD */ | ||
169 | |||
170 | /* | ||
171 | * Note: these mean to be bit fields of a big endian SelfID as seen on a little | ||
172 | * endian machine. Without swapping. | ||
173 | */ | ||
174 | |||
175 | struct selfid { | ||
176 | u32 phy_id:6; | ||
177 | u32 packet_identifier:2; /* always binary 10 */ | ||
178 | /* byte */ | ||
179 | u32 gap_count:6; | ||
180 | u32 link_active:1; | ||
181 | u32 extended:1; /* if true is struct ext_selfid */ | ||
182 | /* byte */ | ||
183 | u32 power_class:3; | ||
184 | u32 contender:1; | ||
185 | u32 phy_delay:2; | ||
186 | u32 speed:2; | ||
187 | /* byte */ | ||
188 | u32 more_packets:1; | ||
189 | u32 initiated_reset:1; | ||
190 | u32 port2:2; | ||
191 | u32 port1:2; | ||
192 | u32 port0:2; | ||
193 | } __attribute__((packed)); | ||
194 | |||
195 | struct ext_selfid { | ||
196 | u32 phy_id:6; | ||
197 | u32 packet_identifier:2; /* always binary 10 */ | ||
198 | /* byte */ | ||
199 | u32 porta:2; | ||
200 | u32 reserved:2; | ||
201 | u32 seq_nr:3; | ||
202 | u32 extended:1; /* if false is struct selfid */ | ||
203 | /* byte */ | ||
204 | u32 porte:2; | ||
205 | u32 portd:2; | ||
206 | u32 portc:2; | ||
207 | u32 portb:2; | ||
208 | /* byte */ | ||
209 | u32 more_packets:1; | ||
210 | u32 reserved2:1; | ||
211 | u32 porth:2; | ||
212 | u32 portg:2; | ||
213 | u32 portf:2; | ||
214 | } __attribute__((packed)); | ||
215 | |||
216 | #else | ||
217 | #error What? PDP endian? | ||
218 | #endif /* __BIG_ENDIAN_BITFIELD */ | ||
219 | |||
220 | #endif /* _IEEE1394_IEEE1394_H */ | ||