1. 27 Oct, 2021 8 commits
    • David S. Miller's avatar
      Merge branch 'hns3-fixes' · 424a4f52
      David S. Miller authored
      Guangbin Huang says:
      
      ====================
      net: hns3: add some fixes for -net
      
      This series adds some fixes for the HNS3 ethernet driver.
      ====================
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      424a4f52
    • Guangbin Huang's avatar
      net: hns3: adjust string spaces of some parameters of tx bd info in debugfs · 630a6738
      Guangbin Huang authored
      This patch adjusts the string spaces of some parameters of tx bd info in
      debugfs according to their maximum needs.
      Signed-off-by: default avatarGuangbin Huang <huangguangbin2@huawei.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      630a6738
    • Guangbin Huang's avatar
      net: hns3: expand buffer len for some debugfs command · c7a6e397
      Guangbin Huang authored
      The specified buffer length for three debugfs files fd_tcam, uc and tqp
      is not enough for their maximum needs, so this patch fixes them.
      
      Fixes: b5a0b70d ("net: hns3: refactor dump fd tcam of debugfs")
      Fixes: 1556ea91 ("net: hns3: refactor dump mac list of debugfs")
      Fixes: d96b0e59 ("net: hns3: refactor dump reg of debugfs")
      Signed-off-by: default avatarGuangbin Huang <huangguangbin2@huawei.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      c7a6e397
    • Jie Wang's avatar
      net: hns3: add more string spaces for dumping packets number of queue info in debugfs · 6754614a
      Jie Wang authored
      As the width of packets number registers is 32 bits, they needs at most
      10 characters for decimal data printing, but now the string spaces is not
      enough, so this patch fixes it.
      
      Fixes: e44c495d ("net: hns3: refactor queue info of debugfs")
      Signed-off-by: default avatarJie Wang <wangjie125@huawei.com>
      Signed-off-by: default avatarGuangbin Huang <huangguangbin2@huawei.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      6754614a
    • Jie Wang's avatar
      net: hns3: fix data endian problem of some functions of debugfs · 2a21dab5
      Jie Wang authored
      The member data in struct hclge_desc is type of __le32, it needs endian
      conversion before using it, and some functions of debugfs didn't do that,
      so this patch fixes it.
      
      Fixes: c0ebebb9 ("net: hns3: Add "dcb register" status information query function")
      Signed-off-by: default avatarJie Wang <wangjie125@huawei.com>
      Signed-off-by: default avatarGuangbin Huang <huangguangbin2@huawei.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      2a21dab5
    • Guangbin Huang's avatar
      net: hns3: ignore reset event before initialization process is done · 0251d196
      Guangbin Huang authored
      Currently, if there is a reset event triggered by RAS during device in
      initialization process, driver may run reset process concurrently with
      initialization process. In this case, it may cause problem. For example,
      the RSS indirection table may has not been alloc memory in initialization
      process yet, but it is used in reset process, it will cause a call trace
      like this:
      
      [61228.744836] Unable to handle kernel NULL pointer dereference at virtual address 0000000000000000
      ...
      [61228.897677] Workqueue: hclgevf hclgevf_service_task [hclgevf]
      [61228.911390] pstate: 40400009 (nZcv daif +PAN -UAO -TCO BTYPE=--)
      [61228.918670] pc : hclgevf_set_rss_indir_table+0xb4/0x190 [hclgevf]
      [61228.927812] lr : hclgevf_set_rss_indir_table+0x90/0x190 [hclgevf]
      [61228.937248] sp : ffff8000162ebb50
      [61228.941087] x29: ffff8000162ebb50 x28: ffffb77add72dbc0 x27: ffff0820c7dc8080
      [61228.949516] x26: 0000000000000000 x25: ffff0820ad4fc880 x24: ffff0820c7dc8080
      [61228.958220] x23: ffff0820c7dc8090 x22: 00000000ffffffff x21: 0000000000000040
      [61228.966360] x20: ffffb77add72b9c0 x19: 0000000000000000 x18: 0000000000000030
      [61228.974646] x17: 0000000000000000 x16: ffffb77ae713feb0 x15: ffff0820ad4fcce8
      [61228.982808] x14: ffffffffffffffff x13: ffff8000962eb7f7 x12: 00003834ec70c960
      [61228.991990] x11: 00e0fafa8c206982 x10: 9670facc78a8f9a8 x9 : ffffb77add717530
      [61229.001123] x8 : ffff0820ad4fd6b8 x7 : 0000000000000000 x6 : 0000000000000011
      [61229.010249] x5 : 00000000000cb1b0 x4 : 0000000000002adb x3 : 0000000000000049
      [61229.018662] x2 : ffff8000162ebbb8 x1 : 0000000000000000 x0 : 0000000000000480
      [61229.027002] Call trace:
      [61229.030177]  hclgevf_set_rss_indir_table+0xb4/0x190 [hclgevf]
      [61229.039009]  hclgevf_rss_init_hw+0x128/0x1b4 [hclgevf]
      [61229.046809]  hclgevf_reset_rebuild+0x17c/0x69c [hclgevf]
      [61229.053862]  hclgevf_reset_service_task+0x4cc/0xa80 [hclgevf]
      [61229.061306]  hclgevf_service_task+0x6c/0x630 [hclgevf]
      [61229.068491]  process_one_work+0x1dc/0x48c
      [61229.074121]  worker_thread+0x15c/0x464
      [61229.078562]  kthread+0x168/0x16c
      [61229.082873]  ret_from_fork+0x10/0x18
      [61229.088221] Code: 7900e7f6 f904a683 d503201f 9101a3e2 (38616b43)
      [61229.095357] ---[ end trace 153661a538f6768c ]---
      
      To fix this problem, don't schedule reset task before initialization
      process is done.
      Signed-off-by: default avatarGuangbin Huang <huangguangbin2@huawei.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      0251d196
    • Yufeng Mo's avatar
      net: hns3: change hclge/hclgevf workqueue to WQ_UNBOUND mode · f29da408
      Yufeng Mo authored
      Currently, the workqueue of hclge/hclgevf is executed on
      the CPU that initiates scheduling requests by default. In
      stress scenarios, the CPU may be busy and workqueue scheduling
      is completed after a long period of time. To avoid this
      situation and implement proper scheduling, use the WQ_UNBOUND
      mode instead. In this way, the workqueue can be performed on
      a relatively idle CPU.
      Signed-off-by: default avatarYufeng Mo <moyufeng@huawei.com>
      Signed-off-by: default avatarGuangbin Huang <huangguangbin2@huawei.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      f29da408
    • Guangbin Huang's avatar
      net: hns3: fix pause config problem after autoneg disabled · 3bda2e5d
      Guangbin Huang authored
      If a TP port is configured by follow steps:
      1.ethtool -s ethx autoneg off speed 100 duplex full
      2.ethtool -A ethx rx on tx on
      3.ethtool -s ethx autoneg on(rx&tx negotiated pause results are off)
      4.ethtool -s ethx autoneg off speed 100 duplex full
      
      In step 3, driver will set rx&tx pause parameters of hardware to off as
      pause parameters negotiated with link partner are off.
      
      After step 4, the "ethtool -a ethx" command shows both rx and tx pause
      parameters are on. However, pause parameters of hardware are still off
      and port has no flow control function actually.
      
      To fix this problem, if autoneg is disabled, driver uses its saved
      parameters to restore pause of hardware. If the speed is not changed in
      this case, there is no link state changed for phy, it will cause the pause
      parameter is not taken effect, so we need to force phy to go down and up.
      
      Fixes: aacbe27e ("net: hns3: modify how pause options is displayed")
      Signed-off-by: default avatarGuangbin Huang <huangguangbin2@huawei.com>
      Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
      3bda2e5d
  2. 26 Oct, 2021 17 commits
  3. 25 Oct, 2021 11 commits
  4. 24 Oct, 2021 2 commits
  5. 23 Oct, 2021 2 commits
    • Quanyang Wang's avatar
      cgroup: Fix memory leak caused by missing cgroup_bpf_offline · 04f8ef56
      Quanyang Wang authored
      When enabling CONFIG_CGROUP_BPF, kmemleak can be observed by running
      the command as below:
      
          $mount -t cgroup -o none,name=foo cgroup cgroup/
          $umount cgroup/
      
      unreferenced object 0xc3585c40 (size 64):
        comm "mount", pid 425, jiffies 4294959825 (age 31.990s)
        hex dump (first 32 bytes):
          01 00 00 80 84 8c 28 c0 00 00 00 00 00 00 00 00  ......(.........
          00 00 00 00 00 00 00 00 6c 43 a0 c3 00 00 00 00  ........lC......
        backtrace:
          [<e95a2f9e>] cgroup_bpf_inherit+0x44/0x24c
          [<1f03679c>] cgroup_setup_root+0x174/0x37c
          [<ed4b0ac5>] cgroup1_get_tree+0x2c0/0x4a0
          [<f85b12fd>] vfs_get_tree+0x24/0x108
          [<f55aec5c>] path_mount+0x384/0x988
          [<e2d5e9cd>] do_mount+0x64/0x9c
          [<208c9cfe>] sys_mount+0xfc/0x1f4
          [<06dd06e0>] ret_fast_syscall+0x0/0x48
          [<a8308cb3>] 0xbeb4daa8
      
      This is because that since the commit 2b0d3d3e ("percpu_ref: reduce
      memory footprint of percpu_ref in fast path") root_cgrp->bpf.refcnt.data
      is allocated by the function percpu_ref_init in cgroup_bpf_inherit which
      is called by cgroup_setup_root when mounting, but not freed along with
      root_cgrp when umounting. Adding cgroup_bpf_offline which calls
      percpu_ref_kill to cgroup_kill_sb can free root_cgrp->bpf.refcnt.data in
      umount path.
      
      This patch also fixes the commit 4bfc0bb2 ("bpf: decouple the lifetime
      of cgroup_bpf from cgroup itself"). A cgroup_bpf_offline is needed to do a
      cleanup that frees the resources which are allocated by cgroup_bpf_inherit
      in cgroup_setup_root.
      
      And inside cgroup_bpf_offline, cgroup_get() is at the beginning and
      cgroup_put is at the end of cgroup_bpf_release which is called by
      cgroup_bpf_offline. So cgroup_bpf_offline can keep the balance of
      cgroup's refcount.
      
      Fixes: 2b0d3d3e ("percpu_ref: reduce memory footprint of percpu_ref in fast path")
      Fixes: 4bfc0bb2 ("bpf: decouple the lifetime of cgroup_bpf from cgroup itself")
      Signed-off-by: default avatarQuanyang Wang <quanyang.wang@windriver.com>
      Signed-off-by: default avatarAlexei Starovoitov <ast@kernel.org>
      Acked-by: default avatarRoman Gushchin <guro@fb.com>
      Acked-by: default avatarJohn Fastabend <john.fastabend@gmail.com>
      Link: https://lore.kernel.org/bpf/20211018075623.26884-1-quanyang.wang@windriver.com
      04f8ef56
    • Xu Kuohai's avatar
      bpf: Fix error usage of map_fd and fdget() in generic_map_update_batch() · fda7a387
      Xu Kuohai authored
      1. The ufd in generic_map_update_batch() should be read from batch.map_fd;
      2. A call to fdget() should be followed by a symmetric call to fdput().
      
      Fixes: aa2e93b8 ("bpf: Add generic support for update and delete batch ops")
      Signed-off-by: default avatarXu Kuohai <xukuohai@huawei.com>
      Signed-off-by: default avatarAlexei Starovoitov <ast@kernel.org>
      Link: https://lore.kernel.org/bpf/20211019032934.1210517-1-xukuohai@huawei.com
      fda7a387