blob: 9b7678f26909a5c014cf86d23be87ed77c29418f [file] [log] [blame]
Sudarsana Reddy Kalluru03dc76c2016-04-28 20:20:52 -04001#include "qed.h"
2#include "qed_dev_api.h"
3#include "qed_mcp.h"
4#include "qed_sp.h"
Baoyou Xie72e8d5f2016-09-07 19:07:00 +08005#include "qed_selftest.h"
Sudarsana Reddy Kalluru03dc76c2016-04-28 20:20:52 -04006
7int qed_selftest_memory(struct qed_dev *cdev)
8{
9 int rc = 0, i;
10
11 for_each_hwfn(cdev, i) {
12 rc = qed_sp_heartbeat_ramrod(&cdev->hwfns[i]);
13 if (rc)
14 return rc;
15 }
16
17 return rc;
18}
19
20int qed_selftest_interrupt(struct qed_dev *cdev)
21{
22 int rc = 0, i;
23
24 for_each_hwfn(cdev, i) {
25 rc = qed_sp_heartbeat_ramrod(&cdev->hwfns[i]);
26 if (rc)
27 return rc;
28 }
29
30 return rc;
31}
32
33int qed_selftest_register(struct qed_dev *cdev)
34{
35 struct qed_hwfn *p_hwfn;
36 struct qed_ptt *p_ptt;
37 int rc = 0, i;
38
39 /* although performed by MCP, this test is per engine */
40 for_each_hwfn(cdev, i) {
41 p_hwfn = &cdev->hwfns[i];
42 p_ptt = qed_ptt_acquire(p_hwfn);
43 if (!p_ptt) {
44 DP_ERR(p_hwfn, "failed to acquire ptt\n");
45 return -EBUSY;
46 }
47 rc = qed_mcp_bist_register_test(p_hwfn, p_ptt);
48 qed_ptt_release(p_hwfn, p_ptt);
49 if (rc)
50 break;
51 }
52
53 return rc;
54}
55
56int qed_selftest_clock(struct qed_dev *cdev)
57{
58 struct qed_hwfn *p_hwfn;
59 struct qed_ptt *p_ptt;
60 int rc = 0, i;
61
62 /* although performed by MCP, this test is per engine */
63 for_each_hwfn(cdev, i) {
64 p_hwfn = &cdev->hwfns[i];
65 p_ptt = qed_ptt_acquire(p_hwfn);
66 if (!p_ptt) {
67 DP_ERR(p_hwfn, "failed to acquire ptt\n");
68 return -EBUSY;
69 }
70 rc = qed_mcp_bist_clock_test(p_hwfn, p_ptt);
71 qed_ptt_release(p_hwfn, p_ptt);
72 if (rc)
73 break;
74 }
75
76 return rc;
77}