Fixes for legacy_sata driver. It now:
* boots Haiku successfully on 2 different test boxes here * no longer screws up when trying to write to PCI config space :) * Supports nVidia nForce chipsets TODO: * Make 4 channel SATA controllers work (currently only recognizes first 2) * SATA PHY initialisation (needed for some BIOSes who might not do it) Feel free to test this, and assign any problems with this driver to me. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@21949 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
063ebe49ae
commit
957200056f
@ -129,7 +129,7 @@ BEOS_ADD_ONS_FILE_SYSTEMS = bfs cdda dos googlefs iso9660 nfs ;
|
|||||||
AddFilesToHaikuImage beos system add-ons kernel bus_managers
|
AddFilesToHaikuImage beos system add-ons kernel bus_managers
|
||||||
: $(BEOS_ADD_ONS_BUS_MANAGERS) ;
|
: $(BEOS_ADD_ONS_BUS_MANAGERS) ;
|
||||||
AddFilesToHaikuImage beos system add-ons kernel busses ide
|
AddFilesToHaikuImage beos system add-ons kernel busses ide
|
||||||
: ahci generic_ide_pci $(X86_ONLY)ide_isa silicon_image_3112 ;
|
: ahci generic_ide_pci $(X86_ONLY)ide_isa silicon_image_3112 legacy_sata ;
|
||||||
AddFilesToHaikuImage beos system add-ons kernel busses usb
|
AddFilesToHaikuImage beos system add-ons kernel busses usb
|
||||||
: <usb>uhci <usb>ohci <usb>ehci ;
|
: <usb>uhci <usb>ohci <usb>ehci ;
|
||||||
AddFilesToHaikuImage beos system add-ons kernel console : vga_text ;
|
AddFilesToHaikuImage beos system add-ons kernel console : vga_text ;
|
||||||
@ -346,7 +346,7 @@ AddFilesToHaikuImage beos system : zbeos ;
|
|||||||
AddBootModuleSymlinksToHaikuImage config_manager bfs block_io fast_log
|
AddBootModuleSymlinksToHaikuImage config_manager bfs block_io fast_log
|
||||||
generic_ide_pci $(X86_ONLY)isa ide ide_adapter $(X86_ONLY)ide_isa intel
|
generic_ide_pci $(X86_ONLY)isa ide ide_adapter $(X86_ONLY)ide_isa intel
|
||||||
locked_pool $(PPC_ONLY)openpic pci scsi scsi_cd scsi_dsk scsi_periph
|
locked_pool $(PPC_ONLY)openpic pci scsi scsi_cd scsi_dsk scsi_periph
|
||||||
ahci silicon_image_3112
|
ahci silicon_image_3112 legacy_sata
|
||||||
;
|
;
|
||||||
|
|
||||||
# add-ons
|
# add-ons
|
||||||
|
@ -5,3 +5,4 @@ SubInclude HAIKU_TOP src add-ons kernel busses ide generic_ide_pci ;
|
|||||||
SubInclude HAIKU_TOP src add-ons kernel busses ide ide_isa ;
|
SubInclude HAIKU_TOP src add-ons kernel busses ide ide_isa ;
|
||||||
SubInclude HAIKU_TOP src add-ons kernel busses ide promise_tx2 ;
|
SubInclude HAIKU_TOP src add-ons kernel busses ide promise_tx2 ;
|
||||||
SubInclude HAIKU_TOP src add-ons kernel busses ide silicon_image_3112 ;
|
SubInclude HAIKU_TOP src add-ons kernel busses ide silicon_image_3112 ;
|
||||||
|
SubInclude HAIKU_TOP src add-ons kernel busses ide legacy_sata ;
|
||||||
|
@ -30,6 +30,22 @@
|
|||||||
#define PCI_device_ALI5287 0x5287
|
#define PCI_device_ALI5287 0x5287
|
||||||
#define PCI_device_ALI5281 0x5281
|
#define PCI_device_ALI5281 0x5281
|
||||||
|
|
||||||
|
#define PCI_vendor_NVIDIA 0x10de
|
||||||
|
#define PCI_device_NF2PROS1 0x008e
|
||||||
|
#define PCI_device_NF3PROS1 0x00e3
|
||||||
|
#define PCI_device_NF3PROS2 0x00ee
|
||||||
|
#define PCI_device_MCP4S1 0x0036
|
||||||
|
#define PCI_device_MCP4S2 0x003e
|
||||||
|
#define PCI_device_CK804S1 0x0054
|
||||||
|
#define PCI_device_CK804S2 0x0055
|
||||||
|
#define PCI_device_MCP51S1 0x0266
|
||||||
|
#define PCI_device_MCP51S2 0x0267
|
||||||
|
#define PCI_device_MCP55S1 0x037e
|
||||||
|
#define PCI_device_MCP55S2 0x037f
|
||||||
|
#define PCI_device_MCP61S1 0x03e7
|
||||||
|
#define PCI_device_MCP61S2 0x03f6
|
||||||
|
#define PCI_device_MCP61S3 0x03f7
|
||||||
|
|
||||||
#define ID(v,d) (((v)<< 16) | (d))
|
#define ID(v,d) (((v)<< 16) | (d))
|
||||||
|
|
||||||
/* XXX: To be moved to PCI.h */
|
/* XXX: To be moved to PCI.h */
|
||||||
@ -75,6 +91,23 @@ controller_supports(device_node_handle parent, bool *_noConnection)
|
|||||||
case ID(PCI_vendor_ALI, PCI_device_ALI5289):
|
case ID(PCI_vendor_ALI, PCI_device_ALI5289):
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
/* NVidia NForce chipsets */
|
||||||
|
case ID(PCI_vendor_NVIDIA, PCI_device_NF2PROS1):
|
||||||
|
case ID(PCI_vendor_NVIDIA, PCI_device_NF3PROS1):
|
||||||
|
case ID(PCI_vendor_NVIDIA, PCI_device_NF3PROS2):
|
||||||
|
case ID(PCI_vendor_NVIDIA, PCI_device_MCP4S1):
|
||||||
|
case ID(PCI_vendor_NVIDIA, PCI_device_MCP4S2):
|
||||||
|
case ID(PCI_vendor_NVIDIA, PCI_device_CK804S1):
|
||||||
|
case ID(PCI_vendor_NVIDIA, PCI_device_CK804S2):
|
||||||
|
case ID(PCI_vendor_NVIDIA, PCI_device_MCP51S1):
|
||||||
|
case ID(PCI_vendor_NVIDIA, PCI_device_MCP51S2):
|
||||||
|
case ID(PCI_vendor_NVIDIA, PCI_device_MCP55S1):
|
||||||
|
case ID(PCI_vendor_NVIDIA, PCI_device_MCP55S2):
|
||||||
|
case ID(PCI_vendor_NVIDIA, PCI_device_MCP61S1):
|
||||||
|
case ID(PCI_vendor_NVIDIA, PCI_device_MCP61S2):
|
||||||
|
case ID(PCI_vendor_NVIDIA, PCI_device_MCP61S3):
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
return 0.0f;
|
return 0.0f;
|
||||||
}
|
}
|
||||||
@ -111,10 +144,21 @@ controller_probe(device_node_handle parent)
|
|||||||
int_num = pci->read_pci_config(device, PCI_interrupt_line, 1);
|
int_num = pci->read_pci_config(device, PCI_interrupt_line, 1);
|
||||||
bus_master_base = pci->read_pci_config(device, PCI_base_registers + 16, 4);
|
bus_master_base = pci->read_pci_config(device, PCI_base_registers + 16, 4);
|
||||||
|
|
||||||
/* enable PCI interrupt */
|
/* Default PCI assigments */
|
||||||
pci->write_pci_config(device, PCI_command,
|
command_block_base[0] = pci->read_pci_config(device, PCI_base_registers + 0, 4 );
|
||||||
pci->read_pci_config(device, PCI_command, 2) & ~PCI_command_interrupt, 2);
|
control_block_base[0] = pci->read_pci_config(device, PCI_base_registers + 4, 4);
|
||||||
|
command_block_base[1] = pci->read_pci_config(device, PCI_base_registers + 8, 4);
|
||||||
|
control_block_base[1] = pci->read_pci_config(device, PCI_base_registers + 12, 4);
|
||||||
|
|
||||||
|
/* enable PCI interrupt */
|
||||||
|
pci->write_pci_config(device, PCI_command, 2,
|
||||||
|
pci->read_pci_config(device, PCI_command, 2) & ~PCI_command_interrupt);
|
||||||
|
|
||||||
|
if (vendor_id == PCI_vendor_NVIDIA) {
|
||||||
|
/* enable control access */
|
||||||
|
pci->write_pci_config(device, 0x50, 1,
|
||||||
|
pci->read_pci_config(device, 0x50, 1) | 0x04);
|
||||||
|
}
|
||||||
|
|
||||||
switch (ID(vendor_id, device_id)) {
|
switch (ID(vendor_id, device_id)) {
|
||||||
case ID(PCI_vendor_VIA,PCI_device_VIA6421):
|
case ID(PCI_vendor_VIA,PCI_device_VIA6421):
|
||||||
@ -136,14 +180,7 @@ controller_probe(device_node_handle parent)
|
|||||||
control_block_base[3] = pci->read_pci_config(device, PCI_base_registers + 4, 4) + 4;
|
control_block_base[3] = pci->read_pci_config(device, PCI_base_registers + 4, 4) + 4;
|
||||||
command_block_base[4] = pci->read_pci_config(device, PCI_base_registers + 8, 4) + 8;
|
command_block_base[4] = pci->read_pci_config(device, PCI_base_registers + 8, 4) + 8;
|
||||||
control_block_base[4] = pci->read_pci_config(device, PCI_base_registers + 12, 4) + 4;
|
control_block_base[4] = pci->read_pci_config(device, PCI_base_registers + 12, 4) + 4;
|
||||||
/* Intentional fall-through */
|
break;
|
||||||
|
|
||||||
default:
|
|
||||||
/* Default PCI assigments */
|
|
||||||
command_block_base[0] = pci->read_pci_config(device, PCI_base_registers + 0, 4 );
|
|
||||||
control_block_base[0] = pci->read_pci_config(device, PCI_base_registers + 4, 4);
|
|
||||||
command_block_base[1] = pci->read_pci_config(device, PCI_base_registers + 8, 4);
|
|
||||||
control_block_base[1] = pci->read_pci_config(device, PCI_base_registers + 12, 4);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
res = ide_adapter->detect_controller(pci, device, parent, bus_master_base,
|
res = ide_adapter->detect_controller(pci, device, parent, bus_master_base,
|
||||||
|
Loading…
Reference in New Issue
Block a user