01 Sep, 2016

6 commits

  • Signed-off-by: Geert Uytterhoeven
    Signed-off-by: David S. Miller

    Geert Uytterhoeven
     
  • Check for ethtool_ops structures that are only stored in the ethtool_ops
    field of a net_device structure or passed as the second argument to
    netdev_set_default_ethtool_ops. These contexts are declared const, so
    ethtool_ops structures that have these properties can be declared as const
    also.

    The semantic patch that makes this change is as follows:
    (http://coccinelle.lip6.fr/)

    //
    @r disable optional_qualifier@
    identifier i;
    position p;
    @@
    static struct ethtool_ops i@p = { ... };

    @ok1@
    identifier r.i;
    struct net_device e;
    position p;
    @@
    e.ethtool_ops = &i@p;

    @ok2@
    identifier r.i;
    expression e;
    position p;
    @@
    netdev_set_default_ethtool_ops(e, &i@p)

    @bad@
    position p != {r.p,ok1.p,ok2.p};
    identifier r.i;
    @@
    i@p

    @depends on !bad disable optional_qualifier@
    identifier r.i;
    @@
    static
    +const
    struct ethtool_ops i = { ... };
    //

    Signed-off-by: Julia Lawall
    Signed-off-by: David S. Miller

    Julia Lawall
     
  • Check for ethtool_ops structures that are only stored in the ethtool_ops
    field of a net_device structure or passed as the second argument to
    netdev_set_default_ethtool_ops. These contexts are declared const, so
    ethtool_ops structures that have these properties can be declared as const
    also.

    The semantic patch that makes this change is as follows:
    (http://coccinelle.lip6.fr/)

    //
    @r disable optional_qualifier@
    identifier i;
    position p;
    @@
    static struct ethtool_ops i@p = { ... };

    @ok1@
    identifier r.i;
    struct net_device e;
    position p;
    @@
    e.ethtool_ops = &i@p;

    @ok2@
    identifier r.i;
    expression e;
    position p;
    @@
    netdev_set_default_ethtool_ops(e, &i@p)

    @bad@
    position p != {r.p,ok1.p,ok2.p};
    identifier r.i;
    @@
    i@p

    @depends on !bad disable optional_qualifier@
    identifier r.i;
    @@
    static
    +const
    struct ethtool_ops i = { ... };
    //

    Signed-off-by: Julia Lawall
    Signed-off-by: David S. Miller

    Julia Lawall
     
  • Check for ethtool_ops structures that are only stored in the ethtool_ops
    field of a net_device structure or passed as the second argument to
    netdev_set_default_ethtool_ops. These contexts are declared const, so
    ethtool_ops structures that have these properties can be declared as const
    also.

    The semantic patch that makes this change is as follows:
    (http://coccinelle.lip6.fr/)

    //
    @r disable optional_qualifier@
    identifier i;
    position p;
    @@
    static struct ethtool_ops i@p = { ... };

    @ok1@
    identifier r.i;
    struct net_device e;
    position p;
    @@
    e.ethtool_ops = &i@p;

    @ok2@
    identifier r.i;
    expression e;
    position p;
    @@
    netdev_set_default_ethtool_ops(e, &i@p)

    @bad@
    position p != {r.p,ok1.p,ok2.p};
    identifier r.i;
    @@
    i@p

    @depends on !bad disable optional_qualifier@
    identifier r.i;
    @@
    static
    +const
    struct ethtool_ops i = { ... };
    //

    Signed-off-by: Julia Lawall
    Signed-off-by: David S. Miller

    Julia Lawall
     
  • Check for ethtool_ops structures that are only stored in the ethtool_ops
    field of a net_device structure or passed as the second argument to
    netdev_set_default_ethtool_ops. These contexts are declared const, so
    ethtool_ops structures that have these properties can be declared as const
    also.

    The semantic patch that makes this change is as follows:
    (http://coccinelle.lip6.fr/)

    //
    @r disable optional_qualifier@
    identifier i;
    position p;
    @@
    static struct ethtool_ops i@p = { ... };

    @ok1@
    identifier r.i;
    struct net_device e;
    position p;
    @@
    e.ethtool_ops = &i@p;

    @ok2@
    identifier r.i;
    expression e;
    position p;
    @@
    netdev_set_default_ethtool_ops(e, &i@p)

    @bad@
    position p != {r.p,ok1.p,ok2.p};
    identifier r.i;
    @@
    i@p

    @depends on !bad disable optional_qualifier@
    identifier r.i;
    @@
    static
    +const
    struct ethtool_ops i = { ... };
    //

    Signed-off-by: Julia Lawall
    Signed-off-by: David S. Miller

    Julia Lawall
     
  • Check for ethtool_ops structures that are only stored in the ethtool_ops
    field of a net_device structure or passed as the second argument to
    netdev_set_default_ethtool_ops. These contexts are declared const, so
    ethtool_ops structures that have these properties can be declared as const
    also.

    The semantic patch that makes this change is as follows:
    (http://coccinelle.lip6.fr/)

    //
    @r disable optional_qualifier@
    identifier i;
    position p;
    @@
    static struct ethtool_ops i@p = { ... };

    @ok1@
    identifier r.i;
    struct net_device e;
    position p;
    @@
    e.ethtool_ops = &i@p;

    @ok2@
    identifier r.i;
    expression e;
    position p;
    @@
    netdev_set_default_ethtool_ops(e, &i@p)

    @bad@
    position p != {r.p,ok1.p,ok2.p};
    identifier r.i;
    @@
    i@p

    @depends on !bad disable optional_qualifier@
    identifier r.i;
    @@
    static
    +const
    struct ethtool_ops i = { ... };
    //

    Signed-off-by: Julia Lawall
    Acked-by: Mark Einon
    Signed-off-by: David S. Miller

    Julia Lawall
     

31 Aug, 2016

10 commits

  • The addition of the per-queue statistics introduced a harmless warning
    on all 32-bit architectures:

    drivers/net/ethernet/qlogic/qede/qede_ethtool.c: In function 'qede_get_ethtool_stats':
    drivers/net/ethernet/qlogic/qede/qede_ethtool.c:244:31: error: cast from pointer to integer of different size [-Werror=pointer-to-int-cast]
    buf[cnt++] = QEDE_TQSTATS_DATA(edev,
    ^
    drivers/net/ethernet/qlogic/qede/qede_ethtool.c:244:22: error: cast to pointer from integer of different size [-Werror=int-to-pointer-cast]
    buf[cnt++] = QEDE_TQSTATS_DATA(edev,
    ^
    This changes the cast to 'void *' to shut up the warning, which
    avoids the assumptions on the size of the pointer type.

    Signed-off-by: Arnd Bergmann
    Fixes: 68db9ec2df07 ("qede: Add support for per-queue stats.")
    Signed-off-by: David S. Miller

    Arnd Bergmann
     
  • When CONFIG_PM_SLEEP is disabled, we get a couple of harmless warnings:

    drivers/net/ethernet/renesas/ravb_main.c:2117:12: error: 'ravb_resume' defined but not used [-Werror=unused-function]
    drivers/net/ethernet/renesas/ravb_main.c:2104:12: error: 'ravb_suspend' defined but not used [-Werror=unused-function]

    The simplest solution here is to replace the #ifdef with __maybe_unused
    annotations, which lets the compiler do the right thing by itself.

    Signed-off-by: Arnd Bergmann
    Fixes: 0184165b2f42 ("ravb: add sleep PM suspend/resume support")
    Acked-by: Sergei Shtylyov
    Signed-off-by: David S. Miller

    Arnd Bergmann
     
  • David Ahern says:

    ====================
    net: mpls: fragmentation and gso fixes for locally originated traffic

    This series fixes mtu and fragmentation for tunnels using lwtunnel
    output redirect, and fixes GSO for MPLS for locally originated traffic
    reported by Lennert Buytenhek.

    A follow on series will address fragmentation and GSO for forwarded
    MPLS traffic. Hardware offload of GSO with MPLS also needs to be
    addressed.

    Simon: Can you verify this works with OVS for single and multiple
    labels?

    v4
    - more updates to mpls_gso_segment per Alex's comments (thanks, Alex)
    - updates to teaching OVS about marking MPLS labels as the network header

    v3
    - updates to mpls_gso_segment per Alex's comments
    - dropped skb->encapsulation = 1 from mpls_xmit per Alex's comment

    v2
    - consistent use of network_header in skb to fix GSO for MPLS
    - update MPLS code in OVS to network_header and inner_network_header
    ====================

    Tested-by: Simon Horman
    Signed-off-by: David S. Miller

    David S. Miller
     
  • veth does not really transmit packets only moves the skb from one
    netdev to another so gso and checksum is not really needed. Add
    the features to mpls_features to get the same benefit and performance
    with MPLS as without it.

    Reported-by: Lennert Buytenhek
    Signed-off-by: David Ahern
    Signed-off-by: David S. Miller

    David Ahern
     
  • As reported by Lennert the MPLS GSO code is failing to properly segment
    large packets. There are a couple of problems:

    1. the inner protocol is not set so the gso segment functions for inner
    protocol layers are not getting run, and

    2 MPLS labels for packets that use the "native" (non-OVS) MPLS code
    are not properly accounted for in mpls_gso_segment.

    The MPLS GSO code was added for OVS. It is re-using skb_mac_gso_segment
    to call the gso segment functions for the higher layer protocols. That
    means skb_mac_gso_segment is called twice -- once with the network
    protocol set to MPLS and again with the network protocol set to the
    inner protocol.

    This patch sets the inner skb protocol addressing item 1 above and sets
    the network_header and inner_network_header to mark where the MPLS labels
    start and end. The MPLS code in OVS is also updated to set the two
    network markers.

    >From there the MPLS GSO code uses the difference between the network
    header and the inner network header to know the size of the MPLS header
    that was pushed. It then pulls the MPLS header, resets the mac_len and
    protocol for the inner protocol and then calls skb_mac_gso_segment
    to segment the skb.

    Afterward the inner protocol segmentation is done the skb protocol
    is set to mpls for each segment and the network and mac headers
    restored.

    Reported-by: Lennert Buytenhek
    Signed-off-by: David Ahern
    Signed-off-by: David S. Miller

    David Ahern
     
  • Today mpls iptunnel lwtunnel_output redirect expects the tunnel
    output function to handle fragmentation. This is ok but can be
    avoided if we did not do the mpls output redirect too early.
    ie we could wait until ip fragmentation is done and then call
    mpls output for each ip fragment.

    To make this work we will need,
    1) the lwtunnel state to carry encap headroom
    2) and do the redirect to the encap output handler on the ip fragment
    (essentially do the output redirect after fragmentation)

    This patch adds tunnel headroom in lwtstate to make sure we
    account for tunnel data in mtu calculations during fragmentation
    and adds new xmit redirect handler to redirect to lwtunnel xmit func
    after ip fragmentation.

    This includes IPV6 and some mtu fixes and testing from David Ahern.

    Signed-off-by: Roopa Prabhu
    Signed-off-by: David Ahern
    Signed-off-by: David S. Miller

    Roopa Prabhu
     
  • After commit 145dd5f9c88f ("net: flush the softnet backlog in process
    context"), we can easily batch calls to flush_all_backlogs() for all
    devices processed in rollback_registered_many()

    Tested:

    Before patch, on an idle host.

    modprobe dummy numdummies=10000
    perf stat -e context-switches -a rmmod dummy

    Performance counter stats for 'system wide':

    1,211,798 context-switches

    1.302137465 seconds time elapsed

    After patch:

    perf stat -e context-switches -a rmmod dummy

    Performance counter stats for 'system wide':

    225,523 context-switches

    0.721623566 seconds time elapsed

    Signed-off-by: Eric Dumazet
    Acked-by: Hannes Frederic Sowa
    Signed-off-by: David S. Miller

    Eric Dumazet
     
  • Remove a useless log message and improve the logic for setting
    a PHY address from the contents of the MNG_IF_SEL register.

    Signed-off-by: Mark Rustad
    Tested-by: Andrew Bowers
    Signed-off-by: Jeff Kirsher
    Signed-off-by: David S. Miller

    Mark Rustad
     
  • …l/git/dhowells/linux-fs

    David Howells says:

    ====================
    rxrpc: Preparation for removal of use of skbs from AFS

    Here's a set of patches that prepare the way for the removal of the use of
    sk_buffs from fs/afs (they'll be entirely retained within net/rxrpc):

    (1) Fix a potential NULL-pointer deref in rxrpc_abort_calls().

    (2) Condense all the terminal call state machine states to a single one
    plus supplementary info.

    (3) Add a trace point for rxrpc call usage debugging.

    (4) Cleanups and missing headers.

    (5) Provide a way for AFS to ask about a call's peer address without
    having an sk_buff to query.

    (6) Use call->peer directly rather than going via call->conn (which might
    be NULL).

    (7) Pass struct socket * to various rxrpc kernel interface functions so
    they can use that directly rather than getting it from the rxrpc_call
    struct.
    ====================

    Signed-off-by: David S. Miller <davem@davemloft.net>

    David S. Miller
     
  • Trivial fix to spelling mistake in dev_warn message.

    Signed-off-by: Colin Ian King
    Signed-off-by: David S. Miller

    Colin Ian King
     

30 Aug, 2016

15 commits

  • Pass struct socket * to more rxrpc kernel interface functions. They should
    be starting from this rather than the socket pointer in the rxrpc_call
    struct if they need to access the socket.

    I have left:

    rxrpc_kernel_is_data_last()
    rxrpc_kernel_get_abort_code()
    rxrpc_kernel_get_error_number()
    rxrpc_kernel_free_skb()
    rxrpc_kernel_data_consumed()

    unmodified as they're all about to be removed (and, in any case, don't
    touch the socket).

    Signed-off-by: David Howells

    David Howells
     
  • Use call->peer rather than call->conn->params.peer as call->conn may become
    NULL.

    Signed-off-by: David Howells

    David Howells
     
  • Provide a function so that kernel users, such as AFS, can ask for the peer
    address of a call:

    void rxrpc_kernel_get_peer(struct rxrpc_call *call,
    struct sockaddr_rxrpc *_srx);

    In the future the kernel service won't get sk_buffs to look inside.
    Further, this allows us to hide any canonicalisation inside AF_RXRPC for
    when IPv6 support is added.

    Also propagate this through to afs_find_server() and issue a warning if we
    can't handle the address family yet.

    Signed-off-by: David Howells

    David Howells
     
  • We should #include linux/random.h to use get_random().

    Signed-off-by: David Howells

    David Howells
     
  • Remove one #ifndef'd-out variable and a couple of excessive blank lines.

    Signed-off-by: David Howells

    David Howells
     
  • Add a trace event for debuging rxrpc_call struct usage.

    Signed-off-by: David Howells

    David Howells
     
  • Condense the terminal states of a call state machine to a single state,
    plus a separate completion type value. The value is then set, along with
    error and abort code values, only when the call is transitioned to the
    completion state.

    Helpers are provided to simplify this.

    Signed-off-by: David Howells

    David Howells
     
  • The call pointer in a channel on a connection will be NULL if there's no
    active call on that channel. rxrpc_abort_calls() needs to check for this
    before trying to take the call's state_lock.

    Signed-off-by: David Howells

    David Howells
     
  • Jeff Kirsher says:

    ====================
    100GbE Intel Wired LAN Driver Updates 2016-08-29

    This series contains updates to fm10k only.

    Jake provides all the changes in this series starting with fixes an issue
    where VF devices may fail during an unbind/bind and we will never zero
    the reference counter for the pci_dev structure. Updated the hot path
    to use SW counters instead of checking for hardware Tx pending for
    possible transmit hangs, which will improve performance. Fixed the NAPI
    budget accounting so that fm10k_poll will return actual work done,
    capped at (budget - 1) instead of returning 0. Added a check to ensure
    that the device is in the normal IO state before continuing to probe,
    which allows us to give a more descriptive message of what is wrong
    in the case of uncorrectable AER error. In preparation for adding Geneve
    Rx offload support, refactored the current VXLAN offload flow to be a bit
    more generic. Added support for receive offloads on one Geneve tunnel.
    Ensure that other bits in the RXQCTL register do not get cleared, to
    make sure that bits related to queue ownership are maintained. Fixed
    an issue in queue ownership assignment which casued a race condition
    between the PF and the VF such that potentially a VF could cause FUM
    fault errors due to normal PF/VF driver behavior.
    ====================

    Signed-off-by: David S. Miller

    David S. Miller
     
  • All three conflicts were cases of simple overlapping
    changes.

    Signed-off-by: David S. Miller

    David S. Miller
     
  • …l/git/groeck/linux-staging

    Pull hwmon fix from Guenter Roeck:
    "Add missing sysfs attribute group terminator to it87 driver"

    * tag 'hwmon-for-linus-v4.8-rc5' of git://git.kernel.org/pub/scm/linux/kernel/git/groeck/linux-staging:
    hwmon: (it87) Add missing sysfs attribute group terminator

    Linus Torvalds
     
  • Pull ext4 fixes from Ted Ts'o:
    "Fix bugs that could cause kernel deadlocks or file system corruption
    while moving xattrs to expand the extended inode.

    Also add some sanity checks to the block group descriptors to make
    sure we don't end up overwriting the superblock"

    * tag 'ext4_for_linus_stable' of git://git.kernel.org/pub/scm/linux/kernel/git/tytso/ext4:
    ext4: avoid deadlock when expanding inode size
    ext4: properly align shifted xattrs when expanding inodes
    ext4: fix xattr shifting when expanding inodes part 2
    ext4: fix xattr shifting when expanding inodes
    ext4: validate that metadata blocks do not overlap superblock
    ext4: reserve xattr index for the Hurd

    Linus Torvalds
     
  • Pull networking fixes from David Miller:

    1) Segregate namespaces properly in conntrack dumps, from Liping Zhang.

    2) tcp listener refcount fix in netfilter tproxy, from Eric Dumazet.

    3) Fix timeouts in qed driver due to xmit_more, from Yuval Mintz.

    4) Fix use-after-free in tcp_xmit_retransmit_queue().

    5) Userspace header fixups (use of __u32, missing includes, etc.) from
    Mikko Rapeli.

    6) Further refinements to fragmentation wrt gso and tunnels, from
    Shmulik Ladkani.

    7) Trigger poll correctly for zero length UDP packets, from Eric
    Dumazet.

    8) TCP window scaling fix, also from Eric Dumazet.

    9) SLAB_DESTROY_BY_RCU is not relevant any more for UDP sockets.

    10) Module refcount leak in qdisc_create_dflt(), from Eric Dumazet.

    11) Fix deadlock in cp_rx_poll() of 8139cp driver, from Gao Feng.

    12) Memory leak in rhashtable's alloc_bucket_locks(), from Eric Dumazet.

    13) Add new device ID to alx driver, from Owen Lin.

    * git://git.kernel.org/pub/scm/linux/kernel/git/davem/net: (83 commits)
    Add Killer E2500 device ID in alx driver.
    net: smc91x: fix SMC accesses
    Documentation: networking: dsa: Remove platform device TODO
    net/mlx5: Increase number of ethtool steering priorities
    net/mlx5: Add error prints when validate ETS failed
    net/mlx5e: Fix memory leak if refreshing TIRs fails
    net/mlx5e: Add ethtool counter for TX xmit_more
    net/mlx5e: Fix ethtool -g/G rx ring parameter report with striding RQ
    net/mlx5e: Don't wait for SQ completions on close
    net/mlx5e: Don't post fragmented MPWQE when RQ is disabled
    net/mlx5e: Don't wait for RQ completions on close
    net/mlx5e: Limit UMR length to the device's limitation
    rhashtable: fix a memory leak in alloc_bucket_locks()
    sfc: fix potential stack corruption from running past stat bitmask
    team: loadbalance: push lacpdus to exact delivery
    net: hns: dereference ppe_cb->ppe_common_cb if it is non-null
    8139cp: Fix one possible deadloop in cp_rx_poll
    i40e: Change some init flow for the client
    Revert "phy: IRQ cannot be shared"
    net: dsa: bcm_sf2: Fix race condition while unmasking interrupts
    ...

    Linus Torvalds
     
  • …linux-platform-drivers-x86

    Pull x86 platform driver fixes from Darren Hart:
    "Remove module related code from two drivers that are only configurable
    as built-in: intel_pmic_gpio and platform/olpc"

    * tag 'platform-drivers-x86-v4.8-4' of git://git.infradead.org/users/dvhart/linux-platform-drivers-x86:
    intel_pmic_gpio: Make explicitly non-modular
    platform/olpc: Make ec explicitly non-modular

    Linus Torvalds
     
  • Pull powerpc fixes from Ben Herrenschmidt:
    "This was meant to be sent early last week, but I has a change pending
    on one of the fixes and other things made me forget all about. Ugh.

    We have some misc fixes for powerpc 4.8. Some trivial bits and some
    regressions, and a trivial cleanup or two that I saw no point in
    letting rot in patchwork"

    * tag 'powerpc-4.8-4' of git://git.kernel.org/pub/scm/linux/kernel/git/powerpc/linux:
    powerpc: signals: Discard transaction state from signal frames
    powerpc/powernv : Drop reference added by kset_find_obj()
    powerpc/tm: do not use r13 for tabort_syscall
    powerpc: move hmi.c to arch/powerpc/kvm/
    powerpc: sysdev: cpm: fix gpio save_regs functions
    powerpc/pseries: PACA save area fix for MCE vs MCE
    powerpc/pseries: PACA save area fix for general exception vs MCE
    powerpc/prom: Fix sub-processor option passed to ibm, client-architecture-support
    powerpc, hotplug: Avoid to touch non-existent cpumasks.
    powerpc: migrate exception table users off module.h and onto extable.h
    powerpc/powernv/pci: fix iterator signedness
    powerpc/pseries: use pci_host_bridge.release_fn() to kfree(phb)
    cxl: use pcibios_free_controller_deferred() when removing vPHBs
    powerpc: mpc8349emitx: Delete unnecessary assignment for the field "owner"
    powerpc/512x: Delete unnecessary assignment for the field "owner"
    drivers/macintosh: Delete owner assignment
    powerpc: cputhreads: Add missing include file

    Linus Torvalds
     

