Skip to content

Commit 5b6ff12

Browse files
vikasbrcmkuba-moo
authored andcommitted
bnxt_en: implement callbacks for devlink selftests
Add callbacks ============= .selftest_check: returns true for flash selftest. .selftest_run: runs a flash selftest. Also, refactor NVM APIs so that they can be used with devlink and ethtool both. Signed-off-by: Vikas Gupta <vikas.gupta@broadcom.com> Reviewed-by: Andy Gospodarek <gospo@broadcom.com> Reviewed-by: Jiri Pirko <jiri@nvidia.com> Signed-off-by: Jakub Kicinski <kuba@kernel.org>
1 parent 08f588f commit 5b6ff12

File tree

3 files changed

+85
-12
lines changed

3 files changed

+85
-12
lines changed

drivers/net/ethernet/broadcom/bnxt/bnxt_devlink.c

Lines changed: 61 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -20,6 +20,8 @@
2020
#include "bnxt_ulp.h"
2121
#include "bnxt_ptp.h"
2222
#include "bnxt_coredump.h"
23+
#include "bnxt_nvm_defs.h"
24+
#include "bnxt_ethtool.h"
2325

2426
static void __bnxt_fw_recover(struct bnxt *bp)
2527
{
@@ -610,6 +612,63 @@ static int bnxt_dl_reload_up(struct devlink *dl, enum devlink_reload_action acti
610612
return rc;
611613
}
612614

615+
static bool bnxt_nvm_test(struct bnxt *bp, struct netlink_ext_ack *extack)
616+
{
617+
u32 datalen;
618+
u16 index;
619+
u8 *buf;
620+
621+
if (bnxt_find_nvram_item(bp->dev, BNX_DIR_TYPE_VPD,
622+
BNX_DIR_ORDINAL_FIRST, BNX_DIR_EXT_NONE,
623+
&index, NULL, &datalen) || !datalen) {
624+
NL_SET_ERR_MSG_MOD(extack, "nvm test vpd entry error");
625+
return false;
626+
}
627+
628+
buf = kzalloc(datalen, GFP_KERNEL);
629+
if (!buf) {
630+
NL_SET_ERR_MSG_MOD(extack, "insufficient memory for nvm test");
631+
return false;
632+
}
633+
634+
if (bnxt_get_nvram_item(bp->dev, index, 0, datalen, buf)) {
635+
NL_SET_ERR_MSG_MOD(extack, "nvm test vpd read error");
636+
goto err;
637+
}
638+
639+
if (bnxt_flash_nvram(bp->dev, BNX_DIR_TYPE_VPD, BNX_DIR_ORDINAL_FIRST,
640+
BNX_DIR_EXT_NONE, 0, 0, buf, datalen)) {
641+
NL_SET_ERR_MSG_MOD(extack, "nvm test vpd write error");
642+
goto err;
643+
}
644+
645+
return true;
646+
647+
err:
648+
kfree(buf);
649+
return false;
650+
}
651+
652+
static bool bnxt_dl_selftest_check(struct devlink *dl, unsigned int id,
653+
struct netlink_ext_ack *extack)
654+
{
655+
return id == DEVLINK_ATTR_SELFTEST_ID_FLASH;
656+
}
657+
658+
static enum devlink_selftest_status bnxt_dl_selftest_run(struct devlink *dl,
659+
unsigned int id,
660+
struct netlink_ext_ack *extack)
661+
{
662+
struct bnxt *bp = bnxt_get_bp_from_dl(dl);
663+
664+
if (id == DEVLINK_ATTR_SELFTEST_ID_FLASH)
665+
return bnxt_nvm_test(bp, extack) ?
666+
DEVLINK_SELFTEST_STATUS_PASS :
667+
DEVLINK_SELFTEST_STATUS_FAIL;
668+
669+
return DEVLINK_SELFTEST_STATUS_SKIP;
670+
}
671+
613672
static const struct devlink_ops bnxt_dl_ops = {
614673
#ifdef CONFIG_BNXT_SRIOV
615674
.eswitch_mode_set = bnxt_dl_eswitch_mode_set,
@@ -622,6 +681,8 @@ static const struct devlink_ops bnxt_dl_ops = {
622681
.reload_limits = BIT(DEVLINK_RELOAD_LIMIT_NO_RESET),
623682
.reload_down = bnxt_dl_reload_down,
624683
.reload_up = bnxt_dl_reload_up,
684+
.selftest_check = bnxt_dl_selftest_check,
685+
.selftest_run = bnxt_dl_selftest_run,
625686
};
626687

627688
static const struct devlink_ops bnxt_vf_dl_ops;

drivers/net/ethernet/broadcom/bnxt/bnxt_ethtool.c

Lines changed: 12 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -2176,14 +2176,14 @@ static void bnxt_print_admin_err(struct bnxt *bp)
21762176
netdev_info(bp->dev, "PF does not have admin privileges to flash or reset the device\n");
21772177
}
21782178

2179-
static int bnxt_find_nvram_item(struct net_device *dev, u16 type, u16 ordinal,
2180-
u16 ext, u16 *index, u32 *item_length,
2181-
u32 *data_length);
2179+
int bnxt_find_nvram_item(struct net_device *dev, u16 type, u16 ordinal,
2180+
u16 ext, u16 *index, u32 *item_length,
2181+
u32 *data_length);
21822182

2183-
static int bnxt_flash_nvram(struct net_device *dev, u16 dir_type,
2184-
u16 dir_ordinal, u16 dir_ext, u16 dir_attr,
2185-
u32 dir_item_len, const u8 *data,
2186-
size_t data_len)
2183+
int bnxt_flash_nvram(struct net_device *dev, u16 dir_type,
2184+
u16 dir_ordinal, u16 dir_ext, u16 dir_attr,
2185+
u32 dir_item_len, const u8 *data,
2186+
size_t data_len)
21872187
{
21882188
struct bnxt *bp = netdev_priv(dev);
21892189
struct hwrm_nvm_write_input *req;
@@ -2836,8 +2836,8 @@ static int bnxt_get_nvram_directory(struct net_device *dev, u32 len, u8 *data)
28362836
return rc;
28372837
}
28382838

2839-
static int bnxt_get_nvram_item(struct net_device *dev, u32 index, u32 offset,
2840-
u32 length, u8 *data)
2839+
int bnxt_get_nvram_item(struct net_device *dev, u32 index, u32 offset,
2840+
u32 length, u8 *data)
28412841
{
28422842
struct bnxt *bp = netdev_priv(dev);
28432843
int rc;
@@ -2871,9 +2871,9 @@ static int bnxt_get_nvram_item(struct net_device *dev, u32 index, u32 offset,
28712871
return rc;
28722872
}
28732873

2874-
static int bnxt_find_nvram_item(struct net_device *dev, u16 type, u16 ordinal,
2875-
u16 ext, u16 *index, u32 *item_length,
2876-
u32 *data_length)
2874+
int bnxt_find_nvram_item(struct net_device *dev, u16 type, u16 ordinal,
2875+
u16 ext, u16 *index, u32 *item_length,
2876+
u32 *data_length)
28772877
{
28782878
struct hwrm_nvm_find_dir_entry_output *output;
28792879
struct hwrm_nvm_find_dir_entry_input *req;

drivers/net/ethernet/broadcom/bnxt/bnxt_ethtool.h

Lines changed: 12 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -58,5 +58,17 @@ int bnxt_flash_package_from_fw_obj(struct net_device *dev, const struct firmware
5858
int bnxt_get_pkginfo(struct net_device *dev, char *ver, int size);
5959
void bnxt_ethtool_init(struct bnxt *bp);
6060
void bnxt_ethtool_free(struct bnxt *bp);
61+
int bnxt_find_nvram_item(struct net_device *dev, u16 type, u16 ordinal,
62+
u16 ext, u16 *index, u32 *item_length,
63+
u32 *data_length);
64+
int bnxt_find_nvram_item(struct net_device *dev, u16 type, u16 ordinal,
65+
u16 ext, u16 *index, u32 *item_length,
66+
u32 *data_length);
67+
int bnxt_flash_nvram(struct net_device *dev, u16 dir_type,
68+
u16 dir_ordinal, u16 dir_ext, u16 dir_attr,
69+
u32 dir_item_len, const u8 *data,
70+
size_t data_len);
71+
int bnxt_get_nvram_item(struct net_device *dev, u32 index, u32 offset,
72+
u32 length, u8 *data);
6173

6274
#endif

0 commit comments

Comments
 (0)