PCI IDE Controller problem
PCI IDE Controller problem
I have a problem with ports in IDE compatibility mode. I try to get the BAR(0,1,2,3) but results are zero in all virtual machines and my physical computer. I also try with the legacy ports but nothing.
I can not find a solution to this problem for months. Please help me
PD: Sorry for my bad english
I can not find a solution to this problem for months. Please help me
PD: Sorry for my bad english
Re: PCI IDE Controller problem
What can you tell about BAR4? Look at https://groups.google.com/forum/#!topic ... OHHHiHTNg4
Last edited by Nable on Mon Aug 18, 2014 2:51 pm, edited 1 time in total.
Re: PCI IDE Controller problem
BAR4 is 0xC001Nable wrote:What can you tell about BAR4? Look at https://groups.google.com/forum/#!topic ... OHHHiHTNg4 , especially at the code that is posted there.
Re: PCI IDE Controller problem
Hm, does your PCI enumeration + BARs reading code work for any other devices?
Re: PCI IDE Controller problem
I think that the code is correctly. Right now I'm to extract some additional data according to the ICH specification.Nable wrote:Hm, does your PCI enumeration + BARs reading code work for any other devices?
Re: PCI IDE Controller problem
I have read some of the documentation and it seems to have understood that I write the addresses myself. Is it true?
Re: PCI IDE Controller problem
By the way, it looks like a good I/O port BAR at 0xC000, did you try to detect it's size and if its length is 16 - use it as a base port for ATA driver?
I've looked at my current laptop under Linux:
I've looked at my current laptop under Linux:
Code: Select all
$ lspci -v
...
00:1f.1 IDE interface: Intel Corporation 82801HM/HEM (ICH8M/ICH8M-E) IDE Controller (rev 03) (prog-if 8a [Master SecP PriP])
Flags: bus master, medium devsel, latency 0, IRQ 16
I/O ports at 01f0 [size=8]
I/O ports at 03f4
I/O ports at 0170 [size=8]
I/O ports at 0374
I/O ports at 1c00 [size=16]
Kernel driver in use: ata_piix
...
Re: PCI IDE Controller problem
Thanks for the responses.
I just noticed something. In my real PC there native mode and I have all the ports I need (did not work before that weird: S) but in virtual machines only appears compatibility mode exists and the first 4 ports are 0.
In virtual machines these ports must be configured manually?
I just noticed something. In my real PC there native mode and I have all the ports I need (did not work before that weird: S) but in virtual machines only appears compatibility mode exists and the first 4 ports are 0.
In virtual machines these ports must be configured manually?
Re: PCI IDE Controller problem
Still I am not sure how to use that port. I keep reading.Nable wrote:By the way, it looks like a good I/O port BAR at 0xC000, did you try to detect it's size and if its length is 16 - use it as a base port for ATA driver?
I've looked at my current laptop under Linux:Code: Select all
$ lspci -v ... 00:1f.1 IDE interface: Intel Corporation 82801HM/HEM (ICH8M/ICH8M-E) IDE Controller (rev 03) (prog-if 8a [Master SecP PriP]) Flags: bus master, medium devsel, latency 0, IRQ 16 I/O ports at 01f0 [size=8] I/O ports at 03f4 I/O ports at 0170 [size=8] I/O ports at 0374 I/O ports at 1c00 [size=16] Kernel driver in use: ata_piix ...
Re: PCI IDE Controller problem
Finding the further information seems to be an easy task: http://wiki.osdev.org/PCI_IDE_Controlle ... Controller -> it's a "Bus Master IDE" port base -> google://bus+mastering+site:wiki.osdev.org -> http://wiki.osdev.org/ATA/ATAPI_using_D ... r_Registerlweb20 wrote:Still I am not sure how to use that port. I keep reading.
Hm, maybe presence of PCI_IDE_Controller article was a non-obvious thing. It looks like I've found it when some weeks ago I was reading random pages from OSDev Wiki.
Re: PCI IDE Controller problem
Thanks but for now it's not so important to me that port.Nable wrote:Finding the further information seems to be an easy task: http://wiki.osdev.org/PCI_IDE_Controlle ... Controller -> it's a "Bus Master IDE" port base -> google://bus+mastering+site:wiki.osdev.org -> http://wiki.osdev.org/ATA/ATAPI_using_D ... r_Registerlweb20 wrote:Still I am not sure how to use that port. I keep reading.
Hm, maybe presence of PCI_IDE_Controller article was a non-obvious thing. It looks like I've found it when some weeks ago I was reading random pages from OSDev Wiki.
After reading ...
I get it. Must use the standard ports (legacy) in compatibility mode and native mode should use the ports in the BAR's. But what is the best way to detect these modes?
Re: PCI IDE Controller problem
Sorry, I don't know the best way but working way looks like this: if you have some "invalid" values (0 or 1) in BARs, then you have to try default ISA IDE ports, else you can try values from BARs.lweb20 wrote:I get it. Must use the standard ports (legacy) in compatibility mode and native mode should use the ports in the BAR's. But what is the best way to detect these modes?
Link from my first post in this topic suggests the following idea:
We hardcode the ISA ranges for BARs 0 through 3 if a PCI IDE controller has the "Primary" or "Secondary" bits set in its programming interface register and don't even look at the BARs. *code follows*
Re: PCI IDE Controller problem
Thanks. I reading the ICH and say:Nable wrote:Sorry, I don't know the best way but working way looks like this: if you have some "invalid" values (0 or 1) in BARs, then you have to try default ISA IDE ports, else you can try values from BARs.lweb20 wrote:I get it. Must use the standard ports (legacy) in compatibility mode and native mode should use the ports in the BAR's. But what is the best way to detect these modes?
Link from my first post in this topic suggests the following idea:We hardcode the ISA ranges for BARs 0 through 3 if a PCI IDE controller has the "Primary" or "Secondary" bits set in its programming interface register and don't even look at the BARs. *code follows*
I think that is.PCI Programming Interface Register (ICH Function 1 PCI Config. Offset 09h)
Primary Capabilities
0: Compatibility Only Supported
1: Native and Compatibility Supported
Secondary Capabilities
0: Compatibility Only Supported
1: Native and Compatibility Supported
The Primary/Secondary Capabilities indicators are “Read-Only” bits, where a “1”
indication is only available with ICH3.
Re: PCI IDE Controller problem
I have ready ata detection on my real computer using compatibility mode (writing in ProgIF) thanks for all. I'm happy