Blame view

drivers/ata/pata_it821x.c 27.4 KB
669a5db41   Jeff Garzik   [libata] Add a bu...
1
  /*
c343a8391   Alan Cox   pata: Trivia
2
   * pata_it821x.c 	- IT821x PATA for new ATA layer
669a5db41   Jeff Garzik   [libata] Add a bu...
3
   *			  (C) 2005 Red Hat Inc
ab7716300   Alan Cox   ata: Switch all m...
4
   *			  Alan Cox <alan@lxorguk.ukuu.org.uk>
374abf2cb   Bartlomiej Zolnierkiewicz   pata_it821x: (par...
5
   *			  (C) 2007 Bartlomiej Zolnierkiewicz
669a5db41   Jeff Garzik   [libata] Add a bu...
6
7
8
9
   *
   * based upon
   *
   * it821x.c
85cd7251b   Jeff Garzik   [libata #pata-dri...
10
   *
669a5db41   Jeff Garzik   [libata] Add a bu...
11
12
   * linux/drivers/ide/pci/it821x.c		Version 0.09	December 2004
   *
ab7716300   Alan Cox   ata: Switch all m...
13
   * Copyright (C) 2004		Red Hat
669a5db41   Jeff Garzik   [libata] Add a bu...
14
15
16
17
   *
   *  May be copied or modified under the terms of the GNU General Public License
   *  Based in part on the ITE vendor provided SCSI driver.
   *
631dd1a88   Justin P. Mattock   Update broken web...
18
19
   *  Documentation available from IT8212F_V04.pdf
   * 	http://www.ite.com.tw/EN/products_more.aspx?CategoryID=3&ID=5,91
669a5db41   Jeff Garzik   [libata] Add a bu...
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
   *  Some other documents are NDA.
   *
   *  The ITE8212 isn't exactly a standard IDE controller. It has two
   *  modes. In pass through mode then it is an IDE controller. In its smart
   *  mode its actually quite a capable hardware raid controller disguised
   *  as an IDE controller. Smart mode only understands DMA read/write and
   *  identify, none of the fancier commands apply. The IT8211 is identical
   *  in other respects but lacks the raid mode.
   *
   *  Errata:
   *  o	Rev 0x10 also requires master/slave hold the same DMA timings and
   *	cannot do ATAPI MWDMA.
   *  o	The identify data for raid volumes lacks CHS info (technically ok)
   *	but also fails to set the LBA28 and other bits. We fix these in
   *	the IDE probe quirk code.
   *  o	If you write LBA48 sized I/O's (ie > 256 sector) in smart mode
   *	raid then the controller firmware dies
   *  o	Smart mode without RAID doesn't clear all the necessary identify
   *	bits to reduce the command set to the one used
   *
   *  This has a few impacts on the driver
   *  - In pass through mode we do all the work you would expect
   *  - In smart mode the clocking set up is done by the controller generally
   *    but we must watch the other limits and filter.
   *  - There are a few extra vendor commands that actually talk to the
   *    controller but only work PIO with no IRQ.
   *
   *  Vendor areas of the identify block in smart mode are used for the
   *  timing and policy set up. Each HDD in raid mode also has a serial
   *  block on the disk. The hardware extra commands are get/set chip status,
   *  rebuild, get rebuild status.
   *
   *  In Linux the driver supports pass through mode as if the device was
   *  just another IDE controller. If the smart mode is running then
   *  volumes are managed by the controller firmware and each IDE "disk"
   *  is a raid volume. Even more cute - the controller can do automated
   *  hotplug and rebuild.
   *
   *  The pass through controller itself is a little demented. It has a
   *  flaw that it has a single set of PIO/MWDMA timings per channel so
   *  non UDMA devices restrict each others performance. It also has a
   *  single clock source per channel so mixed UDMA100/133 performance
   *  isn't perfect and we have to pick a clock. Thankfully none of this
   *  matters in smart mode. ATAPI DMA is not currently supported.
   *
   *  It seems the smart mode is a win for RAID1/RAID10 but otherwise not.
   *
   *  TODO
   *	-	ATAPI and other speed filtering
669a5db41   Jeff Garzik   [libata] Add a bu...
69
70
71
72
73
74
75
76
77
   *	-	RAID configuration ioctls
   */
  
  #include <linux/kernel.h>
  #include <linux/module.h>
  #include <linux/pci.h>
  #include <linux/init.h>
  #include <linux/blkdev.h>
  #include <linux/delay.h>
5a0e3ad6a   Tejun Heo   include cleanup: ...
78
  #include <linux/slab.h>
669a5db41   Jeff Garzik   [libata] Add a bu...
79
80
81
82
83
  #include <scsi/scsi_host.h>
  #include <linux/libata.h>
  
  
  #define DRV_NAME "pata_it821x"
4a99d95fa   Alan Cox   pata_it821x: Upda...
84
  #define DRV_VERSION "0.4.2"
