Skip to content
  1. Feb 06, 2023
  2. Jan 24, 2023
    • Greg Kroah-Hartman's avatar
    • YingChi Long's avatar
      x86/fpu: Use _Alignof to avoid undefined behavior in TYPE_ALIGN · 67c6d797
      YingChi Long authored
      commit 55228db2 upstream.
      
      WG14 N2350 specifies that it is an undefined behavior to have type
      definitions within offsetof", see
      
        https://www.open-std.org/jtc1/sc22/wg14/www/docs/n2350.htm
      
      
      
      This specification is also part of C23.
      
      Therefore, replace the TYPE_ALIGN macro with the _Alignof builtin to
      avoid undefined behavior. (_Alignof itself is C11 and the kernel is
      built with -gnu11).
      
      ISO C11 _Alignof is subtly different from the GNU C extension
      __alignof__. Latter is the preferred alignment and _Alignof the
      minimal alignment. For long long on x86 these are 8 and 4
      respectively.
      
      The macro TYPE_ALIGN's behavior matches _Alignof rather than
      __alignof__.
      
        [ bp: Massage commit message. ]
      
      Signed-off-by: default avatarYingChi Long <me@inclyc.cn>
      Signed-off-by: default avatarBorislav Petkov <bp@suse.de>
      Reviewed-by: default avatarNick Desaulniers <ndesaulniers@google.com>
      Link: https://lore.kernel.org/r/20220925153151.2467884-1-me@inclyc.cn
      
      
      Signed-off-by: default avatarNathan Chancellor <nathan@kernel.org>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      67c6d797
    • Khazhismel Kumykov's avatar
      gsmi: fix null-deref in gsmi_get_variable · ee5763ef
      Khazhismel Kumykov authored
      commit a769b05e upstream.
      
      We can get EFI variables without fetching the attribute, so we must
      allow for that in gsmi.
      
      commit 85974825 ("efi: pstore: Omit efivars caching EFI varstore
      access layer") added a new get_variable call with attr=NULL, which
      triggers panic in gsmi.
      
      Fixes: 74c5b31c
      
       ("driver: Google EFI SMI")
      Cc: stable <stable@kernel.org>
      Signed-off-by: default avatarKhazhismel Kumykov <khazhy@google.com>
      Link: https://lore.kernel.org/r/20230118010212.1268474-1-khazhy@google.com
      
      
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      ee5763ef
    • Tobias Schramm's avatar
      serial: atmel: fix incorrect baudrate setup · 31fa3c5c
      Tobias Schramm authored
      commit 5bfdd3c6 upstream.
      
      Commit ba47f97a ("serial: core: remove baud_rates when serial console
      setup") changed uart_set_options to select the correct baudrate
      configuration based on the absolute error between requested baudrate and
      available standard baudrate settings.
      Prior to that commit the baudrate was selected based on which predefined
      standard baudrate did not exceed the requested baudrate.
      This change of selection logic was never reflected in the atmel serial
      driver. Thus the comment left in the atmel serial driver is no longer
      accurate.
      Additionally the manual rounding up described in that comment and applied
      via (quot - 1) requests an incorrect baudrate. Since uart_set_options uses
      tty_termios_encode_baud_rate to determine the appropriate baudrate flags
      this can cause baudrate selection to fail entirely because
      tty_termios_encode_baud_rate will only select a baudrate if relative error
      between requested and selected baudrate does not exceed +/-2%.
      Fix that by requesting actual, exact baudrate used by the serial.
      
      Fixes: ba47f97a
      
       ("serial: core: remove baud_rates when serial console setup")
      Cc: stable <stable@kernel.org>
      Signed-off-by: default avatarTobias Schramm <t.schramm@manjaro.org>
      Acked-by: default avatarRichard Genoud <richard.genoud@gmail.com>
      Link: https://lore.kernel.org/r/20230109072940.202936-1-t.schramm@manjaro.org
      
      
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      31fa3c5c
    • Ilpo Järvinen's avatar
      serial: pch_uart: Pass correct sg to dma_unmap_sg() · 2fb5b94b
      Ilpo Järvinen authored
      commit e8914b52 upstream.
      
      A local variable sg is used to store scatterlist pointer in
      pch_dma_tx_complete(). The for loop doing Tx byte accounting before
      dma_unmap_sg() alters sg in its increment statement. Therefore, the
      pointer passed into dma_unmap_sg() won't match to the one given to
      dma_map_sg().
      
      To fix the problem, use priv->sg_tx_p directly in dma_unmap_sg()
      instead of the local variable.
      
      Fixes: da3564ee
      
       ("pch_uart: add multi-scatter processing")
      Cc: stable@vger.kernel.org
      Signed-off-by: default avatarIlpo Järvinen <ilpo.jarvinen@linux.intel.com>
      Link: https://lore.kernel.org/r/20230103093435.4396-1-ilpo.jarvinen@linux.intel.com
      
      
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      2fb5b94b
    • Juhyung Park's avatar
      usb-storage: apply IGNORE_UAS only for HIKSEMI MD202 on RTL9210 · 8334e787
      Juhyung Park authored
      commit dbd24ec1 upstream.
      
      The commit e00b488e ("usb-storage: Add Hiksemi USB3-FW to IGNORE_UAS")
      blacklists UAS for all of RTL9210 enclosures.
      
      The RTL9210 controller was advertised with UAS since its release back in
      2019 and was shipped with a lot of enclosure products with different
      firmware combinations.
      
      Blacklist UAS only for HIKSEMI MD202.
      
      This should hopefully be replaced with more robust method than just
      comparing strings.  But with limited information [1] provided thus far
      (dmesg when the device is plugged in, which includes manufacturer and
      product, but no lsusb -v to compare against), this is the best we can do
      for now.
      
      [1] https://lore.kernel.org/all/20230109115550.71688-1-qkrwngud825@gmail.com
      
      Fixes: e00b488e
      
       ("usb-storage: Add Hiksemi USB3-FW to IGNORE_UAS")
      Cc: Alan Stern <stern@rowland.harvard.edu>
      Cc: Hongling Zeng <zenghongling@kylinos.cn>
      Cc: stable@vger.kernel.org
      Signed-off-by: default avatarJuhyung Park <qkrwngud825@gmail.com>
      Acked-by: default avatarOliver Neukum <oneukum@suse.com>
      Link: https://lore.kernel.org/r/20230117085154.123301-1-qkrwngud825@gmail.com
      
      
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      8334e787
    • Maciej Żenczykowski's avatar
      usb: gadget: f_ncm: fix potential NULL ptr deref in ncm_bitrate() · fef6b296
      Maciej Żenczykowski authored
      commit c6ec9295 upstream.
      
      In Google internal bug 265639009 we've received an (as yet) unreproducible
      crash report from an aarch64 GKI 5.10.149-android13 running device.
      
      AFAICT the source code is at:
        https://android.googlesource.com/kernel/common/+/refs/tags/ASB-2022-12-05_13-5.10
      
      
      
      The call stack is:
        ncm_close() -> ncm_notify() -> ncm_do_notify()
      with the crash at:
        ncm_do_notify+0x98/0x270
      Code: 79000d0b b9000a6c f940012a f9400269 (b9405d4b)
      
      Which I believe disassembles to (I don't know ARM assembly, but it looks sane enough to me...):
      
        // halfword (16-bit) store presumably to event->wLength (at offset 6 of struct usb_cdc_notification)
        0B 0D 00 79    strh w11, [x8, #6]
      
        // word (32-bit) store presumably to req->Length (at offset 8 of struct usb_request)
        6C 0A 00 B9    str  w12, [x19, #8]
      
        // x10 (NULL) was read here from offset 0 of valid pointer x9
        // IMHO we're reading 'cdev->gadget' and getting NULL
        // gadget is indeed at offset 0 of struct usb_composite_dev
        2A 01 40 F9    ldr  x10, [x9]
      
        // loading req->buf pointer, which is at offset 0 of struct usb_request
        69 02 40 F9    ldr  x9, [x19]
      
        // x10 is null, crash, appears to be attempt to read cdev->gadget->max_speed
        4B 5D 40 B9    ldr  w11, [x10, #0x5c]
      
      which seems to line up with ncm_do_notify() case NCM_NOTIFY_SPEED code fragment:
      
        event->wLength = cpu_to_le16(8);
        req->length = NCM_STATUS_BYTECOUNT;
      
        /* SPEED_CHANGE data is up/down speeds in bits/sec */
        data = req->buf + sizeof *event;
        data[0] = cpu_to_le32(ncm_bitrate(cdev->gadget));
      
      My analysis of registers and NULL ptr deref crash offset
        (Unable to handle kernel NULL pointer dereference at virtual address 000000000000005c)
      heavily suggests that the crash is due to 'cdev->gadget' being NULL when executing:
        data[0] = cpu_to_le32(ncm_bitrate(cdev->gadget));
      which calls:
        ncm_bitrate(NULL)
      which then calls:
        gadget_is_superspeed(NULL)
      which reads
        ((struct usb_gadget *)NULL)->max_speed
      and hits a panic.
      
      AFAICT, if I'm counting right, the offset of max_speed is indeed 0x5C.
      (remember there's a GKI KABI reservation of 16 bytes in struct work_struct)
      
      It's not at all clear to me how this is all supposed to work...
      but returning 0 seems much better than panic-ing...
      
      Cc: Felipe Balbi <balbi@kernel.org>
      Cc: Lorenzo Colitti <lorenzo@google.com>
      Cc: Carlos Llamas <cmllamas@google.com>
      Cc: stable@vger.kernel.org
      Signed-off-by: default avatarMaciej Żenczykowski <maze@google.com>
      Cc: stable <stable@kernel.org>
      Link: https://lore.kernel.org/r/20230117131839.1138208-1-maze@google.com
      
      
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      fef6b296
    • Daniel Scally's avatar
      usb: gadget: g_webcam: Send color matching descriptor per frame · ea6f2a3b
      Daniel Scally authored
      commit e95765e9 upstream.
      
      Currently the color matching descriptor is only sent across the wire
      a single time, following the descriptors for each format and frame.
      According to the UVC 1.5 Specification 3.9.2.6 ("Color Matching
      Descriptors"):
      
      "Only one instance is allowed for a given format and if present,
      the Color Matching descriptor shall be placed following the Video
      and Still Image Frame descriptors for that format".
      
      Add another reference to the color matching descriptor after the
      yuyv frames so that it's correctly transmitted for that format
      too.
      
      Fixes: a9914127
      
       ("USB gadget: Webcam device")
      Cc: stable <stable@kernel.org>
      Signed-off-by: default avatarDaniel Scally <dan.scally@ideasonboard.com>
      Reviewed-by: default avatarLaurent Pinchart <laurent.pinchart@ideasonboard.com>
      Reviewed-by: default avatarKieran Bingham <kieran.bingham@ideasonboard.com>
      Link: https://lore.kernel.org/r/20221216160528.479094-1-dan.scally@ideasonboard.com
      
      
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      ea6f2a3b
    • Alexander Stein's avatar
      usb: host: ehci-fsl: Fix module alias · b392b477
      Alexander Stein authored
      commit 5d3d01ae upstream.
      
      Commit ca07e1c1 ("drivers:usb:fsl:Make fsl ehci drv an independent
      driver module") changed DRV_NAME which was used for MODULE_ALIAS as well.
      Starting from this the module alias didn't match the platform device
      name created in fsl-mph-dr-of.c
      Change DRV_NAME to match the driver name for host mode in fsl-mph-dr-of.
      This is needed for module autoloading on ls1021a.
      
      Fixes: ca07e1c1
      
       ("drivers:usb:fsl:Make fsl ehci drv an independent driver module")
      Cc: stable <stable@kernel.org>
      Signed-off-by: default avatarAlexander Stein <alexander.stein@ew.tq-group.com>
      Link: https://lore.kernel.org/r/20230120122714.3848784-1-alexander.stein@ew.tq-group.com
      
      
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      b392b477
    • Michael Adler's avatar
      USB: serial: cp210x: add SCALANCE LPE-9000 device id · 371c694e
      Michael Adler authored
      commit 3f9e76e3
      
       upstream.
      
      Add the USB serial console device ID for Siemens SCALANCE LPE-9000
      which have a USB port for their serial console.
      
      Signed-off-by: default avatarMichael Adler <michael.adler@siemens.com>
      Cc: stable@vger.kernel.org
      Signed-off-by: default avatarJohan Hovold <johan@kernel.org>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      371c694e
    • Flavio Suligoi's avatar
      usb: core: hub: disable autosuspend for TI TUSB8041 · 4aed7b3c
      Flavio Suligoi authored
      commit 7171b0e2
      
       upstream.
      
      The Texas Instruments TUSB8041 has an autosuspend problem at high
      temperature.
      
      If there is not USB traffic, after a couple of ms, the device enters in
      autosuspend mode. In this condition the external clock stops working, to
      save energy. When the USB activity turns on, ther hub exits the
      autosuspend state, the clock starts running again and all works fine.
      
      At ambient temperature all works correctly, but at high temperature,
      when the USB activity turns on, the external clock doesn't restart and
      the hub disappears from the USB bus.
      
      Disabling the autosuspend mode for this hub solves the issue.
      
      Signed-off-by: default avatarFlavio Suligoi <f.suligoi@asem.it>
      Cc: stable <stable@kernel.org>
      Acked-by: default avatarAlan Stern <stern@rowland.harvard.edu>
      Link: https://lore.kernel.org/r/20221219124759.3207032-1-f.suligoi@asem.it
      
      
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      4aed7b3c
    • Greg Kroah-Hartman's avatar
      USB: misc: iowarrior: fix up header size for USB_DEVICE_ID_CODEMERCS_IOW100 · 996952e9
      Greg Kroah-Hartman authored
      commit 14ff7460 upstream.
      
      The USB_DEVICE_ID_CODEMERCS_IOW100 header size was incorrect, it should
      be 12, not 13.
      
      Cc: stable <stable@kernel.org>
      Fixes: 17a82716
      
       ("USB: iowarrior: fix up report size handling for some devices")
      Reported-by: default avatarChristoph Jung <jung@codemercs.com>
      Link: https://lore.kernel.org/r/20230120135330.3842518-1-gregkh@linuxfoundation.org
      
      
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      996952e9
    • Duke Xin(辛安文)'s avatar
      USB: serial: option: add Quectel EM05CN modem · b67375c6
      Duke Xin(辛安文) authored
      commit 71dfd381
      
       upstream.
      
      The EM05CN modem has 2 USB configurations that are configurable via the AT
      command AT+QCFG="usbnet",[ 0 | 2 ] which make the modem enumerate with
      the following interfaces, respectively:
      
      "MBIM"  : AT + MBIM + DIAG + NMEA  + MODEM
      "RMNET" : AT + DIAG + NMEA + Modem + QMI
      
      The detailed description of the USB configuration for each mode as follows:
      
      MBIM Mode
      --------------
      T:  Bus=01 Lev=01 Prnt=01 Port=00 Cnt=01 Dev#=  2 Spd=480  MxCh= 0
      D:  Ver= 2.00 Cls=ef(misc ) Sub=02 Prot=01 MxPS=64 #Cfgs=  1
      P:  Vendor=2c7c ProdID=0312 Rev= 3.18
      S:  Manufacturer=Quectel
      S:  Product=Quectel EM05-CN
      C:* #Ifs= 6 Cfg#= 1 Atr=a0 MxPwr=500mA
      A:  FirstIf#= 1 IfCount= 2 Cls=02(comm.) Sub=0e Prot=00
      I:* If#= 3 Alt= 0 #EPs= 2 Cls=ff(vend.) Sub=ff Prot=ff Driver=option
      E:  Ad=81(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=01(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 4 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=83(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=82(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=02(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 0 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=85(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=84(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=03(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 5 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=87(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=86(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=04(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 1 Alt= 0 #EPs= 1 Cls=02(comm.) Sub=0e Prot=00 Driver=cdc_mbim
      E:  Ad=89(I) Atr=03(Int.) MxPS=  64 Ivl=32ms
      I:  If#= 2 Alt= 0 #EPs= 0 Cls=0a(data ) Sub=00 Prot=02 Driver=cdc_mbim
      I:* If#= 2 Alt= 1 #EPs= 2 Cls=0a(data ) Sub=00 Prot=02 Driver=cdc_mbim
      E:  Ad=88(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=05(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      
      RMNET Mode
      --------------
      T:  Bus=01 Lev=01 Prnt=01 Port=00 Cnt=01 Dev#=  3 Spd=480  MxCh= 0
      D:  Ver= 2.00 Cls=ef(misc ) Sub=02 Prot=01 MxPS=64 #Cfgs=  1
      P:  Vendor=2c7c ProdID=0312 Rev= 3.18
      S:  Manufacturer=Quectel
      S:  Product=Quectel EM05-CN
      C:* #Ifs= 5 Cfg#= 1 Atr=a0 MxPwr=500mA
      I:* If#= 3 Alt= 0 #EPs= 2 Cls=ff(vend.) Sub=ff Prot=ff Driver=option
      E:  Ad=81(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=01(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 4 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=83(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=82(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=02(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 0 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=85(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=84(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=03(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 5 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=87(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=86(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=04(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 6 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=ff Prot=ff Driver=(none)
      E:  Ad=89(I) Atr=03(Int.) MxPS=   8 Ivl=32ms
      E:  Ad=88(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=05(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      
      Signed-off-by: default avatarDuke Xin(辛安文) <duke_xinanwen@163.com>
      Cc: stable@vger.kernel.org
      Signed-off-by: default avatarJohan Hovold <johan@kernel.org>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      b67375c6
    • Duke Xin(辛安文)'s avatar
      USB: serial: option: add Quectel EM05CN (SG) modem · 6e0c0330
      Duke Xin(辛安文) authored
      commit 1541dd00
      
       upstream.
      
      The EM05CN (SG) modem has 2 USB configurations that are configurable via the AT
      command AT+QCFG="usbnet",[ 0 | 2 ] which make the modem enumerate with
      the following interfaces, respectively:
      
      "MBIM"  : AT + MBIM + DIAG + NMEA  + MODEM
      "RMNET" : AT + DIAG + NMEA + Modem + QMI
      
      The detailed description of the USB configuration for each mode as follows:
      
      MBIM Mode
      --------------
      T:  Bus=01 Lev=01 Prnt=01 Port=00 Cnt=01 Dev#=  2 Spd=480  MxCh= 0
      D:  Ver= 2.00 Cls=ef(misc ) Sub=02 Prot=01 MxPS=64 #Cfgs=  1
      P:  Vendor=2c7c ProdID=0310 Rev= 3.18
      S:  Manufacturer=Quectel
      S:  Product=Quectel EM05-CN
      C:* #Ifs= 6 Cfg#= 1 Atr=a0 MxPwr=500mA
      A:  FirstIf#= 1 IfCount= 2 Cls=02(comm.) Sub=0e Prot=00
      I:* If#= 3 Alt= 0 #EPs= 2 Cls=ff(vend.) Sub=ff Prot=ff Driver=option
      E:  Ad=81(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=01(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 4 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=83(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=82(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=02(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 0 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=85(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=84(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=03(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 5 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=87(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=86(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=04(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 1 Alt= 0 #EPs= 1 Cls=02(comm.) Sub=0e Prot=00 Driver=cdc_mbim
      E:  Ad=89(I) Atr=03(Int.) MxPS=  64 Ivl=32ms
      I:  If#= 2 Alt= 0 #EPs= 0 Cls=0a(data ) Sub=00 Prot=02 Driver=cdc_mbim
      I:* If#= 2 Alt= 1 #EPs= 2 Cls=0a(data ) Sub=00 Prot=02 Driver=cdc_mbim
      E:  Ad=88(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=05(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      
      RMNET Mode
      --------------
      T:  Bus=01 Lev=01 Prnt=01 Port=00 Cnt=01 Dev#=  3 Spd=480  MxCh= 0
      D:  Ver= 2.00 Cls=ef(misc ) Sub=02 Prot=01 MxPS=64 #Cfgs=  1
      P:  Vendor=2c7c ProdID=0310 Rev= 3.18
      S:  Manufacturer=Quectel
      S:  Product=Quectel EM05-CN
      C:* #Ifs= 5 Cfg#= 1 Atr=a0 MxPwr=500mA
      I:* If#= 3 Alt= 0 #EPs= 2 Cls=ff(vend.) Sub=ff Prot=ff Driver=option
      E:  Ad=81(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=01(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 4 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=83(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=82(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=02(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 0 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=85(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=84(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=03(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 5 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=87(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=86(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=04(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 6 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=ff Prot=ff Driver=(none)
      E:  Ad=89(I) Atr=03(Int.) MxPS=   8 Ivl=32ms
      E:  Ad=88(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=05(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      
      Signed-off-by: default avatarDuke Xin(辛安文) <duke_xinanwen@163.com>
      Cc: stable@vger.kernel.org
      Signed-off-by: default avatarJohan Hovold <johan@kernel.org>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      6e0c0330
    • Ali Mirghasemi's avatar
      USB: serial: option: add Quectel EC200U modem · 272eb9bc
      Ali Mirghasemi authored
      commit d9bbb158
      
       upstream.
      
      Add support for EC200U modem
      
      0x0901: EC200U - AT + AP + CP + NMEA + DIAG + MOS
      
      usb-device output:
      T: Bus=01 Lev=02 Prnt=02 Port=02 Cnt=01 Dev#= 4 Spd=480 MxCh= 0
      D: Ver= 2.00 Cls=00(>ifc ) Sub=00 Prot=00 MxPS=64 #Cfgs= 1
      P: Vendor=2c7c ProdID=0901 Rev= 3.18
      S: Manufacturer=Android
      S: Product=Android
      C:* #Ifs= 9 Cfg#= 1 Atr=e0 MxPwr=400mA
      A: FirstIf#= 0 IfCount= 2 Cls=02(comm.) Sub=06 Prot=00
      I:* If#= 0 Alt= 0 #EPs= 1 Cls=02(comm.) Sub=06 Prot=00 Driver=cdc_ether
      E: Ad=81(I) Atr=03(Int.) MxPS= 16 Ivl=32ms
      I: If#= 1 Alt= 0 #EPs= 0 Cls=0a(data ) Sub=00 Prot=00 Driver=cdc_ether
      I:* If#= 1 Alt= 1 #EPs= 2 Cls=0a(data ) Sub=00 Prot=00 Driver=cdc_ether
      E: Ad=82(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E: Ad=01(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 2 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E: Ad=84(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E: Ad=02(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E: Ad=83(I) Atr=03(Int.) MxPS= 512 Ivl=4096ms
      I:* If#= 3 Alt= 0 #EPs= 2 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E: Ad=85(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E: Ad=03(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 4 Alt= 0 #EPs= 2 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E: Ad=86(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E: Ad=04(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 5 Alt= 0 #EPs= 2 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E: Ad=87(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E: Ad=05(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 6 Alt= 0 #EPs= 2 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E: Ad=88(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E: Ad=06(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 7 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E: Ad=8a(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E: Ad=07(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E: Ad=89(I) Atr=03(Int.) MxPS= 512 Ivl=4096ms
      I:* If#= 8 Alt= 0 #EPs= 2 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E: Ad=8b(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E: Ad=08(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      
      Signed-off-by: default avatarAli Mirghasemi <ali.mirghasemi1376@gmail.com>
      Cc: stable@vger.kernel.org
      Signed-off-by: default avatarJohan Hovold <johan@kernel.org>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      272eb9bc
    • Duke Xin(辛安文)'s avatar
      USB: serial: option: add Quectel EM05-G (RS) modem · aadce0a9
      Duke Xin(辛安文) authored
      commit b72d1397
      
       upstream.
      
      The EM05-G (RS) modem has 2 USB configurations that are configurable via
      the AT command AT+QCFG="usbnet",[ 0 | 2 ] which make the modem enumerate
      with the following interfaces, respectively:
      
      "RMNET" : AT + DIAG + NMEA + Modem + QMI
      "MBIM"  : MBIM + AT + DIAG + NMEA + Modem
      
      The detailed description of the USB configuration for each mode as follows:
      
      RMNET Mode
      --------------
      T:  Bus=01 Lev=01 Prnt=01 Port=00 Cnt=01 Dev#= 21 Spd=480  MxCh= 0
      D:  Ver= 2.00 Cls=ef(misc ) Sub=02 Prot=01 MxPS=64 #Cfgs=  1
      P:  Vendor=2c7c ProdID=0314 Rev= 3.18
      S:  Manufacturer=Quectel
      S:  Product=Quectel EM05-G
      C:* #Ifs= 5 Cfg#= 1 Atr=a0 MxPwr=500mA
      I:* If#= 3 Alt= 0 #EPs= 2 Cls=ff(vend.) Sub=ff Prot=ff Driver=option
      E:  Ad=81(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=01(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 4 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=83(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=82(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=02(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 2 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=85(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=84(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=03(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 5 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=87(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=86(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=04(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 6 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=ff Prot=ff Driver=(none)
      E:  Ad=89(I) Atr=03(Int.) MxPS=   8 Ivl=32ms
      E:  Ad=88(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=05(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      
      MBIM Mode
      --------------
      T:  Bus=01 Lev=01 Prnt=01 Port=00 Cnt=01 Dev#= 16 Spd=480  MxCh= 0
      D:  Ver= 2.00 Cls=ef(misc ) Sub=02 Prot=01 MxPS=64 #Cfgs=  1
      P:  Vendor=2c7c ProdID=0314 Rev= 3.18
      S:  Manufacturer=Quectel
      S:  Product=Quectel EM05-G
      C:* #Ifs= 6 Cfg#= 1 Atr=a0 MxPwr=500mA
      A:  FirstIf#= 0 IfCount= 2 Cls=02(comm.) Sub=0e Prot=00
      I:* If#= 3 Alt= 0 #EPs= 2 Cls=ff(vend.) Sub=ff Prot=ff Driver=option
      E:  Ad=81(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=01(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 4 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=83(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=82(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=02(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 2 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=85(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=84(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=03(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 5 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=87(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=86(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=04(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 0 Alt= 0 #EPs= 1 Cls=02(comm.) Sub=0e Prot=00 Driver=cdc_mbim
      E:  Ad=89(I) Atr=03(Int.) MxPS=  64 Ivl=32ms
      I:  If#= 1 Alt= 0 #EPs= 0 Cls=0a(data ) Sub=00 Prot=02 Driver=cdc_mbim
      I:* If#= 1 Alt= 1 #EPs= 2 Cls=0a(data ) Sub=00 Prot=02 Driver=cdc_mbim
      E:  Ad=88(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=05(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      
      Signed-off-by: default avatarDuke Xin(辛安文) <duke_xinanwen@163.com>
      Cc: stable@vger.kernel.org
      Signed-off-by: default avatarJohan Hovold <johan@kernel.org>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      aadce0a9
    • Duke Xin(辛安文)'s avatar
      USB: serial: option: add Quectel EM05-G (CS) modem · 48cdeccc
      Duke Xin(辛安文) authored
      commit bb78654b
      
       upstream.
      
      The EM05-G (CS) modem has 2 USB configurations that are configurable via
      the AT command AT+QCFG="usbnet",[ 0 | 2 ] which make the modem enumerate
      with the following interfaces, respectively:
      
      "RMNET" : AT + DIAG + NMEA + Modem + QMI
      "MBIM"  : MBIM + AT + DIAG + NMEA + Modem
      
      The detailed description of the USB configuration for each mode as follows:
      
      RMNET Mode
      --------------
      T:  Bus=01 Lev=01 Prnt=01 Port=00 Cnt=01 Dev#= 21 Spd=480  MxCh= 0
      D:  Ver= 2.00 Cls=ef(misc ) Sub=02 Prot=01 MxPS=64 #Cfgs=  1
      P:  Vendor=2c7c ProdID=030C Rev= 3.18
      S:  Manufacturer=Quectel
      S:  Product=Quectel EM05-G
      C:* #Ifs= 5 Cfg#= 1 Atr=a0 MxPwr=500mA
      I:* If#= 3 Alt= 0 #EPs= 2 Cls=ff(vend.) Sub=ff Prot=ff Driver=option
      E:  Ad=81(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=01(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 4 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=83(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=82(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=02(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 2 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=85(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=84(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=03(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 5 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=87(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=86(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=04(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 6 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=ff Prot=ff Driver=(none)
      E:  Ad=89(I) Atr=03(Int.) MxPS=   8 Ivl=32ms
      E:  Ad=88(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=05(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      
      MBIM Mode
      --------------
      T:  Bus=01 Lev=01 Prnt=01 Port=00 Cnt=01 Dev#= 16 Spd=480  MxCh= 0
      D:  Ver= 2.00 Cls=ef(misc ) Sub=02 Prot=01 MxPS=64 #Cfgs=  1
      P:  Vendor=2c7c ProdID=030C Rev= 3.18
      S:  Manufacturer=Quectel
      S:  Product=Quectel EM05-G
      C:* #Ifs= 6 Cfg#= 1 Atr=a0 MxPwr=500mA
      A:  FirstIf#= 0 IfCount= 2 Cls=02(comm.) Sub=0e Prot=00
      I:* If#= 3 Alt= 0 #EPs= 2 Cls=ff(vend.) Sub=ff Prot=ff Driver=option
      E:  Ad=81(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=01(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 4 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=83(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=82(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=02(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 2 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=85(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=84(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=03(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 5 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=87(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=86(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=04(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 0 Alt= 0 #EPs= 1 Cls=02(comm.) Sub=0e Prot=00 Driver=cdc_mbim
      E:  Ad=89(I) Atr=03(Int.) MxPS=  64 Ivl=32ms
      I:  If#= 1 Alt= 0 #EPs= 0 Cls=0a(data ) Sub=00 Prot=02 Driver=cdc_mbim
      I:* If#= 1 Alt= 1 #EPs= 2 Cls=0a(data ) Sub=00 Prot=02 Driver=cdc_mbim
      E:  Ad=88(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=05(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      
      Signed-off-by: default avatarDuke Xin(辛安文) <duke_xinanwen@163.com>
      Cc: stable@vger.kernel.org
      Signed-off-by: default avatarJohan Hovold <johan@kernel.org>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      48cdeccc
    • Duke Xin(辛安文)'s avatar
      USB: serial: option: add Quectel EM05-G (GR) modem · f64feed6
      Duke Xin(辛安文) authored
      commit 6c331f32
      
       upstream.
      
      The EM05-G (GR) modem has 2 USB configurations that are configurable via
      the AT command AT+QCFG="usbnet",[ 0 | 2 ] which make the modem enumerate
      with the following interfaces, respectively:
      
      "RMNET" : AT + DIAG + NMEA + Modem + QMI
      "MBIM"  : MBIM + AT + DIAG + NMEA + Modem
      
      The detailed description of the USB configuration for each mode as follows:
      
      RMNET Mode
      --------------
      T:  Bus=01 Lev=01 Prnt=01 Port=00 Cnt=01 Dev#= 21 Spd=480  MxCh= 0
      D:  Ver= 2.00 Cls=ef(misc ) Sub=02 Prot=01 MxPS=64 #Cfgs=  1
      P:  Vendor=2c7c ProdID=0313 Rev= 3.18
      S:  Manufacturer=Quectel
      S:  Product=Quectel EM05-G
      C:* #Ifs= 5 Cfg#= 1 Atr=a0 MxPwr=500mA
      I:* If#= 3 Alt= 0 #EPs= 2 Cls=ff(vend.) Sub=ff Prot=ff Driver=option
      E:  Ad=81(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=01(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 4 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=83(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=82(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=02(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 2 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=85(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=84(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=03(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 5 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=87(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=86(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=04(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 6 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=ff Prot=ff Driver=(none)
      E:  Ad=89(I) Atr=03(Int.) MxPS=   8 Ivl=32ms
      E:  Ad=88(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=05(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      
      MBIM Mode
      --------------
      T:  Bus=01 Lev=01 Prnt=01 Port=00 Cnt=01 Dev#= 16 Spd=480  MxCh= 0
      D:  Ver= 2.00 Cls=ef(misc ) Sub=02 Prot=01 MxPS=64 #Cfgs=  1
      P:  Vendor=2c7c ProdID=0313 Rev= 3.18
      S:  Manufacturer=Quectel
      S:  Product=Quectel EM05-G
      C:* #Ifs= 6 Cfg#= 1 Atr=a0 MxPwr=500mA
      A:  FirstIf#= 0 IfCount= 2 Cls=02(comm.) Sub=0e Prot=00
      I:* If#= 3 Alt= 0 #EPs= 2 Cls=ff(vend.) Sub=ff Prot=ff Driver=option
      E:  Ad=81(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=01(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 4 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=83(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=82(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=02(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 2 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=85(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=84(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=03(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 5 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
      E:  Ad=87(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
      E:  Ad=86(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=04(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      I:* If#= 0 Alt= 0 #EPs= 1 Cls=02(comm.) Sub=0e Prot=00 Driver=cdc_mbim
      E:  Ad=89(I) Atr=03(Int.) MxPS=  64 Ivl=32ms
      I:  If#= 1 Alt= 0 #EPs= 0 Cls=0a(data ) Sub=00 Prot=02 Driver=cdc_mbim
      I:* If#= 1 Alt= 1 #EPs= 2 Cls=0a(data ) Sub=00 Prot=02 Driver=cdc_mbim
      E:  Ad=88(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      E:  Ad=05(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
      
      Signed-off-by: default avatarDuke Xin(辛安文) <duke_xinanwen@163.com>
      Cc: stable@vger.kernel.org
      Signed-off-by: default avatarJohan Hovold <johan@kernel.org>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      f64feed6
    • Greg Kroah-Hartman's avatar
      prlimit: do_prlimit needs to have a speculation check · 291a0395
      Greg Kroah-Hartman authored
      commit 73979060
      
       upstream.
      
      do_prlimit() adds the user-controlled resource value to a pointer that
      will subsequently be dereferenced.  In order to help prevent this
      codepath from being used as a spectre "gadget" a barrier needs to be
      added after checking the range.
      
      Reported-by: default avatarJordy Zomer <jordyzomer@google.com>
      Tested-by: default avatarJordy Zomer <jordyzomer@google.com>
      Suggested-by: default avatarLinus Torvalds <torvalds@linuxfoundation.org>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      291a0395
    • Jimmy Hu's avatar
      usb: xhci: Check endpoint is valid before dereferencing it · 375be2dd
      Jimmy Hu authored
      commit e8fb5bc7 upstream.
      
      When the host controller is not responding, all URBs queued to all
      endpoints need to be killed. This can cause a kernel panic if we
      dereference an invalid endpoint.
      
      Fix this by using xhci_get_virt_ep() helper to find the endpoint and
      checking if the endpoint is valid before dereferencing it.
      
      [233311.853271] xhci-hcd xhci-hcd.1.auto: xHCI host controller not responding, assume dead
      [233311.853393] Unable to handle kernel NULL pointer dereference at virtual address 00000000000000e8
      
      [233311.853964] pc : xhci_hc_died+0x10c/0x270
      [233311.853971] lr : xhci_hc_died+0x1ac/0x270
      
      [233311.854077] Call trace:
      [233311.854085]  xhci_hc_died+0x10c/0x270
      [233311.854093]  xhci_stop_endpoint_command_watchdog+0x100/0x1a4
      [233311.854105]  call_timer_fn+0x50/0x2d4
      [233311.854112]  expire_timers+0xac/0x2e4
      [233311.854118]  run_timer_softirq+0x300/0xabc
      [233311.854127]  __do_softirq+0x148/0x528
      [233311.854135]  irq_exit+0x194/0x1a8
      [233311.854143]  __handle_domain_irq+0x164/0x1d0
      [233311.854149]  gic_handle_irq.22273+0x10c/0x188
      [233311.854156]  el1_irq+0xfc/0x1a8
      [233311.854175]  lpm_cpuidle_enter+0x25c/0x418 [msm_pm]
      [233311.854185]  cpuidle_enter_state+0x1f0/0x764
      [233311.854194]  do_idle+0x594/0x6ac
      [233311.854201]  cpu_startup_entry+0x7c/0x80
      [233311.854209]  secondary_start_kernel+0x170/0x198
      
      Fixes: 50e8725e
      
       ("xhci: Refactor command watchdog and fix split string.")
      Cc: stable@vger.kernel.org
      Signed-off-by: default avatarJimmy Hu <hhhuuu@google.com>
      Signed-off-by: default avatarMathias Nyman <mathias.nyman@linux.intel.com>
      Message-ID: <0fe978ed-8269-9774-1c40-f8a98c17e838@linux.intel.com>
      Link: https://lore.kernel.org/r/20230116142216.1141605-3-mathias.nyman@linux.intel.com
      
      
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      375be2dd
    • Ricardo Ribalda's avatar
      xhci-pci: set the dma max_seg_size · 44f4b348
      Ricardo Ribalda authored
      commit 93915a41
      
       upstream.
      
      Allow devices to have dma operations beyond 64K, and avoid warnings such
      as:
      
      xhci_hcd 0000:00:14.0: mapping sg segment longer than device claims to support [len=98304] [max=65536]
      
      Cc: stable@vger.kernel.org
      Cc: Takashi Iwai <tiwai@suse.de>
      Signed-off-by: default avatarRicardo Ribalda <ribalda@chromium.org>
      Signed-off-by: default avatarMathias Nyman <mathias.nyman@linux.intel.com>
      Link: https://lore.kernel.org/r/20230116142216.1141605-2-mathias.nyman@linux.intel.com
      
      
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      44f4b348
    • Ryusuke Konishi's avatar
      nilfs2: fix general protection fault in nilfs_btree_insert() · 3c2a2ff6
      Ryusuke Konishi authored
      commit 7633355e upstream.
      
      If nilfs2 reads a corrupted disk image and tries to reads a b-tree node
      block by calling __nilfs_btree_get_block() against an invalid virtual
      block address, it returns -ENOENT because conversion of the virtual block
      address to a disk block address fails.  However, this return value is the
      same as the internal code that b-tree lookup routines return to indicate
      that the block being searched does not exist, so functions that operate on
      that b-tree may misbehave.
      
      When nilfs_btree_insert() receives this spurious 'not found' code from
      nilfs_btree_do_lookup(), it misunderstands that the 'not found' check was
      successful and continues the insert operation using incomplete lookup path
      data, causing the following crash:
      
       general protection fault, probably for non-canonical address
       0xdffffc0000000005: 0000 [#1] PREEMPT SMP KASAN
       KASAN: null-ptr-deref in range [0x0000000000000028-0x000000000000002f]
       ...
       RIP: 0010:nilfs_btree_get_nonroot_node fs/nilfs2/btree.c:418 [inline]
       RIP: 0010:nilfs_btree_prepare_insert fs/nilfs2/btree.c:1077 [inline]
       RIP: 0010:nilfs_btree_insert+0x6d3/0x1c10 fs/nilfs2/btree.c:1238
       Code: bc 24 80 00 00 00 4c 89 f8 48 c1 e8 03 42 80 3c 28 00 74 08 4c 89
       ff e8 4b 02 92 fe 4d 8b 3f 49 83 c7 28 4c 89 f8 48 c1 e8 03 <42> 80 3c
       28 00 74 08 4c 89 ff e8 2e 02 92 fe 4d 8b 3f 49 83 c7 02
       ...
       Call Trace:
       <TASK>
        nilfs_bmap_do_insert fs/nilfs2/bmap.c:121 [inline]
        nilfs_bmap_insert+0x20d/0x360 fs/nilfs2/bmap.c:147
        nilfs_get_block+0x414/0x8d0 fs/nilfs2/inode.c:101
        __block_write_begin_int+0x54c/0x1a80 fs/buffer.c:1991
        __block_write_begin fs/buffer.c:2041 [inline]
        block_write_begin+0x93/0x1e0 fs/buffer.c:2102
        nilfs_write_begin+0x9c/0x110 fs/nilfs2/inode.c:261
        generic_perform_write+0x2e4/0x5e0 mm/filemap.c:3772
        __generic_file_write_iter+0x176/0x400 mm/filemap.c:3900
        generic_file_write_iter+0xab/0x310 mm/filemap.c:3932
        call_write_iter include/linux/fs.h:2186 [inline]
        new_sync_write fs/read_write.c:491 [inline]
        vfs_write+0x7dc/0xc50 fs/read_write.c:584
        ksys_write+0x177/0x2a0 fs/read_write.c:637
        do_syscall_x64 arch/x86/entry/common.c:50 [inline]
        do_syscall_64+0x3d/0xb0 arch/x86/entry/common.c:80
        entry_SYSCALL_64_after_hwframe+0x63/0xcd
       ...
       </TASK>
      
      This patch fixes the root cause of this problem by replacing the error
      code that __nilfs_btree_get_block() returns on block address conversion
      failure from -ENOENT to another internal code -EINVAL which means that the
      b-tree metadata is corrupted.
      
      By returning -EINVAL, it propagates without glitches, and for all relevant
      b-tree operations, functions in the upper bmap layer output an error
      message indicating corrupted b-tree metadata via
      nilfs_bmap_convert_error(), and code -EIO will be eventually returned as
      it should be.
      
      Link: https://lkml.kernel.org/r/000000000000bd89e205f0e38355@google.com
      Link: https://lkml.kernel.org/r/20230105055356.8811-1-konishi.ryusuke@gmail.com
      
      
      Signed-off-by: default avatarRyusuke Konishi <konishi.ryusuke@gmail.com>
      Reported-by: default avatar <syzbot+ede796cecd5296353515@syzkaller.appspotmail.com>
      Tested-by: default avatarRyusuke Konishi <konishi.ryusuke@gmail.com>
      Cc: <stable@vger.kernel.org>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      3c2a2ff6
    • Jaegeuk Kim's avatar
      f2fs: let's avoid panic if extent_tree is not created · dd83a976
      Jaegeuk Kim authored
      [ Upstream commit df9d44b6
      
       ]
      
      This patch avoids the below panic.
      
      pc : __lookup_extent_tree+0xd8/0x760
      lr : f2fs_do_write_data_page+0x104/0x87c
      sp : ffffffc010cbb3c0
      x29: ffffffc010cbb3e0 x28: 0000000000000000
      x27: ffffff8803e7f020 x26: ffffff8803e7ed40
      x25: ffffff8803e7f020 x24: ffffffc010cbb460
      x23: ffffffc010cbb480 x22: 0000000000000000
      x21: 0000000000000000 x20: ffffffff22e90900
      x19: 0000000000000000 x18: ffffffc010c5d080
      x17: 0000000000000000 x16: 0000000000000020
      x15: ffffffdb1acdbb88 x14: ffffff888759e2b0
      x13: 0000000000000000 x12: ffffff802da49000
      x11: 000000000a001200 x10: ffffff8803e7ed40
      x9 : ffffff8023195800 x8 : ffffff802da49078
      x7 : 0000000000000001 x6 : 0000000000000000
      x5 : 0000000000000006 x4 : ffffffc010cbba28
      x3 : 0000000000000000 x2 : ffffffc010cbb480
      x1 : 0000000000000000 x0 : ffffff8803e7ed40
      Call trace:
       __lookup_extent_tree+0xd8/0x760
       f2fs_do_write_data_page+0x104/0x87c
       f2fs_write_single_data_page+0x420/0xb60
       f2fs_write_cache_pages+0x418/0xb1c
       __f2fs_write_data_pages+0x428/0x58c
       f2fs_write_data_pages+0x30/0x40
       do_writepages+0x88/0x190
       __writeback_single_inode+0x48/0x448
       writeback_sb_inodes+0x468/0x9e8
       __writeback_inodes_wb+0xb8/0x2a4
       wb_writeback+0x33c/0x740
       wb_do_writeback+0x2b4/0x400
       wb_workfn+0xe4/0x34c
       process_one_work+0x24c/0x5bc
       worker_thread+0x3e8/0xa50
       kthread+0x150/0x1b4
      
      Signed-off-by: default avatarJaegeuk Kim <jaegeuk@kernel.org>
      Signed-off-by: default avatarSasha Levin <sashal@kernel.org>
      dd83a976
    • Jiri Slaby (SUSE)'s avatar
      RDMA/srp: Move large values to a new enum for gcc13 · bf9db115
      Jiri Slaby (SUSE) authored
      [ Upstream commit 56c5dab2 ]
      
      Since gcc13, each member of an enum has the same type as the enum [1]. And
      that is inherited from its members. Provided these two:
        SRP_TAG_NO_REQ        = ~0U,
        SRP_TAG_TSK_MGMT	= 1U << 31
      all other members are unsigned ints.
      
      Esp. with SRP_MAX_SGE and SRP_TSK_MGMT_SQ_SIZE and their use in min(),
      this results in the following warnings:
        include/linux/minmax.h:20:35: error: comparison of distinct pointer types lacks a cast
        drivers/infiniband/ulp/srp/ib_srp.c:563:42: note: in expansion of macro 'min'
      
        include/linux/minmax.h:20:35: error: comparison of distinct pointer types lacks a cast
        drivers/infiniband/ulp/srp/ib_srp.c:2369:27: note: in expansion of macro 'min'
      
      So move the large values away to a separate enum, so that they don't
      affect other members.
      
      [1] https://gcc.gnu.org/bugzilla/show_bug.cgi?id=36113
      
      Link: https://lore.kernel.org/r/20221212120411.13750-1-jirislaby@kernel.org
      
      
      Signed-off-by: default avatarJiri Slaby (SUSE) <jirislaby@kernel.org>
      Reviewed-by: default avatarBart Van Assche <bvanassche@acm.org>
      Signed-off-by: default avatarLeon Romanovsky <leon@kernel.org>
      Signed-off-by: default avatarSasha Levin <sashal@kernel.org>
      bf9db115
    • Daniil Tatianin's avatar
      net/ethtool/ioctl: return -EOPNOTSUPP if we have no phy stats · 5d71531e
      Daniil Tatianin authored
      [ Upstream commit 9deb1e9f
      
       ]
      
      It's not very useful to copy back an empty ethtool_stats struct and
      return 0 if we didn't actually have any stats. This also allows for
      further simplification of this function in the future commits.
      
      Signed-off-by: default avatarDaniil Tatianin <d-tatianin@yandex-team.ru>
      Reviewed-by: default avatarAndrew Lunn <andrew@lunn.ch>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      Signed-off-by: default avatarSasha Levin <sashal@kernel.org>
      5d71531e
    • Olga Kornievskaia's avatar
      pNFS/filelayout: Fix coalescing test for single DS · 9bf15159
      Olga Kornievskaia authored
      [ Upstream commit a6b9d2fa
      
       ]
      
      When there is a single DS no striping constraints need to be placed on
      the IO. When such constraint is applied then buffered reads don't
      coalesce to the DS's rsize.
      
      Signed-off-by: default avatarOlga Kornievskaia <kolga@netapp.com>
      Signed-off-by: default avatarTrond Myklebust <trond.myklebust@hammerspace.com>
      Signed-off-by: default avatarSasha Levin <sashal@kernel.org>
      9bf15159
  3. Jan 18, 2023