Skip to content
  1. Sep 11, 2023
  2. Sep 05, 2023
    • Gustavo A. R. Silva's avatar
      wifi: mwifiex: Sanity check tlv_len and tlv_bitmap_len · d5a93b7d
      Gustavo A. R. Silva authored
      
      
      Add sanity checks for both `tlv_len` and `tlv_bitmap_len` before
      decoding data from `event_buf`.
      
      This prevents any malicious or buggy firmware from overflowing
      `event_buf` through large values for `tlv_len` and `tlv_bitmap_len`.
      
      Suggested-by: default avatarDan Williams <dcbw@redhat.com>
      Signed-off-by: default avatarGustavo A. R. Silva <gustavoars@kernel.org>
      Reviewed-by: default avatarKees Cook <keescook@chromium.org>
      Signed-off-by: default avatarKalle Valo <kvalo@kernel.org>
      Link: https://lore.kernel.org/r/d4f8780527d551552ee96f17a0229e02e1c200d1.1692931954.git.gustavoars@kernel.org
      d5a93b7d
    • Gustavo A. R. Silva's avatar
      wifi: mwifiex: Replace one-element array with flexible-array member in struct... · c7847241
      Gustavo A. R. Silva authored
      
      wifi: mwifiex: Replace one-element array with flexible-array member in struct mwifiex_ie_types_rxba_sync
      
      One-element and zero-length arrays are deprecated. So, replace
      one-element array in struct mwifiex_ie_types_rxba_sync with
      flexible-array member, and refactor the rest of the code, accordingly.
      
      This results in no differences in binary output.
      
      Signed-off-by: default avatarGustavo A. R. Silva <gustavoars@kernel.org>
      Reviewed-by: default avatarKees Cook <keescook@chromium.org>
      Signed-off-by: default avatarKalle Valo <kvalo@kernel.org>
      Link: https://lore.kernel.org/r/79c801c69c8beece2f80502c60166036d3c047cc.1692931954.git.gustavoars@kernel.org
      c7847241
    • Gustavo A. R. Silva's avatar
      wifi: mwifiex: Fix tlv_buf_left calculation · eec679e4
      Gustavo A. R. Silva authored
      
      
      In a TLV encoding scheme, the Length part represents the length after
      the header containing the values for type and length. In this case,
      `tlv_len` should be:
      
      tlv_len == (sizeof(*tlv_rxba) - 1) - sizeof(tlv_rxba->header) + tlv_bitmap_len
      
      Notice that the `- 1` accounts for the one-element array `bitmap`, which
      1-byte size is already included in `sizeof(*tlv_rxba)`.
      
      So, if the above is correct, there is a double-counting of some members
      in `struct mwifiex_ie_types_rxba_sync`, when `tlv_buf_left` and `tmp`
      are calculated:
      
      968                 tlv_buf_left -= (sizeof(*tlv_rxba) + tlv_len);
      969                 tmp = (u8 *)tlv_rxba + tlv_len + sizeof(*tlv_rxba);
      
      in specific, members:
      
      drivers/net/wireless/marvell/mwifiex/fw.h:777
       777         u8 mac[ETH_ALEN];
       778         u8 tid;
       779         u8 reserved;
       780         __le16 seq_num;
       781         __le16 bitmap_len;
      
      This is clearly wrong, and affects the subsequent decoding of data in
      `event_buf` through `tlv_rxba`:
      
      970                 tlv_rxba = (struct mwifiex_ie_types_rxba_sync *)tmp;
      
      Fix this by using `sizeof(tlv_rxba->header)` instead of `sizeof(*tlv_rxba)`
      in the calculation of `tlv_buf_left` and `tmp`.
      
      This results in the following binary differences before/after changes:
      
      | drivers/net/wireless/marvell/mwifiex/11n_rxreorder.o
      | @@ -4698,11 +4698,11 @@
      |  drivers/net/wireless/marvell/mwifiex/11n_rxreorder.c:968
      |                 tlv_buf_left -= (sizeof(tlv_rxba->header) + tlv_len);
      | -    1da7:      lea    -0x11(%rbx),%edx
      | +    1da7:      lea    -0x4(%rbx),%edx
      |      1daa:      movzwl %bp,%eax
      |  drivers/net/wireless/marvell/mwifiex/11n_rxreorder.c:969
      |                 tmp = (u8 *)tlv_rxba  + sizeof(tlv_rxba->header) + tlv_len;
      | -    1dad:      lea    0x11(%r15,%rbp,1),%r15
      | +    1dad:      lea    0x4(%r15,%rbp,1),%r15
      
      The above reflects the desired change: avoid counting 13 too many bytes;
      which is the total size of the double-counted members in
      `struct mwifiex_ie_types_rxba_sync`:
      
      $ pahole -C mwifiex_ie_types_rxba_sync drivers/net/wireless/marvell/mwifiex/11n_rxreorder.o
      struct mwifiex_ie_types_rxba_sync {
      	struct mwifiex_ie_types_header header;           /*     0     4 */
      
           |-----------------------------------------------------------------------
           |  u8                         mac[6];               /*     4     6 */  |
           |	u8                         tid;                  /*    10     1 */  |
           |  u8                         reserved;             /*    11     1 */  |
           | 	__le16                     seq_num;              /*    12     2 */  |
           | 	__le16                     bitmap_len;           /*    14     2 */  |
           |  u8                         bitmap[1];            /*    16     1 */  |
           |----------------------------------------------------------------------|
      								  | 13 bytes|
      								  -----------
      
      	/* size: 17, cachelines: 1, members: 7 */
      	/* last cacheline: 17 bytes */
      } __attribute__((__packed__));
      
      Fixes: 99ffe72c ("mwifiex: process rxba_sync event")
      Cc: stable@vger.kernel.org
      Signed-off-by: default avatarGustavo A. R. Silva <gustavoars@kernel.org>
      Reviewed-by: default avatarKees Cook <keescook@chromium.org>
      Signed-off-by: default avatarKalle Valo <kvalo@kernel.org>
      Link: https://lore.kernel.org/r/06668edd68e7a26bbfeebd1201ae077a2a7a8bce.1692931954.git.gustavoars@kernel.org
      eec679e4
    • Jeff Johnson's avatar
      MAINTAINERS: wifi: ath12k: add wiki link · af5ff4b7
      Jeff Johnson authored
      
      
      The ath12k wireless driver now has a wiki, so advertise it.
      
      Signed-off-by: default avatarJeff Johnson <quic_jjohnson@quicinc.com>
      Signed-off-by: default avatarKalle Valo <kvalo@kernel.org>
      Link: https://lore.kernel.org/r/20230829-ath12kwiki-v1-1-df37127527a1@quicinc.com
      af5ff4b7
    • Kalle Valo's avatar
      MAINTAINERS: wifi: hostap: remove maintainer and web page · d253fb37
      Kalle Valo authored
      
      
      As hostap is marked as obsolete there's no need to have a maintainer. Also
      remove the link to the web page.
      
      Signed-off-by: default avatarKalle Valo <kvalo@kernel.org>
      Link: https://lore.kernel.org/r/20230828123603.87621-5-kvalo@kernel.org
      d253fb37
    • Kalle Valo's avatar
      MAINTAINERS: wifi: wl12xx: remove git tree · b8c713c1
      Kalle Valo authored
      
      
      Luca's tree hasn't been used for 10 years so remove it.
      
      Signed-off-by: default avatarKalle Valo <kvalo@kernel.org>
      Link: https://lore.kernel.org/r/20230828123603.87621-4-kvalo@kernel.org
      b8c713c1
    • Kalle Valo's avatar
      MAINTAINERS: wifi: rtl8xxxu: remove git tree · 42c5f0e2
      Kalle Valo authored
      
      
      Jes' tree hasn't been used for six years so remove it.
      
      Signed-off-by: default avatarKalle Valo <kvalo@kernel.org>
      Link: https://lore.kernel.org/r/20230828123603.87621-3-kvalo@kernel.org
      42c5f0e2
    • Kalle Valo's avatar
      MAINTAINERS: wifi: rtlwifi: remove git tree · 0b9480da
      Kalle Valo authored
      
      
      Linville's tree hasn't been used for something like 10 years so remove it.
      
      Signed-off-by: default avatarKalle Valo <kvalo@kernel.org>
      Link: https://lore.kernel.org/r/20230828123603.87621-2-kvalo@kernel.org
      0b9480da
    • Kalle Valo's avatar
      MAINTAINERS: wifi: remove generic wiki links from drivers · 84727c57
      Kalle Valo authored
      The top level entry for wireless drivers already contains to the wiki so no
      need to duplicate that in driver entries:
      
      NETWORKING DRIVERS (WIRELESS)
      [...]
      W:	https://wireless.wiki.kernel.org/
      
      
      
      Signed-off-by: default avatarKalle Valo <kvalo@kernel.org>
      Link: https://lore.kernel.org/r/20230828123603.87621-1-kvalo@kernel.org
      84727c57
    • Lorenzo Bianconi's avatar
      wifi: mt76: fix lock dependency problem for wed_lock · 19527314
      Lorenzo Bianconi authored
      
      
      Fix the following kernel depency lock holding wed_lock with BH disabled.
      
      [   40.579696] mt798x-wmac 18000000.wifi: attaching wed device 0 version 2
      [   40.604648] platform 15010000.wed: MTK WED WO Firmware Version: DEV_000000, Build Time: 20221208202138
      [   40.613972] platform 15010000.wed: MTK WED WO Chip ID 00 Region 3
      [   40.943617]
      [   40.945118] ========================================================
      [   40.951457] WARNING: possible irq lock inversion dependency detected
      [   40.957797] 5.15.127 #0 Not tainted
      [   40.961276] --------------------------------------------------------
      [   40.967614] insmod/2329 just changed the state of lock:
      [   40.972827] ffffff8004003b08 (&dev->wed_lock){+.+.}-{2:2}, at: mt76_get_rxwi+0x1c/0xac [mt76]
      [   40.981387] but this lock was taken by another, SOFTIRQ-safe lock in the past:
      [   40.988592]  (&q->lock){+.-.}-{2:2}
      [   40.988602]
      [   40.988602]
      [   40.988602] and interrupts could create inverse lock ordering between them.
      [   40.988602]
      [   41.003445]
      [   41.003445] other info that might help us debug this:
      [   41.009957]  Possible interrupt unsafe locking scenario:
      [   41.009957]
      [   41.016729]        CPU0                    CPU1
      [   41.021245]        ----                    ----
      [   41.025761]   lock(&dev->wed_lock);
      [   41.029241]                                local_irq_disable();
      [   41.035145]                                lock(&q->lock);
      [   41.040620]                                lock(&dev->wed_lock);
      [   41.046616]   <Interrupt>
      [   41.049223]     lock(&q->lock);
      [   41.052356]
      [   41.052356]  *** DEADLOCK ***
      [   41.052356]
      [   41.058260] 1 lock held by insmod/2329:
      [   41.062085]  #0: ffffff80003b9988 (&dev->mutex){....}-{3:3}, at: __driver_attach+0x88/0x190
      [   41.070442]
      [   41.070442] the shortest dependencies between 2nd lock and 1st lock:
      [   41.078257]  -> (&q->lock){+.-.}-{2:2} {
      [   41.082177]     HARDIRQ-ON-W at:
      [   41.085396]                       lock_acquire+0xfc/0x2c0
      [   41.090787]                       _raw_spin_lock_bh+0x84/0xa0
      [   41.096525]                       mt76_dma_cleanup+0x24c/0x650 [mt76]
      [   41.102977]                       mt76_dma_cleanup+0x614/0x650 [mt76]
      [   41.109428]                       mt7915_eeprom_get_power_delta+0x1168/0x2464 [mt7915e]
      [   41.117435]                       mt7915_eeprom_init+0x40/0x340 [mt7915e]
      [   41.124222]                       cleanup_module+0x94/0xb28 [mt7915e]
      [   41.130662]                       platform_probe+0x64/0xbc
      [   41.136139]                       really_probe.part.0+0x98/0x2f4
      [   41.142134]                       __driver_probe_device+0x94/0x16c
      [   41.148303]                       driver_probe_device+0x40/0x120
      [   41.154299]                       __driver_attach+0x94/0x190
      [   41.159947]                       bus_for_each_dev+0x5c/0x94
      [   41.165594]                       driver_attach+0x20/0x30
      [   41.170983]                       bus_add_driver+0x104/0x1f4
      [   41.176631]                       driver_register+0x74/0x120
      [   41.182280]                       __platform_driver_register+0x24/0x30
      [   41.188797]                       0xffffffc000cb1074
      [   41.193754]                       do_one_initcall+0x70/0x2cc
      [   41.199403]                       do_init_module+0x44/0x240
      [   41.204968]                       load_module+0x1f5c/0x2874
      [   41.210532]                       __do_sys_init_module+0x1d8/0x2ac
      [   41.216702]                       __arm64_sys_init_module+0x18/0x20
      [   41.222958]                       invoke_syscall.constprop.0+0x4c/0xe0
      [   41.229474]                       do_el0_svc+0x50/0xf0
      [   41.234602]                       el0_svc+0x4c/0xcc
      [   41.239471]                       el0t_64_sync_handler+0xe0/0x110
      [   41.245556]                       el0t_64_sync+0x15c/0x160
      [   41.251029]     IN-SOFTIRQ-W at:
      [   41.254249]                       lock_acquire+0xfc/0x2c0
      [   41.259638]                       _raw_spin_lock_bh+0x84/0xa0
      [   41.265372]                       mt76_queue_tx_complete+0x34/0x70 [mt76]
      [   41.272170]                       mt76_free_pending_rxwi+0x36c/0x5d0 [mt76]
      [   41.279140]                       mt76_free_pending_rxwi+0x5c0/0x5d0 [mt76]
      [   41.286111]                       mt7915_eeprom_get_power_delta+0x620/0x2464 [mt7915e]
      [   41.294026]                       __napi_poll.constprop.0+0x5c/0x230
      [   41.300372]                       net_rx_action+0xe4/0x294
      [   41.305847]                       _stext+0x154/0x4cc
      [   41.310801]                       do_softirq+0xa4/0xbc
      [   41.315930]                       __local_bh_enable_ip+0x168/0x174
      [   41.322097]                       napi_threaded_poll+0xbc/0x140
      [   41.328007]                       kthread+0x13c/0x150
      [   41.333049]                       ret_from_fork+0x10/0x20
      [   41.338437]     INITIAL USE at:
      [   41.341568]                      lock_acquire+0xfc/0x2c0
      [   41.346869]                      _raw_spin_lock_bh+0x84/0xa0
      [   41.352519]                      mt76_dma_cleanup+0x24c/0x650 [mt76]
      [   41.358882]                      mt76_dma_cleanup+0x614/0x650 [mt76]
      [   41.365245]                      mt7915_eeprom_get_power_delta+0x1168/0x2464 [mt7915e]
      [   41.373160]                      mt7915_eeprom_init+0x40/0x340 [mt7915e]
      [   41.379860]                      cleanup_module+0x94/0xb28 [mt7915e]
      [   41.386213]                      platform_probe+0x64/0xbc
      [   41.391602]                      really_probe.part.0+0x98/0x2f4
      [   41.397511]                      __driver_probe_device+0x94/0x16c
      [   41.403594]                      driver_probe_device+0x40/0x120
      [   41.409502]                      __driver_attach+0x94/0x190
      [   41.415063]                      bus_for_each_dev+0x5c/0x94
      [   41.420625]                      driver_attach+0x20/0x30
      [   41.425926]                      bus_add_driver+0x104/0x1f4
      [   41.431487]                      driver_register+0x74/0x120
      [   41.437049]                      __platform_driver_register+0x24/0x30
      [   41.443479]                      0xffffffc000cb1074
      [   41.448346]                      do_one_initcall+0x70/0x2cc
      [   41.453907]                      do_init_module+0x44/0x240
      [   41.459383]                      load_module+0x1f5c/0x2874
      [   41.464860]                      __do_sys_init_module+0x1d8/0x2ac
      [   41.470944]                      __arm64_sys_init_module+0x18/0x20
      [   41.477113]                      invoke_syscall.constprop.0+0x4c/0xe0
      [   41.483542]                      do_el0_svc+0x50/0xf0
      [   41.488582]                      el0_svc+0x4c/0xcc
      [   41.493364]                      el0t_64_sync_handler+0xe0/0x110
      [   41.499361]                      el0t_64_sync+0x15c/0x160
      [   41.504748]   }
      [   41.506489]   ... key      at: [<ffffffc000c65ba0>] __this_module+0x3e0/0xffffffffffffa840 [mt76]
      [   41.515371]   ... acquired at:
      [   41.518413]    _raw_spin_lock+0x60/0x74
      [   41.522240]    mt76_get_rxwi+0x1c/0xac [mt76]
      [   41.526608]    mt76_dma_cleanup+0x3e0/0x650 [mt76]
      [   41.531410]    mt76_dma_cleanup+0x614/0x650 [mt76]
      [   41.536211]    mt7915_dma_init+0x408/0x7b0 [mt7915e]
      [   41.541177]    mt7915_register_device+0x310/0x620 [mt7915e]
      [   41.546749]    mt7915_mmio_probe+0xcec/0x1d44 [mt7915e]
      [   41.551973]    platform_probe+0x64/0xbc
      [   41.555802]    really_probe.part.0+0x98/0x2f4
      [   41.560149]    __driver_probe_device+0x94/0x16c
      [   41.564670]    driver_probe_device+0x40/0x120
      [   41.569017]    __driver_attach+0x94/0x190
      [   41.573019]    bus_for_each_dev+0x5c/0x94
      [   41.577018]    driver_attach+0x20/0x30
      [   41.580758]    bus_add_driver+0x104/0x1f4
      [   41.584758]    driver_register+0x74/0x120
      [   41.588759]    __platform_driver_register+0x24/0x30
      [   41.593628]    init_module+0x74/0x1000 [mt7915e]
      [   41.598248]    do_one_initcall+0x70/0x2cc
      [   41.602248]    do_init_module+0x44/0x240
      [   41.606162]    load_module+0x1f5c/0x2874
      [   41.610078]    __do_sys_init_module+0x1d8/0x2ac
      [   41.614600]    __arm64_sys_init_module+0x18/0x20
      [   41.619209]    invoke_syscall.constprop.0+0x4c/0xe0
      [   41.624076]    do_el0_svc+0x50/0xf0
      [   41.627555]    el0_svc+0x4c/0xcc
      [   41.630776]    el0t_64_sync_handler+0xe0/0x110
      [   41.635211]    el0t_64_sync+0x15c/0x160
      [   41.639037]
      [   41.640517] -> (&dev->wed_lock){+.+.}-{2:2} {
      [   41.644872]    HARDIRQ-ON-W at:
      [   41.648003]                     lock_acquire+0xfc/0x2c0
      [   41.653219]                     _raw_spin_lock+0x60/0x74
      [   41.658520]                     mt76_free_pending_rxwi+0xc0/0x5d0 [mt76]
      [   41.665232]                     mt76_dma_cleanup+0x1dc/0x650 [mt76]
      [   41.671508]                     mt7915_eeprom_get_power_delta+0x1830/0x2464 [mt7915e]
      [   41.679336]                     mt7915_unregister_device+0x5b4/0x910 [mt7915e]
      [   41.686555]                     mt7915_eeprom_get_target_power+0xb8/0x230 [mt7915e]
      [   41.694209]                     mt7986_wmac_enable+0xc30/0xcd0 [mt7915e]
      [   41.700909]                     platform_remove+0x4c/0x64
      [   41.706298]                     __device_release_driver+0x194/0x240
      [   41.712554]                     driver_detach+0xc0/0x100
      [   41.717857]                     bus_remove_driver+0x54/0xac
      [   41.723418]                     driver_unregister+0x2c/0x54
      [   41.728980]                     platform_driver_unregister+0x10/0x20
      [   41.735323]                     mt7915_ops+0x244/0xffffffffffffed58 [mt7915e]
      [   41.742457]                     __arm64_sys_delete_module+0x170/0x23c
      [   41.748887]                     invoke_syscall.constprop.0+0x4c/0xe0
      [   41.755229]                     do_el0_svc+0x50/0xf0
      [   41.760183]                     el0_svc+0x4c/0xcc
      [   41.764878]                     el0t_64_sync_handler+0xe0/0x110
      [   41.770788]                     el0t_64_sync+0x15c/0x160
      [   41.776088]    SOFTIRQ-ON-W at:
      [   41.779220]                     lock_acquire+0xfc/0x2c0
      [   41.784435]                     _raw_spin_lock+0x60/0x74
      [   41.789737]                     mt76_get_rxwi+0x1c/0xac [mt76]
      [   41.795580]                     mt7915_debugfs_rx_log+0x804/0xb74 [mt7915e]
      [   41.802540]                     mtk_wed_start+0x970/0xaa0
      [   41.807929]                     mt7915_dma_start+0x26c/0x630 [mt7915e]
      [   41.814455]                     mt7915_dma_start+0x5a4/0x630 [mt7915e]
      [   41.820981]                     mt7915_dma_init+0x45c/0x7b0 [mt7915e]
      [   41.827420]                     mt7915_register_device+0x310/0x620 [mt7915e]
      [   41.834467]                     mt7915_mmio_probe+0xcec/0x1d44 [mt7915e]
      [   41.841167]                     platform_probe+0x64/0xbc
      [   41.846469]                     really_probe.part.0+0x98/0x2f4
      [   41.852291]                     __driver_probe_device+0x94/0x16c
      [   41.858286]                     driver_probe_device+0x40/0x120
      [   41.864107]                     __driver_attach+0x94/0x190
      [   41.869582]                     bus_for_each_dev+0x5c/0x94
      [   41.875056]                     driver_attach+0x20/0x30
      [   41.880270]                     bus_add_driver+0x104/0x1f4
      [   41.885745]                     driver_register+0x74/0x120
      [   41.891221]                     __platform_driver_register+0x24/0x30
      [   41.897564]                     init_module+0x74/0x1000 [mt7915e]
      [   41.903657]                     do_one_initcall+0x70/0x2cc
      [   41.909130]                     do_init_module+0x44/0x240
      [   41.914520]                     load_module+0x1f5c/0x2874
      [   41.919909]                     __do_sys_init_module+0x1d8/0x2ac
      [   41.925905]                     __arm64_sys_init_module+0x18/0x20
      [   41.931989]                     invoke_syscall.constprop.0+0x4c/0xe0
      [   41.938331]                     do_el0_svc+0x50/0xf0
      [   41.943285]                     el0_svc+0x4c/0xcc
      [   41.947981]                     el0t_64_sync_handler+0xe0/0x110
      [   41.953892]                     el0t_64_sync+0x15c/0x160
      [   41.959192]    INITIAL USE at:
      [   41.962238]                    lock_acquire+0xfc/0x2c0
      [   41.967365]                    _raw_spin_lock+0x60/0x74
      [   41.972580]                    mt76_free_pending_rxwi+0xc0/0x5d0 [mt76]
      [   41.979206]                    mt76_dma_cleanup+0x1dc/0x650 [mt76]
      [   41.985395]                    mt7915_eeprom_get_power_delta+0x1830/0x2464 [mt7915e]
      [   41.993137]                    mt7915_unregister_device+0x5b4/0x910 [mt7915e]
      [   42.000270]                    mt7915_eeprom_get_target_power+0xb8/0x230 [mt7915e]
      [   42.007837]                    mt7986_wmac_enable+0xc30/0xcd0 [mt7915e]
      [   42.014450]                    platform_remove+0x4c/0x64
      [   42.019753]                    __device_release_driver+0x194/0x240
      [   42.025922]                    driver_detach+0xc0/0x100
      [   42.031137]                    bus_remove_driver+0x54/0xac
      [   42.036612]                    driver_unregister+0x2c/0x54
      [   42.042087]                    platform_driver_unregister+0x10/0x20
      [   42.048344]                    mt7915_ops+0x244/0xffffffffffffed58 [mt7915e]
      [   42.055391]                    __arm64_sys_delete_module+0x170/0x23c
      [   42.061735]                    invoke_syscall.constprop.0+0x4c/0xe0
      [   42.067990]                    do_el0_svc+0x50/0xf0
      [   42.072857]                    el0_svc+0x4c/0xcc
      [   42.077466]                    el0t_64_sync_handler+0xe0/0x110
      [   42.083289]                    el0t_64_sync+0x15c/0x160
      [   42.088503]  }
      [   42.090157]  ... key      at: [<ffffffc000c65c10>] __this_module+0x450/0xffffffffffffa840 [mt76]
      [   42.098951]  ... acquired at:
      [   42.101907]    __lock_acquire+0x718/0x1df0
      [   42.105994]    lock_acquire+0xfc/0x2c0
      [   42.109734]    _raw_spin_lock+0x60/0x74
      [   42.113561]    mt76_get_rxwi+0x1c/0xac [mt76]
      [   42.117929]    mt7915_debugfs_rx_log+0x804/0xb74 [mt7915e]
      [   42.123415]    mtk_wed_start+0x970/0xaa0
      [   42.127328]    mt7915_dma_start+0x26c/0x630 [mt7915e]
      [   42.132379]    mt7915_dma_start+0x5a4/0x630 [mt7915e]
      [   42.137430]    mt7915_dma_init+0x45c/0x7b0 [mt7915e]
      [   42.142395]    mt7915_register_device+0x310/0x620 [mt7915e]
      [   42.147967]    mt7915_mmio_probe+0xcec/0x1d44 [mt7915e]
      [   42.153192]    platform_probe+0x64/0xbc
      [   42.157019]    really_probe.part.0+0x98/0x2f4
      [   42.161367]    __driver_probe_device+0x94/0x16c
      [   42.165887]    driver_probe_device+0x40/0x120
      [   42.170234]    __driver_attach+0x94/0x190
      [   42.174235]    bus_for_each_dev+0x5c/0x94
      [   42.178235]    driver_attach+0x20/0x30
      [   42.181974]    bus_add_driver+0x104/0x1f4
      [   42.185974]    driver_register+0x74/0x120
      [   42.189974]    __platform_driver_register+0x24/0x30
      [   42.194842]    init_module+0x74/0x1000 [mt7915e]
      [   42.199460]    do_one_initcall+0x70/0x2cc
      [   42.203460]    do_init_module+0x44/0x240
      [   42.207376]    load_module+0x1f5c/0x2874
      [   42.211290]    __do_sys_init_module+0x1d8/0x2ac
      [   42.215813]    __arm64_sys_init_module+0x18/0x20
      [   42.220421]    invoke_syscall.constprop.0+0x4c/0xe0
      [   42.225288]    do_el0_svc+0x50/0xf0
      [   42.228768]    el0_svc+0x4c/0xcc
      [   42.231989]    el0t_64_sync_handler+0xe0/0x110
      [   42.236424]    el0t_64_sync+0x15c/0x160
      [   42.240249]
      [   42.241730]
      [   42.241730] stack backtrace:
      [   42.246074] CPU: 1 PID: 2329 Comm: insmod Not tainted 5.15.127 #0
      [   42.252157] Hardware name: GainStrong Oolite-MT7981B V1 Dev Board (NAND boot) (DT)
      [   42.259712] Call trace:
      [   42.262147]  dump_backtrace+0x0/0x174
      [   42.265802]  show_stack+0x14/0x20
      [   42.269108]  dump_stack_lvl+0x84/0xac
      [   42.272761]  dump_stack+0x14/0x2c
      [   42.276066]  print_irq_inversion_bug.part.0+0x1b0/0x1c4
      [   42.281285]  mark_lock+0x8b8/0x8bc
      [   42.284678]  __lock_acquire+0x718/0x1df0
      [   42.288592]  lock_acquire+0xfc/0x2c0
      [   42.292158]  _raw_spin_lock+0x60/0x74
      [   42.295811]  mt76_get_rxwi+0x1c/0xac [mt76]
      [   42.300008]  mt7915_debugfs_rx_log+0x804/0xb74 [mt7915e]
      [   42.305320]  mtk_wed_start+0x970/0xaa0
      [   42.309059]  mt7915_dma_start+0x26c/0x630 [mt7915e]
      [   42.313937]  mt7915_dma_start+0x5a4/0x630 [mt7915e]
      [   42.318815]  mt7915_dma_init+0x45c/0x7b0 [mt7915e]
      [   42.323606]  mt7915_register_device+0x310/0x620 [mt7915e]
      [   42.329005]  mt7915_mmio_probe+0xcec/0x1d44 [mt7915e]
      [   42.334056]  platform_probe+0x64/0xbc
      [   42.337711]  really_probe.part.0+0x98/0x2f4
      [   42.341885]  __driver_probe_device+0x94/0x16c
      [   42.346232]  driver_probe_device+0x40/0x120
      [   42.350407]  __driver_attach+0x94/0x190
      [   42.354234]  bus_for_each_dev+0x5c/0x94
      [   42.358061]  driver_attach+0x20/0x30
      [   42.361627]  bus_add_driver+0x104/0x1f4
      [   42.365454]  driver_register+0x74/0x120
      [   42.369282]  __platform_driver_register+0x24/0x30
      [   42.373977]  init_module+0x74/0x1000 [mt7915e]
      [   42.378423]  do_one_initcall+0x70/0x2cc
      [   42.382249]  do_init_module+0x44/0x240
      [   42.385990]  load_module+0x1f5c/0x2874
      [   42.389733]  __do_sys_init_module+0x1d8/0x2ac
      [   42.394082]  __arm64_sys_init_module+0x18/0x20
      [   42.398518]  invoke_syscall.constprop.0+0x4c/0xe0
      [   42.403211]  do_el0_svc+0x50/0xf0
      [   42.406517]  el0_svc+0x4c/0xcc
      [   42.409565]  el0t_64_sync_handler+0xe0/0x110
      [   42.413827]  el0t_64_sync+0x15c/0x160
      [   42.674858] mt798x-wmac 18000000.wifi: HW/SW Version: 0x8a108a10, Build Time: 20221208201745a
      [   42.674858]
      [   42.692078] mt798x-wmac 18000000.wifi: WM Firmware Version: ____000000, Build Time: 20221208201806
      [   42.735606] mt798x-wmac 18000000.wifi: WA Firmware Version: DEV_000000, Build Time: 20221208202048
      
      Tested-by: default avatarDaniel Golle <daniel@makrotopia.org>
      Fixes: 2666bece ("wifi: mt76: introduce rxwi and rx token utility routines")
      Signed-off-by: default avatarLorenzo Bianconi <lorenzo@kernel.org>
      Acked-by: default avatarFelix Fietkau <nbd@nbd.name>
      Signed-off-by: default avatarKalle Valo <kvalo@kernel.org>
      Link: https://lore.kernel.org/r/ee80be41c2a8d8749d83c6950a272a5e77aadd45.1693228333.git.lorenzo@kernel.org
      19527314
  3. Aug 30, 2023
    • Linus Torvalds's avatar
      Merge tag 'net-next-6.6' of git://git.kernel.org/pub/scm/linux/kernel/git/netdev/net-next · bd6c11bc
      Linus Torvalds authored
      Pull networking updates from Paolo Abeni:
       "Core:
      
         - Increase size limits for to-be-sent skb frag allocations. This
           allows tun, tap devices and packet sockets to better cope with
           large writes operations
      
         - Store netdevs in an xarray, to simplify iterating over netdevs
      
         - Refactor nexthop selection for multipath routes
      
         - Improve sched class lifetime handling
      
         - Add backup nexthop ID support for bridge
      
         - Implement drop reasons support in openvswitch
      
         - Several data races annotations and fixes
      
         - Constify the sk parameter of routing functions
      
         - Prepend kernel version to netconsole message
      
        Protocols:
      
         - Implement support for TCP probing the peer being under memory
           pressure
      
         - Remove hard coded limitation on IPv6 specific info placement inside
           the socket struct
      
         - Get rid of sysctl_tcp_adv_win_scale and use an auto-estimated per
           socket scaling factor
      
         - Scaling-up the IPv6 expired route GC via a separated list of
           expiring routes
      
         - In-kernel support for the TLS alert protocol
      
         - Better support for UDP reuseport with connected sockets
      
         - Add NEXT-C-SID support for SRv6 End.X behavior, reducing the SR
           header size
      
         - Get rid of additional ancillary per MPTCP connection struct socket
      
         - Implement support for BPF-based MPTCP packet schedulers
      
         - Format MPTCP subtests selftests results in TAP
      
         - Several new SMC 2.1 features including unique experimental options,
           max connections per lgr negotiation, max links per lgr negotiation
      
        BPF:
      
         - Multi-buffer support in AF_XDP
      
         - Add multi uprobe BPF links for attaching multiple uprobes and usdt
           probes, which is significantly faster and saves extra fds
      
         - Implement an fd-based tc BPF attach API (TCX) and BPF link support
           on top of it
      
         - Add SO_REUSEPORT support for TC bpf_sk_assign
      
         - Support new instructions from cpu v4 to simplify the generated code
           and feature completeness, for x86, arm64, riscv64
      
         - Support defragmenting IPv(4|6) packets in BPF
      
         - Teach verifier actual bounds of bpf_get_smp_processor_id() and fix
           perf+libbpf issue related to custom section handling
      
         - Introduce bpf map element count and enable it for all program types
      
         - Add a BPF hook in sys_socket() to change the protocol ID from
           IPPROTO_TCP to IPPROTO_MPTCP to cover migration for legacy
      
         - Introduce bpf_me_mcache_free_rcu() and fix OOM under stress
      
         - Add uprobe support for the bpf_get_func_ip helper
      
         - Check skb ownership against full socket
      
         - Support for up to 12 arguments in BPF trampoline
      
         - Extend link_info for kprobe_multi and perf_event links
      
        Netfilter:
      
         - Speed-up process exit by aborting ruleset validation if a fatal
           signal is pending
      
         - Allow NLA_POLICY_MASK to be used with BE16/BE32 types
      
        Driver API:
      
         - Page pool optimizations, to improve data locality and cache usage
      
         - Introduce ndo_hwtstamp_get() and ndo_hwtstamp_set() to avoid the
           need for raw ioctl() handling in drivers
      
         - Simplify genetlink dump operations (doit/dumpit) providing them the
           common information already populated in struct genl_info
      
         - Extend and use the yaml devlink specs to [re]generate the split ops
      
         - Introduce devlink selective dumps, to allow SF filtering SF based
           on handle and other attributes
      
         - Add yaml netlink spec for netlink-raw families, allow route, link
           and address related queries via the ynl tool
      
         - Remove phylink legacy mode support
      
         - Support offload LED blinking to phy
      
         - Add devlink port function attributes for IPsec
      
        New hardware / drivers:
      
         - Ethernet:
            - Broadcom ASP 2.0 (72165) ethernet controller
            - MediaTek MT7988 SoC
            - Texas Instruments AM654 SoC
            - Texas Instruments IEP driver
            - Atheros qca8081 phy
            - Marvell 88Q2110 phy
            - NXP TJA1120 phy
      
         - WiFi:
            - MediaTek mt7981 support
      
         - Can:
            - Kvaser SmartFusion2 PCI Express devices
            - Allwinner T113 controllers
            - Texas Instruments tcan4552/4553 chips
      
         - Bluetooth:
            - Intel Gale Peak
            - Qualcomm WCN3988 and WCN7850
            - NXP AW693 and IW624
            - Mediatek MT2925
      
        Drivers:
      
         - Ethernet NICs:
            - nVidia/Mellanox:
               - mlx5:
                  - support UDP encapsulation in packet offload mode
                  - IPsec packet offload support in eswitch mode
                  - improve aRFS observability by adding new set of counters
                  - extends MACsec offload support to cover RoCE traffic
                  - dynamic completion EQs
               - mlx4:
                  - convert to use auxiliary bus instead of custom interface
                    logic
            - Intel
               - ice:
                  - implement switchdev bridge offload, even for LAG
                    interfaces
                  - implement SRIOV support for LAG interfaces
               - igc:
                  - add support for multiple in-flight TX timestamps
            - Broadcom:
               - bnxt:
                  - use the unified RX page pool buffers for XDP and non-XDP
                  - use the NAPI skb allocation cache
            - OcteonTX2:
               - support Round Robin scheduling HTB offload
               - TC flower offload support for SPI field
            - Freescale:
               - add XDP_TX feature support
            - AMD:
               - ionic: add support for PCI FLR event
               - sfc:
                  - basic conntrack offload
                  - introduce eth, ipv4 and ipv6 pedit offloads
            - ST Microelectronics:
               - stmmac: maximze PTP timestamping resolution
      
         - Virtual NICs:
            - Microsoft vNIC:
               - batch ringing RX queue doorbell on receiving packets
               - add page pool for RX buffers
            - Virtio vNIC:
               - add per queue interrupt coalescing support
            - Google vNIC:
               - add queue-page-list mode support
      
         - Ethernet high-speed switches:
            - nVidia/Mellanox (mlxsw):
               - add port range matching tc-flower offload
               - permit enslavement to netdevices with uppers
      
         - Ethernet embedded switches:
            - Marvell (mv88e6xxx):
               - convert to phylink_pcs
            - Renesas:
               - r8A779fx: add speed change support
               - rzn1: enables vlan support
      
         - Ethernet PHYs:
            - convert mv88e6xxx to phylink_pcs
      
         - WiFi:
            - Qualcomm Wi-Fi 7 (ath12k):
               - extremely High Throughput (EHT) PHY support
            - RealTek (rtl8xxxu):
               - enable AP mode for: RTL8192FU, RTL8710BU (RTL8188GU),
                 RTL8192EU and RTL8723BU
            - RealTek (rtw89):
               - Introduce Time Averaged SAR (TAS) support
      
         - Connector:
            - support for event filtering"
      
      * tag 'net-next-6.6' of git://git.kernel.org/pub/scm/linux/kernel/git/netdev/net-next: (1806 commits)
        net: ethernet: mtk_wed: minor change in wed_{tx,rx}info_show
        net: ethernet: mtk_wed: add some more info in wed_txinfo_show handler
        net: stmmac: clarify difference between "interface" and "phy_interface"
        r8152: add vendor/device ID pair for D-Link DUB-E250
        devlink: move devlink_notify_register/unregister() to dev.c
        devlink: move small_ops definition into netlink.c
        devlink: move tracepoint definitions into core.c
        devlink: push linecard related code into separate file
        devlink: push rate related code into separate file
        devlink: push trap related code into separate file
        devlink: use tracepoint_enabled() helper
        devlink: push region related code into separate file
        devlink: push param related code into separate file
        devlink: push resource related code into separate file
        devlink: push dpipe related code into separate file
        devlink: move and rename devlink_dpipe_send_and_alloc_skb() helper
        devlink: push shared buffer related code into separate file
        devlink: push port related code into separate file
        devlink: push object register/unregister notifications into separate helpers
        inet: fix IP_TRANSPARENT error handling
        ...
      bd6c11bc
    • Linus Torvalds's avatar
      Merge tag 'v6.6-p1' of git://git.kernel.org/pub/scm/linux/kernel/git/herbert/crypto-2.6 · 68cf0176
      Linus Torvalds authored
      Pull crypto updates from Herbert Xu:
       "API:
         - Move crypto engine callback from tfm ctx into algorithm object
         - Fix atomic sleep bug in crypto_destroy_instance
         - Move lib/mpi into lib/crypto
      
        Algorithms:
         - Add chacha20 and poly1305 implementation for powerpc p10
      
        Drivers:
         - Add AES skcipher and aead support to starfive
         - Add Dynamic Boost Control support to ccp
         - Add support for STM32P13 platform to stm32"
      
      * tag 'v6.6-p1' of git://git.kernel.org/pub/scm/linux/kernel/git/herbert/crypto-2.6: (149 commits)
        Revert "dt-bindings: crypto: qcom,prng: Add SM8450"
        crypto: chelsio - Remove unused declarations
        X.509: if signature is unsupported skip validation
        crypto: qat - fix crypto capability detection for 4xxx
        crypto: drivers - Explicitly include correct DT includes
        crypto: engine - Remove crypto_engine_ctx
        crypto: zynqmp - Use new crypto_engine_op interface
        crypto: virtio - Use new cry...
      68cf0176
    • Linus Torvalds's avatar
      Merge tag 'gpio-updates-for-v6.6' of git://git.kernel.org/pub/scm/linux/kernel/git/brgl/linux · f97e18a3
      Linus Torvalds authored
      Pull gpio updates from Bartosz Golaszewski:
       "We have a lot of code refactoring using common helpers and ended up
        removing more lines then we're adding this release cycle.
      
        Nothing really stands out, just small updates all over the place.
      
        Core GPIOLIB updates:
         - wake-up poll() in user-space on device unbind
         - improve fwnode usage
         - interrupt domain handling improvements
         - correctly handle the ngpios property in gpio-mmio
      
        Driver cleanups:
         - remove unneeded calls to platform_set_drvdata() all around the
           place
         - remove unneeded of_match_ptr() expansions whenever a driver depends
           on CONFIG_OF
         - remove redundant calls to dev_err_probe() from gpio-omap and
           gpio-davinci
      
        Driver improvements:
         - use autopointers and guards from cleanup.h in gpio-sim
         - shrink code in gpio-sim using some common helpers
         - convert the idio family of drivers to using gpio-regmap
         - convert gpio-ws16c48 to using gpio-regmap
         - use devres to simplify code in gpio-pisosr and gpio-mxc
         - update gpio-sifive: support IRQ wake, improve interrupt handling,
           allow building as module
         - make gpio-ge and gpio-bcm-kona OF-independent (plus some minor
           tweaks)
         - add support for new models in gpio-pca953x and gpio-ds4520
         - add runtime PM support to gpio-mxc
         - fix a build warning in gpio-mxs
         - add support for adding pin ranges to gpio-mlxbf3
         - add counter/timer support to gpio-104-dio-48e
         - switch to dynamic GPIO base allocation in gpio-vf610
         - minor oneliners here and there
      
        Device-tree bindings updates:
         - enable the gpio-line-names property in snps,dw-apb and STMPE GPIO
         - document new models in fsl-imx-gpio, ds4520 and pca95xx
         - convert the bindings for brcm,kona-gpio to YAML"
      
      * tag 'gpio-updates-for-v6.6' of git://git.kernel.org/pub/scm/linux/kernel/git/brgl/linux: (94 commits)
        gpio: pca953x: add support for TCA9538
        dt-bindings: gpio: pca95xx: document new tca9538 chip
        gpio: pca953x: Use i2c_get_match_data()
        gpio: mlxbf3: use capital "OR" for multiple licenses in SPDX
        gpio: pcf857x: Extend match data support for OF tables
        gpio: vf610: switch to dynamic allocat GPIO base
        gpiolib: provide and use gpiod_line_state_notify()
        gpio: cdev: wake up lineevent poll() on device unbind
        gpio: cdev: wake up linereq poll() on device unbind
        gpio: cdev: wake up chardev poll() on device unbind
        gpiolib: add a second blocking notifier to struct gpio_device
        gpio: cdev: open-code to_gpio_chardev_data()
        gpiolib: rename the gpio_device notifier
        gpio: mlxbf3: Support add_pin_ranges()
        gpio: mxc: Use helper function devm_clk_get_optional_enabled()
        gpio: pca9570: fix kerneldoc
        gpio: sim: simplify code with cleanup helpers
        gpio: sim: replace memmove() + strstrip() with skip_spaces() + strim()
        gpio: sim: simplify gpio_sim_device_config_live_store()
        gpio: mxc: release the parent IRQ in runtime suspend
        ...
      f97e18a3
    • Linus Torvalds's avatar
      Merge tag 'hwmon-for-v6.6' of git://git.kernel.org/pub/scm/linux/kernel/git/groeck/linux-staging · 41e97d7a
      Linus Torvalds authored
      Pull hwmon updates from Guenter Roeck:
       "New drivers:
      
         - Renesas HS3001
      
        Chip support added to existing drivers:
      
         - pmbus/mp2975 driver now supports MP2971 and MP2973
      
        Functional improvements:
      
         - Additional voltage and temperature sensor support for
           NCT6798/NCT6799 in nt6755 driver
      
         - it87 driver now detects AMDTSI sensor type
      
         - dimmtemp now supports more than 32 DIMMs
      
        Driver removals:
      
         - sm665 driver removed as unsupportable and long since obsolete
      
        .. and minor fixes, cleanups, and simplifications in several drivers"
      
      * tag 'hwmon-for-v6.6' of git://git.kernel.org/pub/scm/linux/kernel/git/groeck/linux-staging: (57 commits)
        hwmon: (tmp513) Simplify probe()
        hwmon: (tmp513) Fix the channel number in tmp51x_is_visible()
        hwmon: (mlxreg-fan) Extend number of supported fans
        hwmon: (sis5595) Do PCI error checks on own line
        hwmon: (vt8231) Do PCI error checks on own line
        hwmon: (via686a) Do PCI error checks on own line
        hwmon: pmbus: Fix -EIO seen on pli1209
        hwmon: pmbus: Drop unnecessary clear fault page
        hwmon: pmbus: Reduce clear fault page invocations
        hwmon: (nsa320-hwmon) Remove redundant of_match_ptr()
        hwmon: (pmbus/ucd9200) fix Wvoid-pointer-to-enum-cast warning
        hwmon: (pmbus/ucd9000) fix Wvoid-pointer-to-enum-cast warning
        hwmon: (pmbus/tps53679) fix Wvoid-pointer-to-enum-cast warning
        hwmon: (pmbus/ibm-cffps) fix Wvoid-pointer-to-enum-cast warning
        hwmon: (tmp513) fix Wvoid-pointer-to-enum-cast warning
        hwmon: (max6697) fix Wvoid-pointer-to-enum-cast warning
        hwmon: (max20730) fix Wvoid-pointer-to-enum-cast warning
        hwmon: (lm90) fix Wvoid-pointer-to-enum-cast warning
        hwmon: (lm85) fix Wvoid-pointer-to-enum-cast warning
        hwmon: (lm75) fix Wvoid-pointer-to-enum-cast warning
        ...
      41e97d7a
    • Linus Torvalds's avatar
      Merge tag 'mmc-v6.6' of git://git.kernel.org/pub/scm/linux/kernel/git/ulfh/mmc · 995cda62
      Linus Torvalds authored
      Pull MMC updates from Ulf Hansson:
       "MMC core:
         - Convert drivers to use the ->remove_new() callback
         - Propagate the removable attribute for the card's device
      
        MMC host:
         - Convert drivers to use the ->remove_new() callback
         - atmel-mci: Convert to gpio descriptors and cleanup the code
         - davinci: Make SDIO irq truly optional
         - renesas_sdhi: Register irqs before registering controller
         - sdhci: Simplify the sdhci_pltfm_* interface a bit
         - sdhci-esdhc-imx: Improve support for the 1.8V errata
         - sdhci-of-at91: Add support for the microchip sam9x7 variant
         - sdhci-of-dwcmshc: Add support for runtime PM
         - sdhci-pci-o2micro: Add support for the new Bayhub GG8 variant
         - sdhci-sprd: Add support for SD high-speed mode tuning
         - uniphier-sd: Register irqs before registering controller"
      
      * tag 'mmc-v6.6' of git://git.kernel.org/pub/scm/linux/kernel/git/ulfh/mmc: (108 commits)
        mmc: atmel-mci: Move card detect gpio polarity quirk to gpiolib
        mmc: atmel-mci: move atmel MCI header file
        mmc: atmel-mci: Convert to gpio descriptors
        mmc: sdhci-sprd: Add SD HS mode online tuning
        mmc: core: Add host specific tuning support for SD HS mode
        mmc: sdhci-of-dwcmshc: Add runtime PM operations
        mmc: sdhci-of-dwcmshc: Add error handling in dwcmshc_resume
        mmc: sdhci-esdhc-imx: improve ESDHC_FLAG_ERR010450
        mmc: sdhci-pltfm: Rename sdhci_pltfm_register()
        mmc: sdhci-pltfm: Remove sdhci_pltfm_unregister()
        mmc: sdhci-st: Use sdhci_pltfm_remove()
        mmc: sdhci-pxav2: Use sdhci_pltfm_remove()
        mmc: sdhci-of-sparx5: Use sdhci_pltfm_remove()
        mmc: sdhci-of-hlwd: Use sdhci_pltfm_remove()
        mmc: sdhci-of-esdhc: Use sdhci_pltfm_remove()
        mmc: sdhci-of-at91: Use sdhci_pltfm_remove()
        mmc: sdhci-of-arasan: Use sdhci_pltfm_remove()
        mmc: sdhci-iproc: Use sdhci_pltfm_remove()
        mmc: sdhci_f_sdh30: Use sdhci_pltfm_remove()
        mmc: sdhci-dove: Use sdhci_pltfm_remove()
        ...
      995cda62
    • Linus Torvalds's avatar
      Merge tag 'spi-v6.6' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/spi · 3b6bf5b1
      Linus Torvalds authored
      Pull spi updates from Mark Brown:
       "There's been quite a lot of generic activity here, but more
        administrative than featuers. We also have a bunch of new drivers,
        including one that's part of a MFD so we pulled in the core parts of
        that:
      
         - Lots of work from both Yang Yingliang and Andy Shevchenko on moving
           to host/device/controller based terminology for devices.
      
         - QuadSPI SPI support for Allwinner sun6i.
      
         - New device support Cirrus Logic CS43L43, Longsoon, Qualcomm GENI
           QuPv3 and StarFive JH7110 QSPI"
      
      * tag 'spi-v6.6' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/spi: (151 commits)
        spi: at91-usart: Use PTR_ERR_OR_ZERO() to simplify code
        spi: spi-sn-f-ospi: switch to use modern name
        spi: sifive: switch to use modern name
        spi: sh: switch to use modern name
        spi: sh-sci: switch to use modern name
        spi: sh-msiof: switch to use modern name
        spi: sh-hspi: switch to use modern name
        spi: sc18is602: switch to use modern name
        spi: s3c64xx: switch to use modern name
        spi: rzv2m-csi: switch to use devm_spi_alloc_host()
        spi: rspi: switch to use spi_alloc_host()
        spi: rockchip: switch to use modern name
        spi: rockchip-sfc: switch to use modern name
        spi: realtek-rtl: switch to use devm_spi_alloc_host()
        spi: rb4xx: switch to use modern name
        spi: qup: switch to use modern name
        spi: spi-qcom-qspi: switch to use modern name
        spi: pxa2xx: switch to use modern name
        spi: ppc4xx: switch to use modern name
        spi: spl022: switch to use modern name
        ...
      3b6bf5b1
    • Linus Torvalds's avatar
      Merge tag 'regulator-v6.6' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/regulator · 65234f96
      Linus Torvalds authored
      Pull regulator updates from Mark Brown:
       "Other than new device support and some minor fixes this has been a
        really quiet release, the only notable things are the new drivers.
      
        There's a couple of MFDs among the new devices so the generic parts
        are pulled in:
      
         - Support for Analog Devices MAX77831/57/59, Awinc AW37503, Qualcom
           PMX75 and RFGEN, RealTek RT5733, RichTek RTQ2208 and Texas
           Instruments TPS65086"
      
      * tag 'regulator-v6.6' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/regulator: (68 commits)
        regulator: userspace-consumer: Drop event support for this cycle
        regulator: aw37503: Switch back to use struct i2c_driver's .probe()
        dt-bindings: regulator: qcom,rpmh-regulator: allow i, j, l, m & n as RPMh resource name suffix
        regulator: dt-bindings: Add Awinic AW37503
        regulator: aw37503: add regulator driver for Awinic AW37503
        regulator: tps65086: Select dedicated regulator config for chip variant
        mfd: tps65086: Read DEVICE ID register 1 from device
        regulator: raa215300: Update help description
        regulator: raa215300: Add missing blank space
        regulator: raa215300: Change rate from 32000->32768
        regulator: db8500-prcmu: Remove unused declaration power_state_active_is_enabled()
        regulator: raa215300: Add const definition
        regulator: raa215300: Fix resource leak in case of error
        regulator: rtq2208: Switch back to use struct i2c_driver's .probe()
        regulator: lp872x: Fix Wvoid-pointer-to-enum-cast warning
        regulator: max77857: Fix Wvoid-pointer-to-enum-cast warning
        regulator: ltc3589: Fix Wvoid-pointer-to-enum-cast warning
        regulator: qcom_rpm-regulator: Use devm_kmemdup to replace devm_kmalloc + memcpy
        regulator: tps6286x-regulator: Remove redundant of_match_ptr() macros
        regulator: pfuze100-regulator: Remove redundant of_match_ptr() macro
        ...
      65234f96
    • Linus Torvalds's avatar
      Merge tag 'regmap-v6.6' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/regmap · 0fc81f37
      Linus Torvalds authored
      Pull regmap updates from Mark Brown:
       "This is a much quieter release than the past few, there's one small
        API addition that I noticed a user for in ALSA and a bunch of
        cleanups:
      
         - Provide an interface for determining if a register is present in
           the cache and add a user of it in ALSA.
      
         - Full support for dynamic allocations, following the temporary
           bodges that were done as fixes in the previous release.
      
         - Remove the unused and questionably working 64 bit support"
      
      * tag 'regmap-v6.6' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/regmap:
        regmap: Fix the type used for a bitmap pointer
        regmap: Remove dynamic allocation warnings for rbtree and maple
        regmap: rbtree: Use alloc_flags for memory allocations
        regmap: maple: Use alloc_flags for memory allocations
        regmap: Reject fast_io regmap configurations with RBTREE and MAPLE caches
        ALSA: hda: Use regcache_reg_cached() rather than open coding
        regmap: Provide test for regcache_reg_present()
        regmap: Let users check if a register is cached
        regmap: Provide user selectable option to enable regmap
        regmap: mmio: Remove unused 64-bit support code
        regmap: cache: Revert "Add 64-bit mode support"
        regmap: Revert "add 64-bit mode support" and Co.
      0fc81f37
    • Linus Torvalds's avatar
      Merge tag 'hsi-for-6.6' of git://git.kernel.org/pub/scm/linux/kernel/git/sre/linux-hsi · c35c486c
      Linus Torvalds authored
      Pull HSI update from Sebastian Reichel:
      
       - explicitly include correct DT includes
      
      * tag 'hsi-for-6.6' of git://git.kernel.org/pub/scm/linux/kernel/git/sre/linux-hsi:
        hsi: omap_ssi: Explicitly include correct DT includes
      c35c486c
  4. Aug 29, 2023
    • Linus Torvalds's avatar
      Merge tag 'for-v6.6' of git://git.kernel.org/pub/scm/linux/kernel/git/sre/linux-power-supply · b547f9b3
      Linus Torvalds authored
      Pull power supply and reset updates from Sebastian Reichel:
      
       - core: avoid duplicate hwmon device from thermal framework
      
       - convert multiple drivers to devm_platform_ioremap_resource
      
       - at91-reset: add sysfs interface to the power on reason
      
       - misc small fixes and improvements
      
      * tag 'for-v6.6' of git://git.kernel.org/pub/scm/linux/kernel/git/sre/linux-power-supply:
        power: supply: qcom_pmi8998_charger: fix charger status
        power: supply: qcom_pmi8998_charger: remove CHARGE_CONTROL_LIMIT_* props
        power: supply: qcom_pmi8998_charger: fix uninitialized variable
        power: reset: oxnas-restart: remove obsolete restart driver
        power: supply: core: Avoid duplicate hwmon device from thermal framework
        power: reset: ocelot: Convert to devm_platform_ioremap_resource()
        power: reset: msm: Convert to devm_platform_ioremap_resource()
        power: reset: gemini-poweroff: Convert to devm_platform_ioremap_resource()
        power: reset: brcm-kona: Convert to devm_platform_ioremap_resource()
        power: reset: at91-sama5d2_shdwc: Convert to devm_platform_ioremap_resource()
        power: reset: at91-poweroff: Convert to devm_platform_ioremap_resource()
        power: reset: at91-reset: add sysfs interface to the power on reason
        power: supply: bd99954: make read-only array sub_status_reg
        power: supply: bq24190: Considers FORCE_20PCT when getting IPRECHG
        power: Explicitly include correct DT includes
      b547f9b3
    • Linus Torvalds's avatar
      Merge tag 'auxdisplay-6.6' of https://github.com/ojeda/linux · 5ea0cf77
      Linus Torvalds authored
      Pull auxdisplay update from Miguel Ojeda:
      
       - hd44780: move cursor home after clear display command
      
         The change allows to support displays like the NewHaven
         NHD-0220DZW-AG5 which has a non-standard controller.
      
      * tag 'auxdisplay-6.6' of https://github.com/ojeda/linux:
        auxdisplay: hd44780: move cursor home after clear display command
      5ea0cf77
    • Linus Torvalds's avatar
      Merge tag 'rust-6.6' of https://github.com/Rust-for-Linux/linux · a031fe8d
      Linus Torvalds authored
      Pull rust updates from Miguel Ojeda:
       "In terms of lines, most changes this time are on the pinned-init API
        and infrastructure. While we have a Rust version upgrade, and thus a
        bunch of changes from the vendored 'alloc' crate as usual, this time
        those do not account for many lines.
      
        Toolchain and infrastructure:
      
         - Upgrade to Rust 1.71.1. This is the second such upgrade, which is a
           smaller jump compared to the last time.
      
           This version allows us to remove the '__rust_*' allocator functions
           -- the compiler now generates them as expected, thus now our
           'KernelAllocator' is used.
      
           It also introduces the 'offset_of!' macro in the standard library
           (as an unstable feature) which we will need soon. So far, we were
           using a declarative macro as a prerequisite in some not-yet-landed
           patch series, which did not support sub-fields (i.e. nested
           structs):
      
               #[repr(C)]
               struct S {
                   a: u16,
                   b: (u8, u8),
               }
      
               assert_eq!(offset_of!(S, b.1), 3);
      
         - Upgrade to bindgen 0.65.1. This is the first time we upgrade its
           version.
      
           Given it is a fairly big jump, it comes with a fair number of
           improvements/changes that affect us, such as a fix needed to
           support LLVM 16 as well as proper support for '__noreturn' C
           functions, which are now mapped to return the '!' type in Rust:
      
               void __noreturn f(void); // C
               pub fn f() -> !;         // Rust
      
         - 'scripts/rust_is_available.sh' improvements and fixes.
      
           This series takes care of all the issues known so far and adds a
           few new checks to cover for even more cases, plus adds some more
           help texts. All this together will hopefully make problematic
           setups easier to identify and to be solved by users building the
           kernel.
      
           In addition, it adds a test suite which covers all branches of the
           shell script, as well as tests for the issues found so far.
      
         - Support rust-analyzer for out-of-tree modules too.
      
         - Give 'cfg's to rust-analyzer for the 'core' and 'alloc' crates.
      
         - Drop 'scripts/is_rust_module.sh' since it is not needed anymore.
      
        Macros crate:
      
         - New 'paste!' proc macro.
      
           This macro is a more flexible version of 'concat_idents!': it
           allows the resulting identifier to be used to declare new items and
           it allows to transform the identifiers before concatenating them,
           e.g.
      
               let x_1 = 42;
               paste!(let [<x _2>] = [<x _1>];);
               assert!(x_1 == x_2);
      
           The macro is then used for several of the pinned-init API changes
           in this pull.
      
        Pinned-init API:
      
         - Make '#[pin_data]' compatible with conditional compilation of
           fields, allowing to write code like:
      
               #[pin_data]
               pub struct Foo {
                   #[cfg(CONFIG_BAR)]
                   a: Bar,
                   #[cfg(not(CONFIG_BAR))]
                   a: Baz,
               }
      
         - New '#[derive(Zeroable)]' proc macro for the 'Zeroable' trait,
           which allows 'unsafe' implementations for structs where every field
           implements the 'Zeroable' trait, e.g.:
      
               #[derive(Zeroable)]
               pub struct DriverData {
                   id: i64,
                   buf_ptr: *mut u8,
                   len: usize,
               }
      
         - Add '..Zeroable::zeroed()' syntax to the 'pin_init!' macro for
           zeroing all other fields, e.g.:
      
               pin_init!(Buf {
                   buf: [1; 64],
                   ..Zeroable::zeroed()
               });
      
         - New '{,pin_}init_array_from_fn()' functions to create array
           initializers given a generator function, e.g.:
      
               let b: Box<[usize; 1_000]> = Box::init::<Error>(
                   init_array_from_fn(|i| i)
               ).unwrap();
      
               assert_eq!(b.len(), 1_000);
               assert_eq!(b[123], 123);
      
         - New '{,pin_}chain' methods for '{,Pin}Init<T, E>' that allow to
           execute a closure on the value directly after initialization, e.g.:
      
               let foo = init!(Foo {
                   buf <- init::zeroed()
               }).chain(|foo| {
                   foo.setup();
                   Ok(())
               });
      
         - Support arbitrary paths in init macros, instead of just identifiers
           and generic types.
      
         - Implement the 'Zeroable' trait for the 'UnsafeCell<T>' and
           'Opaque<T>' types.
      
         - Make initializer values inaccessible after initialization.
      
         - Make guards in the init macros hygienic.
      
        'allocator' module:
      
         - Use 'krealloc_aligned()' in 'KernelAllocator::alloc' preventing
           misaligned allocations when the Rust 1.71.1 upgrade is applied
           later in this pull.
      
           The equivalent fix for the previous compiler version (where
           'KernelAllocator' is not yet used) was merged into 6.5 already,
           which added the 'krealloc_aligned()' function used here.
      
         - Implement 'KernelAllocator::{realloc, alloc_zeroed}' for
           performance, using 'krealloc_aligned()' too, which forwards the
           call to the C API.
      
        'types' module:
      
         - Make 'Opaque' be '!Unpin', removing the need to add a
           'PhantomPinned' field to Rust structs that contain C structs which
           must not be moved.
      
         - Make 'Opaque' use 'UnsafeCell' as the outer type, rather than
           inner.
      
        Documentation:
      
         - Suggest obtaining the source code of the Rust's 'core' library
           using the tarball instead of the repository.
      
        MAINTAINERS:
      
         - Andreas and Alice, from Samsung and Google respectively, are
           joining as reviewers of the "RUST" entry.
      
        As well as a few other minor changes and cleanups"
      
      * tag 'rust-6.6' of https://github.com/Rust-for-Linux/linux: (42 commits)
        rust: init: update expanded macro explanation
        rust: init: add `{pin_}chain` functions to `{Pin}Init<T, E>`
        rust: init: make `PinInit<T, E>` a supertrait of `Init<T, E>`
        rust: init: implement `Zeroable` for `UnsafeCell<T>` and `Opaque<T>`
        rust: init: add support for arbitrary paths in init macros
        rust: init: add functions to create array initializers
        rust: init: add `..Zeroable::zeroed()` syntax for zeroing all missing fields
        rust: init: make initializer values inaccessible after initializing
        rust: init: wrap type checking struct initializers in a closure
        rust: init: make guards in the init macros hygienic
        rust: add derive macro for `Zeroable`
        rust: init: make `#[pin_data]` compatible with conditional compilation of fields
        rust: init: consolidate init macros
        docs: rust: clarify what 'rustup override' does
        docs: rust: update instructions for obtaining 'core' source
        docs: rust: add command line to rust-analyzer section
        scripts: generate_rust_analyzer: provide `cfg`s for `core` and `alloc`
        rust: bindgen: upgrade to 0.65.1
        rust: enable `no_mangle_with_rust_abi` Clippy lint
        rust: upgrade to Rust 1.71.1
        ...
      a031fe8d
    • Linus Torvalds's avatar
      Merge tag 'tpmdd-v6.6' of git://git.kernel.org/pub/scm/linux/kernel/git/jarkko/linux-tpmdd · f2586d92
      Linus Torvalds authored
      Pull tpm updates from Jarkko Sakkinen:
      
       - Restrict linking of keys to .ima and .evm keyrings based on
         digitalSignature attribute in the certificate
      
       - PowerVM: load machine owner keys into the .machine [1] keyring
      
       - PowerVM: load module signing keys into the secondary trusted keyring
         (keys blessed by the vendor)
      
       - tpm_tis_spi: half-duplex transfer mode
      
       - tpm_tis: retry corrupted transfers
      
       - Apply revocation list (.mokx) to an all system keyrings (e.g.
         .machine keyring)
      
      Link: https://blogs.oracle.com/linux/post/the-machine-keyring [1]
      
      * tag 'tpmdd-v6.6' of git://git.kernel.org/pub/scm/linux/kernel/git/jarkko/linux-tpmdd:
        certs: Reference revocation list for all keyrings
        tpm/tpm_tis_synquacer: Use module_platform_driver macro to simplify the code
        tpm: remove redundant variable len
        tpm_tis: Resend command to recover from data transfer errors
        tpm_tis: Use responseRetry to recover from data transfer errors
        tpm_tis: Move CRC check to generic send routine
        tpm_tis_spi: Add hardware wait polling
        KEYS: Replace all non-returning strlcpy with strscpy
        integrity: PowerVM support for loading third party code signing keys
        integrity: PowerVM machine keyring enablement
        integrity: check whether imputed trust is enabled
        integrity: remove global variable from machine_keyring.c
        integrity: ignore keys failing CA restrictions on non-UEFI platform
        integrity: PowerVM support for loading CA keys on machine keyring
        integrity: Enforce digitalSignature usage in the ima and evm keyrings
        KEYS: DigitalSignature link restriction
        tpm_tis: Revert "tpm_tis: Disable interrupts on ThinkPad T490s"
      f2586d92
    • Paolo Abeni's avatar
      Merge git://git.kernel.org/pub/scm/linux/kernel/git/netdev/net · c873512e
      Paolo Abeni authored
      
      
      Merge in late fixes to prepare for the 6.6 net-next PR.
      
      No conflicts.
      
      Signed-off-by: default avatarPaolo Abeni <pabeni@redhat.com>
      c873512e
    • Linus Torvalds's avatar
      Merge tag 'linux-kselftest-nolibc-6.6-rc1' of... · 1c59d383
      Linus Torvalds authored
      Merge tag 'linux-kselftest-nolibc-6.6-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest
      
      Pull nolibc updates from Shuah Khan:
       "Nolibc:
         - improved portability by removing build errors with -ENOSYS
         - added syscall6() on MIPS to support pselect6() and mmap()
         - added setvbuf(), rmdir(), pipe(), pipe2()
         - add support for ppc/ppc64
         - environ is no longer optional
         - fixed frame pointer issues at -O0
         - dropped sys_stat() in favor of sys_statx()
         - centralized _start_c() to remove lots of asm code
         - switched size_t to __SIZE_TYPE__
      
        Selftests:
         - improved status reporting (success/warning/failure counts, path to
           log file)
         - various code cleanups (indent, unused variables, ...)
         - more consistent test numbering
         - enabled compiler warnings
         - dropped unreliable chmod_net test
         - improved reliability (create /dev/zero & /tmp, rely less on /proc)
         - new tests (brk/sbrk/mmap/munmap)
         - improved compatibility with musl
         - new run-nolibc-test target to build and run natively
         - new run-libc-test target to build and run against native libc
         - made the cmdline parser more reliable against boolean arguments
         - dropped dependency on memfd for vfprintf() test
         - nolibc-test is no longer stripped
         - added support for extending ARCH via XARCH
      
        Other:
         - add Thomas as co-maintainer"
      
      * tag 'linux-kselftest-nolibc-6.6-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest: (103 commits)
        tools/nolibc: avoid undesired casts in the __sysret() macro
        tools/nolibc: keep brk(), sbrk(), mmap() away from __sysret()
        tools/nolibc: silence ppc64 compile warnings
        selftests/nolibc: libc-test: use HOSTCC instead of CC
        tools/nolibc: stackprotector.h: make __stack_chk_init static
        selftests/nolibc: allow report with existing test log
        selftests/nolibc: add test support for ppc64
        selftests/nolibc: add test support for ppc64le
        selftests/nolibc: add test support for ppc
        selftests/nolibc: add XARCH and ARCH mapping support
        tools/nolibc: add support for powerpc64
        tools/nolibc: add support for powerpc
        MAINTAINERS: nolibc: add myself as co-maintainer
        selftests/nolibc: enable compiler warnings
        selftests/nolibc: don't strip nolibc-test
        selftests/nolibc: prevent out of bounds access in expect_vfprintf
        selftests/nolibc: use correct return type for read() and write()
        selftests/nolibc: avoid sign-compare warnings
        selftests/nolibc: avoid unused parameter warnings
        selftests/nolibc: make functions static if possible
        ...
      1c59d383
    • Linus Torvalds's avatar
      Merge tag 'linux-kselftest-kunit-6.6-rc1' of... · 815c24a0
      Linus Torvalds authored
      Merge tag 'linux-kselftest-kunit-6.6-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest
      
      Pull kunit updates from Shuah Khan:
      
       - add support for running Rust documentation tests as KUnit tests
      
       - make init, str, sync, types doctests compilable/testable
      
       - add support for attributes API which include speed, modules
         attributes, ability to filter and report attributes
      
       - add support for marking tests slow using attributes API
      
       - add attributes API documentation
      
       - fix a wild-memory-access bug in kunit_filter_suites() and a possible
         memory leak in kunit_filter_suites()
      
       - add support for counting number of test suites in a module, list
         action to kunit test modules, and test filtering on module tests
      
      * tag 'linux-kselftest-kunit-6.6-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest: (25 commits)
        kunit: fix struct kunit_attr header
        kunit: replace KUNIT_TRIGGER_STATIC_STUB maro with KUNIT_STATIC_STUB_REDIRECT
        kunit: Allow kunit test modules to use test filtering
        kunit: Make 'list' action available to kunit test modules
        kunit: Report the count of test suites in a module
        kunit: fix uninitialized variables bug in attributes filtering
        kunit: fix possible memory leak in kunit_filter_suites()
        kunit: fix wild-memory-access bug in kunit_filter_suites()
        kunit: Add documentation of KUnit test attributes
        kunit: add tests for filtering attributes
        kunit: time: Mark test as slow using test attributes
        kunit: memcpy: Mark tests as slow using test attributes
        kunit: tool: Add command line interface to filter and report attributes
        kunit: Add ability to filter attributes
        kunit: Add module attribute
        kunit: Add speed attribute
        kunit: Add test attributes API structure
        MAINTAINERS: add Rust KUnit files to the KUnit entry
        rust: support running Rust documentation tests as KUnit ones
        rust: types: make doctests compilable/testable
        ...
      815c24a0
    • Linus Torvalds's avatar
      Merge tag 'linux-kselftest-next-6.6-rc1' of... · 5a31cc72
      Linus Torvalds authored
      Merge tag 'linux-kselftest-next-6.6-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest
      
      Pull Kselftest updates from Shuah Khan:
       "A mix of fixes, enhancements, and new tests. Bulk of the changes
        enhance and fix rseq and resctrl tests.
      
        In addition, user_events, dmabuf-heaps and perf_events are added to
        default kselftest build and test coverage. A futex test fix, enhance
        prctl test coverage, and minor fixes are included in this update"
      
      * tag 'linux-kselftest-next-6.6-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest: (32 commits)
        selftests: cachestat: use proper syscall number macro
        selftests: cachestat: properly link in librt
        selftests/futex: Order calls to futex_lock_pi
        selftests: Hook more tests into the build infrastructure
        selftests/user_events: Reenable build
        selftests/filesystems: Add six consecutive 'x' characters to mktemp
        selftests/rseq: Use rseq_unqual_scalar_typeof in macros
        selftests/rseq: Fix arm64 buggy load-acquire/store-release macros
        selftests/rseq: Implement rseq_unqual_scalar_typeof
        selftests/rseq: Fix CID_ID typo in Makefile
        selftests:prctl: add set-process-name to .gitignore
        selftests:prctl: Fix make clean override warning
        selftests/resctrl: Remove test type checks from cat_val()
        selftests/resctrl: Pass the real number of tests to show_cache_info()
        selftests/resctrl: Move CAT/CMT test global vars to function they are used in
        selftests/resctrl: Don't use variable argument list for ->setup()
        selftests/resctrl: Don't pass test name to fill_buf
        selftests/resctrl: Improve parameter consistency in fill_buf
        selftests/resctrl: Remove unnecessary startptr global from fill_buf
        selftests/resctrl: Remove "malloc_and_init_memory" param from run_fill_buf()
        ...
      5a31cc72
    • Linus Torvalds's avatar
      Merge tag 'thermal-6.6-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm · 36534782
      Linus Torvalds authored
      Pull thermal control updates from Rafael Wysocki:
       "These rework the Intel DTS IOSF and the ACPI thermal drivers to pass
        tables of generic trip point structures to the core during
        initialization and make some requisite modifications in the thermal
        core, fix a few issues elsewhere and clean up code.
      
        This includes changes that are present in the ACPI updates too,
        because they involve both ACPI and the thermal core. The list of
        specific changes below is limited to thermal control, however.
      
        Specifics:
      
         - Make the ACPI thermal driver use its own Notify() handler (Michal
           Wilczynski)
      
         - Rework the ACPI thermal driver to use a table of generic trip point
           structures on top of the internal representation of trip points and
           remove thermal zone callbacks that are not necessary any more from
           that driver (Rafael Wysocki)
      
         - Fix a few issues in the Intel DTS IOSF thermal driver, clean up
           code in it and make it pass tables of generic trip point structures
           to the core during thermal zone registration (Rafael Wysocki)
      
         - Drop a redundant check from the Intel DTS IOSF thermal driver's
           "remove" routine (Zhang Rui)
      
         - Use module_platform_driver() to replace an open-coded counterpart
           of it in the int340x thermal driver (Yang Yingliang)
      
         - Fix possible uninitialized value access in __thermal_of_bind() and
           __thermal_of_unbind() (Peng Fan)
      
         - Make the int3400 driver use thermal zone device wrappers (Daniel
           Lezcano)
      
         - Remove redundant thermal zone state check from the int340x thermal
           driver (Daniel Lezcano)
      
         - Drop non-functional nocrt parameter from ACPI thermal (Mario
           Limonciello)
      
         - Explicitly include correct DT includes in the thermal core and
           drivers (Rob Herring)"
      
      * tag 'thermal-6.6-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm:
        thermal: intel: intel_soc_dts_iosf: Remove redundant check
        thermal: intel: int340x: simplify the code with module_platform_driver()
        thermal/of: Fix potential uninitialized value access
        thermal: intel: intel_soc_dts_iosf: Use struct thermal_trip
        thermal: intel: intel_soc_dts_iosf: Rework critical trip setup
        thermal: intel: intel_soc_dts_iosf: Add helper for resetting trip points
        thermal: intel: intel_soc_dts_iosf: Change initialization ordering
        thermal: intel: intel_soc_dts_iosf: Pass sensors to update_trip_temp()
        thermal: intel: intel_soc_dts_iosf: Untangle update_trip_temp()
        thermal: intel: intel_soc_dts_iosf: Always assume notification support
        thermal: intel: intel_soc_dts_iosf: Drop redundant symbol definition
        thermal: intel: intel_soc_dts_iosf: Always use 2 trips
        thermal: Explicitly include correct DT includes
        thermal/drivers/int340x: Do not check the thermal zone state
        thermal/drivers/int3400: Use thermal zone device wrappers
      36534782
    • Linus Torvalds's avatar
      Merge tag 'pm-6.6-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm · ccc5e981
      Linus Torvalds authored
      Pull power management updates from Rafael Wysocki:
       "These rework cpuidle governors to call tick_nohz_get_sleep_length()
        less often and fix one of them, rework hibernation to avoid storing
        pages filled with zeros in hibernation images, switch over some
        cpufreq drivers to use void remove callbacks, fix and clean up
        multiple cpufreq drivers, fix the devfreq core, update the cpupower
        utility and make other assorted improvements.
      
        Specifics:
      
         - Rework the menu and teo cpuidle governors to avoid calling
           tick_nohz_get_sleep_length(), which is likely to become quite
           expensive going forward, too often and improve making decisions
           regarding whether or not to stop the scheduler tick in the teo
           governor (Rafael Wysocki)
      
         - Improve the performance of cpufreq_stats_create_table() in some
           cases (Liao Chang)
      
         - Fix two issues in the amd-pstate-ut cpufreq driver (Swapnil Sapkal)
      
         - Use clamp() helper macro to improve the code readability in
           cpufreq_verify_within_limits() (Liao Chang)
      
         - Set stale CPU frequency to minimum in intel_pstate (Doug Smythies)
      
         - Migrate cpufreq drivers for various platforms to use void remove
           callback (Yangtao Li)
      
         - Add online/offline/exit hooks for Tegra driver (Sumit Gupta)
      
         - Explicitly include correct DT includes in cpufreq (Rob Herring)
      
         - Frequency domain updates for qcom-hw driver (Neil Armstrong)
      
         - Modify AMD pstate driver return the highest_perf value (Meng Li)
      
         - Generic cleanups for cppc, mediatek and powernow driver (Liao
           Chang, Konrad Dybcio)
      
         - Add more platforms to cpufreq-arm driver's blocklist
           (AngeloGioacchino Del Regno and Konrad Dybcio)
      
         - brcmstb-avs-cpufreq: Fix -Warray-bounds bug (Gustavo A. R. Silva)
      
         - Add device PM helpers to allow a device to remain powered-on during
           system-wide transitions (Ulf Hansson)
      
         - Rework hibernation memory snapshotting to avoid storing pages
           filled with zeros in hibernation image files (Brian Geffon)
      
         - Add check to make sure that CPU latency QoS constraints do not use
           negative values (Clive Lin)
      
         - Optimize rp->domains memory allocation in the Intel RAPL power
           capping driver (xiongxin)
      
         - Remove recursion while parsing zones in the arm_scmi power capping
           driver (Cristian Marussi)
      
         - Fix memory leak in devfreq_dev_release() (Boris Brezillon)
      
         - Rewrite devfreq_monitor_start() kerneldoc comment (Manivannan
           Sadhasivam)
      
         - Explicitly include correct DT includes in devfreq (Rob Herring)
      
         - Remove unsued pm_runtime_update_max_time_suspended() extern
           declaration (YueHaibing)
      
         - Add turbo-boost support to cpupower (Wyes Karny)
      
         - Add support for amd_pstate mode change to cpupower (Wyes Karny)
      
         - Fix 'cpupower idle_set' command to accept only numeric values of
           arguments (Likhitha Korrapati)
      
         - Clean up OPP code and add new frequency related APIs to it (Viresh
           Kumar, Manivannan Sadhasivam)
      
         - Convert ti cpufreq/opp bindings to json schema (Nishanth Menon)"
      
      * tag 'pm-6.6-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm: (74 commits)
        cpufreq: tegra194: remove opp table in exit hook
        cpufreq: powernow-k8: Use related_cpus instead of cpus in driver.exit()
        cpufreq: tegra194: add online/offline hooks
        cpuidle: teo: Avoid unnecessary variable assignments
        cpufreq: qcom-cpufreq-hw: add support for 4 freq domains
        dt-bindings: cpufreq: qcom-hw: add a 4th frequency domain
        cpufreq: amd-pstate-ut: Fix kernel panic when loading the driver
        cpufreq: amd-pstate-ut: Remove module parameter access
        cpufreq: Use clamp() helper macro to improve the code readability
        PM: sleep: Add helpers to allow a device to remain powered-on
        PM: QoS: Add check to make sure CPU latency is non-negative
        PM: runtime: Remove unsued extern declaration of pm_runtime_update_max_time_suspended()
        cpufreq: intel_pstate: set stale CPU frequency to minimum
        cpufreq: stats: Improve the performance of cpufreq_stats_create_table()
        dt-bindings: cpufreq: Convert ti-cpufreq to json schema
        dt-bindings: opp: Convert ti-omap5-opp-supply to json schema
        OPP: Fix argument name in doc comment
        cpuidle: menu: Skip tick_nohz_get_sleep_length() call in some cases
        cpufreq: cppc: Set fie_disabled to FIE_DISABLED if fails to create kworker_fie
        cpufreq: cppc: cppc_cpufreq_get_rate() returns zero in all error cases.
        ...
      ccc5e981
    • Linus Torvalds's avatar
      Merge tag 'acpi-6.6-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm · 330235e8
      Linus Torvalds authored
      Pull ACPI updates from Rafael Wysocki:
       "These include new ACPICA material, a rework of the ACPI thermal
        driver, a switch-over of the ACPI processor driver to using _OSC
        instead of (long deprecated) _PDC for CPU initialization, a rework of
        firmware notifications handling in several drivers, fixes and cleanups
        for suspend-to-idle handling on AMD systems, ACPI backlight driver
        updates and more.
      
        Specifics:
      
         - Update the ACPICA code in the kernel to upstream revision 20230628
           including the following changes:
            - Suppress a GCC 12 dangling-pointer warning (Philip Prindeville)
            - Reformat the ACPI_STATE_COMMON macro and its users (George Guo)
            - Replace the ternary operator with ACPI_MIN() (Jiangshan Yi)
            - Add support for _DSC as per ACPI 6.5 (Saket Dumbre)
            - Remove a duplicate macro from zephyr header (Najumon B.A)
            - Add data structures for GED and _EVT tracking (Jose Marinho)
            - Fix misspelled CDAT DSMAS define (Dave Jiang)
            - Simplify an error message in acpi_ds_result_push() (Christophe
              Jaillet)
            - Add a struct size macro related to SRAT (Dave Jiang)
            - Add AML_NO_OPERAND_RESOLVE flag to Timer (Abhishek Mainkar)
            - Add support for RISC-V external interrupt controllers in MADT
              (Sunil V L)
            - Add RHCT flags, CMO and MMU nodes (Sunil V L)
            - Change ACPICA version to 20230628 (Bob Moore)
      
         - Introduce new wrappers for ACPICA notify handler install/remove and
           convert multiple drivers to using their own Notify() handlers
           instead of the ACPI bus type .notify() slated for removal (Michal
           Wilczynski)
      
         - Add backlight=native DMI quirk for Apple iMac12,1 and iMac12,2
           (Hans de Goede)
      
         - Put ACPI video and its child devices explicitly into D0 on boot to
           avoid platform firmware confusion (Kai-Heng Feng)
      
         - Add backlight=native DMI quirk for Lenovo Ideapad Z470 (Jiri Slaby)
      
         - Support obtaining physical CPU ID from MADT on LoongArch (Bibo Mao)
      
         - Convert ACPI CPU initialization to using _OSC instead of _PDC that
           has been depreceted since 2018 and dropped from the specification
           in ACPI 6.5 (Michal Wilczynski, Rafael Wysocki)
      
         - Drop non-functional nocrt parameter from ACPI thermal (Mario
           Limonciello)
      
         - Clean up the ACPI thermal driver, rework the handling of firmware
           notifications in it and make it provide a table of generic trip
           point structures to the core during initialization (Rafael Wysocki)
      
         - Defer enumeration of devices with _DEP pointing to IVSC (Wentong
           Wu)
      
         - Install SystemCMOS address space handler for ACPI000E (TAD) to meet
           platform firmware expectations on some platforms (Zhang Rui)
      
         - Fix finding the generic error data in the ACPi extlog driver for
           compatibility with old and new firmware interface versions
           (Xiaochun Lee)
      
         - Remove assorted unused declarations of functions (Yue Haibing)
      
         - Move AMBA bus scan handling into arm64 specific directory (Sudeep
           Holla)
      
         - Fix and clean up suspend-to-idle interface for AMD systems (Mario
           Limonciello, Andy Shevchenko)
      
         - Fix string truncation warning in pnpacpi_add_device() (Sunil V L)"
      
      * tag 'acpi-6.6-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm: (66 commits)
        ACPI: x86: s2idle: Add a function to get LPS0 constraint for a device
        ACPI: x86: s2idle: Add for_each_lpi_constraint() helper
        ACPI: x86: s2idle: Add more debugging for AMD constraints parsing
        ACPI: x86: s2idle: Fix a logic error parsing AMD constraints table
        ACPI: x86: s2idle: Catch multiple ACPI_TYPE_PACKAGE objects
        ACPI: x86: s2idle: Post-increment variables when getting constraints
        ACPI: Adjust #ifdef for *_lps0_dev use
        ACPI: TAD: Install SystemCMOS address space handler for ACPI000E
        ACPI: Remove assorted unused declarations of functions
        ACPI: extlog: Fix finding the generic error data for v3 structure
        PNP: ACPI: Fix string truncation warning
        ACPI: Remove unused extern declaration acpi_paddr_to_node()
        ACPI: video: Add backlight=native DMI quirk for Apple iMac12,1 and iMac12,2
        ACPI: video: Put ACPI video and its child devices into D0 on boot
        ACPI: processor: LoongArch: Get physical ID from MADT
        ACPI: scan: Defer enumeration of devices with a _DEP pointing to IVSC device
        ACPI: thermal: Eliminate code duplication from acpi_thermal_notify()
        ACPI: thermal: Drop unnecessary thermal zone callbacks
        ACPI: thermal: Rework thermal_get_trend()
        ACPI: thermal: Use trip point table to register thermal zones
        ...
      330235e8
    • Linus Torvalds's avatar
      Merge tag 'tag-chrome-platform-firmware-for-v6.6' of... · 2927d226
      Linus Torvalds authored
      Merge tag 'tag-chrome-platform-firmware-for-v6.6' of git://git.kernel.org/pub/scm/linux/kernel/git/chrome-platform/linux
      
      Pull chrome platform firmware update from Tzung-Bi Shih:
      
       - Add MAINTAINERS entry for chrome platform firmware
      
      * tag 'tag-chrome-platform-firmware-for-v6.6' of git://git.kernel.org/pub/scm/linux/kernel/git/chrome-platform/linux:
        MAINTAINERS: Add drivers/firmware/google/ entry
      2927d226
    • Linus Torvalds's avatar
      Merge tag 'tag-chrome-platform-for-v6.6' of... · 670f0897
      Linus Torvalds authored
      Merge tag 'tag-chrome-platform-for-v6.6' of git://git.kernel.org/pub/scm/linux/kernel/git/chrome-platform/linux
      
      Pull chrome platform updates from Tzung-Bi Shih:
       "Improvements:
      
        - Remove shutdown timeout on EC panic for offering the filesystem a
          chance to sync
      
        - Support official HID "GOOG0016" for ChromeOS ACPI
      
        Fixes:
      
        - Print hex string instead of using "%s" for ACPI_TYPE_BUFFER
      
        Misc:
      
        - Update MAINTAINERS"
      
      * tag 'tag-chrome-platform-for-v6.6' of git://git.kernel.org/pub/scm/linux/kernel/git/chrome-platform/linux:
        platform/chrome: chromeos_acpi: print hex string for ACPI_TYPE_BUFFER
        platform/chrome: chromeos_acpi: support official HID GOOG0016
        platform/chrome: cros_ec_lpc: Remove EC panic shutdown timeout
        MAINTAINERS: update maintainers of chrome-platform
      670f0897
    • Linus Torvalds's avatar
      Merge tag 'for-linus-6.6-rc1-tag' of git://git.kernel.org/pub/scm/linux/kernel/git/xen/tip · 6383cb42
      Linus Torvalds authored
      Pull xen updates from Juergen Gross:
      
       - a bunch of minor cleanups
      
       - a patch adding irqfd support for virtio backends running as user
         daemon supporting Xen guests
      
      * tag 'for-linus-6.6-rc1-tag' of git://git.kernel.org/pub/scm/linux/kernel/git/xen/tip:
        xen: privcmd: Add support for irqfd
        xen/xenbus: Avoid a lockdep warning when adding a watch
        xen: Fix one kernel-doc comment
        xen: xenbus: Use helper function IS_ERR_OR_NULL()
        xen: Switch to use kmemdup() helper
        xen-pciback: Remove unused function declarations
        x86/xen: Make virt_to_pfn() a static inline
        xen: remove a confusing comment on auto-translated guest I/O
        xen/evtchn: Remove unused function declaration xen_set_affinity_evtchn()
      6383cb42