background image

Theory of Operation 

 

R

 

 

28 

SATA Programmer’s Reference Manual

 

 

 

The accuracy of the 

PxP 

bits cannot be guaranteed if the SATA PHY and associated device is in a 

slumber state. System software shall first disable the port and then re-enable it. This will cause the 
SATA PHY and associated device to wake, thus allowing the SATA hardware to properly detect 
and report the port connect status.  

Note: 

In the above figure (Figure 9), because the cumulative amount of time ‘

y

’ is not bound to any spec-

ed value and can vary from device manufacturer to manufacturer. Because this time can very short 
(e.g., within 10 ms) or very long (10+ ms), system software may choose to exclusively use device 
“readiness” as an indicator of device presence instead of relying on the setting of 

PxP

. Selecting a 

mechanism for use by system software is beyond the scope of this paper. 

4.4.2 

Device Detection – Software Examples 

System software may examine the port presence bits using two different methods:  

1.  Direct reads to the SATA host controller I/O space.  

2.  ACPI control methods. 

The sample code in 

A.3

 

Device Presence Check – Using I/O 

illustrates how system software could 

directly read the port presence bits to determine the connect status of the SATA ports.  

The sample code (for Windows WDM drivers) in 

A.4

 

Device Presence Check – Using ACPI

 

illustrates how to execute an ACPI control method that returns the connection status for the SATA 
port(s) associated with a logical SATA channel. This code assumes that a PDO (

Physical Device 

Object

) exists for both the logical primary and secondary channels. WDM device drivers can only 

execute control methods associated with their corresponding _ADR object in ACPI namespace (of 
which there is a direct relationship between the _ADR object and the PDO). 

Note that in these two examples, the ACPI control method handles the complexities of determining 
whether the SATA host controller is configured for Compatible mode and which SATA ports are 
the logical master and logical slave (if applicable). This sample driver code uses the ACPI sample 
code illustrated in 

A.5

 

ACPI Control Method (GSPS)

4.5 

ATA Swap Bay Support 

While the ICH5 SATA host controller does not support surprise (removal of a SATA device while 
transactions are active on the SATA bus) device removals, it does provide basic ATA Swap Bay 
Support. Using the 

PCS

 register configuration bits (

PxE 

and 

PxP

) and power management flows, 

a device can be powered down by system software, and the port can then be powered off, allowing 
removal and insertion of a new device.  

How system software handles device swapping is very dependent on the target platform. For 
example, mobile platforms may continue to use a combination of specialized hardware, interrupts 
and ACPI control methods (especially useful for swap bays that could support traditional P-ATA 
devices in addition to SATA devices) for communicating device insertions and removals to the 
operating system. Other platform types (e.g., desktop, workstations) traditionally do not implement 
additional hardware (interrupts) and ACPI control methods and may require that the operating 
system (device drivers) implement specific software based device detection algorithms. How this 
is implemented is beyond the scope of this document. 

Summary of Contents for 82801EB

Page 1: ...Intel 82801EB ICH5 and Intel 82801ER ICH5R Serial ATA Controller Programmer s Reference Manual PRM July 2003 Document Number 252671 002 R...

Page 2: ...ke changes to specifications and product descriptions at any time without notice Designers must not rely on the absence or characteristics of any features or instructions marked reserved or undefined...

Page 3: ...set 09h 21 4 2 2 MAP Register Programming 23 4 3 PCS Port Control and Status Register Offset 92h 23 4 3 1 1 Port Enabling Disabling 24 4 3 1 1 1 BIOS Considerations 24 4 3 1 1 2 Enabling Disabling a S...

Page 4: ...Option 3a 18 Figure 5 Compatible Configuration Option 3b 19 Figure 6 Compatible Configuration Option 3c 19 Figure 7 Compatible Configuration Option 3d 20 Figure 8 Enhanced Configuration 21 Figure 9 P...

Page 5: ...5 Revision History Revision Number Description Revision Date 001 Initial Release April 2003 002 Updated register bit names to match Intel 82801EB I O Controller Hub 5 ICH5 Intel 82801ER I O Controlle...

Page 6: ...R 6 SATA Programmer s Reference Manual This page is intentionally left blank...

Page 7: ...iable operation of the platform This document will be supplemented from time to time with specification updates The specification updates contain information relating to the latest programming changes...

Page 8: ...Introduction R 8 SATA Programmer s Reference Manual This page is intentionally left blank...

Page 9: ...Code SCC bits 0 7 implemented within the Class Code CC offset 0Ah register in the PCI Configuration space Offset 0Ah Class Code Register CC Bits Type Reset Description 15 08 RO 01h Base Class Code BC...

Page 10: ...Conventions R 10 SATA Programmer s Reference Manual This page is intentionally left blank...

Page 11: ...ing requirements Has its Programming Interface register set for legacy mode Shall interrupt via IRQ14 primary channel and IRQ15 secondary channel Command and control block are accessed at fixed I O lo...

