Skip to content

Commit e5b0d2d

Browse files
xliyujonmason
authored andcommitted
NTB: add support for hotplug feature
AMD NTB support hotplug under B2B mode. NTB will trigger link up/down interrupt event when doing plug add/remove, this patch implements the two interrupt event to support B2B hotplug function. Signed-off-by: Xiangliang Yu <Xiangliang.Yu@amd.com> Signed-off-by: Shyam Sundar S K <Shyam-sundar.S-k@amd.com> Acked-by: Allen Hubbe <Allen.Hubbe@dell.com> Signed-off-by: Jon Mason <jdmason@kudzu.us>
1 parent 783dfa6 commit e5b0d2d

File tree

2 files changed

+12
-2
lines changed

2 files changed

+12
-2
lines changed

drivers/ntb/hw/amd/ntb_hw_amd.c

Lines changed: 8 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -199,6 +199,11 @@ static int amd_link_is_up(struct amd_ntb_dev *ndev)
199199
if (!ndev->peer_sta)
200200
return NTB_LNK_STA_ACTIVE(ndev->cntl_sta);
201201

202+
if (ndev->peer_sta & AMD_LINK_UP_EVENT) {
203+
ndev->peer_sta = 0;
204+
return 1;
205+
}
206+
202207
/* If peer_sta is reset or D0 event, the ISR has
203208
* started a timer to check link status of hardware.
204209
* So here just clear status bit. And if peer_sta is
@@ -207,7 +212,7 @@ static int amd_link_is_up(struct amd_ntb_dev *ndev)
207212
*/
208213
if (ndev->peer_sta & AMD_PEER_RESET_EVENT)
209214
ndev->peer_sta &= ~AMD_PEER_RESET_EVENT;
210-
else if (ndev->peer_sta & AMD_PEER_D0_EVENT)
215+
else if (ndev->peer_sta & (AMD_PEER_D0_EVENT | AMD_LINK_DOWN_EVENT))
211216
ndev->peer_sta = 0;
212217

213218
return 0;
@@ -491,6 +496,8 @@ static void amd_handle_event(struct amd_ntb_dev *ndev, int vec)
491496
break;
492497
case AMD_PEER_D3_EVENT:
493498
case AMD_PEER_PMETO_EVENT:
499+
case AMD_LINK_UP_EVENT:
500+
case AMD_LINK_DOWN_EVENT:
494501
amd_ack_smu(ndev, status);
495502

496503
/* link down */

drivers/ntb/hw/amd/ntb_hw_amd.h

Lines changed: 4 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -148,9 +148,12 @@ enum {
148148
AMD_PEER_D3_EVENT = BIT(2),
149149
AMD_PEER_PMETO_EVENT = BIT(3),
150150
AMD_PEER_D0_EVENT = BIT(4),
151+
AMD_LINK_UP_EVENT = BIT(5),
152+
AMD_LINK_DOWN_EVENT = BIT(6),
151153
AMD_EVENT_INTMASK = (AMD_PEER_FLUSH_EVENT |
152154
AMD_PEER_RESET_EVENT | AMD_PEER_D3_EVENT |
153-
AMD_PEER_PMETO_EVENT | AMD_PEER_D0_EVENT),
155+
AMD_PEER_PMETO_EVENT | AMD_PEER_D0_EVENT |
156+
AMD_LINK_UP_EVENT | AMD_LINK_DOWN_EVENT),
154157

155158
AMD_PMESTAT_OFFSET = 0x480,
156159
AMD_PMSGTRIG_OFFSET = 0x490,

0 commit comments

Comments
 (0)