1. 11 11月, 2019 11 次提交
  2. 09 11月, 2019 2 次提交
  3. 08 11月, 2019 2 次提交
  4. 07 11月, 2019 14 次提交
  5. 04 11月, 2019 11 次提交
    • D
      Merge branch 'bpf-libbpf-bitfield-size-relo' · f23c7ce3
      Daniel Borkmann 提交于
      Andrii Nakryiko says:
      
      ====================
      This patch set adds support for reading bitfields in a relocatable manner
      through a set of relocations emitted by Clang, corresponding libbpf support
      for those relocations, as well as abstracting details into
      BPF_CORE_READ_BITFIELD/BPF_CORE_READ_BITFIELD_PROBED macro.
      
      We also add support for capturing relocatable field size, so that BPF program
      code can adjust its logic to actual amount of data it needs to operate on,
      even if it changes between kernels. New convenience macro is added to
      bpf_core_read.h (bpf_core_field_size(), in the same family of macro as
      bpf_core_read() and bpf_core_field_exists()). Corresponding set of selftests
      are added to excercise this logic and validate correctness in a variety of
      scenarios.
      
      Some of the overly strict logic of matching fields is relaxed to support wider
      variety of scenarios. See patch #1 for that.
      
      Patch #1 removes few overly strict test cases.
      Patch #2 adds support for bitfield-related relocations.
      Patch #3 adds some further adjustments to support generic field size
      relocations and introduces bpf_core_field_size() macro.
      Patch #4 tests bitfield reading.
      Patch #5 tests field size relocations.
      
      v1 -> v2:
        - added direct memory read-based macro and tests for bitfield reads.
      ====================
      Signed-off-by: NDaniel Borkmann <daniel@iogearbox.net>
      f23c7ce3
    • A
      selftests/bpf: Add field size relocation tests · 0b163565
      Andrii Nakryiko 提交于
      Add test verifying correctness and logic of field size relocation support in
      libbpf.
      Signed-off-by: NAndrii Nakryiko <andriin@fb.com>
      Signed-off-by: NDaniel Borkmann <daniel@iogearbox.net>
      Link: https://lore.kernel.org/bpf/20191101222810.1246166-6-andriin@fb.com
      0b163565
    • A
      selftest/bpf: Add relocatable bitfield reading tests · 8b1cb1c9
      Andrii Nakryiko 提交于
      Add a bunch of selftests verifying correctness of relocatable bitfield reading
      support in libbpf. Both bpf_probe_read()-based and direct read-based bitfield
      macros are tested. core_reloc.c "test_harness" is extended to support raw
      tracepoint and new typed raw tracepoints as test BPF program types.
      Signed-off-by: NAndrii Nakryiko <andriin@fb.com>
      Signed-off-by: NDaniel Borkmann <daniel@iogearbox.net>
      Link: https://lore.kernel.org/bpf/20191101222810.1246166-5-andriin@fb.com
      8b1cb1c9
    • A
      libbpf: Add support for field size relocations · 94f060e9
      Andrii Nakryiko 提交于
      Add bpf_core_field_size() macro, capturing a relocation against field size.
      Adjust bits of internal libbpf relocation logic to allow capturing size
      relocations of various field types: arrays, structs/unions, enums, etc.
      Signed-off-by: NAndrii Nakryiko <andriin@fb.com>
      Signed-off-by: NDaniel Borkmann <daniel@iogearbox.net>
      Link: https://lore.kernel.org/bpf/20191101222810.1246166-4-andriin@fb.com
      94f060e9
    • A
      libbpf: Add support for relocatable bitfields · ee26dade
      Andrii Nakryiko 提交于
      Add support for the new field relocation kinds, necessary to support
      relocatable bitfield reads. Provide macro for abstracting necessary code doing
      full relocatable bitfield extraction into u64 value. Two separate macros are
      provided:
      - BPF_CORE_READ_BITFIELD macro for direct memory read-enabled BPF programs
      (e.g., typed raw tracepoints). It uses direct memory dereference to extract
      bitfield backing integer value.
      - BPF_CORE_READ_BITFIELD_PROBED macro for cases where bpf_probe_read() needs
      to be used to extract same backing integer value.
      Signed-off-by: NAndrii Nakryiko <andriin@fb.com>
      Signed-off-by: NDaniel Borkmann <daniel@iogearbox.net>
      Link: https://lore.kernel.org/bpf/20191101222810.1246166-3-andriin@fb.com
      ee26dade
    • A
      selftests/bpf: Remove too strict field offset relo test cases · 42765ede
      Andrii Nakryiko 提交于
      As libbpf is going to gain support for more field relocations, including field
      size, some restrictions about exact size match are going to be lifted. Remove
      test cases that explicitly test such failures.
      Signed-off-by: NAndrii Nakryiko <andriin@fb.com>
      Signed-off-by: NDaniel Borkmann <daniel@iogearbox.net>
      Link: https://lore.kernel.org/bpf/20191101222810.1246166-2-andriin@fb.com
      42765ede
    • D
      Merge tag 'mlx5-updates-2019-11-01' of git://git.kernel.org/pub/scm/linux/kernel/git/saeed/linux · 1574cf83
      David S. Miller 提交于
      Saeed Mahameed says:
      
      ====================
      mlx5-updates-2019-11-01
      
      Misc updates for mlx5 netdev and core driver
      
      1) Steering Core: Replace CRC32 internal implementation with standard
         kernel lib.
      2) Steering Core: Support IPv4 and IPv6 mixed matcher.
      3) Steering Core: Lockless FTE read lookups
      4) TC: Bit sized fields rewrite support.
      5) FPGA: Standalone FPGA support.
      6) SRIOV: Reset VF parameters configurations on SRIOV disable.
      7) netdev: Dump WQs wqe descriptors on CQE with error events.
      8) MISC Cleanups.
      ====================
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      1574cf83
    • Y
      mISDN: remove unused variable 'faxmodulation_s' · a37ac8ae
      YueHaibing 提交于
      drivers/isdn/hardware/mISDN/mISDNisar.c:30:17:
       warning: faxmodulation_s defined but not used [-Wunused-const-variable=]
      
      It is never used, so can be removed.
      Signed-off-by: NYueHaibing <yuehaibing@huawei.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      a37ac8ae
    • V
      ptp: Add a ptp clock driver for IDT ClockMatrix. · 3a6ba7dc
      Vincent Cheng 提交于
      The IDT ClockMatrix (TM) family includes integrated devices that provide
      eight PLL channels.  Each PLL channel can be independently configured as a
      frequency synthesizer, jitter attenuator, digitally controlled
      oscillator (DCO), or a digital phase lock loop (DPLL).  Typically
      these devices are used as timing references and clock sources for PTP
      applications.  This patch adds support for the device.
      Co-developed-by: NRichard Cochran <richardcochran@gmail.com>
      Signed-off-by: NRichard Cochran <richardcochran@gmail.com>
      Signed-off-by: NVincent Cheng <vincent.cheng.xh@renesas.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      3a6ba7dc
    • V
      dt-bindings: ptp: Add device tree binding for IDT ClockMatrix based PTP clock · 5c5e7aac
      Vincent Cheng 提交于
      Add device tree binding doc for the IDT ClockMatrix PTP clock.
      Signed-off-by: NVincent Cheng <vincent.cheng.xh@renesas.com>
      Reviewed-by: NSimon Horman <simon.horman@netronome.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      5c5e7aac
    • F
      net: icmp6: provide input address for traceroute6 · fac6fce9
      Francesco Ruggeri 提交于
      traceroute6 output can be confusing, in that it shows the address
      that a router would use to reach the sender, rather than the address
      the packet used to reach the router.
      Consider this case:
      
              ------------------------ N2
               |                    |
             ------              ------  N3  ----
             | R1 |              | R2 |------|H2|
             ------              ------      ----
               |                    |
              ------------------------ N1
                        |
                       ----
                       |H1|
                       ----
      
      where H1's default route is through R1, and R1's default route is
      through R2 over N2.
      traceroute6 from H1 to H2 shows R2's address on N1 rather than on N2.
      
      The script below can be used to reproduce this scenario.
      
      traceroute6 output without this patch:
      
      traceroute to 2000:103::4 (2000:103::4), 30 hops max, 80 byte packets
       1  2000:101::1 (2000:101::1)  0.036 ms  0.008 ms  0.006 ms
       2  2000:101::2 (2000:101::2)  0.011 ms  0.008 ms  0.007 ms
       3  2000:103::4 (2000:103::4)  0.013 ms  0.010 ms  0.009 ms
      
      traceroute6 output with this patch:
      
      traceroute to 2000:103::4 (2000:103::4), 30 hops max, 80 byte packets
       1  2000:101::1 (2000:101::1)  0.056 ms  0.019 ms  0.006 ms
       2  2000:102::2 (2000:102::2)  0.013 ms  0.008 ms  0.008 ms
       3  2000:103::4 (2000:103::4)  0.013 ms  0.009 ms  0.009 ms
      
      #!/bin/bash
      #
      #        ------------------------ N2
      #         |                    |
      #       ------              ------  N3  ----
      #       | R1 |              | R2 |------|H2|
      #       ------              ------      ----
      #         |                    |
      #        ------------------------ N1
      #                  |
      #                 ----
      #                 |H1|
      #                 ----
      #
      # N1: 2000:101::/64
      # N2: 2000:102::/64
      # N3: 2000:103::/64
      #
      # R1's host part of address: 1
      # R2's host part of address: 2
      # H1's host part of address: 3
      # H2's host part of address: 4
      #
      # For example:
      # the IPv6 address of R1's interface on N2 is 2000:102::1/64
      #
      # Nets are implemented by macvlan interfaces (bridge mode) over
      # dummy interfaces.
      #
      
      # Create net namespaces
      ip netns add host1
      ip netns add host2
      ip netns add rtr1
      ip netns add rtr2
      
      # Create nets
      ip link add net1 type dummy; ip link set net1 up
      ip link add net2 type dummy; ip link set net2 up
      ip link add net3 type dummy; ip link set net3 up
      
      # Add interfaces to net1, move them to their nemaspaces
      ip link add link net1 dev host1net1 type macvlan mode bridge
      ip link set host1net1 netns host1
      ip link add link net1 dev rtr1net1 type macvlan mode bridge
      ip link set rtr1net1 netns rtr1
      ip link add link net1 dev rtr2net1 type macvlan mode bridge
      ip link set rtr2net1 netns rtr2
      
      # Add interfaces to net2, move them to their nemaspaces
      ip link add link net2 dev rtr1net2 type macvlan mode bridge
      ip link set rtr1net2 netns rtr1
      ip link add link net2 dev rtr2net2 type macvlan mode bridge
      ip link set rtr2net2 netns rtr2
      
      # Add interfaces to net3, move them to their nemaspaces
      ip link add link net3 dev rtr2net3 type macvlan mode bridge
      ip link set rtr2net3 netns rtr2
      ip link add link net3 dev host2net3 type macvlan mode bridge
      ip link set host2net3 netns host2
      
      # Configure interfaces and routes in host1
      ip netns exec host1 ip link set lo up
      ip netns exec host1 ip link set host1net1 up
      ip netns exec host1 ip -6 addr add 2000:101::3/64 dev host1net1
      ip netns exec host1 ip -6 route add default via 2000:101::1
      
      # Configure interfaces and routes in rtr1
      ip netns exec rtr1 ip link set lo up
      ip netns exec rtr1 ip link set rtr1net1 up
      ip netns exec rtr1 ip -6 addr add 2000:101::1/64 dev rtr1net1
      ip netns exec rtr1 ip link set rtr1net2 up
      ip netns exec rtr1 ip -6 addr add 2000:102::1/64 dev rtr1net2
      ip netns exec rtr1 ip -6 route add default via 2000:102::2
      ip netns exec rtr1 sysctl net.ipv6.conf.all.forwarding=1
      
      # Configure interfaces and routes in rtr2
      ip netns exec rtr2 ip link set lo up
      ip netns exec rtr2 ip link set rtr2net1 up
      ip netns exec rtr2 ip -6 addr add 2000:101::2/64 dev rtr2net1
      ip netns exec rtr2 ip link set rtr2net2 up
      ip netns exec rtr2 ip -6 addr add 2000:102::2/64 dev rtr2net2
      ip netns exec rtr2 ip link set rtr2net3 up
      ip netns exec rtr2 ip -6 addr add 2000:103::2/64 dev rtr2net3
      ip netns exec rtr2 sysctl net.ipv6.conf.all.forwarding=1
      
      # Configure interfaces and routes in host2
      ip netns exec host2 ip link set lo up
      ip netns exec host2 ip link set host2net3 up
      ip netns exec host2 ip -6 addr add 2000:103::4/64 dev host2net3
      ip netns exec host2 ip -6 route add default via 2000:103::2
      
      # Ping host2 from host1
      ip netns exec host1 ping6 -c5 2000:103::4
      
      # Traceroute host2 from host1
      ip netns exec host1 traceroute6 2000:103::4
      
      # Delete nets
      ip link del net3
      ip link del net2
      ip link del net1
      
      # Delete namespaces
      ip netns del rtr2
      ip netns del rtr1
      ip netns del host2
      ip netns del host1
      Signed-off-by: NFrancesco Ruggeri <fruggeri@arista.com>
      Original-patch-by: NHonggang Xu <hxu@arista.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      fac6fce9