Page 12: ...wo serial ATA devices The flexibility and software transparency of the SATA host controller presents an interesting problem for older operating systems that do not comprehend or support the native mod...

Page 13: ...nd SATA controller can be configured to consume legacy resources see Section 3 1 Legacy Sub Mode that causes the issues i e the primary and secondary channel interfaces will attempt to share the same...

Page 14: ...ology and may result in undefined behavior Bit Type Reset Description 7 3 RO 0 Reserved 2 0 RW 000 Map Value MV The value in the bits below indicate the address range the SATA port responds to and whe...

Page 15: ...is configuration system BIOS 1 Shall not program the SATA Device 31 Function 2 controller s base address registers Offsets 10h 24h in PCI configuration space 2 Shall disable access to the SATA control...

Page 16: ...ding from the slave device registers will return all 1 The Drive Head register offset 06h in the command block is the exception To enable this configuration system BIOS 1 Shall not program the P ATA D...

Page 17: ...ne P ATA device maximum of two are connected to both SATA and P ATA host controllers and are both accessible by software This configuration is referred to as the combined mode In combined mode of oper...

Page 18: ...will insure that operating system configuration software does not enumerate and configure the P ATA function 4 Shall program the MAP MV register as follows If SATA is the primary channel and P ATA is...

Page 19: ...Port 0 device is secondary master and Port 1 device is secondary slave then MAP MV 110b Figure 6 illustrates this configuration Figure 6 Compatible Configuration Option 3c S M S ATA P ATA Port 0 Port...

Page 20: ...is intended for those operating systems e g Microsoft Windows 2000 Windows XP that comprehend both legacy and native modes of operation It is the preferred configuration for system software due to the...

Page 21: ...d for either native mode only or a combination of legacy and native modes This is controlled via the Programming Interface register The programming interface register is found in both the SATA and P A...

Page 22: ...A Device 31 Function 2 P ATA Device 31 Function 1 POP_MODE_SEL SOP_MODE_SEL POP_MODE_SEL SOP_MODE_SEL 1 1 0 0 Note The SATA and P ATA host controllers do not support the programming of the primary and...

Page 23: ...provide better power management and device presence capabilities the SATA host controller implements a Port Control and Status PCS register The PCS register provides improved power savings in that it...

Page 24: ...1 for Port 1 bits to be accurate See Section 4 4 1 Hardware and Software Considerations As part of a robust power conservation strategy a port on the ICH5 SATA host controller should be disabled when...

Page 25: ...e control methods can be used to supplement the device power management and are executed whenever the operating system wishes to place the SATA into the D0 and D3 power states respectively control met...

Page 26: ...and Software Considerations The value of the port presence bits is valid only under the following conditions The SATA host controller is in the D0 power state The port to be checked is enabled Note Th...

Page 27: ...ent v1 0 specification this document is available from the Serial ATA Working Group at http www serialata org This duration is highly dependent on the manufacturer of the SATA device The time value z...

Page 28: ...h the logical primary and secondary channels WDM device drivers can only execute control methods associated with their corresponding _ADR object in ACPI namespace of which there is a direct relationsh...

Page 29: ...ting the Intel ICH5 SATA Host Controller in ACPI Namespace See Appendix B Example ACPI Namespace for an example of an ACPI namespace for the ICH5 SATA host controller This example supports the ICH5 SA...

Page 30: ...Theory of Operation R 30 SATA Programmer s Reference Manual This page is intentionally left blank...

Page 31: ...how a WDM driver could read write the PCS PxE bits for enabling or disabling the SATA port s This example assumes direct access to the SATA PCI Configuration space Disable the ports For simplicity we...

Page 32: ...config space to read write Length size of pBuf Exit returns NT_SUCCESS if no errors NTSTATUS ReadWriteConfigSpace PDEVICE_OBJECT pDO BOOLEAN fRead PVOID pBuf ULONG Offset ULONG Length KEVENT event PIR...

Page 33: ...is sample ASL code demonstrates how to enable and disable the SATA port s from the _PS0 and _PS3 control methods OperationRegion IDEC PCI_Config 0x90 3 Field IDEC ByteAcc NoLock Preserve MAP 8 SATA Ma...

Page 34: ...ing Port 0 If LAnd Arg0 0x01 If LAnd Local2 0x10 Decrement Local1 Port 0 is enabled Else Since a device detect failed we disable the port This will insure that the port remains disabled this is not re...

Page 35: ...settings In Combined mode both SATA ports are viewed as a single logical channel implementing a master slave configuration in which case both ports are enabled Enable Power to the device Set the GPIO...

Page 36: ...l Name _ADR 1 Logical secondary channel Port 0 or 1 BIOS selectable Device DRV0 Logical secondary master Name _ADR 0 Handle transitions to D0 power state Method _PS0 0 make sure the OS drivers finds t...

