• B
    qmi_wwan/cdc_ether: let qmi_wwan handle the Huawei E1820 · c2020be3
    Bjørn Mork 提交于
    Another QMI speaking Qualcomm based device, which should be
    driven by qmi_wwan, while cdc_ether should ignore it.
    
    Like on other Huawei devices, the wwan function can appear
    either as a single vendor specific interface or as a CDC ECM
    class function using separate control and data interfaces.
    The ECM control interface protocol is 0xff, likely in an
    attempt to indicate that vendor specific management is
    required.
    
    In addition to the near standard CDC class, Huawei also add
    vendor specific AT management commands to their firmwares.
    This is probably an attempt to support non-Windows systems
    using standard class drivers.  Unfortunately, this part of
    the firmware is often buggy.  Linux is much better off using
    whatever native vendor specific management protocol the
    device offers, and Windows uses, whenever possible. This
    means QMI in the case of Qualcomm based devices.
    
    The E1820 has been verified to work fine with QMI.
    
    Matching on interface number is necessary to distiguish the
    wwan function from serial functions in the single interface
    mode, as both function types will have class/subclass/function
    set to ff/ff/ff.
    
    The control interface number does not change in CDC ECM mode,
    so the interface number matching rule is sufficient to handle
    both modes.  The cdc_ether blacklist entry is only relevant in
    CDC ECM mode, but using a similar interface number based rule
    helps document this as a transfer from one driver to another.
    
    Other Huawei 02/06/ff devices are left with the cdc_ether driver
    because we do not know whether they are based on Qualcomm chips.
    The Huawei specific AT command management is known to be somewhat
    hardware independent, and their usage of these class codes may
    also be independent of the modem hardware.
    Reported-by: NGraham Inggs <graham.inggs@uct.ac.za>
    Signed-off-by: NBjørn Mork <bjorn@mork.no>
    Signed-off-by: NDavid S. Miller <davem@davemloft.net>
    c2020be3
qmi_wwan.c 24.1 KB