Several HWRM (HardWare Resource Manager) commands used for diagnostics,
firmware management, and NVM access carry one or more DMA address fields
in their input structures. Until now these commands could not be issued
through the fwctl interface because the driver had no mechanism to safely
broker the host-side DMA buffers on userspace's behalf.
This series adds that mechanism in three steps.
In patch #1, the fwctl core UAPI adds a new driver_data field in struct
fwctl_rpc. Drivers that need a driver_data payload receive the value and
are free to interpret it. Drivers that do not define one will reject any
non-zero value with -EOPNOTSUPP. Existing mlx5 and pds fwctl drivers are
updated accordingly.
In patch #2, the bnxt HSI header is updated to add the missing struct
definitions for the HWRM commands that the bnxt fwctl driver will support.
In patch #3, the bnxt fwctl driver consumes driver_data as a pointer to
a new bnxt UAPI struct fwctl_bnxt_driver_data, which describes indirect
DMA buffers.
Pavan Chebbi (3):
fwctl: Add driver_data field to fwctl_rpc
bnxt_en: Update bnxt firmware spec
fwctl/bnxt: add DMA buffer support for HWRM commands
drivers/fwctl/bnxt/main.c | 323 ++++++++++++++++++++-
drivers/fwctl/main.c | 3 +-
drivers/fwctl/mlx5/main.c | 6 +-
drivers/fwctl/pds/main.c | 6 +-
include/linux/bnxt/hsi.h | 554 +++++++++++++++++++++++++++++++++++++
include/linux/fwctl.h | 8 +-
include/uapi/fwctl/bnxt.h | 38 +++
include/uapi/fwctl/fwctl.h | 3 +
8 files changed, 934 insertions(+), 7 deletions(-)
--
2.52.0