Page 37: ...ed here dependent on the MAP settings In Combined mode both SATA ports are viewed as a single logical channel implementing a master slave configuration in which case both ports are disabled Store Zero...

Page 38: ...primary channel if bMAP 0x06 Not P ATA device Must be SATA if bPCS 0x10 iPort0Status 1 Port 0 device present if bPCS 0x20 iPort1Status 1 Port 1 device present Now we need to figure out which is master...

Page 39: ...DM device drivers can only execute control methods associated with their corresponding _ADR object in ACPI namespace of which there is a direct relationship between the _ADR object and the PDO This sa...

Page 40: ...device present 1 Device presence unknown NTSTATUS SATA_CheckPortStatus IN PDEVICE_OBJECT pDO PDWORD pdwStatus NTSTATUS status STATUS_SUCCESS PACPI_METHOD_ARGUMENTpArgBuf ACPI_EVAL_INPUT_BUFFER InputBu...

Page 41: ...Irp to ACPI Entry Pdo target of the request Ioctl the request InputBuffer ptr to input parameters InputSize size of InputBuffer OutputBuffer ptr to receive results OutputSize size of OutputBuffer Exi...

Page 42: ...k MajorFunction IRP_MJ_DEVICE_CONTROL Pass the request to the Pdo always wait for the completion routine status IoCallDriver Pdo Irp if status STATUS_PENDING Wait for the IRP to be completed then grab...

Page 43: ...umes BIOS populated the SATA timing registers appropriately depending on which port is configured as primary and secondary This control method determines if device s are present on the logical primary...

Page 44: ...x20 Store One Local4 Port 1 device present Now we need to figure out which is master and slave if applicable If LNot LAnd Local1 0x01 is Port 0 master Port 0 is master Store Local3 Local5 If LAnd Loca...

Page 45: ...rn 0xffffffff Device DRV0 Logical primary master Name _ADR 0 Device SECD Secondary channel Method GSPS 0 Get the port status Similar to GSPS for PRID Name _ADR 1 Logical secondary channel Port 0 or 1...

Page 46: ...Theory of Operation R 46 SATA Programmer s Reference Manual This page is intentionally left blank...

Page 47: ...y master Port 1 logical primary master Note that a separate P ATA device namespace is required in the event that non Combined mode is used If in Combined mode P ATA and SATA combined as a single PCI f...

Page 48: ...non combined modes Entry arg0 bit map indicating which port s to enable bit 0 set enable Port 0 bit 1 set enable Port 1 all other bits must be zero Since the ports operate independently we can enable...

Page 49: ...This method determines the type of device being managed by the specified logical channel Entry Arg0 specifies which channel is to be checked 0 Primary 1 Secondary Exit Returns 0 if the channel is host...

Page 50: ...P 0x1 LLess MAP 0x6 Store 0x1 Local0 SATA is primary combined Else If LEqual MAP Zero Store 3 Local0 port 0 is primary master If LEqual MAP One Store 4 Local0 port 1 is primary master Else Check the s...

Page 51: ...logical primary master or P ATA Primary master slave Device PRID Name _ADR 0 Logical primary channel Port 0 1 BIOS selectable or P_ATA Method _GTM similar to current P ATA implementations Method _STM...

Page 52: ...30 power must be applied for at least 30ms Store 0x03 Local1 is combined enable both ports If LEqual Local0 3 Enable Power to the device platform specific Sleep 30 power must be applied for at least...

Page 53: ...gical channel implementing a master slave configuration in which case both ports are disabled If LEqual Local0 1 Store 0x0 PCS is combined disable both ports If LEqual Local0 3 NAnd PCS 0x01 PCS only...

Page 54: ...n configured for Combined mode In non Combined mode SATA devices use a master master arrangement Device DRV1 Logical primary slave SATA Port 0 1 or P ATA device 1 Name _ADR 1 similar to current P ATA...

Page 55: ...ary master or P ATA logical secondary master slave Device SECD Name _ADR 1 Method _GTM similar to current P ATA implementations Method _STM 3 similar to current P ATA implementations Like the _GTF met...

Page 56: ...x03 Local1 is combined enable both ports If LEqual Local0 5 Enable Power to the device platform specific Sleep 30 power must be applied for at least 30ms Store 0x01 Local1 only enable port 0 If LEqual...

Page 57: ...rts are disabled If LEqual Local0 2 Store 0x0 PCS is combined disable both ports If LEqual Local0 5 NAnd PCS 0x01 PCS only disable port 0 If LEqual Local0 6 NAnd PCS 0x02 PCS only disable port 1 Disab...

Page 58: ...Combined mode SATA devices use a master master arrangement Device DRV1 Logical secondary slave SATA Port 0 1 or P ATA device 1 Name _ADR 1 similar to current P ATA implementations Since this device no...

Page 59: ...Theory of Operation R SATA Programmer s Reference Manual 59...

Reviews: