Commit 7662d923 authored by Hannes Reinecke's avatar Hannes Reinecke Committed by Martin K. Petersen
parent bcd5c59f
...@@ -211,7 +211,7 @@ typedef enum { ...@@ -211,7 +211,7 @@ typedef enum {
*/ */
typedef enum { typedef enum {
AHD_FENONE = 0x00000, AHD_FENONE = 0x00000,
AHD_WIDE = 0x00001,/* Wide Channel */ AHD_WIDE = 0x00001,/* Wide Channel */
AHD_AIC79XXB_SLOWCRC = 0x00002,/* SLOWCRC bit should be set */ AHD_AIC79XXB_SLOWCRC = 0x00002,/* SLOWCRC bit should be set */
AHD_MULTI_FUNC = 0x00100,/* Multi-Function/Channel Device */ AHD_MULTI_FUNC = 0x00100,/* Multi-Function/Channel Device */
AHD_TARGETMODE = 0x01000,/* Has tested target mode support */ AHD_TARGETMODE = 0x01000,/* Has tested target mode support */
...@@ -433,7 +433,7 @@ union initiator_data { ...@@ -433,7 +433,7 @@ union initiator_data {
* Target mode version of the shared data SCB segment. * Target mode version of the shared data SCB segment.
*/ */
struct target_data { struct target_data {
uint32_t spare[2]; uint32_t spare[2];
uint8_t scsi_status; /* SCSI status to give to initiator */ uint8_t scsi_status; /* SCSI status to give to initiator */
uint8_t target_phases; /* Bitmap of phases to execute */ uint8_t target_phases; /* Bitmap of phases to execute */
uint8_t data_phase; /* Data-In or Data-Out */ uint8_t data_phase; /* Data-In or Data-Out */
...@@ -608,9 +608,9 @@ struct scb { ...@@ -608,9 +608,9 @@ struct scb {
struct ahd_softc *ahd_softc; struct ahd_softc *ahd_softc;
scb_flag flags; scb_flag flags;
struct scb_platform_data *platform_data; struct scb_platform_data *platform_data;
struct map_node *hscb_map; struct map_node *hscb_map;
struct map_node *sg_map; struct map_node *sg_map;
struct map_node *sense_map; struct map_node *sense_map;
void *sg_list; void *sg_list;
uint8_t *sense_data; uint8_t *sense_data;
dma_addr_t sg_list_busaddr; dma_addr_t sg_list_busaddr;
...@@ -674,7 +674,7 @@ struct scb_data { ...@@ -674,7 +674,7 @@ struct scb_data {
struct target_cmd { struct target_cmd {
uint8_t scsiid; /* Our ID and the initiator's ID */ uint8_t scsiid; /* Our ID and the initiator's ID */
uint8_t identify; /* Identify message */ uint8_t identify; /* Identify message */
uint8_t bytes[22]; /* uint8_t bytes[22]; /*
* Bytes contains any additional message * Bytes contains any additional message
* bytes terminated by 0xFF. The remainder * bytes terminated by 0xFF. The remainder
* is the cdb to execute. * is the cdb to execute.
...@@ -712,7 +712,7 @@ struct ahd_tmode_event { ...@@ -712,7 +712,7 @@ struct ahd_tmode_event {
* structure here so we can store arrays of them, etc. in OS neutral * structure here so we can store arrays of them, etc. in OS neutral
* data structures. * data structures.
*/ */
#ifdef AHD_TARGET_MODE #ifdef AHD_TARGET_MODE
struct ahd_tmode_lstate { struct ahd_tmode_lstate {
struct cam_path *path; struct cam_path *path;
struct ccb_hdr_slist accept_tios; struct ccb_hdr_slist accept_tios;
...@@ -807,11 +807,11 @@ struct ahd_tmode_tstate { ...@@ -807,11 +807,11 @@ struct ahd_tmode_tstate {
/***************************** Lookup Tables **********************************/ /***************************** Lookup Tables **********************************/
/* /*
* Phase -> name and message out response * Phase -> name and message out response
* to parity errors in each phase table. * to parity errors in each phase table.
*/ */
struct ahd_phase_table_entry { struct ahd_phase_table_entry {
uint8_t phase; uint8_t phase;
uint8_t mesg_out; /* Message response to parity errors */ uint8_t mesg_out; /* Message response to parity errors */
const char *phasemsg; const char *phasemsg;
}; };
...@@ -844,7 +844,7 @@ struct seeprom_config { ...@@ -844,7 +844,7 @@ struct seeprom_config {
#define CFBS_ENABLED 0x04 #define CFBS_ENABLED 0x04
#define CFBS_DISABLED_SCAN 0x08 #define CFBS_DISABLED_SCAN 0x08
#define CFENABLEDV 0x0010 /* Perform Domain Validation */ #define CFENABLEDV 0x0010 /* Perform Domain Validation */
#define CFCTRL_A 0x0020 /* BIOS displays Ctrl-A message */ #define CFCTRL_A 0x0020 /* BIOS displays Ctrl-A message */
#define CFSPARITY 0x0040 /* SCSI parity */ #define CFSPARITY 0x0040 /* SCSI parity */
#define CFEXTEND 0x0080 /* extended translation enabled */ #define CFEXTEND 0x0080 /* extended translation enabled */
#define CFBOOTCD 0x0100 /* Support Bootable CD-ROM */ #define CFBOOTCD 0x0100 /* Support Bootable CD-ROM */
...@@ -858,7 +858,7 @@ struct seeprom_config { ...@@ -858,7 +858,7 @@ struct seeprom_config {
/* /*
* Host Adapter Control Bits * Host Adapter Control Bits
*/ */
uint16_t adapter_control; /* word 17 */ uint16_t adapter_control; /* word 17 */
#define CFAUTOTERM 0x0001 /* Perform Auto termination */ #define CFAUTOTERM 0x0001 /* Perform Auto termination */
#define CFSTERM 0x0002 /* SCSI low byte termination */ #define CFSTERM 0x0002 /* SCSI low byte termination */
#define CFWSTERM 0x0004 /* SCSI high byte termination */ #define CFWSTERM 0x0004 /* SCSI high byte termination */
...@@ -867,7 +867,7 @@ struct seeprom_config { ...@@ -867,7 +867,7 @@ struct seeprom_config {
#define CFSEHIGHTERM 0x0020 /* Ultra2 secondary high term */ #define CFSEHIGHTERM 0x0020 /* Ultra2 secondary high term */
#define CFSTPWLEVEL 0x0040 /* Termination level control */ #define CFSTPWLEVEL 0x0040 /* Termination level control */
#define CFBIOSAUTOTERM 0x0080 /* Perform Auto termination */ #define CFBIOSAUTOTERM 0x0080 /* Perform Auto termination */
#define CFTERM_MENU 0x0100 /* BIOS displays termination menu */ #define CFTERM_MENU 0x0100 /* BIOS displays termination menu */
#define CFCLUSTERENB 0x8000 /* Cluster Enable */ #define CFCLUSTERENB 0x8000 /* Cluster Enable */
/* /*
...@@ -881,7 +881,7 @@ struct seeprom_config { ...@@ -881,7 +881,7 @@ struct seeprom_config {
/* /*
* Maximum targets * Maximum targets
*/ */
uint16_t max_targets; /* word 19 */ uint16_t max_targets; /* word 19 */
#define CFMAXTARG 0x00ff /* maximum targets */ #define CFMAXTARG 0x00ff /* maximum targets */
#define CFBOOTLUN 0x0f00 /* Lun to boot from */ #define CFBOOTLUN 0x0f00 /* Lun to boot from */
#define CFBOOTID 0xf000 /* Target to boot from */ #define CFBOOTID 0xf000 /* Target to boot from */
...@@ -941,7 +941,7 @@ struct vpd_config { ...@@ -941,7 +941,7 @@ struct vpd_config {
#define FLX_ROMSTAT_EE_2MBx8 0x2 #define FLX_ROMSTAT_EE_2MBx8 0x2
#define FLX_ROMSTAT_EE_4MBx8 0x3 #define FLX_ROMSTAT_EE_4MBx8 0x3
#define FLX_ROMSTAT_EE_16MBx8 0x4 #define FLX_ROMSTAT_EE_16MBx8 0x4
#define CURSENSE_ENB 0x1 #define CURSENSE_ENB 0x1
#define FLXADDR_FLEXSTAT 0x2 #define FLXADDR_FLEXSTAT 0x2
#define FLX_FSTAT_BUSY 0x1 #define FLX_FSTAT_BUSY 0x1
#define FLXADDR_CURRENT_STAT 0x4 #define FLXADDR_CURRENT_STAT 0x4
...@@ -1051,8 +1051,8 @@ struct ahd_completion ...@@ -1051,8 +1051,8 @@ struct ahd_completion
}; };
struct ahd_softc { struct ahd_softc {
bus_space_tag_t tags[2]; bus_space_tag_t tags[2];
bus_space_handle_t bshs[2]; bus_space_handle_t bshs[2];
struct scb_data scb_data; struct scb_data scb_data;
struct hardware_scb *next_queued_hscb; struct hardware_scb *next_queued_hscb;
...@@ -1243,7 +1243,7 @@ struct ahd_softc { ...@@ -1243,7 +1243,7 @@ struct ahd_softc {
u_int int_coalescing_threshold; u_int int_coalescing_threshold;
u_int int_coalescing_stop_threshold; u_int int_coalescing_stop_threshold;
uint16_t user_discenable;/* Disconnection allowed */ uint16_t user_discenable;/* Disconnection allowed */
uint16_t user_tagenable;/* Tagged Queuing allowed */ uint16_t user_tagenable;/* Tagged Queuing allowed */
}; };
......
This diff is collapsed.
...@@ -242,7 +242,7 @@ struct ahd_linux_device { ...@@ -242,7 +242,7 @@ struct ahd_linux_device {
int active; int active;
/* /*
* The currently allowed number of * The currently allowed number of
* transactions that can be queued to * transactions that can be queued to
* the device. Must be signed for * the device. Must be signed for
* conversion from tagged to untagged * conversion from tagged to untagged
...@@ -256,7 +256,7 @@ struct ahd_linux_device { ...@@ -256,7 +256,7 @@ struct ahd_linux_device {
* device's queue is halted. * device's queue is halted.
*/ */
u_int qfrozen; u_int qfrozen;
/* /*
* Cumulative command counter. * Cumulative command counter.
*/ */
...@@ -340,11 +340,11 @@ struct ahd_platform_data { ...@@ -340,11 +340,11 @@ struct ahd_platform_data {
/* /*
* Fields accessed from interrupt context. * Fields accessed from interrupt context.
*/ */
struct scsi_target *starget[AHD_NUM_TARGETS]; struct scsi_target *starget[AHD_NUM_TARGETS];
spinlock_t spin_lock; spinlock_t spin_lock;
struct completion *eh_done; struct completion *eh_done;
struct Scsi_Host *host; /* pointer to scsi host */ struct Scsi_Host *host; /* pointer to scsi host */
#define AHD_LINUX_NOIRQ ((uint32_t)~0) #define AHD_LINUX_NOIRQ ((uint32_t)~0)
uint32_t irq; /* IRQ for this adapter */ uint32_t irq; /* IRQ for this adapter */
uint32_t bios_address; uint32_t bios_address;
...@@ -655,9 +655,9 @@ static inline void ...@@ -655,9 +655,9 @@ static inline void
ahd_freeze_scb(struct scb *scb) ahd_freeze_scb(struct scb *scb)
{ {
if ((scb->io_ctx->result & (CAM_DEV_QFRZN << 16)) == 0) { if ((scb->io_ctx->result & (CAM_DEV_QFRZN << 16)) == 0) {
scb->io_ctx->result |= CAM_DEV_QFRZN << 16; scb->io_ctx->result |= CAM_DEV_QFRZN << 16;
scb->platform_data->dev->qfrozen++; scb->platform_data->dev->qfrozen++;
} }
} }
void ahd_platform_set_tags(struct ahd_softc *ahd, struct scsi_device *sdev, void ahd_platform_set_tags(struct ahd_softc *ahd, struct scsi_device *sdev,
......
...@@ -45,8 +45,8 @@ ...@@ -45,8 +45,8 @@
/* Define the macro locally since it's different for different class of chips. /* Define the macro locally since it's different for different class of chips.
*/ */
#define ID(x) \ #define ID(x) \
ID2C(x), \ ID2C(x), \
ID2C(IDIROC(x)) ID2C(IDIROC(x))
static const struct pci_device_id ahd_linux_pci_id_table[] = { static const struct pci_device_id ahd_linux_pci_id_table[] = {
...@@ -367,7 +367,7 @@ ahd_pci_map_int(struct ahd_softc *ahd) ...@@ -367,7 +367,7 @@ ahd_pci_map_int(struct ahd_softc *ahd)
IRQF_SHARED, "aic79xx", ahd); IRQF_SHARED, "aic79xx", ahd);
if (!error) if (!error)
ahd->platform_data->irq = ahd->dev_softc->irq; ahd->platform_data->irq = ahd->dev_softc->irq;
return (-error); return (-error);
} }
......
...@@ -100,17 +100,17 @@ ahd_format_transinfo(struct seq_file *m, struct ahd_transinfo *tinfo) ...@@ -100,17 +100,17 @@ ahd_format_transinfo(struct seq_file *m, struct ahd_transinfo *tinfo)
seq_puts(m, "Renegotiation Pending\n"); seq_puts(m, "Renegotiation Pending\n");
return; return;
} }
speed = 3300; speed = 3300;
freq = 0; freq = 0;
if (tinfo->offset != 0) { if (tinfo->offset != 0) {
freq = ahd_calc_syncsrate(tinfo->period); freq = ahd_calc_syncsrate(tinfo->period);
speed = freq; speed = freq;
} }
speed *= (0x01 << tinfo->width); speed *= (0x01 << tinfo->width);
mb = speed / 1000; mb = speed / 1000;
if (mb > 0) if (mb > 0)
seq_printf(m, "%d.%03dMB/s transfers", mb, speed % 1000); seq_printf(m, "%d.%03dMB/s transfers", mb, speed % 1000);
else else
seq_printf(m, "%dKB/s transfers", speed); seq_printf(m, "%dKB/s transfers", speed);
if (freq != 0) { if (freq != 0) {
...@@ -242,7 +242,8 @@ ahd_proc_write_seeprom(struct Scsi_Host *shost, char *buffer, int length) ...@@ -242,7 +242,8 @@ ahd_proc_write_seeprom(struct Scsi_Host *shost, char *buffer, int length)
u_int start_addr; u_int start_addr;
if (ahd->seep_config == NULL) { if (ahd->seep_config == NULL) {
ahd->seep_config = kmalloc(sizeof(*ahd->seep_config), GFP_ATOMIC); ahd->seep_config = kmalloc(sizeof(*ahd->seep_config),
GFP_ATOMIC);
if (ahd->seep_config == NULL) { if (ahd->seep_config == NULL) {
printk("aic79xx: Unable to allocate serial " printk("aic79xx: Unable to allocate serial "
"eeprom buffer. Write failing\n"); "eeprom buffer. Write failing\n");
......
...@@ -73,8 +73,8 @@ ...@@ -73,8 +73,8 @@
* add other 93Cx6 functions. * add other 93Cx6 functions.
*/ */
struct seeprom_cmd { struct seeprom_cmd {
uint8_t len; uint8_t len;
uint8_t bits[11]; uint8_t bits[11];
}; };
/* Short opcodes for the c46 */ /* Short opcodes for the c46 */
......
This diff is collapsed.
...@@ -452,7 +452,7 @@ ahc_insb(struct ahc_softc * ahc, long port, uint8_t *array, int count) ...@@ -452,7 +452,7 @@ ahc_insb(struct ahc_softc * ahc, long port, uint8_t *array, int count)
static void ahc_linux_unmap_scb(struct ahc_softc*, struct scb*); static void ahc_linux_unmap_scb(struct ahc_softc*, struct scb*);
static int ahc_linux_map_seg(struct ahc_softc *ahc, struct scb *scb, static int ahc_linux_map_seg(struct ahc_softc *ahc, struct scb *scb,
struct ahc_dma_seg *sg, struct ahc_dma_seg *sg,
dma_addr_t addr, bus_size_t len); dma_addr_t addr, bus_size_t len);
static void static void
...@@ -571,7 +571,7 @@ ahc_linux_target_alloc(struct scsi_target *starget) ...@@ -571,7 +571,7 @@ ahc_linux_target_alloc(struct scsi_target *starget)
target_offset = starget->id; target_offset = starget->id;
if (starget->channel != 0) if (starget->channel != 0)
target_offset += 8; target_offset += 8;
if (starget->channel) if (starget->channel)
our_id = ahc->our_id_b; our_id = ahc->our_id_b;
...@@ -597,18 +597,18 @@ ahc_linux_target_alloc(struct scsi_target *starget) ...@@ -597,18 +597,18 @@ ahc_linux_target_alloc(struct scsi_target *starget)
ultra = 0; ultra = 0;
flags &= ~CFXFER; flags &= ~CFXFER;
} }
if ((ahc->features & AHC_ULTRA2) != 0) { if ((ahc->features & AHC_ULTRA2) != 0) {
scsirate = (flags & CFXFER) | (ultra ? 0x8 : 0); scsirate = (flags & CFXFER) | (ultra ? 0x8 : 0);
} else { } else {
scsirate = (flags & CFXFER) << 4; scsirate = (flags & CFXFER) << 4;
maxsync = ultra ? AHC_SYNCRATE_ULTRA : maxsync = ultra ? AHC_SYNCRATE_ULTRA :
AHC_SYNCRATE_FAST; AHC_SYNCRATE_FAST;
} }
spi_max_width(starget) = (flags & CFWIDEB) ? 1 : 0; spi_max_width(starget) = (flags & CFWIDEB) ? 1 : 0;
if (!(flags & CFSYNCH)) if (!(flags & CFSYNCH))
spi_max_offset(starget) = 0; spi_max_offset(starget) = 0;
spi_min_period(starget) = spi_min_period(starget) =
ahc_find_period(ahc, scsirate, maxsync); ahc_find_period(ahc, scsirate, maxsync);
} }
ahc_compile_devinfo(&devinfo, our_id, starget->id, ahc_compile_devinfo(&devinfo, our_id, starget->id,
...@@ -657,7 +657,7 @@ ahc_linux_slave_alloc(struct scsi_device *sdev) ...@@ -657,7 +657,7 @@ ahc_linux_slave_alloc(struct scsi_device *sdev)
* a tagged queuing capable device. * a tagged queuing capable device.
*/ */
dev->maxtags = 0; dev->maxtags = 0;
spi_period(starget) = 0; spi_period(starget) = 0;
return 0; return 0;
...@@ -1219,8 +1219,8 @@ ahc_platform_free(struct ahc_softc *ahc) ...@@ -1219,8 +1219,8 @@ ahc_platform_free(struct ahc_softc *ahc)
starget = ahc->platform_data->starget[i]; starget = ahc->platform_data->starget[i];
if (starget != NULL) { if (starget != NULL) {
ahc->platform_data->starget[i] = NULL; ahc->platform_data->starget[i] = NULL;
} }
} }
if (ahc->platform_data->irq != AHC_LINUX_NOIRQ) if (ahc->platform_data->irq != AHC_LINUX_NOIRQ)
free_irq(ahc->platform_data->irq, ahc); free_irq(ahc->platform_data->irq, ahc);
...@@ -1267,7 +1267,7 @@ ahc_platform_set_tags(struct ahc_softc *ahc, struct scsi_device *sdev, ...@@ -1267,7 +1267,7 @@ ahc_platform_set_tags(struct ahc_softc *ahc, struct scsi_device *sdev,
default: default:
case AHC_QUEUE_NONE: case AHC_QUEUE_NONE:
now_queuing = 0; now_queuing = 0;
break; break;
case AHC_QUEUE_BASIC: case AHC_QUEUE_BASIC:
now_queuing = AHC_DEV_Q_BASIC; now_queuing = AHC_DEV_Q_BASIC;
break; break;
...@@ -1468,10 +1468,10 @@ ahc_linux_run_command(struct ahc_softc *ahc, struct ahc_linux_device *dev, ...@@ -1468,10 +1468,10 @@ ahc_linux_run_command(struct ahc_softc *ahc, struct ahc_linux_device *dev,
hscb->scsioffset = tinfo->curr.offset; hscb->scsioffset = tinfo->curr.offset;
if ((tstate->ultraenb & mask) != 0) if ((tstate->ultraenb & mask) != 0)
hscb->control |= ULTRAENB; hscb->control |= ULTRAENB;
if ((ahc->user_discenable & mask) != 0) if ((ahc->user_discenable & mask) != 0)
hscb->control |= DISCENB; hscb->control |= DISCENB;
if ((tstate->auto_negotiate & mask) != 0) { if ((tstate->auto_negotiate & mask) != 0) {
scb->flags |= SCB_AUTO_NEGOTIATE; scb->flags |= SCB_AUTO_NEGOTIATE;
scb->hscb->control |= MK_MESSAGE; scb->hscb->control |= MK_MESSAGE;
...@@ -1531,7 +1531,7 @@ ahc_linux_run_command(struct ahc_softc *ahc, struct ahc_linux_device *dev, ...@@ -1531,7 +1531,7 @@ ahc_linux_run_command(struct ahc_softc *ahc, struct ahc_linux_device *dev,
*/ */
scb->hscb->sgptr = scb->hscb->sgptr =
ahc_htole32(scb->sg_list_phys | SG_FULL_RESID); ahc_htole32(scb->sg_list_phys | SG_FULL_RESID);
/* /*
* Copy the first SG into the "current" * Copy the first SG into the "current"
* data pointer area. * data pointer area.
...@@ -1551,7 +1551,7 @@ ahc_linux_run_command(struct ahc_softc *ahc, struct ahc_linux_device *dev, ...@@ -1551,7 +1551,7 @@ ahc_linux_run_command(struct ahc_softc *ahc, struct ahc_linux_device *dev,
dev->commands_issued++; dev->commands_issued++;
if ((dev->flags & AHC_DEV_PERIODIC_OTAG) != 0) if ((dev->flags & AHC_DEV_PERIODIC_OTAG) != 0)
dev->commands_since_idle_or_otag++; dev->commands_since_idle_or_otag++;
scb->flags |= SCB_ACTIVE; scb->flags |= SCB_ACTIVE;
if (untagged_q) { if (untagged_q) {
TAILQ_INSERT_TAIL(untagged_q, scb, links.tqe); TAILQ_INSERT_TAIL(untagged_q, scb, links.tqe);
...@@ -1572,7 +1572,7 @@ ahc_linux_isr(int irq, void *dev_id) ...@@ -1572,7 +1572,7 @@ ahc_linux_isr(int irq, void *dev_id)
int ours; int ours;
ahc = (struct ahc_softc *) dev_id; ahc = (struct ahc_softc *) dev_id;
ahc_lock(ahc, &flags); ahc_lock(ahc, &flags);
ours = ahc_intr(ahc); ours = ahc_intr(ahc);
ahc_unlock(ahc, &flags); ahc_unlock(ahc, &flags);
return IRQ_RETVAL(ours); return IRQ_RETVAL(ours);
...@@ -1647,22 +1647,22 @@ ahc_send_async(struct ahc_softc *ahc, char channel, ...@@ -1647,22 +1647,22 @@ ahc_send_async(struct ahc_softc *ahc, char channel,
spi_display_xfer_agreement(starget); spi_display_xfer_agreement(starget);
break; break;
} }
case AC_SENT_BDR: case AC_SENT_BDR:
{ {
WARN_ON(lun != CAM_LUN_WILDCARD); WARN_ON(lun != CAM_LUN_WILDCARD);
scsi_report_device_reset(ahc->platform_data->host, scsi_report_device_reset(ahc->platform_data->host,
channel - 'A', target); channel - 'A', target);
break; break;
} }
case AC_BUS_RESET: case AC_BUS_RESET:
if (ahc->platform_data->host != NULL) { if (ahc->platform_data->host != NULL) {
scsi_report_bus_reset(ahc->platform_data->host, scsi_report_bus_reset(ahc->platform_data->host,
channel - 'A'); channel - 'A');
} }
break; break;
default: default:
panic("ahc_send_async: Unexpected async event"); panic("ahc_send_async: Unexpected async event");
} }
} }
/* /*
...@@ -1802,7 +1802,7 @@ ahc_linux_handle_scsi_status(struct ahc_softc *ahc, ...@@ -1802,7 +1802,7 @@ ahc_linux_handle_scsi_status(struct ahc_softc *ahc,
sdev->sdev_target->id, sdev->lun, sdev->sdev_target->id, sdev->lun,
sdev->sdev_target->channel == 0 ? 'A' : 'B', sdev->sdev_target->channel == 0 ? 'A' : 'B',
ROLE_INITIATOR); ROLE_INITIATOR);
/* /*
* We don't currently trust the mid-layer to * We don't currently trust the mid-layer to
* properly deal with queue full or busy. So, * properly deal with queue full or busy. So,
...@@ -2108,7 +2108,7 @@ ahc_linux_queue_recovery_cmd(struct scsi_cmnd *cmd, scb_flag flag) ...@@ -2108,7 +2108,7 @@ ahc_linux_queue_recovery_cmd(struct scsi_cmnd *cmd, scb_flag flag)
/* Any SCB for this device will do for a target reset */ /* Any SCB for this device will do for a target reset */
LIST_FOREACH(pending_scb, &ahc->pending_scbs, pending_links) { LIST_FOREACH(pending_scb, &ahc->pending_scbs, pending_links) {
if (ahc_match_scb(ahc, pending_scb, scmd_id(cmd), if (ahc_match_scb(ahc, pending_scb, scmd_id(cmd),
scmd_channel(cmd) + 'A', scmd_channel(cmd) + 'A',
CAM_LUN_WILDCARD, CAM_LUN_WILDCARD,
SCB_LIST_NULL, ROLE_INITIATOR)) SCB_LIST_NULL, ROLE_INITIATOR))
...@@ -2329,7 +2329,7 @@ static void ahc_linux_set_period(struct scsi_target *starget, int period) ...@@ -2329,7 +2329,7 @@ static void ahc_linux_set_period(struct scsi_target *starget, int period)
struct Scsi_Host *shost = dev_to_shost(starget->dev.parent); struct Scsi_Host *shost = dev_to_shost(starget->dev.parent);
struct ahc_softc *ahc = *((struct ahc_softc **)shost->hostdata); struct ahc_softc *ahc = *((struct ahc_softc **)shost->hostdata);
struct ahc_tmode_tstate *tstate; struct ahc_tmode_tstate *tstate;
struct ahc_initiator_tinfo *tinfo struct ahc_initiator_tinfo *tinfo
= ahc_fetch_transinfo(ahc, = ahc_fetch_transinfo(ahc,
starget->channel + 'A', starget->channel + 'A',
shost->this_id, starget->id, &tstate); shost->this_id, starget->id, &tstate);
...@@ -2361,7 +2361,8 @@ static void ahc_linux_set_period(struct scsi_target *starget, int period) ...@@ -2361,7 +2361,8 @@ static void ahc_linux_set_period(struct scsi_target *starget, int period)
ppr_options &= MSG_EXT_PPR_QAS_REQ; ppr_options &= MSG_EXT_PPR_QAS_REQ;
} }
syncrate = ahc_find_syncrate(ahc, &period, &ppr_options, AHC_SYNCRATE_DT); syncrate = ahc_find_syncrate(ahc, &period, &ppr_options,
AHC_SYNCRATE_DT);
ahc_lock(ahc, &flags); ahc_lock(ahc, &flags);
ahc_set_syncrate(ahc, &devinfo, syncrate, period, offset, ahc_set_syncrate(ahc, &devinfo, syncrate, period, offset,
ppr_options, AHC_TRANS_GOAL, FALSE); ppr_options, AHC_TRANS_GOAL, FALSE);
...@@ -2373,7 +2374,7 @@ static void ahc_linux_set_offset(struct scsi_target *starget, int offset) ...@@ -2373,7 +2374,7 @@ static void ahc_linux_set_offset(struct scsi_target *starget, int offset)
struct Scsi_Host *shost = dev_to_shost(starget->dev.parent); struct Scsi_Host *shost = dev_to_shost(starget->dev.parent);
struct ahc_softc *ahc = *((struct ahc_softc **)shost->hostdata); struct ahc_softc *ahc = *((struct ahc_softc **)shost->hostdata);
struct ahc_tmode_tstate *tstate; struct ahc_tmode_tstate *tstate;
struct ahc_initiator_tinfo *tinfo struct ahc_initiator_tinfo *tinfo
= ahc_fetch_transinfo(ahc, = ahc_fetch_transinfo(ahc,
starget->channel + 'A', starget->channel + 'A',
shost->this_id, starget->id, &tstate); shost->this_id, starget->id, &tstate);
...@@ -2386,7 +2387,8 @@ static void ahc_linux_set_offset(struct scsi_target *starget, int offset) ...@@ -2386,7 +2387,8 @@ static void ahc_linux_set_offset(struct scsi_target *starget, int offset)
ahc_compile_devinfo(&devinfo, shost->this_id, starget->id, 0, ahc_compile_devinfo(&devinfo, shost->this_id, starget->id, 0,
starget->channel + 'A', ROLE_INITIATOR); starget->channel + 'A', ROLE_INITIATOR);
if (offset != 0) { if (offset != 0) {
syncrate = ahc_find_syncrate(ahc, &period, &ppr_options, AHC_SYNCRATE_DT); syncrate = ahc_find_syncrate(ahc, &period, &ppr_options,
AHC_SYNCRATE_DT);
period = tinfo->goal.period; period = tinfo->goal.period;
ppr_options = tinfo->goal.ppr_options; ppr_options = tinfo->goal.ppr_options;
} }
...@@ -2401,7 +2403,7 @@ static void ahc_linux_set_dt(struct scsi_target *starget, int dt) ...@@ -2401,7 +2403,7 @@ static void ahc_linux_set_dt(struct scsi_target *starget, int dt)
struct Scsi_Host *shost = dev_to_shost(starget->dev.parent); struct Scsi_Host *shost = dev_to_shost(starget->dev.parent);
struct ahc_softc *ahc = *((struct ahc_softc **)shost->hostdata); struct ahc_softc *ahc = *((struct ahc_softc **)shost->hostdata);
struct ahc_tmode_tstate *tstate; struct ahc_tmode_tstate *tstate;
struct ahc_initiator_tinfo *tinfo struct ahc_initiator_tinfo *tinfo
= ahc_fetch_transinfo(ahc, = ahc_fetch_transinfo(ahc,
starget->channel + 'A', starget->channel + 'A',
shost->this_id, starget->id, &tstate); shost->this_id, starget->id, &tstate);
...@@ -2422,7 +2424,8 @@ static void ahc_linux_set_dt(struct scsi_target *starget, int dt) ...@@ -2422,7 +2424,8 @@ static void ahc_linux_set_dt(struct scsi_target *starget, int dt)
ahc_compile_devinfo(&devinfo, shost->this_id, starget->id, 0, ahc_compile_devinfo(&devinfo, shost->this_id, starget->id, 0,
starget->channel + 'A', ROLE_INITIATOR); starget->channel + 'A', ROLE_INITIATOR);
syncrate = ahc_find_syncrate(ahc, &period, &ppr_options,AHC_SYNCRATE_DT); syncrate = ahc_find_syncrate(ahc, &period, &ppr_options,
AHC_SYNCRATE_DT);
ahc_lock(ahc, &flags); ahc_lock(ahc, &flags);
ahc_set_syncrate(ahc, &devinfo, syncrate, period, tinfo->goal.offset, ahc_set_syncrate(ahc, &devinfo, syncrate, period, tinfo->goal.offset,
ppr_options, AHC_TRANS_GOAL, FALSE); ppr_options, AHC_TRANS_GOAL, FALSE);
...@@ -2439,7 +2442,7 @@ static void ahc_linux_set_qas(struct scsi_target *starget, int qas) ...@@ -2439,7 +2442,7 @@ static void ahc_linux_set_qas(struct scsi_target *starget, int qas)
struct Scsi_Host *shost = dev_to_shost(starget->dev.parent); struct Scsi_Host *shost = dev_to_shost(starget->dev.parent);
struct ahc_softc *ahc = *((struct ahc_softc **)shost->hostdata); struct ahc_softc *ahc = *((struct ahc_softc **)shost->hostdata);
struct ahc_tmode_tstate *tstate; struct ahc_tmode_tstate *tstate;
struct ahc_initiator_tinfo *tinfo struct ahc_initiator_tinfo *tinfo
= ahc_fetch_transinfo(ahc, = ahc_fetch_transinfo(ahc,
starget->channel + 'A', starget->channel + 'A',
shost->this_id, starget->id, &tstate); shost->this_id, starget->id, &tstate);
...@@ -2455,7 +2458,8 @@ static void ahc_linux_set_qas(struct scsi_target *starget, int qas) ...@@ -2455,7 +2458,8 @@ static void ahc_linux_set_qas(struct scsi_target *starget, int qas)
ahc_compile_devinfo(&devinfo, shost->this_id, starget->id, 0, ahc_compile_devinfo(&devinfo, shost->this_id, starget->id, 0,
starget->channel + 'A', ROLE_INITIATOR); starget->channel + 'A', ROLE_INITIATOR);
syncrate = ahc_find_syncrate(ahc, &period, &ppr_options, AHC_SYNCRATE_DT); syncrate = ahc_find_syncrate(ahc, &period, &ppr_options,
AHC_SYNCRATE_DT);
ahc_lock(ahc, &flags); ahc_lock(ahc, &flags);
ahc_set_syncrate(ahc, &devinfo, syncrate, period, tinfo->goal.offset, ahc_set_syncrate(ahc, &devinfo, syncrate, period, tinfo->goal.offset,
ppr_options, AHC_TRANS_GOAL, FALSE); ppr_options, AHC_TRANS_GOAL, FALSE);
...@@ -2467,7 +2471,7 @@ static void ahc_linux_set_iu(struct scsi_target *starget, int iu) ...@@ -2467,7 +2471,7 @@ static void ahc_linux_set_iu(struct scsi_target *starget, int iu)
struct Scsi_Host *shost = dev_to_shost(starget->dev.parent); struct Scsi_Host *shost = dev_to_shost(starget->dev.parent);
struct ahc_softc *ahc = *((struct ahc_softc **)shost->hostdata); struct ahc_softc *ahc = *((struct ahc_softc **)shost->hostdata);
struct ahc_tmode_tstate *tstate; struct ahc_tmode_tstate *tstate;
struct ahc_initiator_tinfo *tinfo struct ahc_initiator_tinfo *tinfo
= ahc_fetch_transinfo(ahc, = ahc_fetch_transinfo(ahc,
starget->channel + 'A', starget->channel + 'A',
shost->this_id, starget->id, &tstate); shost->this_id, starget->id, &tstate);
...@@ -2483,7 +2487,8 @@ static void ahc_linux_set_iu(struct scsi_target *starget, int iu) ...@@ -2483,7 +2487,8 @@ static void ahc_linux_set_iu(struct scsi_target *starget, int iu)
ahc_compile_devinfo(&devinfo, shost->this_id, starget->id, 0, ahc_compile_devinfo(&devinfo, shost->this_id, starget->id, 0,
starget->channel + 'A', ROLE_INITIATOR); starget->channel + 'A', ROLE_INITIATOR);
syncrate = ahc_find_syncrate(ahc, &period, &ppr_options, AHC_SYNCRATE_DT); syncrate = ahc_find_syncrate(ahc, &period, &ppr_options,
AHC_SYNCRATE_DT);
ahc_lock(ahc, &flags); ahc_lock(ahc, &flags);
ahc_set_syncrate(ahc, &devinfo, syncrate, period, tinfo->goal.offset, ahc_set_syncrate(ahc, &devinfo, syncrate, period, tinfo->goal.offset,
ppr_options, AHC_TRANS_GOAL, FALSE); ppr_options, AHC_TRANS_GOAL, FALSE);
...@@ -2499,7 +2504,7 @@ static void ahc_linux_get_signalling(struct Scsi_Host *shost) ...@@ -2499,7 +2504,7 @@ static void ahc_linux_get_signalling(struct Scsi_Host *shost)
if (!(ahc->features & AHC_ULTRA2)) { if (!(ahc->features & AHC_ULTRA2)) {
/* non-LVD chipset, may not have SBLKCTL reg */ /* non-LVD chipset, may not have SBLKCTL reg */
spi_signalling(shost) = spi_signalling(shost) =
ahc->features & AHC_HVD ? ahc->features & AHC_HVD ?
SPI_SIGNAL_HVD : SPI_SIGNAL_HVD :
SPI_SIGNAL_SE; SPI_SIGNAL_SE;
......
...@@ -258,7 +258,7 @@ struct ahc_linux_device { ...@@ -258,7 +258,7 @@ struct ahc_linux_device {
int active; int active;
/* /*
* The currently allowed number of * The currently allowed number of
* transactions that can be queued to * transactions that can be queued to
* the device. Must be signed for * the device. Must be signed for
* conversion from tagged to untagged * conversion from tagged to untagged
...@@ -272,7 +272,7 @@ struct ahc_linux_device { ...@@ -272,7 +272,7 @@ struct ahc_linux_device {
* device's queue is halted. * device's queue is halted.
*/ */
u_int qfrozen; u_int qfrozen;
/* /*
* Cumulative command counter. * Cumulative command counter.
*/ */
...@@ -351,16 +351,16 @@ struct ahc_platform_data { ...@@ -351,16 +351,16 @@ struct ahc_platform_data {
/* /*
* Fields accessed from interrupt context. * Fields accessed from interrupt context.
*/ */
struct scsi_target *starget[AHC_NUM_TARGETS]; struct scsi_target *starget[AHC_NUM_TARGETS];
spinlock_t spin_lock; spinlock_t spin_lock;
u_int qfrozen; u_int qfrozen;
struct completion *eh_done; struct completion *eh_done;
struct Scsi_Host *host; /* pointer to scsi host */ struct Scsi_Host *host; /* pointer to scsi host */
#define AHC_LINUX_NOIRQ ((uint32_t)~0) #define AHC_LINUX_NOIRQ ((uint32_t)~0)
uint32_t irq; /* IRQ for this adapter */ uint32_t irq; /* IRQ for this adapter */
uint32_t bios_address; uint32_t bios_address;
resource_size_t mem_busaddr; /* Mem Base Addr */ resource_size_t mem_busaddr; /* Mem Base Addr */
}; };
void ahc_delay(long); void ahc_delay(long);
...@@ -671,9 +671,9 @@ static inline void ...@@ -671,9 +671,9 @@ static inline void
ahc_freeze_scb(struct scb *scb) ahc_freeze_scb(struct scb *scb)
{ {
if ((scb->io_ctx->result & (CAM_DEV_QFRZN << 16)) == 0) { if ((scb->io_ctx->result & (CAM_DEV_QFRZN << 16)) == 0) {
scb->io_ctx->result |= CAM_DEV_QFRZN << 16; scb->io_ctx->result |= CAM_DEV_QFRZN << 16;
scb->platform_data->dev->qfrozen++; scb->platform_data->dev->qfrozen++;
} }
} }
void ahc_platform_set_tags(struct ahc_softc *ahc, struct scsi_device *sdev, void ahc_platform_set_tags(struct ahc_softc *ahc, struct scsi_device *sdev,
......
...@@ -97,17 +97,17 @@ ahc_format_transinfo(struct seq_file *m, struct ahc_transinfo *tinfo) ...@@ -97,17 +97,17 @@ ahc_format_transinfo(struct seq_file *m, struct ahc_transinfo *tinfo)
u_int freq; u_int freq;
u_int mb; u_int mb;
speed = 3300; speed = 3300;
freq = 0; freq = 0;
if (tinfo->offset != 0) { if (tinfo->offset != 0) {
freq = ahc_calc_syncsrate(tinfo->period); freq = ahc_calc_syncsrate(tinfo->period);
speed = freq; speed = freq;
} }
speed *= (0x01 << tinfo->width); speed *= (0x01 << tinfo->width);
mb = speed / 1000; mb = speed / 1000;
if (mb > 0) if (mb > 0)
seq_printf(m, "%d.%03dMB/s transfers", mb, speed % 1000); seq_printf(m, "%d.%03dMB/s transfers", mb, speed % 1000);
else else
seq_printf(m, "%dKB/s transfers", speed); seq_printf(m, "%dKB/s transfers", speed);
if (freq != 0) { if (freq != 0) {
...@@ -234,7 +234,7 @@ ahc_proc_write_seeprom(struct Scsi_Host *shost, char *buffer, int length) ...@@ -234,7 +234,7 @@ ahc_proc_write_seeprom(struct Scsi_Host *shost, char *buffer, int length)
if ((ahc->chip & AHC_VL) != 0) { if ((ahc->chip & AHC_VL) != 0) {
sd.sd_control_offset = SEECTL_2840; sd.sd_control_offset = SEECTL_2840;
sd.sd_status_offset = STATUS_2840; sd.sd_status_offset = STATUS_2840;
sd.sd_dataout_offset = STATUS_2840; sd.sd_dataout_offset = STATUS_2840;
sd.sd_chip = C46; sd.sd_chip = C46;
sd.sd_MS = 0; sd.sd_MS = 0;
sd.sd_RDY = EEPROM_TF; sd.sd_RDY = EEPROM_TF;
...@@ -255,7 +255,8 @@ ahc_proc_write_seeprom(struct Scsi_Host *shost, char *buffer, int length) ...@@ -255,7 +255,8 @@ ahc_proc_write_seeprom(struct Scsi_Host *shost, char *buffer, int length)
u_int start_addr; u_int start_addr;
if (ahc->seep_config == NULL) { if (ahc->seep_config == NULL) {
ahc->seep_config = kmalloc(sizeof(*ahc->seep_config), GFP_ATOMIC); ahc->seep_config = kmalloc(sizeof(*ahc->seep_config),
GFP_ATOMIC);
if (ahc->seep_config == NULL) { if (ahc->seep_config == NULL) {
printk("aic7xxx: Unable to allocate serial " printk("aic7xxx: Unable to allocate serial "
"eeprom buffer. Write failing\n"); "eeprom buffer. Write failing\n");
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment