mirror of
https://git.FreeBSD.org/src.git
synced 2025-01-13 14:40:22 +00:00
Compatibility with IBM firmware.
This commit is contained in:
parent
caf29fab8c
commit
761d31e8bf
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=230999
@ -178,7 +178,8 @@ cpcht_attach(device_t dev)
|
|||||||
if (OF_getprop(node, "reg", reg, sizeof(reg)) < 12)
|
if (OF_getprop(node, "reg", reg, sizeof(reg)) < 12)
|
||||||
return (ENXIO);
|
return (ENXIO);
|
||||||
|
|
||||||
sc->pci_sc.sc_quirks = OFW_PCI_QUIRK_RANGES_ON_CHILDREN;
|
if (OF_getproplen(node, "ranges") <= 0)
|
||||||
|
sc->pci_sc.sc_quirks = OFW_PCI_QUIRK_RANGES_ON_CHILDREN;
|
||||||
sc->sc_populated_slots = 0;
|
sc->sc_populated_slots = 0;
|
||||||
sc->sc_data = (vm_offset_t)pmap_mapdev(reg[1], reg[2]);
|
sc->sc_data = (vm_offset_t)pmap_mapdev(reg[1], reg[2]);
|
||||||
|
|
||||||
@ -214,12 +215,13 @@ cpcht_configure_htbridge(device_t dev, phandle_t child)
|
|||||||
int ptr, nextptr;
|
int ptr, nextptr;
|
||||||
uint32_t vend, val;
|
uint32_t vend, val;
|
||||||
int i, nirq, irq;
|
int i, nirq, irq;
|
||||||
u_int f, s;
|
u_int b, f, s;
|
||||||
|
|
||||||
sc = device_get_softc(dev);
|
sc = device_get_softc(dev);
|
||||||
if (OF_getprop(child, "reg", &pcir, sizeof(pcir)) == -1)
|
if (OF_getprop(child, "reg", &pcir, sizeof(pcir)) == -1)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
b = OFW_PCI_PHYS_HI_BUS(pcir.phys_hi);
|
||||||
s = OFW_PCI_PHYS_HI_DEVICE(pcir.phys_hi);
|
s = OFW_PCI_PHYS_HI_DEVICE(pcir.phys_hi);
|
||||||
f = OFW_PCI_PHYS_HI_FUNCTION(pcir.phys_hi);
|
f = OFW_PCI_PHYS_HI_FUNCTION(pcir.phys_hi);
|
||||||
|
|
||||||
@ -242,41 +244,41 @@ cpcht_configure_htbridge(device_t dev, phandle_t child)
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
/* All the devices we are interested in have caps */
|
/* All the devices we are interested in have caps */
|
||||||
if (!(PCIB_READ_CONFIG(dev, 0, s, f, PCIR_STATUS, 2)
|
if (!(PCIB_READ_CONFIG(dev, b, s, f, PCIR_STATUS, 2)
|
||||||
& PCIM_STATUS_CAPPRESENT))
|
& PCIM_STATUS_CAPPRESENT))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
nextptr = PCIB_READ_CONFIG(dev, 0, s, f, PCIR_CAP_PTR, 1);
|
nextptr = PCIB_READ_CONFIG(dev, b, s, f, PCIR_CAP_PTR, 1);
|
||||||
while (nextptr != 0) {
|
while (nextptr != 0) {
|
||||||
ptr = nextptr;
|
ptr = nextptr;
|
||||||
nextptr = PCIB_READ_CONFIG(dev, 0, s, f,
|
nextptr = PCIB_READ_CONFIG(dev, b, s, f,
|
||||||
ptr + PCICAP_NEXTPTR, 1);
|
ptr + PCICAP_NEXTPTR, 1);
|
||||||
|
|
||||||
/* Find the HT IRQ capabilities */
|
/* Find the HT IRQ capabilities */
|
||||||
if (PCIB_READ_CONFIG(dev, 0, s, f,
|
if (PCIB_READ_CONFIG(dev, b, s, f,
|
||||||
ptr + PCICAP_ID, 1) != PCIY_HT)
|
ptr + PCICAP_ID, 1) != PCIY_HT)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
val = PCIB_READ_CONFIG(dev, 0, s, f, ptr + PCIR_HT_COMMAND, 2);
|
val = PCIB_READ_CONFIG(dev, b, s, f, ptr + PCIR_HT_COMMAND, 2);
|
||||||
if ((val & PCIM_HTCMD_CAP_MASK) != PCIM_HTCAP_INTERRUPT)
|
if ((val & PCIM_HTCMD_CAP_MASK) != PCIM_HTCAP_INTERRUPT)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
/* Ask for the IRQ count */
|
/* Ask for the IRQ count */
|
||||||
PCIB_WRITE_CONFIG(dev, 0, s, f, ptr + PCIR_HT_COMMAND, 0x1, 1);
|
PCIB_WRITE_CONFIG(dev, b, s, f, ptr + PCIR_HT_COMMAND, 0x1, 1);
|
||||||
nirq = PCIB_READ_CONFIG(dev, 0, s, f, ptr + 4, 4);
|
nirq = PCIB_READ_CONFIG(dev, b, s, f, ptr + 4, 4);
|
||||||
nirq = ((nirq >> 16) & 0xff) + 1;
|
nirq = ((nirq >> 16) & 0xff) + 1;
|
||||||
|
|
||||||
device_printf(dev, "%d HT IRQs on device %d.%d\n", nirq, s, f);
|
device_printf(dev, "%d HT IRQs on device %d.%d\n", nirq, s, f);
|
||||||
|
|
||||||
for (i = 0; i < nirq; i++) {
|
for (i = 0; i < nirq; i++) {
|
||||||
PCIB_WRITE_CONFIG(dev, 0, s, f,
|
PCIB_WRITE_CONFIG(dev, b, s, f,
|
||||||
ptr + PCIR_HT_COMMAND, 0x10 + (i << 1), 1);
|
ptr + PCIR_HT_COMMAND, 0x10 + (i << 1), 1);
|
||||||
irq = PCIB_READ_CONFIG(dev, 0, s, f, ptr + 4, 4);
|
irq = PCIB_READ_CONFIG(dev, b, s, f, ptr + 4, 4);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Mask this interrupt for now.
|
* Mask this interrupt for now.
|
||||||
*/
|
*/
|
||||||
PCIB_WRITE_CONFIG(dev, 0, s, f, ptr + 4,
|
PCIB_WRITE_CONFIG(dev, b, s, f, ptr + 4,
|
||||||
irq | HTAPIC_MASK, 4);
|
irq | HTAPIC_MASK, 4);
|
||||||
irq = (irq >> 16) & 0xff;
|
irq = (irq >> 16) & 0xff;
|
||||||
|
|
||||||
@ -285,10 +287,10 @@ cpcht_configure_htbridge(device_t dev, phandle_t child)
|
|||||||
sc->htirq_map[irq].ht_base = sc->sc_data +
|
sc->htirq_map[irq].ht_base = sc->sc_data +
|
||||||
(((((s & 0x1f) << 3) | (f & 0x07)) << 8) | (ptr));
|
(((((s & 0x1f) << 3) | (f & 0x07)) << 8) | (ptr));
|
||||||
|
|
||||||
PCIB_WRITE_CONFIG(dev, 0, s, f,
|
PCIB_WRITE_CONFIG(dev, b, s, f,
|
||||||
ptr + PCIR_HT_COMMAND, 0x11 + (i << 1), 1);
|
ptr + PCIR_HT_COMMAND, 0x11 + (i << 1), 1);
|
||||||
sc->htirq_map[irq].eoi_data =
|
sc->htirq_map[irq].eoi_data =
|
||||||
PCIB_READ_CONFIG(dev, 0, s, f, ptr + 4, 4) |
|
PCIB_READ_CONFIG(dev, b, s, f, ptr + 4, 4) |
|
||||||
0x80000000;
|
0x80000000;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -296,7 +298,7 @@ cpcht_configure_htbridge(device_t dev, phandle_t child)
|
|||||||
* in how we signal EOIs. Check if this device was
|
* in how we signal EOIs. Check if this device was
|
||||||
* made by Apple, and act accordingly.
|
* made by Apple, and act accordingly.
|
||||||
*/
|
*/
|
||||||
vend = PCIB_READ_CONFIG(dev, 0, s, f,
|
vend = PCIB_READ_CONFIG(dev, b, s, f,
|
||||||
PCIR_DEVVENDOR, 4);
|
PCIR_DEVVENDOR, 4);
|
||||||
if ((vend & 0xffff) == 0x106b)
|
if ((vend & 0xffff) == 0x106b)
|
||||||
sc->htirq_map[irq].apple_eoi =
|
sc->htirq_map[irq].apple_eoi =
|
||||||
|
Loading…
Reference in New Issue
Block a user