29 Aug, 2016

9 commits

  • Attribute array it87_attributes_in lacks its NULL terminator,
    causing random behavior when operating on the attribute group.

    Fixes: 52929715634a ("hwmon: (it87) Use is_visible for voltage sensors")
    Signed-off-by: Jean Delvare
    Cc: Martin Blumenstingl
    Cc: Guenter Roeck
    Cc: stable@vger.kernel.org
    Signed-off-by: Guenter Roeck

    Jean Delvare
     
  • When the PF assigns a new MAC address to a VF it uses the base address
    registers to store the MAC address. This allows a VF which loads after
    this setup the ability to get the initial address without having to wait
    for a mailbox message. Unfortunately to do this, the PF must take queue
    ownership away from the VF, which can cause fault errors when there is
    already an active VF driver.

    This queue ownership assignment causes race condition between the PF and
    the VF such that potentially a VF can cause FUM fault errors due to
    normal PF/VF driver behavior.

    It is not safe to simply allow the PF to write the base address
    registers without taking queue ownership back as the PF must also
    disable the queues, and this would impact active VF use. The current
    code is safe because the queue ownership will prevent the VF from
    actually writing but does trigger the FUM fault.

    We can do better by simply avoiding the register write process when
    a mailbox message suffices. If the message can be sent over the mailbox,
    then we will not perform the queue ownership assignment and we won't
    update the base address to be the same as the MAC address.

    We do still have to write the TXQCTL registers in order to update the
    VID of the queue. This is necessary because the TXQCTL register is
    read-only from the VF, and thus the VF cannot do this for itself. This
    register does not need to wait for the Tx queue to be disabled and is
    safe for the PF to write during normal VF operation, so we move this
    write to the top of the function above the mailbox message. Without
    this, the TXQCTL register would be misconfigured and cause the VF to Tx
    hang.

    Signed-off-by: Jacob Keller
    Tested-by: Krishneil Singh
    Signed-off-by: Jeff Kirsher

    Jacob Keller
     
  • Ensure that other bits in the RXQCTL register do not get cleared. This
    ensures that bits related to queue ownership are maintained.

    Signed-off-by: Jacob Keller
    Tested-by: Krishneil Singh
    Signed-off-by: Jeff Kirsher

    Jacob Keller
     
  • Signed-off-by: Jacob Keller
    Tested-by: Krishneil Singh
    Signed-off-by: Jeff Kirsher

    Jacob Keller
     
  • Similar to how we handle VXLAN offload, enable support for a single
    Geneve tunnel.

    Signed-off-by: Jacob Keller
    Tested-by: Krishneil Singh
    Signed-off-by: Jeff Kirsher

    Jacob Keller
     
  • In preparation for adding Geneve Rx offload support, refactor the
    current VXLAN offload flow to be a bit more generic so that it will be
    easier to add the new Geneve code. The fm10k hardware supports one VXLAN
    and one Geneve tunnel, so we will eventually treat the VXLAN and Geneve
    tunnels identically. To this end, factor out the code that handles the
    current list so that we can use the generic flow for both tunnels in the
    next patch.

    Signed-off-by: Jacob Keller
    Tested-by: Krishneil Singh
    Signed-off-by: Jeff Kirsher

    Jacob Keller
     
  • In the event of a surprise remove, we expect the driver to go down,
    which includes calling .stop_hw(). However, this function will return an
    error because the queues won't appear to cleanly disable. Prevent this
    and avoid the unnecessary checks by just returning when
    FM10K_REMOVED(hw->hw_addr) is true.

    Signed-off-by: Jacob Keller
    Tested-by: Krishneil Singh
    Signed-off-by: Jeff Kirsher

    Jacob Keller
     
  • In the event of an uncorrectable AER error occurring when the driver has
    not loaded, the recovery routines are not done. This is done because
    future loads of the driver may not be aware of the IO state and may not
    be able to recover at all. In this case, when we next load the driver it
    fails due to what appears to be a surprise remove event. Instead, add
    a check to ensure that the device is in the normal IO state before
    continuing to probe. This allows us to give a more descriptive message
    of what is wrong.

    Without this change, the driver will attempt to probe up to our first
    call of .reset_hw() which will be unable to read registers and act as if
    a surprise remove event occurred.

    Signed-off-by: Jacob Keller
    Tested-by: Krishneil Singh
    Signed-off-by: Jeff Kirsher

    Jacob Keller
     
  • Signed-off-by: Jacob Keller
    Tested-by: Krishneil Singh
    Signed-off-by: Jeff Kirsher

    Jacob Keller