提交 c91b4a12 编写于 作者: C Caz Yokoyama 提交者: Greg Kroah-Hartman

staging/rdma/hfi1: Reset firmware instead of reloading Sbus

Reset firmware instead of reloading Sbus firmware if it's already done for this
ASIC.  To work around thermal polling problem in firmware, don't reload Sbus
firmware, instead, reset the firmware on the initialization of the second HFI.
Reviewed-by: NEaswar Hariharan <easwar.hariharan@intel.com>
Reviewed-by: NDennis Dalessandro <dennis.dalessandro@intel.com>
Reviewed-by: NDean Luick <dean.luick@intel.com>
Signed-off-by: NCaz Yokoyama <caz.yokoyama@intel.com>
Signed-off-by: NIra Weiny <ira.weiny@intel.com>
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 07839049
...@@ -609,6 +609,7 @@ static inline void write_uctxt_csr(struct hfi1_devdata *dd, int ctxt, ...@@ -609,6 +609,7 @@ static inline void write_uctxt_csr(struct hfi1_devdata *dd, int ctxt,
u64 create_pbc(struct hfi1_pportdata *ppd, u64, int, u32, u32); u64 create_pbc(struct hfi1_pportdata *ppd, u64, int, u32, u32);
/* firmware.c */ /* firmware.c */
#define SBUS_MASTER_BROADCAST 0xfd
#define NUM_PCIE_SERDES 16 /* number of PCIe serdes on the SBus */ #define NUM_PCIE_SERDES 16 /* number of PCIe serdes on the SBus */
extern const u8 pcie_serdes_broadcast[]; extern const u8 pcie_serdes_broadcast[];
extern const u8 pcie_pcs_addrs[2][NUM_PCIE_SERDES]; extern const u8 pcie_pcs_addrs[2][NUM_PCIE_SERDES];
......
...@@ -924,9 +924,6 @@ static int load_8051_firmware(struct hfi1_devdata *dd, ...@@ -924,9 +924,6 @@ static int load_8051_firmware(struct hfi1_devdata *dd,
return 0; return 0;
} }
/* SBus Master broadcast address */
#define SBUS_MASTER_BROADCAST 0xfd
/* /*
* Write the SBus request register * Write the SBus request register
* *
...@@ -1255,6 +1252,7 @@ int load_firmware(struct hfi1_devdata *dd) ...@@ -1255,6 +1252,7 @@ int load_firmware(struct hfi1_devdata *dd)
ret = load_sbus_firmware(dd, &fw_sbus); ret = load_sbus_firmware(dd, &fw_sbus);
if (ret) if (ret)
goto clear; goto clear;
fw_sbus_load = 0;
} }
if (fw_fabric_serdes_load) { if (fw_fabric_serdes_load) {
......
...@@ -946,9 +946,20 @@ int do_pcie_gen3_transition(struct hfi1_devdata *dd) ...@@ -946,9 +946,20 @@ int do_pcie_gen3_transition(struct hfi1_devdata *dd)
__func__); __func__);
} }
retry:
if (therm) {
/* toggle SPICO_ENABLE to get back to the state
just after the firmware load */
sbus_request(dd, SBUS_MASTER_BROADCAST, 0x01,
WRITE_SBUS_RECEIVER, 0x00000040);
sbus_request(dd, SBUS_MASTER_BROADCAST, 0x01,
WRITE_SBUS_RECEIVER, 0x00000140);
dd_dev_info(dd, "%s: toggle SPICO_ENABLE to reset the bus\n",
__func__);
}
/* step 3: download SBus Master firmware */ /* step 3: download SBus Master firmware */
/* step 4: download PCIe Gen3 SerDes firmware */ /* step 4: download PCIe Gen3 SerDes firmware */
retry:
dd_dev_info(dd, "%s: downloading firmware\n", __func__); dd_dev_info(dd, "%s: downloading firmware\n", __func__);
ret = load_pcie_firmware(dd); ret = load_pcie_firmware(dd);
if (ret) if (ret)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册