On Mon, 21 Oct 2019 01:34:26 -0400, Michael Chan wrote:
> diff --git a/drivers/net/ethernet/broadcom/bnxt/bnxt_devlink.c 
> b/drivers/net/ethernet/broadcom/bnxt/bnxt_devlink.c
> index 68f74f5..bd4b9f3 100644
> --- a/drivers/net/ethernet/broadcom/bnxt/bnxt_devlink.c
> +++ b/drivers/net/ethernet/broadcom/bnxt/bnxt_devlink.c
> @@ -226,12 +226,55 @@ static const struct bnxt_dl_nvm_param nvm_params[] = {
>        BNXT_NVM_SHARED_CFG, 1, 1},
>  };
>  
> +union bnxt_nvm_data {
> +     u8      val8;
> +     __le32  val32;
> +};
> +
> +static void bnxt_copy_to_nvm_data(union bnxt_nvm_data *dst,
> +                               union devlink_param_value *src,
> +                               int nvm_num_bits, int dl_num_bytes)
> +{
> +     u32 val32 = 0;
> +
> +     if (nvm_num_bits == 1) {
> +             dst->val8 = src->vbool;
> +             return;
> +     }

Why do you special case the num_bits == 1? If val32 is __le32 the low
byte would have landed on the first byte anyway, no? 🤔

just curious

> +     if (dl_num_bytes == 4)
> +             val32 = src->vu32;
> +     else if (dl_num_bytes == 2)
> +             val32 = (u32)src->vu16;
> +     else if (dl_num_bytes == 1)
> +             val32 = (u32)src->vu8;
> +     dst->val32 = cpu_to_le32(val32);
> +}

Reply via email to