IB/hfi1: Cache neighbor secure data after link up
Secure data is transferred across the link during verify cap. This includes Neighbor Guid, Type, and Port Number. This transfer is not guaranteed to complete until the 8051 firmware has completed processing of the state_complete frame. Move the consumption of this data from verify cap handling to link up handling to ensure the data is finalized. Additionally, do not notify the SM that the link is up until after this data is actually available. Reviewed-by: Ira Weiny <ira.weiny@intel.com> Reviewed-by: Easwar Hariharan <easwar.hariharan@intel.com> Reviewed-by: Mike Marciniszyn <mike.marciniszyn@intel.com> Signed-off-by: Stuart Summers <john.s.summers@intel.com> Signed-off-by: Dennis Dalessandro <dennis.dalessandro@intel.com> Signed-off-by: Doug Ledford <dledford@redhat.com>
此提交包含在:
@@ -1307,7 +1307,16 @@ int hfi1_reset_device(int);
|
||||
/* return the driver's idea of the logical OPA port state */
|
||||
static inline u32 driver_lstate(struct hfi1_pportdata *ppd)
|
||||
{
|
||||
return ppd->lstate; /* use the cached value */
|
||||
/*
|
||||
* The driver does some processing from the time the logical
|
||||
* link state is at INIT to the time the SM can be notified
|
||||
* as such. Return IB_PORT_DOWN until the software state
|
||||
* is ready.
|
||||
*/
|
||||
if (ppd->lstate == IB_PORT_INIT && !(ppd->host_link_state & HLS_UP))
|
||||
return IB_PORT_DOWN;
|
||||
else
|
||||
return ppd->lstate;
|
||||
}
|
||||
|
||||
void receive_interrupt_work(struct work_struct *work);
|
||||
|
新增問題並參考
封鎖使用者