aboutsummaryrefslogtreecommitdiffstats
path: root/include/linux
diff options
context:
space:
mode:
authorTejun Heo <htejun@gmail.com>2007-08-06 05:36:22 -0400
committerJeff Garzik <jeff@garzik.org>2007-10-12 14:55:30 -0400
commit9af5c9c97dc9d599281778864c72b385f0c63341 (patch)
tree8359986bd42c4a9a5b1993078aa9ee4c7971ac3d /include/linux
parent640fdb504941fa2b9f6f274716fc9f97f2bf6bff (diff)
libata-link: introduce ata_link
Introduce ata_link. It abstracts PHY and sits between ata_port and ata_device. This new level of abstraction is necessary to support SATA Port Multiplier, which basically adds a bunch of links (PHYs) to a ATA host port. Fields related to command execution, spd_limit and EH are per-link and thus moved to ata_link. This patch only defines the host link. Multiple link handling will be added later. Also, a lot of ap->link derefences are added but many of them will be removed as each part is converted to deal directly with ata_link instead of ata_port. This patch introduces no behavior change. Signed-off-by: Tejun Heo <htejun@gmail.com> Cc: James Bottomley <James.Bottomley@SteelEye.com> Signed-off-by: Jeff Garzik <jeff@garzik.org>
Diffstat (limited to 'include/linux')
-rw-r--r--include/linux/libata.h40
1 files changed, 25 insertions, 15 deletions
diff --git a/include/linux/libata.h b/include/linux/libata.h
index a67bb9075e9b..ca4493125fa0 100644
--- a/include/linux/libata.h
+++ b/include/linux/libata.h
@@ -436,7 +436,7 @@ struct ata_ering {
436}; 436};
437 437
438struct ata_device { 438struct ata_device {
439 struct ata_port *ap; 439 struct ata_link *link;
440 unsigned int devno; /* 0 or 1 */ 440 unsigned int devno; /* 0 or 1 */
441 unsigned long flags; /* ATA_DFLAG_xxx */ 441 unsigned long flags; /* ATA_DFLAG_xxx */
442 unsigned int horkage; /* List of broken features */ 442 unsigned int horkage; /* List of broken features */
@@ -510,6 +510,24 @@ struct ata_acpi_gtm {
510 u32 flags; 510 u32 flags;
511} __packed; 511} __packed;
512 512
513struct ata_link {
514 struct ata_port *ap;
515
516 unsigned int active_tag; /* active tag on this link */
517 u32 sactive; /* active NCQ commands */
518
519 unsigned int hw_sata_spd_limit;
520 unsigned int sata_spd_limit;
521 unsigned int sata_spd; /* current SATA PHY speed */
522
523 /* record runtime error info, protected by host_set lock */
524 struct ata_eh_info eh_info;
525 /* EH context */
526 struct ata_eh_context eh_context;
527
528 struct ata_device device[ATA_MAX_DEVICES];
529};
530
513struct ata_port { 531struct ata_port {
514 struct Scsi_Host *scsi_host; /* our co-allocated scsi host */ 532 struct Scsi_Host *scsi_host; /* our co-allocated scsi host */
515 const struct ata_port_operations *ops; 533 const struct ata_port_operations *ops;
@@ -533,23 +551,12 @@ struct ata_port {
533 unsigned int mwdma_mask; 551 unsigned int mwdma_mask;
534 unsigned int udma_mask; 552 unsigned int udma_mask;
535 unsigned int cbl; /* cable type; ATA_CBL_xxx */ 553 unsigned int cbl; /* cable type; ATA_CBL_xxx */
536 unsigned int hw_sata_spd_limit;
537 unsigned int sata_spd_limit; /* SATA PHY speed limit */
538 unsigned int sata_spd; /* current SATA PHY speed */
539
540 /* record runtime error info, protected by host lock */
541 struct ata_eh_info eh_info;
542 /* EH context owned by EH */
543 struct ata_eh_context eh_context;
544
545 struct ata_device device[ATA_MAX_DEVICES];
546 554
547 struct ata_queued_cmd qcmd[ATA_MAX_QUEUE]; 555 struct ata_queued_cmd qcmd[ATA_MAX_QUEUE];
548 unsigned long qc_allocated; 556 unsigned long qc_allocated;
549 unsigned int qc_active; 557 unsigned int qc_active;
550 558
551 unsigned int active_tag; 559 struct ata_link link; /* host default link */
552 u32 sactive;
553 560
554 struct ata_port_stats stats; 561 struct ata_port_stats stats;
555 struct ata_host *host; 562 struct ata_host *host;
@@ -912,8 +919,11 @@ extern void ata_do_eh(struct ata_port *ap, ata_prereset_fn_t prereset,
912#define ata_port_printk(ap, lv, fmt, args...) \ 919#define ata_port_printk(ap, lv, fmt, args...) \
913 printk(lv"ata%u: "fmt, (ap)->print_id , ##args) 920 printk(lv"ata%u: "fmt, (ap)->print_id , ##args)
914 921
922#define ata_link_printk(link, lv, fmt, args...) \
923 printk(lv"ata%u: "fmt, (link)->ap->print_id , ##args)
924
915#define ata_dev_printk(dev, lv, fmt, args...) \ 925#define ata_dev_printk(dev, lv, fmt, args...) \
916 printk(lv"ata%u.%02u: "fmt, (dev)->ap->print_id, (dev)->devno , ##args) 926 printk(lv"ata%u.%02u: "fmt, (dev)->link->ap->print_id, (dev)->devno , ##args)
917 927
918/* 928/*
919 * ata_eh_info helpers 929 * ata_eh_info helpers
@@ -1149,7 +1159,7 @@ static inline void ata_tf_init(struct ata_device *dev, struct ata_taskfile *tf)
1149{ 1159{
1150 memset(tf, 0, sizeof(*tf)); 1160 memset(tf, 0, sizeof(*tf));
1151 1161
1152 tf->ctl = dev->ap->ctl; 1162 tf->ctl = dev->link->ap->ctl;
1153 if (dev->devno == 0) 1163 if (dev->devno == 0)
1154 tf->device = ATA_DEVICE_OBS; 1164 tf->device = ATA_DEVICE_OBS;
1155 else 1165 else