Bug 12898
Summary: | External drive on eSATA are not considered as removable/hotplug | ||
---|---|---|---|
Product: | IO/Storage | Reporter: | Patrice Vetsel (ubuntu) |
Component: | Serial ATA | Assignee: | Tejun Heo (tj) |
Status: | REJECTED INVALID | ||
Severity: | normal | CC: | phill |
Priority: | P1 | ||
Hardware: | All | ||
OS: | Linux | ||
Kernel Version: | 2.6.28-11-generic | Subsystem: | |
Regression: | --- | Bisected commit-id: |
Description
Patrice Vetsel
2009-03-20 07:06:06 UTC
Currently, the only controller which has a way to tell the kernel whether a port is external or not is ahci. Unfortunately, there doesn't seem to be many machines which actually use the facility. I haven't seen any yet. The only workable solution seems to be developing eSATA whitelist on the hal side. Rejecting as INVALID. If someone has a machine with working ahci external port marking, I have patches to test but given that most other controllers don't have such feature, I think we need hal whitelisting one way or the other. Thanks Tejun Heo. I also developed a patch to have the ahci driver export the external bit and it seems to work well on my Dell Netbook. I am hoping that this patch can be applied and help to resolve this issue finally. Can this bug be reopened please? For machines where the bit is not reliable, a persistent udev rule seems the way to go. FYI I added an attribute "ahci_port_external" to the host device that returns 0 or 1. It has been pointed out that the underlying bit is already exposed in ahci_port_cmd, but this is an attribute of the scsi_host device rather than the host device, which is a sibling of, rather than parent of the scsi target device. This arrangement makes it impossible for udev to identify the attribute as being associated with the disk device, and is a totally broken arrangement according to Kay Sievers. If this were fixed, and udev gained bitwise comparison support, then this could be accomplished without adding new attributes, but would cause existing attributes to move around. It seems like this would be the better fix, but is far more involved and likely to cause breakage. |