diff options
author | Jon Mason <jon.mason@intel.com> | 2013-09-13 20:05:23 -0400 |
---|---|---|
committer | Jon Mason <jon.mason@intel.com> | 2013-11-20 11:57:31 -0500 |
commit | 9fec60c41416c9c40ec520bb79064345d2396632 (patch) | |
tree | 5196b6e6ad2899a1f8055e38cfe6cd76d3634462 /drivers/ntb/ntb_hw.c | |
parent | c529aa30337b928bd6bc34293608cb3d4505856e (diff) |
NTB: Fix NTB-RP Link Up
The Xeon NTB-RP setup, the transparent side does not get a link up/down
interrupt. Since the presence of a NTB device on the transparent side
means that we have a NTB link up, we can work around the lack of an
interrupt by simply calling the link up function to notify the upper
layers.
Signed-off-by: Jon Mason <jon.mason@intel.com>
Diffstat (limited to 'drivers/ntb/ntb_hw.c')
-rw-r--r-- | drivers/ntb/ntb_hw.c | 36 |
1 files changed, 28 insertions, 8 deletions
diff --git a/drivers/ntb/ntb_hw.c b/drivers/ntb/ntb_hw.c index 6c9d73348735..a9b065f3973a 100644 --- a/drivers/ntb/ntb_hw.c +++ b/drivers/ntb/ntb_hw.c | |||
@@ -1296,6 +1296,32 @@ static void ntb_free_debugfs(struct ntb_device *ndev) | |||
1296 | } | 1296 | } |
1297 | } | 1297 | } |
1298 | 1298 | ||
1299 | static void ntb_hw_link_up(struct ntb_device *ndev) | ||
1300 | { | ||
1301 | if (ndev->conn_type == NTB_CONN_TRANSPARENT) | ||
1302 | ntb_link_event(ndev, NTB_LINK_UP); | ||
1303 | else | ||
1304 | /* Let's bring the NTB link up */ | ||
1305 | writel(NTB_CNTL_BAR23_SNOOP | NTB_CNTL_BAR45_SNOOP, | ||
1306 | ndev->reg_ofs.lnk_cntl); | ||
1307 | } | ||
1308 | |||
1309 | static void ntb_hw_link_down(struct ntb_device *ndev) | ||
1310 | { | ||
1311 | u32 ntb_cntl; | ||
1312 | |||
1313 | if (ndev->conn_type == NTB_CONN_TRANSPARENT) { | ||
1314 | ntb_link_event(ndev, NTB_LINK_DOWN); | ||
1315 | return; | ||
1316 | } | ||
1317 | |||
1318 | /* Bring NTB link down */ | ||
1319 | ntb_cntl = readl(ndev->reg_ofs.lnk_cntl); | ||
1320 | ntb_cntl &= ~(NTB_CNTL_BAR23_SNOOP | NTB_CNTL_BAR45_SNOOP); | ||
1321 | ntb_cntl |= NTB_CNTL_LINK_DISABLE; | ||
1322 | writel(ntb_cntl, ndev->reg_ofs.lnk_cntl); | ||
1323 | } | ||
1324 | |||
1299 | static int ntb_pci_probe(struct pci_dev *pdev, const struct pci_device_id *id) | 1325 | static int ntb_pci_probe(struct pci_dev *pdev, const struct pci_device_id *id) |
1300 | { | 1326 | { |
1301 | struct ntb_device *ndev; | 1327 | struct ntb_device *ndev; |
@@ -1384,9 +1410,7 @@ static int ntb_pci_probe(struct pci_dev *pdev, const struct pci_device_id *id) | |||
1384 | if (rc) | 1410 | if (rc) |
1385 | goto err6; | 1411 | goto err6; |
1386 | 1412 | ||
1387 | /* Let's bring the NTB link up */ | 1413 | ntb_hw_link_up(ndev); |
1388 | writel(NTB_CNTL_BAR23_SNOOP | NTB_CNTL_BAR45_SNOOP, | ||
1389 | ndev->reg_ofs.lnk_cntl); | ||
1390 | 1414 | ||
1391 | return 0; | 1415 | return 0; |
1392 | 1416 | ||
@@ -1416,12 +1440,8 @@ static void ntb_pci_remove(struct pci_dev *pdev) | |||
1416 | { | 1440 | { |
1417 | struct ntb_device *ndev = pci_get_drvdata(pdev); | 1441 | struct ntb_device *ndev = pci_get_drvdata(pdev); |
1418 | int i; | 1442 | int i; |
1419 | u32 ntb_cntl; | ||
1420 | 1443 | ||
1421 | /* Bring NTB link down */ | 1444 | ntb_hw_link_down(ndev); |
1422 | ntb_cntl = readl(ndev->reg_ofs.lnk_cntl); | ||
1423 | ntb_cntl |= NTB_CNTL_LINK_DISABLE; | ||
1424 | writel(ntb_cntl, ndev->reg_ofs.lnk_cntl); | ||
1425 | 1445 | ||
1426 | ntb_transport_free(ndev->ntb_transport); | 1446 | ntb_transport_free(ndev->ntb_transport); |
1427 | 1447 | ||