Hi Adrian, thanks again for submitting this patch. I got two comments
off-list. Sharing them here.

On Fri, Jul 31, 2020 at 11:47:25AM +0300, Adrian Pop wrote:
> +/**
> + * Print the cable assembly length, for both passive copper and active
> + * optical or electrical cables. The base length (bits 5-0) must be
> + * multiplied with the SMF length multiplier (bits 7-6) to obtain the
> + * correct value. Relevant documents:
> + * [1] CMIS Rev. 3, pag. 59, section 1.7.3.10, Table 31
> + * [2] CMIS Rev. 4, pag. 94, section 8.3.10, Table 8-19
> + */
> +static void qsfp_dd_show_cbl_asm_len(const __u8 *id)
> +{
> +     static const char *fn = "Cable assembly length";
> +     float mul = 1.0f;
> +     float val = 0.0f;
> +
> +     /* Check if max length */
> +     if (id[QSFP_DD_CBL_ASM_LEN_OFFSET] == QSFP_DD_6300M_MAX_LEN) {
> +             printf("\t%-41s : > 6.3km\n", fn);
> +             return;
> +     }
> +
> +     /* Get the multiplier from the first two bits */
> +     switch (id[QSFP_DD_CBL_ASM_LEN_OFFSET] & QSFP_DD_LEN_MUL_MASK) {
> +     case QSFP_DD_MULTIPLIER_00:
> +             mul = 0.1f;
> +             break;
> +     case QSFP_DD_MULTIPLIER_01:
> +             mul = 1.0f;
> +             break;
> +     case QSFP_DD_MULTIPLIER_10:
> +             mul = 10.0f;
> +             break;
> +     case QSFP_DD_MULTIPLIER_11:
> +             mul = 100.0f;
> +             break;
> +     default:
> +             break;
> +     }
> +
> +     /* Get base value from first 6 bits and multiply by mul */
> +     val = (id[QSFP_DD_CBL_ASM_LEN_OFFSET] & QSFP_DD_LEN_VAL_MASK);
> +     val = (float)val * mul;
> +     printf("\t%-41s : %0.2fkm\n", fn, val);

Should be:

printf("\t%-41s : %0.2fm\n", fn, val);

Since the specification says "Link length base value in meters".

Before:

        Cable assembly length                     : 0.50km

After:

        Cable assembly length                     : 0.50m

> +}

...

> diff --git a/qsfp-dd.h b/qsfp-dd.h
> new file mode 100644
> index 0000000..a7a7051
> --- /dev/null
> +++ b/qsfp-dd.h
> @@ -0,0 +1,236 @@
> +#ifndef QSFP_DD_H__
> +#define QSFP_DD_H__
> +
> +#define QSFP_DD_PAG_SIZE                     0x80
> +#define QSFP_DD_EEPROM_5PAG                  (0x80 * 6)
> +#define QSFP_DD_MAX_CHANNELS                 0x08
> +#define QSFP_DD_MAX_DESC_SIZE                        0x2A
> +#define QSFP_DD_READ_TX                              0x00
> +#define QSFP_DD_READ_RX                              0x01
> +
> +/* Struct for the current/power of a channel */
> +struct qsfp_dd_channel_diags {
> +     __u16 bias_cur;
> +     __u16 rx_power;
> +     __u16 tx_power;
> +};
> +
> +struct qsfp_dd_diags {
> +     /* Voltage in 0.1mV units; the first 4 elements represent
> +      * the high/low alarm, high/low warning and the last one
> +      * represent the current voltage of the module.
> +      */
> +     __u16 sfp_voltage[4];
> +
> +     /**
> +      * Temperature in 16-bit signed 1/256 Celsius; the first 4
> +      * elements represent the high/low alarm, high/low warning
> +      * and the last one represent the current temp of the module.
> +      */
> +     __s16 sfp_temp[4];
> +
> +     /* Tx bias current in 2uA units */
> +     __u16 bias_cur[4];
> +
> +     /* Measured TX Power */
> +     __u16 tx_power[4];
> +
> +     /* Measured RX Power */
> +     __u16 rx_power[4];
> +
> +     /* Rx alarms and warnings */
> +     bool rxaw[QSFP_DD_MAX_CHANNELS][4];
> +
> +     /* Tx alarms and warnings */
> +     bool txaw[QSFP_DD_MAX_CHANNELS][4];
> +
> +     struct qsfp_dd_channel_diags scd[QSFP_DD_MAX_CHANNELS];
> +};
> +
> +#define HA                                   0
> +#define LA                                   1
> +#define HW                                   2
> +#define LW                                   3
> +
> +/* Identifier and revision compliance (Page 0) */
> +#define      QSFP_DD_ID_OFFSET                       0x00
> +#define QSFP_DD_REV_COMPLIANCE_OFFSET                0x01
> +
> +#define QSFP_DD_MODULE_TYPE_OFFSET           0x55
> +#define QSFP_DD_MT_MMF                               0x01
> +#define QSFP_DD_MT_SMF                               0x02
> +
> +/* Module-Level Monitors (Page 0) */
> +#define QSFP_DD_CURR_TEMP_OFFSET             0x0E
> +#define QSFP_DD_CURR_CURR_OFFSET             0x10
> +
> +#define QSFP_DD_CTOR_OFFSET                  0xCB
> +
> +/* Vendor related information (Page 0) */
> +#define QSFP_DD_VENDOR_NAME_START_OFFSET     0x81
> +#define QSFP_DD_VENDOR_NAME_END_OFFSET               0x90
> +
> +#define QSFP_DD_VENDOR_OUI_OFFSET            0x91
> +
> +#define QSFP_DD_VENDOR_PN_START_OFFSET               0x94
> +#define QSFP_DD_VENDOR_PN_END_OFFSET         0xA3
> +
> +#define QSFP_DD_VENDOR_REV_START_OFFSET              0xA4
> +#define QSFP_DD_VENDOR_REV_END_OFFSET                0xA5
> +
> +#define QSFP_DD_VENDOR_SN_START_OFFSET               0xA6
> +#define QSFP_DD_VENDOR_SN_END_OFFSET         0xB5
> +
> +#define QSFP_DD_DATE_YEAR_OFFSET             0xB6
> +#define QSFP_DD_DATE_VENDOR_LOT_OFFSET               0xBD

According to the specification (section 8.3.7), the offset is 188, so
should be 0xBC.

Before:

        Date code                                 : 200507  _

After:

        Date code                                 : 200507

Reply via email to