Major Fixes:

Don't enable/disable I/O space except for SAS adapters.
  This fixes a problem with VMware 4.5 Workstation.

  Fix an egregious bug introduced to target mode so it actually
  will not panic when you first enable a lun.

Minor fixes:

  Take more infor from port facts and configuration pages.

MFC after:	1 week
This commit is contained in:
mjacob 2006-06-25 04:23:26 +00:00
parent 4a62627c84
commit c55984e606
4 changed files with 47 additions and 30 deletions

View File

@ -1484,13 +1484,7 @@ mpt_send_ioc_init(struct mpt_softc *mpt, uint32_t who)
memset(&init, 0, sizeof init); memset(&init, 0, sizeof init);
init.WhoInit = who; init.WhoInit = who;
init.Function = MPI_FUNCTION_IOC_INIT; init.Function = MPI_FUNCTION_IOC_INIT;
if (mpt->is_fc) { init.MaxDevices = mpt->mpt_max_devices;
init.MaxDevices = 255;
} else if (mpt->is_sas) {
init.MaxDevices = mpt->mpt_max_devices;
} else {
init.MaxDevices = 16;
}
init.MaxBuses = 1; init.MaxBuses = 1;
init.MsgVersion = htole16(MPI_VERSION); init.MsgVersion = htole16(MPI_VERSION);
@ -2189,13 +2183,17 @@ mpt_diag_outsl(struct mpt_softc *mpt, uint32_t addr,
uint32_t *data_end; uint32_t *data_end;
data_end = data + (roundup2(len, sizeof(uint32_t)) / 4); data_end = data + (roundup2(len, sizeof(uint32_t)) / 4);
pci_enable_io(mpt->dev, SYS_RES_IOPORT); if (mpt->is_sas) {
pci_enable_io(mpt->dev, SYS_RES_IOPORT);
}
mpt_pio_write(mpt, MPT_OFFSET_DIAG_ADDR, addr); mpt_pio_write(mpt, MPT_OFFSET_DIAG_ADDR, addr);
while (data != data_end) { while (data != data_end) {
mpt_pio_write(mpt, MPT_OFFSET_DIAG_DATA, *data); mpt_pio_write(mpt, MPT_OFFSET_DIAG_DATA, *data);
data++; data++;
} }
pci_disable_io(mpt->dev, SYS_RES_IOPORT); if (mpt->is_sas) {
pci_disable_io(mpt->dev, SYS_RES_IOPORT);
}
} }
static int static int
@ -2233,7 +2231,9 @@ mpt_download_fw(struct mpt_softc *mpt)
ext->ImageSize); ext->ImageSize);
} }
pci_enable_io(mpt->dev, SYS_RES_IOPORT); if (mpt->is_sas) {
pci_enable_io(mpt->dev, SYS_RES_IOPORT);
}
/* Setup the address to jump to on reset. */ /* Setup the address to jump to on reset. */
mpt_pio_write(mpt, MPT_OFFSET_DIAG_ADDR, fw_hdr->IopResetRegAddr); mpt_pio_write(mpt, MPT_OFFSET_DIAG_ADDR, fw_hdr->IopResetRegAddr);
mpt_pio_write(mpt, MPT_OFFSET_DIAG_DATA, fw_hdr->IopResetVectorValue); mpt_pio_write(mpt, MPT_OFFSET_DIAG_DATA, fw_hdr->IopResetVectorValue);
@ -2248,7 +2248,9 @@ mpt_download_fw(struct mpt_softc *mpt)
mpt_pio_write(mpt, MPT_OFFSET_DIAG_ADDR, MPT_DIAG_MEM_CFG_BASE); mpt_pio_write(mpt, MPT_OFFSET_DIAG_ADDR, MPT_DIAG_MEM_CFG_BASE);
mpt_pio_write(mpt, MPT_OFFSET_DIAG_DATA, data); mpt_pio_write(mpt, MPT_OFFSET_DIAG_DATA, data);
pci_disable_io(mpt->dev, SYS_RES_IOPORT); if (mpt->is_sas) {
pci_disable_io(mpt->dev, SYS_RES_IOPORT);
}
/* /*
* Re-enable the processor and clear the boot halt flag. * Re-enable the processor and clear the boot halt flag.

View File

@ -551,7 +551,9 @@ struct mpt_softc {
#define mpt_disc_enable cfg.spi._disc_enable #define mpt_disc_enable cfg.spi._disc_enable
struct mpi_fc_cfg { struct mpi_fc_cfg {
CONFIG_PAGE_FC_PORT_0 _port_page0; CONFIG_PAGE_FC_PORT_0 _port_page0;
uint32_t _port_speed;
#define mpt_fcport_page0 cfg.fc._port_page0 #define mpt_fcport_page0 cfg.fc._port_page0
#define mpt_fcport_speed cfg.fc._port_speed
} fc; } fc;
} cfg; } cfg;

View File

@ -371,7 +371,7 @@ static int
mpt_read_config_info_fc(struct mpt_softc *mpt) mpt_read_config_info_fc(struct mpt_softc *mpt)
{ {
char *topology = NULL; char *topology = NULL;
int rv, speed = 0; int rv;
rv = mpt_read_cfg_header(mpt, MPI_CONFIG_PAGETYPE_FC_PORT, 0, rv = mpt_read_cfg_header(mpt, MPI_CONFIG_PAGETYPE_FC_PORT, 0,
0, &mpt->mpt_fcport_page0.Header, FALSE, 5000); 0, &mpt->mpt_fcport_page0.Header, FALSE, 5000);
@ -392,12 +392,12 @@ mpt_read_config_info_fc(struct mpt_softc *mpt)
return (-1); return (-1);
} }
speed = mpt->mpt_fcport_page0.CurrentSpeed; mpt->mpt_fcport_speed = mpt->mpt_fcport_page0.CurrentSpeed;
switch (mpt->mpt_fcport_page0.Flags & switch (mpt->mpt_fcport_page0.Flags &
MPI_FCPORTPAGE0_FLAGS_ATTACH_TYPE_MASK) { MPI_FCPORTPAGE0_FLAGS_ATTACH_TYPE_MASK) {
case MPI_FCPORTPAGE0_FLAGS_ATTACH_NO_INIT: case MPI_FCPORTPAGE0_FLAGS_ATTACH_NO_INIT:
speed = 0; mpt->mpt_fcport_speed = 0;
topology = "<NO LOOP>"; topology = "<NO LOOP>";
break; break;
case MPI_FCPORTPAGE0_FLAGS_ATTACH_POINT_TO_POINT: case MPI_FCPORTPAGE0_FLAGS_ATTACH_POINT_TO_POINT:
@ -413,7 +413,7 @@ mpt_read_config_info_fc(struct mpt_softc *mpt)
topology = "FL-Port"; topology = "FL-Port";
break; break;
default: default:
speed = 0; mpt->mpt_fcport_speed = 0;
topology = "?"; topology = "?";
break; break;
} }
@ -425,7 +425,7 @@ mpt_read_config_info_fc(struct mpt_softc *mpt)
mpt->mpt_fcport_page0.WWNN.Low, mpt->mpt_fcport_page0.WWNN.Low,
mpt->mpt_fcport_page0.WWPN.High, mpt->mpt_fcport_page0.WWPN.High,
mpt->mpt_fcport_page0.WWPN.Low, mpt->mpt_fcport_page0.WWPN.Low,
speed); mpt->mpt_fcport_speed);
return (0); return (0);
} }
@ -3017,26 +3017,36 @@ mpt_action(struct cam_sim *sim, union ccb *ccb)
cpi->version_num = 1; cpi->version_num = 1;
cpi->target_sprt = 0; cpi->target_sprt = 0;
cpi->hba_eng_cnt = 0; cpi->hba_eng_cnt = 0;
cpi->max_lun = 7; cpi->max_target = mpt->mpt_max_devices - 1;
cpi->bus_id = cam_sim_bus(sim); /*
/* XXX Report base speed more accurately for FC/SAS, etc.*/ * XXX: FC cards report MAX_DEVICES of 512- but we
if (mpt->is_fc) { * XXX: seem to hang when going higher than 255.
/* XXX SHOULD BE BASED UPON IOC FACTS XXX XXX */ */
if (cpi->max_target > 255)
cpi->max_target = 255; cpi->max_target = 255;
cpi->max_lun = 7;
cpi->initiator_id = mpt->mpt_ini_id;
cpi->bus_id = cam_sim_bus(sim);
/*
* Actual speed for each device varies.
*
* The base speed is the speed of the underlying connection.
* This is strictly determined for SPI (async, narrow). If
* link is up for Fibre Channel, then speed can be gotten
* from that.
*/
if (mpt->is_fc) {
cpi->hba_misc = PIM_NOBUSRESET; cpi->hba_misc = PIM_NOBUSRESET;
cpi->initiator_id = mpt->mpt_ini_id; cpi->base_transfer_speed =
cpi->base_transfer_speed = 100000; mpt->mpt_fcport_speed * 100000;
cpi->hba_inquiry = PI_TAG_ABLE; cpi->hba_inquiry = PI_TAG_ABLE;
} else if (mpt->is_sas) { } else if (mpt->is_sas) {
cpi->max_target = 63; /* XXX */
cpi->hba_misc = PIM_NOBUSRESET; cpi->hba_misc = PIM_NOBUSRESET;
cpi->initiator_id = mpt->mpt_ini_id;
cpi->base_transfer_speed = 300000; cpi->base_transfer_speed = 300000;
cpi->hba_inquiry = PI_TAG_ABLE; cpi->hba_inquiry = PI_TAG_ABLE;
} else { } else {
cpi->max_target = 15;
cpi->hba_misc = PIM_SEQSCAN; cpi->hba_misc = PIM_SEQSCAN;
cpi->initiator_id = mpt->mpt_ini_id;
cpi->base_transfer_speed = 3300; cpi->base_transfer_speed = 3300;
cpi->hba_inquiry = PI_SDTR_ABLE|PI_TAG_ABLE|PI_WIDE_16; cpi->hba_inquiry = PI_SDTR_ABLE|PI_TAG_ABLE|PI_WIDE_16;
} }
@ -3126,13 +3136,14 @@ mpt_action(struct cam_sim *sim, union ccb *ccb)
} }
mpt_set_ccb_status(ccb, CAM_REQ_INPROG); mpt_set_ccb_status(ccb, CAM_REQ_INPROG);
MPTLOCK_2_CAMLOCK(mpt); MPTLOCK_2_CAMLOCK(mpt);
break; return;
} }
case XPT_CONT_TARGET_IO: case XPT_CONT_TARGET_IO:
CAMLOCK_2_MPTLOCK(mpt); CAMLOCK_2_MPTLOCK(mpt);
mpt_target_start_io(mpt, ccb); mpt_target_start_io(mpt, ccb);
MPTLOCK_2_CAMLOCK(mpt); MPTLOCK_2_CAMLOCK(mpt);
break; return;
default: default:
ccb->ccb_h.status = CAM_REQ_INVALID; ccb->ccb_h.status = CAM_REQ_INVALID;
break; break;

View File

@ -524,7 +524,9 @@ mpt_pci_attach(device_t dev)
/* /*
* Disable PIO until we need it * Disable PIO until we need it
*/ */
pci_disable_io(dev, SYS_RES_IOPORT); if (mpt->is_sas) {
pci_disable_io(dev, SYS_RES_IOPORT);
}
/* Initialize the hardware */ /* Initialize the hardware */
if (mpt->disabled == 0) { if (mpt->disabled == 0) {