Author: hselasky
Date: Thu May 16 16:01:45 2019
New Revision: 347738
URL: https://svnweb.freebsd.org/changeset/base/347738

Log:
  MFC r347274:
  Add MCC (Management Component Control) register definitions in mlx5core.
  
  MCC (Management Component Control) allows to control a firmware
  component update.
  
  MCDA (Management Component Data Access) allows to read and write
  a firmware component.
  
  MCQI (Management Component Query Information) allows to query
  information about firmware components.
  
  Linux commit:
  4717628938423fcba0aa8fa889e9fed4eb6a655f
  
  Submitted by: slavash@
  Sponsored by: Mellanox Technologies

Modified:
  stable/12/sys/dev/mlx5/driver.h
  stable/12/sys/dev/mlx5/mlx5_ifc.h
Directory Properties:
  stable/12/   (props changed)

Modified: stable/12/sys/dev/mlx5/driver.h
==============================================================================
--- stable/12/sys/dev/mlx5/driver.h     Thu May 16 16:01:11 2019        
(r347737)
+++ stable/12/sys/dev/mlx5/driver.h     Thu May 16 16:01:45 2019        
(r347738)
@@ -155,6 +155,9 @@ enum {
        MLX5_REG_MTMP            = 0x900a,
        MLX5_REG_MCIA            = 0x9014,
        MLX5_REG_MPCNT           = 0x9051,
+       MLX5_REG_MCQI            = 0x9061,
+       MLX5_REG_MCC             = 0x9062,
+       MLX5_REG_MCDA            = 0x9063,
        MLX5_REG_MCAM            = 0x907f,
 };
 

Modified: stable/12/sys/dev/mlx5/mlx5_ifc.h
==============================================================================
--- stable/12/sys/dev/mlx5/mlx5_ifc.h   Thu May 16 16:01:11 2019        
(r347737)
+++ stable/12/sys/dev/mlx5/mlx5_ifc.h   Thu May 16 16:01:45 2019        
(r347738)
@@ -9927,6 +9927,85 @@ struct mlx5_ifc_mpcnt_reg_bits {
        union mlx5_ifc_mpcnt_cntrs_grp_data_layout_bits counter_set;
 };
 
+struct mlx5_ifc_mcqi_cap_bits {
+       u8         supported_info_bitmask[0x20];
+
+       u8         component_size[0x20];
+
+       u8         max_component_size[0x20];
+
+       u8         log_mcda_word_size[0x4];
+       u8         reserved_at_64[0xc];
+       u8         mcda_max_write_size[0x10];
+
+       u8         rd_en[0x1];
+       u8         reserved_at_81[0x1];
+       u8         match_chip_id[0x1];
+       u8         match_psid[0x1];
+       u8         check_user_timestamp[0x1];
+       u8         match_base_guid_mac[0x1];
+       u8         reserved_at_86[0x1a];
+};
+
+struct mlx5_ifc_mcqi_reg_bits {
+       u8         read_pending_component[0x1];
+       u8         reserved_at_1[0xf];
+       u8         component_index[0x10];
+
+       u8         reserved_at_20[0x20];
+
+       u8         reserved_at_40[0x1b];
+       u8         info_type[0x5];
+
+       u8         info_size[0x20];
+
+       u8         offset[0x20];
+
+       u8         reserved_at_a0[0x10];
+       u8         data_size[0x10];
+
+       u8         data[0][0x20];
+};
+
+struct mlx5_ifc_mcc_reg_bits {
+       u8         reserved_at_0[0x4];
+       u8         time_elapsed_since_last_cmd[0xc];
+       u8         reserved_at_10[0x8];
+       u8         instruction[0x8];
+
+       u8         reserved_at_20[0x10];
+       u8         component_index[0x10];
+
+       u8         reserved_at_40[0x8];
+       u8         update_handle[0x18];
+
+       u8         handle_owner_type[0x4];
+       u8         handle_owner_host_id[0x4];
+       u8         reserved_at_68[0x1];
+       u8         control_progress[0x7];
+       u8         error_code[0x8];
+       u8         reserved_at_78[0x4];
+       u8         control_state[0x4];
+
+       u8         component_size[0x20];
+
+       u8         reserved_at_a0[0x60];
+};
+
+struct mlx5_ifc_mcda_reg_bits {
+       u8         reserved_at_0[0x8];
+       u8         update_handle[0x18];
+
+       u8         offset[0x20];
+
+       u8         reserved_at_40[0x10];
+       u8         size[0x10];
+
+       u8         reserved_at_60[0x20];
+
+       u8         data[0][0x20];
+};
+
 union mlx5_ifc_ports_control_registers_document_bits {
        struct mlx5_ifc_ib_portcntrs_attribute_grp_data_bits 
ib_portcntrs_attribute_grp_data;
        struct mlx5_ifc_bufferx_reg_bits bufferx_reg;
_______________________________________________
svn-src-all@freebsd.org mailing list
https://lists.freebsd.org/mailman/listinfo/svn-src-all
To unsubscribe, send any mail to "svn-src-all-unsubscr...@freebsd.org"

Reply via email to