summaryrefslogtreecommitdiff
path: root/src/southbridge/amd/amd8111/amd8111_ide.c
blob: 6f8e018fe66e49000efdb0541d8a786c6fc2c268 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
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
#include <console/console.h>
#include <device/device.h>
#include <device/pci.h>
#include <device/pci_ids.h>
#include <device/pci_ops.h>
#include "amd8111.h"

static void ide_init(struct device *dev)
{

	/* Enable ide devices so the linux ide driver will work */
	uint16_t word;
	int enable_a=1, enable_b=1;

	word = pci_read_config16(dev, 0x40);
	/* Ensure prefetch is disabled */
	word &= ~((1 << 15) | (1 << 13));
	if (enable_b) {
		/* Enable secondary ide interface */
		word |= (1<<0);
		printk_debug("IDE1 ");
	}
	if (enable_a) {
		/* Enable primary ide interface */
		word |= (1<<1);
		printk_debug("IDE0 ");
	}

	word |= (1<<12);
	word |= (1<<14);

	pci_write_config16(dev, 0x40, word);

	word = 0x0f;
	pci_write_config16(dev, 0x42, word);

	/* The AMD768 has a bug where the BM DMA address must be
	 * 256 byte aligned while it is only 16 bytes long.
	 * Hard code this to a valid address below 0x1000
	 * where automatic port address assignment starts.
	 * FIXME: I assume the 8111 does the same thing. We should
	 * clarify. stepan@suse.de
	 */
	pci_write_config32(dev, 0x20, 0xf01);

	pci_write_config32(dev, 0x48, 0x205e5e5e);
	word = 0x06a;
	pci_write_config16(dev, 0x4c, word);
}

static struct device_operations ide_ops  = {
	.read_resources   = pci_dev_read_resources,
	.set_resources    = pci_dev_set_resources,
	.enable_resources = pci_dev_enable_resources,
	.init             = ide_init,
	.scan_bus         = 0,
};

static struct pci_driver ide_driver __pci_driver = {
	.ops    = &ide_ops,
	.vendor = PCI_VENDOR_ID_AMD,
	.device = PCI_DEVICE_ID_AMD_8111_IDE,
};