669a5db41   Jeff Garzik   [libata] Add a bu...
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
  
  struct it821x_dev
  {
  	unsigned int smart:1,		/* Are we in smart raid mode */
  		timing10:1;		/* Rev 0x10 */
  	u8	clock_mode;		/* 0, ATA_50 or ATA_66 */
  	u8	want[2][2];		/* Mode/Pri log for master slave */
  	/* We need these for switching the clock when DMA goes on/off
  	   The high byte is the 66Mhz timing */
  	u16	pio[2];			/* Cached PIO values */
  	u16	mwdma[2];		/* Cached MWDMA values */
  	u16	udma[2];		/* Cached UDMA values (per drive) */
  	u16	last_device;		/* Master or slave loaded ? */
  };
  
  #define ATA_66		0
  #define ATA_50		1
  #define ATA_ANY		2
  
  #define UDMA_OFF	0
  #define MWDMA_OFF	0
  
  /*
   *	We allow users to force the card into non raid mode without
3a4fa0a25   Robert P. J. Day   Fix misspellings ...
109
   *	flashing the alternative BIOS. This is also necessary right now
669a5db41   Jeff Garzik   [libata] Add a bu...
110
111
112
113
114
115
116
   *	for embedded platforms that cannot run a PC BIOS but are using this
   *	device.
   */
  
  static int it8212_noraid;
  
  /**
669a5db41   Jeff Garzik   [libata] Add a bu...
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
   *	it821x_program	-	program the PIO/MWDMA registers
   *	@ap: ATA port
   *	@adev: Device to program
   *	@timing: Timing value (66Mhz in top 8bits, 50 in the low 8)
   *
   *	Program the PIO/MWDMA timing for this channel according to the
   *	current clock. These share the same register so are managed by
   *	the DMA start/stop sequence as with the old driver.
   */
  
  static void it821x_program(struct ata_port *ap, struct ata_device *adev, u16 timing)
  {
  	struct pci_dev *pdev = to_pci_dev(ap->host->dev);
  	struct it821x_dev *itdev = ap->private_data;
  	int channel = ap->port_no;
  	u8 conf;
  
  	/* Program PIO/MWDMA timing bits */
  	if (itdev->clock_mode == ATA_66)
  		conf = timing >> 8;
  	else
  		conf = timing & 0xFF;
  	pci_write_config_byte(pdev, 0x54 + 4 * channel, conf);
  }
  
  
  /**
   *	it821x_program_udma	-	program the UDMA registers
   *	@ap: ATA port
   *	@adev: ATA device to update
   *	@timing: Timing bits. Top 8 are for 66Mhz bottom for 50Mhz
   *
   *	Program the UDMA timing for this drive according to the
   *	current clock. Handles the dual clocks and also knows about
   *	the errata on the 0x10 revision. The UDMA errata is partly handled
   *	here and partly in start_dma.
   */
  
  static void it821x_program_udma(struct ata_port *ap, struct ata_device *adev, u16 timing)
  {
  	struct it821x_dev *itdev = ap->private_data;
  	struct pci_dev *pdev = to_pci_dev(ap->host->dev);
  	int channel = ap->port_no;
  	int unit = adev->devno;
  	u8 conf;
  
  	/* Program UDMA timing bits */
  	if (itdev->clock_mode == ATA_66)
  		conf = timing >> 8;
  	else
  		conf = timing & 0xFF;
  	if (itdev->timing10 == 0)
  		pci_write_config_byte(pdev, 0x56 + 4 * channel + unit, conf);
  	else {
  		/* Early revision must be programmed for both together */
  		pci_write_config_byte(pdev, 0x56 + 4 * channel, conf);
  		pci_write_config_byte(pdev, 0x56 + 4 * channel + 1, conf);
  	}
  }
  
  /**
   *	it821x_clock_strategy
   *	@ap: ATA interface
   *	@adev: ATA device being updated
   *
   *	Select between the 50 and 66Mhz base clocks to get the best
   *	results for this interface.
   */
  
  static void it821x_clock_strategy(struct ata_port *ap, struct ata_device *adev)
  {
  	struct pci_dev *pdev = to_pci_dev(ap->host->dev);
  	struct it821x_dev *itdev = ap->private_data;
  	u8 unit = adev->devno;
  	struct ata_device *pair = ata_dev_pair(adev);
  
  	int clock, altclock;
  	u8 v;
  	int sel = 0;
  
  	/* Look for the most wanted clocking */
  	if (itdev->want[0][0] > itdev->want[1][0]) {
  		clock = itdev->want[0][1];
  		altclock = itdev->want[1][1];
  	} else {
  		clock = itdev->want[1][1];
  		altclock = itdev->want[0][1];
  	}
  
  	/* Master doesn't care does the slave ? */
  	if (clock == ATA_ANY)
  		clock = altclock;
  
  	/* Nobody cares - keep the same clock */
  	if (clock == ATA_ANY)
  		return;
  	/* No change */
  	if (clock == itdev->clock_mode)
  		return;
  
  	/* Load this into the controller */
  	if (clock == ATA_66)
  		itdev->clock_mode = ATA_66;
  	else {
  		itdev->clock_mode = ATA_50;
  		sel = 1;
  	}
  	pci_read_config_byte(pdev, 0x50, &v);
  	v &= ~(1 << (1 + ap->port_no));
  	v |= sel << (1 + ap->port_no);
  	pci_write_config_byte(pdev, 0x50, v);
  
  	/*
  	 *	Reprogram the UDMA/PIO of the pair drive for the switch
  	 *	MWDMA will be dealt with by the dma switcher
  	 */
  	if (pair && itdev->udma[1-unit] != UDMA_OFF) {
  		it821x_program_udma(ap, pair, itdev->udma[1-unit]);
  		it821x_program(ap, pair, itdev->pio[1-unit]);
  	}
  	/*
  	 *	Reprogram the UDMA/PIO of our drive for the switch.
  	 *	MWDMA will be dealt with by the dma switcher
  	 */
  	if (itdev->udma[unit] != UDMA_OFF) {
  		it821x_program_udma(ap, adev, itdev->udma[unit]);
  		it821x_program(ap, adev, itdev->pio[unit]);
  	}
  }
  
  /**
   *	it821x_passthru_set_piomode	-	set PIO mode data
   *	@ap: ATA interface
   *	@adev: ATA device
   *
   *	Configure for PIO mode. This is complicated as the register is
   *	shared by PIO and MWDMA and for both channels.
   */
  
  static void it821x_passthru_set_piomode(struct ata_port *ap, struct ata_device *adev)
  {
  	/* Spec says 89 ref driver uses 88 */
  	static const u16 pio[]	= { 0xAA88, 0xA382, 0xA181, 0x3332, 0x3121 };
  	static const u8 pio_want[]    = { ATA_66, ATA_66, ATA_66, ATA_66, ATA_ANY };
  
  	struct it821x_dev *itdev = ap->private_data;
  	int unit = adev->devno;
  	int mode_wanted = adev->pio_mode - XFER_PIO_0;
85cd7251b   Jeff Garzik   [libata #pata-dri...
265

669a5db41   Jeff Garzik   [libata] Add a bu...
266
267
268
269
270
271
272
273
274
275
276
277
278
279
  	/* We prefer 66Mhz clock for PIO 0-3, don't care for PIO4 */
  	itdev->want[unit][1] = pio_want[mode_wanted];
  	itdev->want[unit][0] = 1;	/* PIO is lowest priority */
  	itdev->pio[unit] = pio[mode_wanted];
  	it821x_clock_strategy(ap, adev);
  	it821x_program(ap, adev, itdev->pio[unit]);
  }
  
  /**
   *	it821x_passthru_set_dmamode	-	set initial DMA mode data
   *	@ap: ATA interface
   *	@adev: ATA device
   *
   *	Set up the DMA modes. The actions taken depend heavily on the mode
85cd7251b   Jeff Garzik   [libata #pata-dri...
280
   *	to use. If UDMA is used as is hopefully the usual case then the
669a5db41   Jeff Garzik   [libata] Add a bu...
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
   *	timing register is private and we need only consider the clock. If
   *	we are using MWDMA then we have to manage the setting ourself as
   *	we switch devices and mode.
   */
  
  static void it821x_passthru_set_dmamode(struct ata_port *ap, struct ata_device *adev)
  {
  	static const u16 dma[]	= 	{ 0x8866, 0x3222, 0x3121 };
  	static const u8 mwdma_want[] =  { ATA_ANY, ATA_66, ATA_ANY };
  	static const u16 udma[]	= 	{ 0x4433, 0x4231, 0x3121, 0x2121, 0x1111, 0x2211, 0x1111 };
  	static const u8 udma_want[] =   { ATA_ANY, ATA_50, ATA_ANY, ATA_66, ATA_66, ATA_50, ATA_66 };
  
  	struct pci_dev *pdev = to_pci_dev(ap->host->dev);
  	struct it821x_dev *itdev = ap->private_data;
  	int channel = ap->port_no;
  	int unit = adev->devno;
  	u8 conf;
  
  	if (adev->dma_mode >= XFER_UDMA_0) {
  		int mode_wanted = adev->dma_mode - XFER_UDMA_0;
85cd7251b   Jeff Garzik   [libata #pata-dri...
301

669a5db41   Jeff Garzik   [libata] Add a bu...
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
  		itdev->want[unit][1] = udma_want[mode_wanted];
  		itdev->want[unit][0] = 3;	/* UDMA is high priority */
  		itdev->mwdma[unit] = MWDMA_OFF;
  		itdev->udma[unit] = udma[mode_wanted];
  		if (mode_wanted >= 5)
  			itdev->udma[unit] |= 0x8080;	/* UDMA 5/6 select on */
  
  		/* UDMA on. Again revision 0x10 must do the pair */
  		pci_read_config_byte(pdev, 0x50, &conf);
  		if (itdev->timing10)
  			conf &= channel ? 0x9F: 0xE7;
  		else
  			conf &= ~ (1 << (3 + 2 * channel + unit));
  		pci_write_config_byte(pdev, 0x50, conf);
  		it821x_clock_strategy(ap, adev);
  		it821x_program_udma(ap, adev, itdev->udma[unit]);
  	} else {
  		int mode_wanted = adev->dma_mode - XFER_MW_DMA_0;
85cd7251b   Jeff Garzik   [libata #pata-dri...
320

669a5db41   Jeff Garzik   [libata] Add a bu...
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
  		itdev->want[unit][1] = mwdma_want[mode_wanted];
  		itdev->want[unit][0] = 2;	/* MWDMA is low priority */
  		itdev->mwdma[unit] = dma[mode_wanted];
  		itdev->udma[unit] = UDMA_OFF;
  
  		/* UDMA bits off - Revision 0x10 do them in pairs */
  		pci_read_config_byte(pdev, 0x50, &conf);
  		if (itdev->timing10)
  			conf |= channel ? 0x60: 0x18;
  		else
  			conf |= 1 << (3 + 2 * channel + unit);
  		pci_write_config_byte(pdev, 0x50, conf);
  		it821x_clock_strategy(ap, adev);
  	}
  }
  
  /**
   *	it821x_passthru_dma_start	-	DMA start callback
   *	@qc: Command in progress
   *
   *	Usually drivers set the DMA timing at the point the set_dmamode call
85cd7251b   Jeff Garzik   [libata #pata-dri...
342
   *	is made. IT821x however requires we load new timings on the
669a5db41   Jeff Garzik   [libata] Add a bu...
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
   *	transitions in some cases.
   */
  
  static void it821x_passthru_bmdma_start(struct ata_queued_cmd *qc)
  {
  	struct ata_port *ap = qc->ap;
  	struct ata_device *adev = qc->dev;
  	struct it821x_dev *itdev = ap->private_data;
  	int unit = adev->devno;
  
  	if (itdev->mwdma[unit] != MWDMA_OFF)
  		it821x_program(ap, adev, itdev->mwdma[unit]);
  	else if (itdev->udma[unit] != UDMA_OFF && itdev->timing10)
  		it821x_program_udma(ap, adev, itdev->udma[unit]);
  	ata_bmdma_start(qc);
  }
  
  /**
   *	it821x_passthru_dma_stop	-	DMA stop callback
   *	@qc: ATA command
   *
   *	We loaded new timings in dma_start, as a result we need to restore
   *	the PIO timings in dma_stop so that the next command issue gets the
   *	right clock values.
   */
  
  static void it821x_passthru_bmdma_stop(struct ata_queued_cmd *qc)
  {
  	struct ata_port *ap = qc->ap;
  	struct ata_device *adev = qc->dev;
  	struct it821x_dev *itdev = ap->private_data;
  	int unit = adev->devno;
  
  	ata_bmdma_stop(qc);
  	if (itdev->mwdma[unit] != MWDMA_OFF)
  		it821x_program(ap, adev, itdev->pio[unit]);
  }
  
  
  /**
   *	it821x_passthru_dev_select	-	Select master/slave
   *	@ap: ATA port
   *	@device: Device number (not pointer)
   *
3a4fa0a25   Robert P. J. Day   Fix misspellings ...
387
   *	Device selection hook. If necessary perform clock switching
669a5db41   Jeff Garzik   [libata] Add a bu...
388
   */
85cd7251b   Jeff Garzik   [libata #pata-dri...
389

669a5db41   Jeff Garzik   [libata] Add a bu...
390
391
392
393
394
  static void it821x_passthru_dev_select(struct ata_port *ap,
  				       unsigned int device)
  {
  	struct it821x_dev *itdev = ap->private_data;
  	if (itdev && device != itdev->last_device) {
9af5c9c97   Tejun Heo   libata-link: intr...
395
  		struct ata_device *adev = &ap->link.device[device];
669a5db41   Jeff Garzik   [libata] Add a bu...
396
397
398
  		it821x_program(ap, adev, itdev->pio[adev->devno]);
  		itdev->last_device = device;
  	}
9363c3825   Tejun Heo   libata: rename SF...
399
  	ata_sff_dev_select(ap, device);
669a5db41   Jeff Garzik   [libata] Add a bu...
400
401
402
  }
  
  /**
9363c3825   Tejun Heo   libata: rename SF...
403
   *	it821x_smart_qc_issue		-	wrap qc issue prot
669a5db41   Jeff Garzik   [libata] Add a bu...
404
405
406
407
408
409
   *	@qc: command
   *
   *	Wrap the command issue sequence for the IT821x. We need to
   *	perform out own device selection timing loads before the
   *	usual happenings kick off
   */
85cd7251b   Jeff Garzik   [libata #pata-dri...
410

9363c3825   Tejun Heo   libata: rename SF...
411
  static unsigned int it821x_smart_qc_issue(struct ata_queued_cmd *qc)
669a5db41   Jeff Garzik   [libata] Add a bu...
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
  {
  	switch(qc->tf.command)
  	{
  		/* Commands the firmware supports */
  		case ATA_CMD_READ:
  		case ATA_CMD_READ_EXT:
  		case ATA_CMD_WRITE:
  		case ATA_CMD_WRITE_EXT:
  		case ATA_CMD_PIO_READ:
  		case ATA_CMD_PIO_READ_EXT:
  		case ATA_CMD_PIO_WRITE:
  		case ATA_CMD_PIO_WRITE_EXT:
  		case ATA_CMD_READ_MULTI:
  		case ATA_CMD_READ_MULTI_EXT:
  		case ATA_CMD_WRITE_MULTI:
  		case ATA_CMD_WRITE_MULTI_EXT:
  		case ATA_CMD_ID_ATA:
963e4975c   Alan Cox   pata_it821x: Driv...
429
430
  		case ATA_CMD_INIT_DEV_PARAMS:
  		case 0xFC:	/* Internal 'report rebuild state' */
669a5db41   Jeff Garzik   [libata] Add a bu...
431
432
  		/* Arguably should just no-op this one */
  		case ATA_CMD_SET_FEATURES:
360ff7833   Tejun Heo   libata-sff: separ...
433
  			return ata_bmdma_qc_issue(qc);
669a5db41   Jeff Garzik   [libata] Add a bu...
434
435
436
  	}
  	printk(KERN_DEBUG "it821x: can't process command 0x%02X
  ", qc->tf.command);
c5038fc05   Alan Cox   libata/pata_it821...
437
  	return AC_ERR_DEV;
669a5db41   Jeff Garzik   [libata] Add a bu...
438
439
440
  }
  
  /**
9363c3825   Tejun Heo   libata: rename SF...
441
   *	it821x_passthru_qc_issue	-	wrap qc issue prot
669a5db41   Jeff Garzik   [libata] Add a bu...
442
443
444
445
446
447
   *	@qc: command
   *
   *	Wrap the command issue sequence for the IT821x. We need to
   *	perform out own device selection timing loads before the
   *	usual happenings kick off
   */
85cd7251b   Jeff Garzik   [libata #pata-dri...
448

9363c3825   Tejun Heo   libata: rename SF...
449
  static unsigned int it821x_passthru_qc_issue(struct ata_queued_cmd *qc)
669a5db41   Jeff Garzik   [libata] Add a bu...
450
451
  {
  	it821x_passthru_dev_select(qc->ap, qc->dev->devno);
360ff7833   Tejun Heo   libata-sff: separ...
452
  	return ata_bmdma_qc_issue(qc);
669a5db41   Jeff Garzik   [libata] Add a bu...
453
454
455
456
  }
  
  /**
   *	it821x_smart_set_mode	-	mode setting
0260731f0   Tejun Heo   libata-link: link...
457
   *	@link: interface to set up
b229a7b0a   Alan Cox   libata: set_mode,...
458
   *	@unused: device that failed (error only)
669a5db41   Jeff Garzik   [libata] Add a bu...
459
460
461
462
   *
   *	Use a non standard set_mode function. We don't want to be tuned.
   *	The BIOS configured everything. Our job is not to fiddle. We
   *	read the dma enabled bits from the PCI configuration of the device
85cd7251b   Jeff Garzik   [libata #pata-dri...
463
   *	and respect them.
669a5db41   Jeff Garzik   [libata] Add a bu...
464
   */
85cd7251b   Jeff Garzik   [libata #pata-dri...
465

0260731f0   Tejun Heo   libata-link: link...
466
  static int it821x_smart_set_mode(struct ata_link *link, struct ata_device **unused)
669a5db41   Jeff Garzik   [libata] Add a bu...
467
  {
f58229f80   Tejun Heo   libata-link: impl...
468
  	struct ata_device *dev;
669a5db41   Jeff Garzik   [libata] Add a bu...
469

1eca4365b   Tejun Heo   libata: beef up i...
470
471
472
473
474
475
476
  	ata_for_each_dev(dev, link, ENABLED) {
  		/* We don't really care */
  		dev->pio_mode = XFER_PIO_0;
  		dev->dma_mode = XFER_MW_DMA_0;
  		/* We do need the right mode information for DMA or PIO
  		   and this comes from the current configuration flags */
  		if (ata_id_has_dma(dev->id)) {
a9a79dfec   Joe Perches   ata: Convert ata_...
477
478
  			ata_dev_info(dev, "configured for DMA
  ");
1eca4365b   Tejun Heo   libata: beef up i...
479
480
481
482
  			dev->xfer_mode = XFER_MW_DMA_0;
  			dev->xfer_shift = ATA_SHIFT_MWDMA;
  			dev->flags &= ~ATA_DFLAG_PIO;
  		} else {
a9a79dfec   Joe Perches   ata: Convert ata_...
483
484
  			ata_dev_info(dev, "configured for PIO
  ");
1eca4365b   Tejun Heo   libata: beef up i...
485
486
487
  			dev->xfer_mode = XFER_PIO_0;
  			dev->xfer_shift = ATA_SHIFT_PIO;
  			dev->flags |= ATA_DFLAG_PIO;
669a5db41   Jeff Garzik   [libata] Add a bu...
488
489
  		}
  	}
b229a7b0a   Alan Cox   libata: set_mode,...
490
  	return 0;
669a5db41   Jeff Garzik   [libata] Add a bu...
491
492
493
494
  }
  
  /**
   *	it821x_dev_config	-	Called each device identify
669a5db41   Jeff Garzik   [libata] Add a bu...
495
496
497
498
499
500
   *	@adev: Device that has just been identified
   *
   *	Perform the initial setup needed for each device that is chip
   *	special. In our case we need to lock the sector count to avoid
   *	blowing the brains out of the firmware with large LBA48 requests
   *
669a5db41   Jeff Garzik   [libata] Add a bu...
501
   */
85cd7251b   Jeff Garzik   [libata #pata-dri...
502

cd0d3bbcd   Alan Cox   libata: dev_confi...
503
  static void it821x_dev_config(struct ata_device *adev)
669a5db41   Jeff Garzik   [libata] Add a bu...
504
  {
8bfa79fcb   Tejun Heo   libata: use ata_i...
505
  	unsigned char model_num[ATA_ID_PROD_LEN + 1];
669a5db41   Jeff Garzik   [libata] Add a bu...
506

8bfa79fcb   Tejun Heo   libata: use ata_i...
507
  	ata_id_c_string(adev->id, model_num, ATA_ID_PROD, sizeof(model_num));
669a5db41   Jeff Garzik   [libata] Add a bu...
508
509
510
  
  	if (adev->max_sectors > 255)
  		adev->max_sectors = 255;
85cd7251b   Jeff Garzik   [libata #pata-dri...
511

669a5db41   Jeff Garzik   [libata] Add a bu...
512
513
  	if (strstr(model_num, "Integrated Technology Express")) {
  		/* RAID mode */
a9a79dfec   Joe Perches   ata: Convert ata_...
514
515
516
  		ata_dev_info(adev, "%sRAID%d volume",
  			     adev->id[147] ? "Bootable " : "",
  			     adev->id[129]);
669a5db41   Jeff Garzik   [libata] Add a bu...
517
  		if (adev->id[129] != 1)
a9a79dfec   Joe Perches   ata: Convert ata_...
518
519
520
  			pr_cont("(%dK stripe)", adev->id[146]);
  		pr_cont("
  ");
669a5db41   Jeff Garzik   [libata] Add a bu...
521
  	}
c5038fc05   Alan Cox   libata/pata_it821...
522
523
524
  	/* This is a controller firmware triggered funny, don't
  	   report the drive faulty! */
  	adev->horkage &= ~ATA_HORKAGE_DIAGNOSTIC;
963e4975c   Alan Cox   pata_it821x: Driv...
525
526
  	/* No HPA in 'smart' mode */
  	adev->horkage |= ATA_HORKAGE_BROKEN_HPA;
c5038fc05   Alan Cox   libata/pata_it821...
527
528
529
  }
  
  /**
963e4975c   Alan Cox   pata_it821x: Driv...
530
531
532
533
   *	it821x_read_id	-	Hack identify data up
   *	@adev: device to read
   *	@tf: proposed taskfile
   *	@id: buffer for returned ident data
c5038fc05   Alan Cox   libata/pata_it821...
534
   *
963e4975c   Alan Cox   pata_it821x: Driv...
535
   *	Query the devices on this firmware driven port and slightly
c5038fc05   Alan Cox   libata/pata_it821...
536
537
538
   *	mash the identify data to stop us and common tools trying to
   *	use features not firmware supported. The firmware itself does
   *	some masking (eg SMART) but not enough.
c5038fc05   Alan Cox   libata/pata_it821...
539
   */
963e4975c   Alan Cox   pata_it821x: Driv...
540
541
  static unsigned int it821x_read_id(struct ata_device *adev,
  					struct ata_taskfile *tf, u16 *id)
c5038fc05   Alan Cox   libata/pata_it821...
542
  {
963e4975c   Alan Cox   pata_it821x: Driv...
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
  	unsigned int err_mask;
  	unsigned char model_num[ATA_ID_PROD_LEN + 1];
  
  	err_mask = ata_do_dev_read_id(adev, tf, id);
  	if (err_mask)
  		return err_mask;
  	ata_id_c_string(id, model_num, ATA_ID_PROD, sizeof(model_num));
  
  	id[83] &= ~(1 << 12);	/* Cache flush is firmware handled */
  	id[83] &= ~(1 << 13);	/* Ditto for LBA48 flushes */
  	id[84] &= ~(1 << 6);	/* No FUA */
  	id[85] &= ~(1 << 10);	/* No HPA */
  	id[76] = 0;		/* No NCQ/AN etc */
  
  	if (strstr(model_num, "Integrated Technology Express")) {
  		/* Set feature bits the firmware neglects */
  		id[49] |= 0x0300;	/* LBA, DMA */
963e4975c   Alan Cox   pata_it821x: Driv...
560
  		id[83] &= 0x7FFF;
054e5f616   Ondrej Zary   libata: Fix LBA48...
561
  		id[83] |= 0x4400;	/* Word 83 is valid and LBA48 */
963e4975c   Alan Cox   pata_it821x: Driv...
562
563
  		id[86] |= 0x0400;	/* LBA48 on */
  		id[ATA_ID_MAJOR_VER] |= 0x1F;
7ba07d16b   Ondrej Zary   pata_it821x: resu...
564
565
566
  		/* Clear the serial number because it's different each boot
  		   which breaks validation on resume */
  		memset(&id[ATA_ID_SERNO], 0x20, ATA_ID_SERNO_LEN);
c5038fc05   Alan Cox   libata/pata_it821...
567
  	}
963e4975c   Alan Cox   pata_it821x: Driv...
568
  	return err_mask;
669a5db41   Jeff Garzik   [libata] Add a bu...
569
  }
669a5db41   Jeff Garzik   [libata] Add a bu...
570
571
572
573
574
575
576
  /**
   *	it821x_check_atapi_dma	-	ATAPI DMA handler
   *	@qc: Command we are about to issue
   *
   *	Decide if this ATAPI command can be issued by DMA on this
   *	controller. Return 0 if it can be.
   */
85cd7251b   Jeff Garzik   [libata #pata-dri...
577

669a5db41   Jeff Garzik   [libata] Add a bu...
578
579
580
581
  static int it821x_check_atapi_dma(struct ata_queued_cmd *qc)
  {
  	struct ata_port *ap = qc->ap;
  	struct it821x_dev *itdev = ap->private_data;
85cd7251b   Jeff Garzik   [libata #pata-dri...
582

bce7d5e0e   Jeff Norden   pata_it821x: fix ...
583
  	/* Only use dma for transfers to/from the media. */
b63b13316   Tejun Heo   pata_it821x: use ...
584
  	if (ata_qc_raw_nbytes(qc) < 2048)
bce7d5e0e   Jeff Norden   pata_it821x: fix ...
585
  		return -EOPNOTSUPP;
669a5db41   Jeff Garzik   [libata] Add a bu...
586
587
588
589
590
591
592
593
594
  	/* No ATAPI DMA in smart mode */
  	if (itdev->smart)
  		return -EOPNOTSUPP;
  	/* No ATAPI DMA on rev 10 */
  	if (itdev->timing10)
  		return -EOPNOTSUPP;
  	/* Cool */
  	return 0;
  }
85cd7251b   Jeff Garzik   [libata #pata-dri...
595

963e4975c   Alan Cox   pata_it821x: Driv...
596
597
598
599
600
601
602
603
604
605
606
607
608
  /**
   *	it821x_display_disk	-	display disk setup
   *	@n: Device number
   *	@buf: Buffer block from firmware
   *
   *	Produce a nice informative display of the device setup as provided
   *	by the firmware.
   */
  
  static void it821x_display_disk(int n, u8 *buf)
  {
  	unsigned char id[41];
  	int mode = 0;
4ef281853   Jeff Garzik   [libata] pata_it8...
609
  	char *mtype = "";
963e4975c   Alan Cox   pata_it821x: Driv...
610
611
612
613
  	char mbuf[8];
  	char *cbl = "(40 wire cable)";
  
  	static const char *types[5] = {
1c30c0275   Jean Delvare   pata_it821x: Fix ...
614
  		"RAID0", "RAID1", "RAID 0+1", "JBOD", "DISK"
963e4975c   Alan Cox   pata_it821x: Driv...
615
616
617
618
  	};
  
  	if (buf[52] > 4)	/* No Disk */
  		return;
4fca377f7   Jeff Garzik   [libata] trivial:...
619
  	ata_id_c_string((u16 *)buf, id, 0, 41);
963e4975c   Alan Cox   pata_it821x: Driv...
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
  
  	if (buf[51]) {
  		mode = ffs(buf[51]);
  		mtype = "UDMA";
  	} else if (buf[49]) {
  		mode = ffs(buf[49]);
  		mtype = "MWDMA";
  	}
  
  	if (buf[76])
  		cbl = "";
  
  	if (mode)
  		snprintf(mbuf, 8, "%5s%d", mtype, mode - 1);
  	else
  		strcpy(mbuf, "PIO");
  	if (buf[52] == 4)
  		printk(KERN_INFO "%d: %-6s %-8s          %s %s
  ",
  				n, mbuf, types[buf[52]], id, cbl);
  	else
  		printk(KERN_INFO "%d: %-6s %-8s Volume: %1d %s %s
  ",
  				n, mbuf, types[buf[52]], buf[53], id, cbl);
  	if (buf[125] < 100)
  		printk(KERN_INFO "%d: Rebuilding: %d%%
  ", n, buf[125]);
  }
  
  /**
   *	it821x_firmware_command		-	issue firmware command
   *	@ap: IT821x port to interrogate
   *	@cmd: command
   *	@len: length
   *
   *	Issue firmware commands expecting data back from the controller. We
   *	use this to issue commands that do not go via the normal paths. Other
   *	commands such as 0xFC can be issued normally.
   */
  
  static u8 *it821x_firmware_command(struct ata_port *ap, u8 cmd, int len)
  {
  	u8 status;
  	int n = 0;
  	u16 *buf = kmalloc(len, GFP_KERNEL);
  	if (buf == NULL) {
  		printk(KERN_ERR "it821x_firmware_command: Out of memory
  ");
  		return NULL;
  	}
  	/* This isn't quite a normal ATA command as we are talking to the
  	   firmware not the drives */
  	ap->ctl |= ATA_NIEN;
  	iowrite8(ap->ctl, ap->ioaddr.ctl_addr);
  	ata_wait_idle(ap);
  	iowrite8(ATA_DEVICE_OBS, ap->ioaddr.device_addr);
  	iowrite8(cmd, ap->ioaddr.command_addr);
  	udelay(1);
  	/* This should be almost immediate but a little paranoia goes a long
  	   way. */
  	while(n++ < 10) {
  		status = ioread8(ap->ioaddr.status_addr);
  		if (status & ATA_ERR) {
  			kfree(buf);
  			printk(KERN_ERR "it821x_firmware_command: rejected
  ");
  			return NULL;
  		}
  		if (status & ATA_DRQ) {
  			ioread16_rep(ap->ioaddr.data_addr, buf, len/2);
  			return (u8 *)buf;
  		}
  		mdelay(1);
  	}
  	kfree(buf);
  	printk(KERN_ERR "it821x_firmware_command: timeout
  ");
  	return NULL;
  }
  
  /**
   *	it821x_probe_firmware	-	firmware reporting/setup
   *	@ap: IT821x port being probed
   *
   *	Probe the firmware of the controller by issuing firmware command
   *	0xFA and analysing the returned data.
   */
  
  static void it821x_probe_firmware(struct ata_port *ap)
  {
  	u8 *buf;
  	int i;
  
  	/* This is a bit ugly as we can't just issue a task file to a device
  	   as this is controller magic */
  
  	buf = it821x_firmware_command(ap, 0xFA, 512);
  
  	if (buf != NULL) {
  		printk(KERN_INFO "pata_it821x: Firmware %02X/%02X/%02X%02X
  ",
  				buf[505],
  				buf[506],
  				buf[507],
  				buf[508]);
  		for (i = 0; i < 4; i++)
   			it821x_display_disk(i, buf + 128 * i);
  		kfree(buf);
  	}
  }
669a5db41   Jeff Garzik   [libata] Add a bu...
730
731
732
733
734
735
736
  
  /**
   *	it821x_port_start	-	port setup
   *	@ap: ATA port being set up
   *
   *	The it821x needs to maintain private data structures and also to
   *	use the standard PCI interface which lacks support for this
85cd7251b   Jeff Garzik   [libata #pata-dri...
737
   *	functionality. We instead set up the private data on the port
669a5db41   Jeff Garzik   [libata] Add a bu...
738
739
   *	start hook, and tear it down on port stop
   */
85cd7251b   Jeff Garzik   [libata #pata-dri...
740

669a5db41   Jeff Garzik   [libata] Add a bu...
741
742
743
744
745
  static int it821x_port_start(struct ata_port *ap)
  {
  	struct pci_dev *pdev = to_pci_dev(ap->host->dev);
  	struct it821x_dev *itdev;
  	u8 conf;
c7087652e   Tejun Heo   libata-sff: clean...
746
  	int ret = ata_bmdma_port_start(ap);
669a5db41   Jeff Garzik   [libata] Add a bu...
747
748
  	if (ret < 0)
  		return ret;
85cd7251b   Jeff Garzik   [libata #pata-dri...
749

24dc5f33e   Tejun Heo   libata: update li...
750
751
  	itdev = devm_kzalloc(&pdev->dev, sizeof(struct it821x_dev), GFP_KERNEL);
  	if (itdev == NULL)
669a5db41   Jeff Garzik   [libata] Add a bu...
752
  		return -ENOMEM;
24dc5f33e   Tejun Heo   libata: update li...
753
  	ap->private_data = itdev;
669a5db41   Jeff Garzik   [libata] Add a bu...
754
755
756
757
758
759
760
761
  
  	pci_read_config_byte(pdev, 0x50, &conf);
  
  	if (conf & 1) {
  		itdev->smart = 1;
  		/* Long I/O's although allowed in LBA48 space cause the
  		   onboard firmware to enter the twighlight zone */
  		/* No ATAPI DMA in this mode either */
963e4975c   Alan Cox   pata_it821x: Driv...
762
763
  		if (ap->port_no == 0)
  			it821x_probe_firmware(ap);
669a5db41   Jeff Garzik   [libata] Add a bu...
764
765
766
767
768
769
770
771
772
773
  	}
  	/* Pull the current clocks from 0x50 */
  	if (conf & (1 << (1 + ap->port_no)))
  		itdev->clock_mode = ATA_50;
  	else
  		itdev->clock_mode = ATA_66;
  
  	itdev->want[0][1] = ATA_ANY;
  	itdev->want[1][1] = ATA_ANY;
  	itdev->last_device = -1;
604de6e0e   Alan Cox   pata_it821x: Fix ...
774
  	if (pdev->revision == 0x10) {
669a5db41   Jeff Garzik   [libata] Add a bu...
775
776
777
778
779
780
781
782
783
  		itdev->timing10 = 1;
  		/* Need to disable ATAPI DMA for this case */
  		if (!itdev->smart)
  			printk(KERN_WARNING DRV_NAME": Revision 0x10, workarounds activated.
  ");
  	}
  
  	return 0;
  }
963e4975c   Alan Cox   pata_it821x: Driv...
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
  /**
   *	it821x_rdc_cable	-	Cable detect for RDC1010
   *	@ap: port we are checking
   *
   *	Return the RDC1010 cable type. Unlike the IT821x we know how to do
   *	this and can do host side cable detect
   */
  
  static int it821x_rdc_cable(struct ata_port *ap)
  {
  	u16 r40;
  	struct pci_dev *pdev = to_pci_dev(ap->host->dev);
  
  	pci_read_config_word(pdev, 0x40, &r40);
  	if (r40 & (1 << (2 + ap->port_no)))
  		return ATA_CBL_PATA40;
  	return ATA_CBL_PATA80;
  }
669a5db41   Jeff Garzik   [libata] Add a bu...
802
  static struct scsi_host_template it821x_sht = {
68d1d07b5   Tejun Heo   libata: implement...
803
  	ATA_BMDMA_SHT(DRV_NAME),
669a5db41   Jeff Garzik   [libata] Add a bu...
804
805
806
  };
  
  static struct ata_port_operations it821x_smart_port_ops = {
029cfd6b7   Tejun Heo   libata: implement...
807
  	.inherits	= &ata_bmdma_port_ops,
85cd7251b   Jeff Garzik   [libata #pata-dri...
808

669a5db41   Jeff Garzik   [libata] Add a bu...
809
  	.check_atapi_dma= it821x_check_atapi_dma,
9363c3825   Tejun Heo   libata: rename SF...
810
  	.qc_issue	= it821x_smart_qc_issue,
bda302881   Jeff Garzik   [libata] Don't us...
811

963e4975c   Alan Cox   pata_it821x: Driv...
812
  	.cable_detect	= ata_cable_80wire,
029cfd6b7   Tejun Heo   libata: implement...
813
814
  	.set_mode	= it821x_smart_set_mode,
  	.dev_config	= it821x_dev_config,
963e4975c   Alan Cox   pata_it821x: Driv...
815
  	.read_id	= it821x_read_id,
669a5db41   Jeff Garzik   [libata] Add a bu...
816
817
  
  	.port_start	= it821x_port_start,
85cd7251b   Jeff Garzik   [libata #pata-dri...
818
  };
669a5db41   Jeff Garzik   [libata] Add a bu...
819
820
  
  static struct ata_port_operations it821x_passthru_port_ops = {
029cfd6b7   Tejun Heo   libata: implement...
821
  	.inherits	= &ata_bmdma_port_ops,
85cd7251b   Jeff Garzik   [libata #pata-dri...
822

669a5db41   Jeff Garzik   [libata] Add a bu...
823
  	.check_atapi_dma= it821x_check_atapi_dma,
5682ed33a   Tejun Heo   libata: rename SF...
824
  	.sff_dev_select	= it821x_passthru_dev_select,
669a5db41   Jeff Garzik   [libata] Add a bu...
825
826
  	.bmdma_start 	= it821x_passthru_bmdma_start,
  	.bmdma_stop	= it821x_passthru_bmdma_stop,
9363c3825   Tejun Heo   libata: rename SF...
827
  	.qc_issue	= it821x_passthru_qc_issue,
bda302881   Jeff Garzik   [libata] Don't us...
828

029cfd6b7   Tejun Heo   libata: implement...
829
830
831
  	.cable_detect	= ata_cable_unknown,
  	.set_piomode	= it821x_passthru_set_piomode,
  	.set_dmamode	= it821x_passthru_set_dmamode,
669a5db41   Jeff Garzik   [libata] Add a bu...
832
833
  
  	.port_start	= it821x_port_start,
85cd7251b   Jeff Garzik   [libata #pata-dri...
834
  };
669a5db41   Jeff Garzik   [libata] Add a bu...
835

963e4975c   Alan Cox   pata_it821x: Driv...
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
  static struct ata_port_operations it821x_rdc_port_ops = {
  	.inherits	= &ata_bmdma_port_ops,
  
  	.check_atapi_dma= it821x_check_atapi_dma,
  	.sff_dev_select	= it821x_passthru_dev_select,
  	.bmdma_start 	= it821x_passthru_bmdma_start,
  	.bmdma_stop	= it821x_passthru_bmdma_stop,
  	.qc_issue	= it821x_passthru_qc_issue,
  
  	.cable_detect	= it821x_rdc_cable,
  	.set_piomode	= it821x_passthru_set_piomode,
  	.set_dmamode	= it821x_passthru_set_dmamode,
  
  	.port_start	= it821x_port_start,
  };
112cc2b51   Randy Dunlap   pata_it821x: fix ...
851
  static void it821x_disable_raid(struct pci_dev *pdev)
669a5db41   Jeff Garzik   [libata] Add a bu...
852
  {
963e4975c   Alan Cox   pata_it821x: Driv...
853
854
855
856
  	/* Neither the RDC nor the IT8211 */
  	if (pdev->vendor != PCI_VENDOR_ID_ITE ||
  			pdev->device != PCI_DEVICE_ID_ITE_8212)
  			return;
669a5db41   Jeff Garzik   [libata] Add a bu...
857
858
859
860
861
862
863
864
865
866
867
868
869
870
  	/* Reset local CPU, and set BIOS not ready */
  	pci_write_config_byte(pdev, 0x5E, 0x01);
  
  	/* Set to bypass mode, and reset PCI bus */
  	pci_write_config_byte(pdev, 0x50, 0x00);
  	pci_write_config_word(pdev, PCI_COMMAND,
  			      PCI_COMMAND_PARITY | PCI_COMMAND_IO |
  			      PCI_COMMAND_MEMORY | PCI_COMMAND_MASTER);
  	pci_write_config_word(pdev, 0x40, 0xA0F3);
  
  	pci_write_config_dword(pdev,0x4C, 0x02040204);
  	pci_write_config_byte(pdev, 0x42, 0x36);
  	pci_write_config_byte(pdev, PCI_LATENCY_TIMER, 0x20);
  }
85cd7251b   Jeff Garzik   [libata #pata-dri...
871

669a5db41   Jeff Garzik   [libata] Add a bu...
872
873
874
  static int it821x_init_one(struct pci_dev *pdev, const struct pci_device_id *id)
  {
  	u8 conf;
85cd7251b   Jeff Garzik   [libata #pata-dri...
875

1626aeb88   Tejun Heo   libata: clean up ...
876
  	static const struct ata_port_info info_smart = {
1d2808fd3   Jeff Garzik   [libata] PATA dri...
877
  		.flags = ATA_FLAG_SLAVE_POSS,
14bdef982   Erik Inge Bolsø   [libata] convert ...
878
879
  		.pio_mask = ATA_PIO4,
  		.mwdma_mask = ATA_MWDMA2,
963e4975c   Alan Cox   pata_it821x: Driv...
880
  		.udma_mask = ATA_UDMA6,
669a5db41   Jeff Garzik   [libata] Add a bu...
881
882
  		.port_ops = &it821x_smart_port_ops
  	};
1626aeb88   Tejun Heo   libata: clean up ...
883
  	static const struct ata_port_info info_passthru = {
1d2808fd3   Jeff Garzik   [libata] PATA dri...
884
  		.flags = ATA_FLAG_SLAVE_POSS,
14bdef982   Erik Inge Bolsø   [libata] convert ...
885
886
  		.pio_mask = ATA_PIO4,
  		.mwdma_mask = ATA_MWDMA2,
bf6263a85   Jeff Garzik   [libata] Use ATA_...
887
  		.udma_mask = ATA_UDMA6,
669a5db41   Jeff Garzik   [libata] Add a bu...
888
889
  		.port_ops = &it821x_passthru_port_ops
  	};
963e4975c   Alan Cox   pata_it821x: Driv...
890
891
  	static const struct ata_port_info info_rdc = {
  		.flags = ATA_FLAG_SLAVE_POSS,
14bdef982   Erik Inge Bolsø   [libata] convert ...
892
893
  		.pio_mask = ATA_PIO4,
  		.mwdma_mask = ATA_MWDMA2,
4a99d95fa   Alan Cox   pata_it821x: Upda...
894
895
896
897
898
  		.udma_mask = ATA_UDMA6,
  		.port_ops = &it821x_rdc_port_ops
  	};
  	static const struct ata_port_info info_rdc_11 = {
  		.flags = ATA_FLAG_SLAVE_POSS,
14bdef982   Erik Inge Bolsø   [libata] convert ...
899
900
  		.pio_mask = ATA_PIO4,
  		.mwdma_mask = ATA_MWDMA2,
963e4975c   Alan Cox   pata_it821x: Driv...
901
902
903
  		/* No UDMA */
  		.port_ops = &it821x_rdc_port_ops
  	};
85cd7251b   Jeff Garzik   [libata #pata-dri...
904

1626aeb88   Tejun Heo   libata: clean up ...
905
  	const struct ata_port_info *ppi[] = { NULL, NULL };
669a5db41   Jeff Garzik   [libata] Add a bu...
906
  	static char *mode[2] = { "pass through", "smart" };
f08048e94   Tejun Heo   libata: PCI devic...
907
908
909
910
911
  	int rc;
  
  	rc = pcim_enable_device(pdev);
  	if (rc)
  		return rc;
4fca377f7   Jeff Garzik   [libata] trivial:...
912

963e4975c   Alan Cox   pata_it821x: Driv...
913
  	if (pdev->vendor == PCI_VENDOR_ID_RDC) {
4a99d95fa   Alan Cox   pata_it821x: Upda...
914
915
916
917
918
  		/* Deal with Vortex86SX */
  		if (pdev->revision == 0x11)
  			ppi[0] = &info_rdc_11;
  		else
  			ppi[0] = &info_rdc;
963e4975c   Alan Cox   pata_it821x: Driv...
919
920
921
922
923
924
925
926
927
  	} else {
  		/* Force the card into bypass mode if so requested */
  		if (it8212_noraid) {
  			printk(KERN_INFO DRV_NAME ": forcing bypass mode.
  ");
  			it821x_disable_raid(pdev);
  		}
  		pci_read_config_byte(pdev, 0x50, &conf);
  		conf &= 1;
669a5db41   Jeff Garzik   [libata] Add a bu...
928

963e4975c   Alan Cox   pata_it821x: Driv...
929
930
931
932
933
934
935
  		printk(KERN_INFO DRV_NAME": controller in %s mode.
  ",
  								mode[conf]);
  		if (conf == 0)
  			ppi[0] = &info_passthru;
  		else
  			ppi[0] = &info_smart;
669a5db41   Jeff Garzik   [libata] Add a bu...
936
  	}
1c5afdf7a   Tejun Heo   libata-sff: separ...
937
  	return ata_pci_bmdma_init_one(pdev, ppi, &it821x_sht, NULL, 0);
669a5db41   Jeff Garzik   [libata] Add a bu...
938
  }
438ac6d5e   Tejun Heo   libata: add missi...
939
  #ifdef CONFIG_PM
f535d53f3   Alan Cox   [PATCH] pata_it82...
940
941
  static int it821x_reinit_one(struct pci_dev *pdev)
  {
f08048e94   Tejun Heo   libata: PCI devic...
942
943
944
945
946
947
  	struct ata_host *host = dev_get_drvdata(&pdev->dev);
  	int rc;
  
  	rc = ata_pci_device_do_resume(pdev);
  	if (rc)
  		return rc;
f535d53f3   Alan Cox   [PATCH] pata_it82...
948
949
950
  	/* Resume - turn raid back off if need be */
  	if (it8212_noraid)
  		it821x_disable_raid(pdev);
f08048e94   Tejun Heo   libata: PCI devic...
951
952
  	ata_host_resume(host);
  	return rc;
f535d53f3   Alan Cox   [PATCH] pata_it82...
953
  }
438ac6d5e   Tejun Heo   libata: add missi...
954
  #endif
f535d53f3   Alan Cox   [PATCH] pata_it82...
955

2d2744fc8   Jeff Garzik   [libata] PCI ID t...
956
957
958
  static const struct pci_device_id it821x[] = {
  	{ PCI_VDEVICE(ITE, PCI_DEVICE_ID_ITE_8211), },
  	{ PCI_VDEVICE(ITE, PCI_DEVICE_ID_ITE_8212), },
4192be640   Otavio Salvador   pata-it821x: use ...
959
  	{ PCI_VDEVICE(RDC, PCI_DEVICE_ID_RDC_D1010), },
2d2744fc8   Jeff Garzik   [libata] PCI ID t...
960
961
  
  	{ },
669a5db41   Jeff Garzik   [libata] Add a bu...
962
963
964
  };
  
  static struct pci_driver it821x_pci_driver = {
2d2744fc8   Jeff Garzik   [libata] PCI ID t...
965
  	.name 		= DRV_NAME,
669a5db41   Jeff Garzik   [libata] Add a bu...
966
967
  	.id_table	= it821x,
  	.probe 		= it821x_init_one,
f535d53f3   Alan Cox   [PATCH] pata_it82...
968
  	.remove		= ata_pci_remove_one,
438ac6d5e   Tejun Heo   libata: add missi...
969
  #ifdef CONFIG_PM
f535d53f3   Alan Cox   [PATCH] pata_it82...
970
971
  	.suspend	= ata_pci_device_suspend,
  	.resume		= it821x_reinit_one,
438ac6d5e   Tejun Heo   libata: add missi...
972
  #endif
669a5db41   Jeff Garzik   [libata] Add a bu...
973
974
975
976
977
978
  };
  
  static int __init it821x_init(void)
  {
  	return pci_register_driver(&it821x_pci_driver);
  }
669a5db41   Jeff Garzik   [libata] Add a bu...
979
980
981
982
  static void __exit it821x_exit(void)
  {
  	pci_unregister_driver(&it821x_pci_driver);
  }
669a5db41   Jeff Garzik   [libata] Add a bu...
983
984
985
986
987
988
989
990
  MODULE_AUTHOR("Alan Cox");
  MODULE_DESCRIPTION("low-level driver for the IT8211/IT8212 IDE RAID controller");
  MODULE_LICENSE("GPL");
  MODULE_DEVICE_TABLE(pci, it821x);
  MODULE_VERSION(DRV_VERSION);
  
  
  module_param_named(noraid, it8212_noraid, int, S_IRUGO);
5fe675e2b   Stas Sergeev   fix module_param ...
991
  MODULE_PARM_DESC(noraid, "Force card into bypass mode");
669a5db41   Jeff Garzik   [libata] Add a bu...
992
993
994
  
  module_init(it821x_init);
  module_exit(it821x_exit);